Curve fitting function (fit) error

I am using function "fit" to fit a surface to my data. I have a 3 dimentional data , z(x,y). I use the function as below: surfacefit=fit([x y],z,'polyll') I am sure both my x and y are column matrix and have the same dimension. But i get this error : Error using fit>iFit (line 133) Y must be a column vector.
Error in fit (line 109) [fitobj, goodness, output, convmsg] = iFit( xdatain, ydatain, fittypeobj, ...

Respuestas (3)

Di Xu
Di Xu el 8 de Sept. de 2016

2 votos

Hi,
I think your z is a matrix, right?
But in fit([x y],z,'polyll'), z must be a column.
So you can use the reshape function http://nl.mathworks.com/help/matlab/ref/reshape.html You can simply reshape z into a column by z=reshape(z,[],1). Of course, you should accordingly change x and y, in order that they have the same disension as z, i.e. for every element in z, its coordinates should be at the according position in x and y.
Then you can run fit.
Walter Roberson
Walter Roberson el 2 de Nov. de 2012
surfacefit=fit([x(:), y(:)],z(:),'polyll')

3 comentarios

sepideh
sepideh el 2 de Nov. de 2012
Hi, thanks for the answer, but i still get the same error.
Susarla
Susarla el 5 de Feb. de 2015
Many Thanks for this answer
chuenkiong
chuenkiong el 15 de Mzo. de 2023
Thank you so much!

Iniciar sesión para comentar.

Kutsop
Kutsop el 12 de Mayo de 2016

0 votos

I had the same problem. "Y" in this case is the second variable called in fit("X","Y","fittype") where for a 3D fit "X" is usually "[x,y]" and "Y" is "z" or in other words fit("[x,y]","z","fittype"). So if for z is a 64 by 64 array and x = 1:64; y = 1:64; then you need to make both x and y 64 by 64 arrays with repeated column and row values respectively, and then use reshape to make x,y,z all 4096 by 1 column vectors. You bassically need to unravel your 3D array.

Categorías

Más información sobre Get Started with Curve Fitting Toolbox en Centro de ayuda y File Exchange.

Preguntada:

el 2 de Nov. de 2012

Comentada:

el 15 de Mzo. de 2023

Community Treasure Hunt

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

Start Hunting!

Translated by