Revision 63d8a43408637eef9a81e05ffd7e6ff3afa51947 authored by Robert B. Gramacy on 20 September 2006, 00:00:00 UTC, committed by Gabor Csardi on 20 September 2006, 00:00:00 UTC
1 parent 622e02d
exp_sep.h
/********************************************************************************
*
* Bayesian Regression and Adaptive Sampling with Gaussian Process Trees
* Copyright (C) 2005, University of California
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*
* Questions? Contact Robert B. Gramacy (rbgramacy@ams.ucsc.edu)
*
********************************************************************************/
#ifndef __EXP_SEP_H__
#define __EXP_SEP_H__
#include "corr.h"
class ExpSep_Prior;
/*
* CLASS for the implementation of the separable exponentia
* power family of correlation functions
*/
class ExpSep : public Corr
{
private:
double *d; /* kernel correlation width parameter */
int *b; /* dimension-wize linearization */
double *d_eff; /* dimension-wize linearization */
double *pb; /* prob of dimension-wize linearization */
unsigned int dreject; /* d rejection counter */
public:
ExpSep(unsigned int col, Base_Prior *base_prior);
virtual Corr& operator=(const Corr &c);
virtual ~ExpSep(void);
virtual void Update(unsigned int n1, unsigned int n2, double **K, double **X, double **XX);
virtual void Update(unsigned int n1, double **X);
virtual void Update(unsigned int n1, double **K, double **X);
virtual int Draw(unsigned int n, double **F, double **X, double *Z,
double *lambda, double **bmu, double **Vb, double tau2, void *state);
virtual void Combine(Corr *c1, Corr *c2, void *state);
virtual void Split(Corr *c1, Corr *c2, void *state);
virtual char* State(void);
virtual unsigned int sum_b(void);
virtual void ToggleLinear(void);
virtual bool DrawNug(unsigned int n, double **X, double **F, double *Z,
double *lambda, double **bmu,
double **Vb, double tau2, void *state);
virtual double* Trace(unsigned int* len);
void get_delta_d(ExpSep* c1, ExpSep* c2, void *state);
void propose_new_d(ExpSep* c1, ExpSep* c2, void *state);
bool propose_new_d(double* d_new, int * b_new, double *pb_new,
double *q_fwd, double *q_bak, void *state);
virtual double log_Prior(void);
void draw_d_from_prior(double *d_new, void *state);
double *D(void);
};
/*
* CLASS for the prior parameterization of the separable
* exponential power family of correlation functions
*/
class ExpSep_Prior : public Corr_Prior
{
private:
double *d;
double **d_alpha; /* d gamma-mixture prior alphas */
double **d_beta; /* d gamma-mixture prior beta */
bool fix_d; /* estimate d-mixture parameters or not */
double d_alpha_lambda[2]; /* d prior alpha lambda parameter */
double d_beta_lambda[2]; /* d prior beta lambda parameter */
public:
ExpSep_Prior(unsigned int col);
ExpSep_Prior(Corr_Prior *c);
virtual ~ExpSep_Prior(void);
virtual void read_double(double *dprior);
virtual void read_ctrlfile(std::ifstream* ctrlfile);
virtual Corr_Prior* Dup(void);
virtual void Draw(Corr **corr, unsigned int howmany, void *state);
virtual Corr* newCorr(void);
virtual void Print(FILE *outfile);
virtual Base_Prior* BasePrior(void);
virtual void SetBasePrior(Base_Prior *base_prior);
virtual double log_HierPrior(void);
void draw_d_from_prior(double *d_new, void *state);
double* D(void);
double** DAlpha(void);
double** DBeta(void);
void default_d_priors(void);
void default_d_lambdas(void);
double log_Prior(double *d, int *b, double *pb, bool linear);
double log_DPrior_pdf(double *d);
void DPrior_rand(double *d_new, void *state);
};
#endif
![swh spinner](/static/img/swh-spinner.gif)
Computing file changes ...