00001 #ifndef INDII_ML_AUX_UNIFORMTREEPDF_HPP
00002 #define INDII_ML_AUX_UNIFORMTREEPDF_HPP
00003
00004 #include "Pdf.hpp"
00005
00006 namespace indii {
00007 namespace ml {
00008 namespace aux {
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021 class UniformPdf : public Pdf {
00022 public:
00023
00024
00025
00026
00027
00028
00029
00030 UniformPdf();
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040 UniformPdf(const vector& lower, const vector& upper);
00041
00042
00043
00044
00045 ~UniformPdf();
00046
00047
00048
00049
00050 virtual UniformPdf& operator=(const UniformPdf& o);
00051
00052 virtual void setDimensions(const unsigned int N,
00053 const bool preserve = false);
00054
00055 virtual const vector& getExpectation();
00056
00057 virtual const symmetric_matrix& getCovariance();
00058
00059 virtual vector sample();
00060
00061 virtual double densityAt(const vector& x);
00062
00063 private:
00064
00065
00066
00067 double p;
00068
00069
00070
00071
00072 vector lower;
00073
00074
00075
00076
00077 vector upper;
00078
00079
00080
00081
00082 vector mu;
00083
00084
00085
00086
00087 symmetric_matrix sigma;
00088
00089
00090
00091
00092 bool haveMu;
00093
00094
00095
00096
00097 bool haveSigma;
00098
00099
00100
00101
00102 void calculateExpectation();
00103
00104
00105
00106
00107 void calculateCovariance();
00108
00109
00110
00111
00112 void calculateDensity();
00113
00114
00115
00116
00117 template<class Archive>
00118 void save(Archive& ar, const unsigned int version) const;
00119
00120
00121
00122
00123 template<class Archive>
00124 void load(Archive& ar, const unsigned int version);
00125
00126
00127
00128
00129 BOOST_SERIALIZATION_SPLIT_MEMBER()
00130 friend class boost::serialization::access;
00131
00132 };
00133
00134 }
00135 }
00136 }
00137
00138 template<class Archive>
00139 void indii::ml::aux::UniformPdf::save(Archive& ar,
00140 const unsigned int version) const {
00141 ar & boost::serialization::base_object<Pdf>(*this);
00142 ar & p;
00143 ar & lower;
00144 ar & upper;
00145 }
00146
00147 template<class Archive>
00148 void indii::ml::aux::UniformPdf::load(Archive& ar,
00149 const unsigned int version) {
00150 ar & boost::serialization::base_object<Pdf>(*this);
00151 ar & p;
00152 ar & lower;
00153 ar & upper;
00154
00155 haveMu = false;
00156 haveSigma = false;
00157 mu.resize(N);
00158 sigma.resize(N);
00159 }
00160
00161 #endif
00162