freConstrainedAccuracySOMetric.txx

Go to the documentation of this file.
00001 /*=========================================================================
00002 
00003   Program:   F.R.E.E. - flexible registration evaluation engine
00004   Version:   v.1.0.0
00005   Date:      $Date: 2006/09/01 12:00:00 $
00006   Module:    $RCSfile: freConstrainedAccuracySOMetric.txx,v $
00007   Language:  C++
00008 
00009 
00010 
00011   Copyright (c) 2007 Ralf o Floca (Department of Medical Informatics,
00012   Institute for Medical Biometry and Informatics, University of Heidelberg,
00013   Germany). All rights reserved.
00014   See FREECopyright.txt or http://www.mi.med.uni-hd.de/free/copyright.htm
00015   for details.
00016 
00017      This software is distributed WITHOUT ANY WARRANTY; without even 
00018      the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
00019      PURPOSE.  See the above copyright notices for more information.
00020 
00021 =========================================================================*/
00022 #ifndef __freConstrainedAccuracySOMetric_txx
00023 #define __freConstrainedAccuracySOMetric_txx
00024 
00025 #include "freConstrainedAccuracySOMetric.h"
00026 
00027 namespace FREE
00028 {
00029 
00030         template <unsigned int VImageDimension>
00031   typename ConstrainedAccuracySOMetric<VImageDimension>::DecomposedMeasureType
00032         ConstrainedAccuracySOMetric<VImageDimension>::
00033   ComputeDecomposedValue( const ParametersType & parameters ) const
00034         {
00035                 DecomposedMeasureType result(this->GetNumberOfValues());
00036     result.Fill(0.0);
00037 
00038                 DecomposedMeasureType constraints;
00039     DecomposedMeasureType values(this->Superclass::GetNumberOfValues());
00040     values.Fill(0.0);
00041 
00042     if (ComputeConstraintPenalties(parameters,constraints))
00043     { //evaluation is no failure by exceeding the failure
00044       //threshold of the penalty computation, so compute the
00045       //metric values;
00046 
00047       values = Superclass::ComputeDecomposedValue(parameters);
00048     }
00049 
00050                 for (unsigned int iPos = 0; iPos != values.Size(); ++iPos)
00051                 {
00052                         result.SetElement(iPos, values[iPos]);
00053                 }
00054 
00055                 for (unsigned int iPos = 0; iPos != constraints.Size(); ++iPos)
00056                 {
00057                         result.SetElement(iPos+values.Size(), constraints[iPos]);
00058                 }
00059 
00060                 return result;
00061         };
00062 
00063 template <unsigned int VImageDimension>
00064 ConstrainedAccuracySOMetric<VImageDimension>::
00065 ConstrainedAccuracySOMetric()
00066 {
00067         this->m_MaxConstraintPenalty = 100000;
00068         ResetConstraints();
00069 };
00070 
00071 } // end namespace FREE
00072 
00073 #endif

Generated at Sat Oct 13 15:39:21 2007 for f.r.e.e. - Flexible Registration and Evaluation Engine by doxygen 1.5.3 written by Dimitri van Heesch, © 1997-2000