data:image/s3,"s3://crabby-images/cb757/cb7574e9e5fde58ab11a3ba84ab75ac52ab81614" alt=""
A finite difference approximation would be (in Octave):
dfdx = ( f(x+h) - f(x) )/ h;
Complex step is even cooler, because you don't have any subtraction (there's no difference), so you can choose a very small step size without loosing accuracy due to subtractive cancelation:
complex_step = complex( 0, 1e-320 );
The derivative is approximated by just the imaginary part:
x = x + complex_step;
dfdx = imag( f(x) )/imag( complex_step );
So the derivative with respect to x looks like this:
data:image/s3,"s3://crabby-images/941b0/941b0a2734c94cbbb9364bcf89bf0ce0b0092d24" alt=""
And the estimated derivative with respect to y:
data:image/s3,"s3://crabby-images/2edbe/2edbe8108de623ed11c5383e30ff22b4a2a2acf8" alt=""
This approach is really useful for design sensitivity analysis, and since modern Fortran supports complex types we can even use this method for serious number crunching!
No comments:
Post a Comment