How to use generated code from cftool to find unknown variables

4 Ansichten (letzte 30 Tage)
DARSHAN N KANNUR
DARSHAN N KANNUR am 1 Apr. 2021
Beantwortet: Walter Roberson am 5 Apr. 2021
I have three variables x y and z where x is speed (mx1 array), y is torque (nx1 array), z is efficiency (mxn array). This is a motor data. On using auto fit in cftool it chose interpolant-linear.
I want to find efficiency (z)of the motor at any given speed and torque (i.e x and y). I don't know what to do after generating the code and saving the results in workspace.
  4 Kommentare
Walter Roberson
Walter Roberson am 5 Apr. 2021
z_at_query = interp2(x, y, z.', x_query, y_query)
The .' on z is important. Your data has x going down columns, but in MATLAB x goes across rows.
DARSHAN N KANNUR
DARSHAN N KANNUR am 5 Apr. 2021
Thank you so much. it worked. How to accept your answer.

Melden Sie sich an, um zu kommentieren.

Antworten (2)

Steven Lord
Steven Lord am 1 Apr. 2021
The fitted object you export to the workspace is an sfit object. You can evaluate an sfit object by passing the values at which you want to evaluate it into the object as shown in the example on that documentation page. The same holds for cfit objects:
load census
f = fit(cdate, pop, 'poly2')
f =
Linear model Poly2: f(x) = p1*x^2 + p2*x + p3 Coefficients (with 95% confidence bounds): p1 = 0.006541 (0.006124, 0.006958) p2 = -23.51 (-25.09, -21.93) p3 = 2.113e+04 (1.964e+04, 2.262e+04)
plot(cdate, pop, 'o-') % show the data
hold on
plot(1985, f(1985), 'x') % show the fitted value for 1985
The X looks to be pretty close to the line.
  1 Kommentar
DARSHAN N KANNUR
DARSHAN N KANNUR am 5 Apr. 2021
could you please edit the code and send as per my requirement. where x, y, z variables are plotted using cftool with interpolant linear. where i should find z value for any x and y input.

Melden Sie sich an, um zu kommentieren.


Walter Roberson
Walter Roberson am 5 Apr. 2021
The use of interpolant in this case can be replaced by just calling interp2() without using cftool at all.
x y and z where x is speed (mx1 array), y is torque (nx1 array), z is efficiency (mxn array).
z_at_query = interp2(x, y, z.', x_query, y_query)
The .' on z is important. Your data has x going down columns, but in MATLAB x goes across rows.

Kategorien

Mehr zu Get Started with Curve Fitting Toolbox finden Sie in Help Center und File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by