Problem using polyfit in a loop

2 visualizaciones (últimos 30 días)
shaina dhamija
shaina dhamija el 3 de Jun. de 2021
Comentada: dpb el 7 de Jun. de 2021
Hello
I am having problem using polyfit in a for loop.
A is a null matrix. Polynomial fitting of order 10 has to be subtracted from the raw data z((I(:,j)+100/dt:end),j) and the residual has to be zero padded. t(I(:,j)+100/dt:end) is the time axis. But the loop shows matrix dimensions do not agree. Please find the code below.
for j = 1 : 1 : L
z1(:,j) = A(:,j) + (padarray(z((I(:,j)+100/dt:end),j)-polyval(polyfit(t(I(:,j)+100/dt:end),z((I(:,j)+100/dt:end),j),10),t(I(:,j+100/dt:end)),j)),N-length(z((I(:,j)+100/dt:end),j),0,'post');
end
  2 comentarios
dpb
dpb el 4 de Jun. de 2021
You don't have to try to write everything in one line...factor your code first so you can read it and debug...once have done that, use the debugger to step through and see where your logic error is.
shaina dhamija
shaina dhamija el 7 de Jun. de 2021
Thank you for your response. I could debug it by not writing everything in a line. Found the error.

Iniciar sesión para comentar.

Respuestas (1)

Steven Lord
Steven Lord el 4 de Jun. de 2021
If you're trying to remove a polynomial trend from your data, see the detrend function. As of release R2019a you can specify a degree >1 of the polynomial trend to remove.
  2 comentarios
shaina dhamija
shaina dhamija el 7 de Jun. de 2021
Thank you for responding. I wil check the detrend function if it works for me.
dpb
dpb el 7 de Jun. de 2021
High-order polynomials are notroiously ill-behaved and prone to numeric issues...depending upon what range of values are for x, x.^10 can become extremely large. Consider using some other form than such a high-order polynomial or at least use the option in polyfit|polyval to standarize the inputs that will help on the numerics...

Iniciar sesión para comentar.

Categorías

Más información sobre Polynomials en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by