First and second derivative of the function using fft?

 Respuesta aceptada

David Young
David Young el 7 de Dic. de 2011
See my answer to this question.

5 comentarios

Feruz
Feruz el 7 de Dic. de 2011
Thank you for your answer, but the idea is to compute approximation to first and second derivative of function (any) with *fft*...
The fft is always applied to numerical data, never to a function proper, so if you are asking about finding a derivative of a function using the fft, you must mean numerically estimating the derivative from data generated by calling that function.
The answer I referred you to does exactly that. The example code is for 2-D data, but the simplification to 1-D is trivial (and in fact you can use the exact same code, just on a vector). Getting the second derivative is simply a matter of multiplying again.
The key thing you need to know is how to write the derivative operator in the frequency domain. The answer I referred you has it, as ftdiff.
Feruz
Feruz el 7 de Dic. de 2011
I see, second derivative you mention multiply again?!
i.e.
g = ifft(bsxfun(@times, fft(f), ftdiff))
gg = ifft(bsxfun(@times, fft(g), ftdiff))
Is that so?
Yes, you can do that. But you don't need the bsxfun if you're working in 1-D - you just multiply. In addition, you can do both multiplications before transforming back. So something like this:
F = fft(f);
FD = F .* ftdiff;
FDD = FD .* ftdiff;
fd = ifft(FD);
fdd = ifft(FDD);
where uppercase variables are in the frequency domain, and d or D means differentiated.
Feruz
Feruz el 7 de Dic. de 2011
Thank you very much!

Iniciar sesión para comentar.

Más respuestas (1)

Dr. Seis
Dr. Seis el 7 de Dic. de 2011
I have another example, here
In that case I am converting acceleration data to displacement, which is (double) integration in the time domain and division in the frequency domain. In the frequency domain, this is essentially done by dividing the complex acceleration amplitude at frequency 'f' by (sqrt(-1)*2*pi*f)^2.
To go from displacement to velocity, you would multiply the displacement amplitude at frequency 'f' by sqrt(-1)*2*pi*f
To go from displacement to acceleration you would multiply the displacement amplitude at frequency 'f' by (sqrt(-1)*2*pi*f)^2
This is what David was referring to when he says the second derivative is "simply a matter of multiplying again."

1 comentario

Feruz
Feruz el 7 de Dic. de 2011
I see, but I am doing numerical approximation, and exact, as I understood, my numerical approx is by fft, so in a sense multiplying again, doesn't mean multiply as I wrote???

Iniciar sesión para comentar.

Categorías

Más información sobre MATLAB en Centro de ayuda y File Exchange.

Preguntada:

el 7 de Dic. de 2011

Community Treasure Hunt

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

Start Hunting!

Translated by