Adjustable with Plug-Unplug Systematics Multi-Purpose Modular Discovery Vehicle with Nuclear and Chemical Data Calculation System
You can access the project's article here
// The image above is shown as an example
// The robot can be used in both manual and object tracking mode. (motor-control && controller)
- ppm = a*ratio^b (a: valuea b: valueb)
- ppm = 10^[(log10(ratio)-b)/m] (m: logm b: logb)
If R^2 equals 1 :
a*ratio^b = 10^[(log10(ratio)-b)/m]
logm = valueb, logb = log10(valuea)
[(1,10), (2,4), (3,3)]
loge(b) = ln(b)
(ln(1),ln(10)) for ≈ (0,2.3026)
(ln(2),ln(4)) ≈ (0.6931,1.3863) and
(ln(3),ln(3)) ≈ (1.0986,1.0986)
b = ∑ i=1 n (x i − x ˉ ) 2 ∑ i=1 n (xi − xˉ)(yi−yˉ)
ln(x):(0,0.6931,1.0986)ln(y):(2.3026,1.3863,1.0986)ln(y)ˉ=(2.3026+1.3863+1.0986)/3≈1.5958
ln(x)ˉ=(0+0.6931+1.0986)/3≈0.5972
b = (0−0.5972)(2.3026−1.5958)+(0.6931−0.5972)(1.3863−1.5958)+(1.0986−0.5972)(1.0986−1.5958)/(0−0.5972)^2+(0.6931−0.5972)^2+(1.0986−0.5972)^2 ≈ -1.2
ln(a) = − ln ˉ (y) - b ln ˉ (x) ≈ 1.5958−(−1.2)⋅0.5972≈2.31244
a=e^2.31244 ≈ 9.947
y = mx+ n
n = b
log10(y) = m*log10(x) + b
-b = m*log10(x) - log10(y)
last b = log10(y) - m*log10(x)
m = (y - y0) / (x - x0)
m = (log10(y) - log10(y0)) / (log10(x) - log10(x0))
if y= a*x^b:
last m = log10(y/y0) / log10(x/x0)
m = slope of the line
b = intersection point
m = log10(y/y0) / log10(x/x0)
b = log10(y) - m*log10(x)
if r_squared >= 0.9995:
print("R-squared value for {gas name} is above 0.9995, plotting against first and last values.")
x0, y0 = x[0], y[0]
xn, yn = x[-1], y[-1]
b = np.log10(yn/y0) / np.log10(xn/x0)
a = 10**(np.log10(yn) - b * np.log10(xn))
b2 = np.log10(yn) - b * np.log10(xn)
b2_rounded = round(b2, 4)
a_rounded = round(a, 4)
b_rounded = round(b, 4)
The first formula is determined according to all points (OldCurve.py, OldCurve), while the second formula is determined according to the first and last point. Therefore, in order to collect them all in the same formula and to increase the accuracy rate, we used the method in the second formula and took the logarithm (if R^2 = 1 (%100) always: logm = valueb, logb = log10(valuea)) for slopes greater than 99.95% and collected them all in the first formula, thus we increased the accuracy rate without having to use 2 different formulas (Regression.py, NewCurve).