freESIndividual.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: freESIndividual.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 __freESIndividual_txx
00023 #define __freESIndividual_txx
00024 
00025 #include "freESIndividual.h"
00026 
00027 namespace FREE
00028 {
00029   namespace ES
00030   {
00031 
00032     template <class TOPValueType, class TSPValueType, class TOValueType>
00033     Individual<TOPValueType, TSPValueType, TOValueType>::
00034     Individual()
00035     {
00036       m_ObjectiveValueIsSet=false;
00037       m_StrategicParameters = StrategicParametersType::New();
00038     };
00039       
00040     template <class TOPValueType, class TSPValueType, class TOValueType>
00041     typename Individual<TOPValueType, TSPValueType, TOValueType>::Pointer
00042     Individual<TOPValueType, TSPValueType, TOValueType>::
00043     Clone() const
00044     {
00045       Pointer newIndividual = Self::New();
00046       *(newIndividual.GetPointer()) = *this;
00047       return newIndividual;
00048     };
00049 
00050     template <class TOPValueType, class TSPValueType, class TOValueType>
00051     void
00052     Individual<TOPValueType, TSPValueType, TOValueType>::
00053     operator=(const Self & individual)
00054     {
00055       m_GenerationID = individual.GetGenerationID();
00056       m_IndividualID = individual.GetIndividualID();
00057 
00058       m_ObjectiveValue = individual.GetObjectiveValue();
00059       m_ObjectiveValueIsSet = individual.GetObjectiveValueIsSet(); 
00060 
00061       m_ObjectiveParameters = individual.ObjectiveParameters();
00062 
00063       m_StrategicParameters = individual.StrategicParameters().Clone();
00064     };
00065 
00066     template <class TOPValueType, class TSPValueType, class TOValueType>
00067     void
00068     Individual<TOPValueType, TSPValueType, TOValueType>::
00069     PrintSelf(std::ostream& os, itk::Indent indent) const
00070     {
00071       os << indent << "IID: " << this->GetIndividualID() << std::endl;
00072       os << indent << "GID: " << this->GetGenerationID() << std::endl;
00073       os << indent << "Value: " << this->GetObjectiveValue() << std::endl;
00074 
00075       os << indent << "OParameters: ";
00076       typename ObjectiveParametersType::const_iterator posO;
00077       for (posO = m_ObjectiveParameters.begin(); posO!=m_ObjectiveParameters.end(); ++posO)
00078       {
00079         os << *posO <<"; ";
00080       }
00081       os << std::endl;
00082 
00083 
00084       os << indent << "SParameters: ";
00085       m_StrategicParameters->Print(os);
00086       os << std::endl;
00087     };
00088 
00089   } // End namespace ES
00090 } // End namespace FREE
00091 
00092 
00093 #endif // __freESIndividual_txx

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