[vtk-developers] vtkAmoebaMinimizer

David Gobbi dgobbi at irus.rri.ca
Mon Jun 10 09:12:16 EDT 2002


Hi All,

I added a downhill simplex minimization class to VTK over the weekend,
it is in the Hybrid directory in CVS and includes examples in
Hybrid/Testing/Cxx and Hybrid/Testing/Tcl.

My intention is to eventually split off a vtkAbstractMinimizer base
class (once I know whether people like the basic interface), but for now
if anyone wants to create their own minimizer class they can derive from
vtkAmoebaMinimizer and override the Iterate() and Minimize() methods.

Here is a short example (in python) of how to use the class:

m = vtkAmoebaMinimizer()

# create the function that will be minimized
def func():
    x = m.GetParameterValue("x")
    y = m.GetParameterValue("y")
    z = m.GetParameterValue("z")

    r = (x-5)*(x-5) + (y+2)*(y+2) + (z)*(z)

    m.SetResult(r)

m.SetFunction(func)
m.SetParameterBracket("x",-2,2)  # initial guess is -2, 2nd guess is +2
m.SetParameterBracket("y",-2,2)
m.SetParameterBracket("z",-2,2)
m.Minimize()
m.Iterate()

print "should get x=5, y=-2, z=0"

print "x =", m.GetParameterValue("x")
print "y =", m.GetParameterValue("y")
print "z =", m.GetParameterValue("z")

print "minimum =", m.GetResult()

print "iterations =", m.GetIterations()


 - David

--
  David Gobbi, MSc                       dgobbi at irus.rri.ca
  Advanced Imaging Research Group
  Robarts Research Institute, University of Western Ontario




More information about the vtk-developers mailing list