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
00034
00035
00036
00037
00038 #ifndef MOEOREALOBJECTIVEVECTOR_H_
00039 #define MOEOREALOBJECTIVEVECTOR_H_
00040
00041 #include <iostream>
00042 #include <math.h>
00043 #include <comparator/moeoObjectiveObjectiveVectorComparator.h>
00044 #include <comparator/moeoParetoObjectiveVectorComparator.h>
00045 #include <core/moeoObjectiveVector.h>
00046
00051 template < class ObjectiveVectorTraits >
00052 class moeoRealObjectiveVector : public moeoObjectiveVector < ObjectiveVectorTraits, double >
00053 {
00054 public:
00055
00056 using moeoObjectiveVector < ObjectiveVectorTraits, double >::size;
00057 using moeoObjectiveVector < ObjectiveVectorTraits, double >::operator[];
00058
00062 moeoRealObjectiveVector(double _value = 0.0) : moeoObjectiveVector < ObjectiveVectorTraits, double > (_value)
00063 {}
00064
00065
00070 moeoRealObjectiveVector(std::vector < double > & _v) : moeoObjectiveVector < ObjectiveVectorTraits, double > (_v)
00071 {}
00072
00073
00079 bool dominates(const moeoRealObjectiveVector < ObjectiveVectorTraits > & _other) const
00080 {
00081 moeoParetoObjectiveVectorComparator < moeoRealObjectiveVector<ObjectiveVectorTraits> > comparator;
00082 return comparator(_other, *this);
00083 }
00084
00085
00090 bool operator==(const moeoRealObjectiveVector < ObjectiveVectorTraits > & _other) const
00091 {
00092 for (unsigned int i=0; i < size(); i++)
00093 {
00094 if ( fabs(operator[](i) - _other[i]) > ObjectiveVectorTraits::tolerance() )
00095 {
00096 return false;
00097 }
00098 }
00099 return true;
00100 }
00101
00102
00107 bool operator!=(const moeoRealObjectiveVector < ObjectiveVectorTraits > & _other) const
00108 {
00109 return ! operator==(_other);
00110 }
00111
00112
00118 bool operator<(const moeoRealObjectiveVector < ObjectiveVectorTraits > & _other) const
00119 {
00120 moeoObjectiveObjectiveVectorComparator < moeoRealObjectiveVector < ObjectiveVectorTraits > > cmp;
00121 return cmp(*this, _other);
00122 }
00123
00124
00130 bool operator>(const moeoRealObjectiveVector < ObjectiveVectorTraits > & _other) const
00131 {
00132 return _other < *this;
00133 }
00134
00135
00141 bool operator<=(const moeoRealObjectiveVector < ObjectiveVectorTraits > & _other) const
00142 {
00143 return operator==(_other) || operator<(_other);
00144 }
00145
00146
00152 bool operator>=(const moeoRealObjectiveVector < ObjectiveVectorTraits > & _other) const
00153 {
00154 return operator==(_other) || operator>(_other);
00155 }
00156
00157 };
00158
00159
00165 template < class ObjectiveVectorTraits >
00166 std::ostream & operator<<(std::ostream & _os, const moeoRealObjectiveVector < ObjectiveVectorTraits > & _objectiveVector)
00167 {
00168 for (unsigned int i=0; i<_objectiveVector.size(); i++)
00169 {
00170 _os << _objectiveVector[i] << '\t';
00171 }
00172 return _os;
00173 }
00174
00180 template < class ObjectiveVectorTraits >
00181 std::istream & operator>>(std::istream & _is, moeoRealObjectiveVector < ObjectiveVectorTraits > & _objectiveVector)
00182 {
00183 _objectiveVector = moeoRealObjectiveVector < ObjectiveVectorTraits > ();
00184 for (unsigned int i=0; i<_objectiveVector.size(); i++)
00185 {
00186 _is >> _objectiveVector[i];
00187 }
00188 return _is;
00189 }
00190
00191 #endif