data:image/s3,"s3://crabby-images/a6f81/a6f81938c9b631da7948052e910a6518d8b580d8" 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/eb631/eb63125ed11e05e80703624a618678623cd16533" alt=""
And the estimated derivative with respect to y:
data:image/s3,"s3://crabby-images/e08dc/e08dc50c61f6c8a0f287e41e0a7e299a9ddd84c9" 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