using FindMinimum and FindRoot with "numerically defined" functions
- To: mathgroup at smc.vnet.net
- Subject: [mg81044] using FindMinimum and FindRoot with "numerically defined" functions
- From: Scott.T.Milner at gmail.com
- Date: Sun, 9 Sep 2007 06:12:49 -0400 (EDT)
Many times I have wanted to use Mathematica to find the minimum or a
root of a function that was defined in terms of a numerical solution
to a differential equation. (For example, solving a 1-dimensional ODE
boundary value problem by the "shooting method" can be expressed in
this way.)
Here is a simple example (in which we pretend that we do not know how
to solve analytically the ODE presented).
fcn[x_] := Block[{},
ans = NDSolve[{y''[t] == -x y[t], y'[0] == 0, y[0] == 1}, y, {t,
0, 1}];
y[1] /. ans[[1]]]
If you plot this function with Plot[fcn[x], {x, 0, 24}], you will find
a minimum at about x=10. So for instance, I would like to find the
minimum of fcn[x] using FindMinimum[ ], but this does not work:
I attempt to use FindMinimum[ ] (supplying two initial values to avoid
using derivatives):
FindMinimum[fcn[x], {x, 10, 10.1}]
which generates a long string of error messages (NDSolve::ndnum and
several ReplaceAll::reps).
Similar errors are generated if I attempt to use this function with
FindRoot[ ], as in:
FindRoot[fcn[x] == 0., {x, 4, 4.1}]
Is there some way to successfully use FindMinimum[ ] and FindRoot[ ]
with a function defined in terms of the numerical solution to an ODE
using NDSolve, or other such "numerically defined" functions?