Go to the documentation of this file.00001 #include "gaussian_process/covarianceFunctions.h"
00002 
00003 CovFunc1D::CovFunc1D() {
00004         hyperParam = vector<double>(2);
00005     setHyperparameter(-1.6,1.4);
00006 }
00007 
00008 CovFunc1D::CovFunc1D(double ell_0, double sigma) {
00009         hyperParam = vector<double>(2);
00010         setHyperparameter(ell_0,sigma);
00011 }
00012 
00013 void CovFunc1D::setHyperparameter(vector<double>& newHyperParam) {
00014         CovFunc<TDoubleVector>::setHyperparameter(newHyperParam);
00015         
00016         
00017     this->ell_0 = exp(newHyperParam[0]);
00018     this->sigma = exp(2*newHyperParam[1]);
00019   }
00020   
00021 void CovFunc1D::setHyperparameter(double ell0,double sigma) {
00022         hyperParam[0] = ell0;
00023         hyperParam[1] = sigma;
00024 
00025         
00026     this->ell_0 = exp(hyperParam[0]);
00027     this->sigma = exp(2*hyperParam[1]);
00028 }
00029  
00030   
00031 double CovFunc1D::getCov( const TDoubleVector &x, const TDoubleVector &y ) {
00032 
00033     double dist_0 = fabs(x[0]-y[0]);
00034     
00035     double tt2 = 1./(ell_0 * ell_0) * dist_0 * dist_0;
00036     
00037     double rr2 =  sigma * exp(-0.5 * tt2);
00038     
00039     return rr2;
00040   }
00041 
00042 
00043 double CovFunc1D::getDerivative(const TDoubleVector &x, const TDoubleVector &y, int parameter) {
00044 
00045     double r=0;
00046     switch (parameter) {
00047     case 0:
00048       r =  getCov(x, y) * (fabs((x[0]-y[0])/ell_0) * fabs((x[0]-y[0])/ell_0)) ;
00049       break;
00050         
00051     case 1:
00052       r = 2*getCov(x,y);
00053       break;
00054     }
00055     return r;
00056   }
00057   
00058 int CovFunc1D::getNumParameter() {
00059     return 2;
00060   }
00061 
00062 
00063 
00064 CovFunc2D::CovFunc2D() {
00065         hyperParam = vector<double>(3);
00066     setHyperparameter(-1.6,-1.6,1.4);
00067 }
00068 
00069 CovFunc2D::CovFunc2D(double ell_0, double ell_1, double sigma) {
00070         hyperParam = vector<double>(3);
00071         setHyperparameter(ell_0,ell_1,sigma);
00072 }
00073 
00074 void CovFunc2D::setHyperparameter(vector<double>& hyperParam) {
00075         CovFunc<TDoubleVector>::setHyperparameter(hyperParam);
00076         
00077         
00078     this->ell_0 = exp(hyperParam[0]);
00079     this->ell_1 = exp(hyperParam[1]);
00080     this->sigma = exp(2*hyperParam[2]);
00081   }
00082 
00083 void CovFunc2D::setHyperparameter(double ell_0, double ell_1,double sigma) {
00084         hyperParam[0] = ell_0;
00085         hyperParam[1] = ell_1;
00086         hyperParam[2] = sigma;
00087 
00088         
00089     this->ell_0 = exp(hyperParam[0]);
00090     this->ell_1 = exp(hyperParam[1]);
00091     this->sigma = exp(2*hyperParam[2]);
00092 }
00093  
00094 double CovFunc2D::getCov( const TDoubleVector &x, const TDoubleVector &y ) {
00095 
00096     double dist_0 = fabs(x[0]-y[0]);
00097     double dist_1 = fabs(x[1]-y[1]);
00098     double tt2 = 1./(ell_0 * ell_0) * dist_0 * dist_0 + 1./(ell_1 * ell_1) * dist_1 * dist_1;
00099     double rr2 =  sigma * exp(-0.5 * tt2);
00100     
00101     return rr2;
00102   }
00103 
00104 double CovFunc2D::getDerivative(const TDoubleVector &x, const TDoubleVector &y, int parameter) {
00105 
00106     double r=0;
00107     switch (parameter) {
00108     case 0:
00109       
00110       r =  getCov(x, y) * (fabs((x[0]-y[0])/ell_0) * fabs((x[0]-y[0])/ell_0)) ;
00111       break;
00112         
00113     case 1:
00114       
00115       r =  getCov(x, y) * (fabs((x[1]-y[1])/ell_1) * fabs((x[1]-y[1])/ell_1)) ;
00116       break;
00117         
00118     case 2:
00119       r = 2*getCov(x,y);
00120       break;
00121     }
00122     return r;
00123   }
00124   
00125 int CovFunc2D::getNumParameter() {
00126     return 3;
00127   }
00128 
00129 
00130 
00131 CovFuncND::CovFuncND() {
00132         hyperParam = vector<double>(2);
00133         evalParam = vector<double>(2);
00134         n = 1;
00135         hyperParam[0] = 5;
00136         hyperParam[1] = 0.8;
00137         
00138         setHyperparameter(hyperParam);
00139 }
00140 
00141 CovFuncND::CovFuncND(int n,double ell, double sigma) {
00142         hyperParam = vector<double>(n+1);
00143         evalParam = vector<double>(n+1);
00144         for(int i=0;i<n;i++) 
00145                 hyperParam[i] = ell;
00146         hyperParam[n] = sigma;
00147 
00148         setHyperparameter(hyperParam);
00149 }
00150 
00151 void CovFuncND::setHyperparameter(vector<double>& hyperParam) {
00152         CovFunc<TDoubleVector>::setHyperparameter(hyperParam);
00153         n = hyperParam.size()-1;
00154         
00155         
00156         evalParam = vector<double>(n+1);
00157         for(int i=0;i<n;i++) 
00158                 evalParam[i] = exp(hyperParam[i]);
00159         evalParam[n] = exp(2*hyperParam[n]); 
00160   }
00161 
00162 double CovFuncND::getCov( const TDoubleVector &x, const TDoubleVector &y ) {
00163         double tt2=0;
00164         double dist;
00165         for(int i=0;i<n;i++) {
00166                 dist = fabs(x[i]-y[i]);
00167                 tt2 += 1./(evalParam[i] * evalParam[i]) * dist*dist; 
00168         }
00169     double rr2 =  evalParam[n] * exp(-0.5 * tt2);
00170     
00171     return rr2;
00172   }
00173 
00174 double CovFuncND::getDerivative(const TDoubleVector &x, const TDoubleVector &y, int parameter) {
00175     if(parameter<n) {
00176       return  getCov(x, y) 
00177         * fabs((x[parameter]-y[parameter])/evalParam[parameter]) 
00178         * fabs((x[parameter]-y[parameter])/evalParam[parameter]);
00179     } else {
00180         return 2*getCov(x,y);
00181     }
00182   }
00183   
00184 int CovFuncND::getNumParameter() {
00185     return n+1;
00186   }
00187