Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033 #include "cmtkMultiLevelOptimizer.h"
00034
00035 #include <System/cmtkException.h>
00036
00037 namespace
00038 cmtk
00039 {
00040
00043
00044 CallbackResult
00045 MultiLevelOptimizer::Optimize( CoordinateVector& v, const Types::Coordinate, const Types::Coordinate )
00046 {
00047 if ( ! this->m_Optimizer )
00048 {
00049 throw( Exception( "MultiLevelOptimizer.m_Optimizer must be set before calling Optimize().", this ) );
00050 }
00051
00052 if ( ! this->m_FunctionalList.size() )
00053 {
00054 throw( Exception( "MultiLevelOptimizer must have at least one functional before calling Optimize().", this ) );
00055 }
00056
00057
00058
00059 this->SetFinalValue( (*(this->m_FunctionalList.rbegin()))->m_Functional->EvaluateAt( v ) );
00060 CoordinateVector vOriginal( v );
00061
00062
00063
00064 CallbackResult result = CALLBACK_OK;
00065 FunctionalListType::iterator fit = this->m_FunctionalList.begin();
00066 while ( (fit != this->m_FunctionalList.end()) && (result == CALLBACK_OK) )
00067 {
00068 this->m_Optimizer->SetFunctional( (*fit)->m_Functional );
00069 result = this->m_Optimizer->Optimize
00070 ( v, (*fit)->m_InitialStepSize, (*fit)->m_FinalStepSize );
00071 ++fit;
00072 }
00073
00074
00075
00076 const Self::ReturnType finalFunctionalValue = this->m_Optimizer->GetFinalValue();
00077 if ( finalFunctionalValue < this->GetFinalValue() )
00078 {
00079 v = vOriginal;
00080 }
00081 else
00082 {
00083 this->SetFinalValue( finalFunctionalValue );
00084 }
00085
00086 return result;
00087 }
00088
00089 }