3-d order derivative

4 vues (au cours des 30 derniers jours)
Max Demesh
Max Demesh le 13 Fév 2022
Commenté : Matt J le 14 Fév 2022
Dear all,
there is the following problem with the calculation of a 3-d order derivative.
I have two vectors of lambda and refractive index, respectively. I take the 3-d order derivative using a gradient().
dndl=gradient(n)./gradient(lambda);
d2ndl2=gradient(dndl)./gradient(lambda);
d3ndl3=gradient(d2ndl2)./gradient(lambda);
When I use a relatively small number of points (for example 3000) , I get a smooth plot.
In the case of more points (30 000) there is some oscillation in the plot.
What is the reason of such behavior?
Thank you a lot.
  2 commentaires
Matt J
Matt J le 13 Fév 2022
What do you mean by "use more points"? If it's a different input array why expect the same results?
Max Demesh
Max Demesh le 13 Fév 2022
What do you mean by "use more points"?
I mean, that I make the differences smaller and increase the accuracy.
Moreover, if I find the analytical function and then take the 3-d order derivative, I obtain smooth plots in any case.

Connectez-vous pour commenter.

Réponses (3)

Catalytic
Catalytic le 13 Fév 2022
If the points are too close together, the difference between neighbours will be so small as to be dominated by floating point errors
  1 commentaire
Max Demesh
Max Demesh le 13 Fév 2022
It seems to be true. Using non SI base units do not help.
I guess in this case there is no way to solve this issue.
P.S. For the 2-nd derivative there is no problem for any number of points.

Connectez-vous pour commenter.


Matt J
Matt J le 13 Fév 2022
You could try diff(x,3)
  2 commentaires
Max Demesh
Max Demesh le 14 Fév 2022
It does not work too, because diff() uses a forward difference, but the gradient() uses a central difference.
Matt J
Matt J le 14 Fév 2022
Why care whether its forward or central? For a smooth curve, it should work out the same.

Connectez-vous pour commenter.


Max Demesh
Max Demesh le 14 Fév 2022

Catégories

En savoir plus sur Spatial Search dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by