gstlearn  1.0.0
CCC
GibbsUMulti Class Reference

#include <GibbsUMulti.hpp>

Inheritance diagram for GibbsUMulti:
GibbsMulti AGibbs AStringable

Public Member Functions

 GibbsUMulti ()
 
 GibbsUMulti (Db *db, Model *model)
 
 GibbsUMulti (const GibbsUMulti &r)
 
GibbsUMultioperator= (const GibbsUMulti &r)
 
virtual ~GibbsUMulti ()
 
void update (VectorVectorDouble &y, int isimu, int ipgs, int iter) override
 
int covmatAlloc (bool verbose, bool verboseTimer=false) override
 
- Public Member Functions inherited from GibbsMulti
 GibbsMulti ()
 
 GibbsMulti (Db *db, Model *model)
 
 GibbsMulti (const GibbsMulti &r)
 
GibbsMultioperator= (const GibbsMulti &r)
 
virtual ~GibbsMulti ()
 
int calculInitialize (VectorVectorDouble &y, int isimu, int ipgs)
 
double getSimulate (VectorVectorDouble &y, double yk, double sk, int ipgs, int ivar, int iact, int iter)
 
int checkGibbs (const VectorVectorDouble &y, int isimu, int ipgs)
 
ModelgetModel () const
 
- Public Member Functions inherited from AGibbs
 AGibbs ()
 
 AGibbs (Db *db)
 
 AGibbs (Db *db, int npgs, int nvar, int nburn, int niter, int seed, int flag_order, bool flag_decay)
 
 AGibbs (const AGibbs &r)
 
AGibbsoperator= (const AGibbs &r)
 
virtual ~AGibbs ()
 
virtual String toString (const AStringFormat *strfmt=nullptr) const override
 
virtual int run (VectorVectorDouble &y, int ipgs=0, int isimu=0, bool verbose=false, bool flagCheck=false)
 
virtual void cleanup ()
 
void init (int npgs, int nvar, int nburn, int niter, int seed=3241, int flag_order=0, bool flag_decay=true)
 
void getBoundsDecay (int iter, double *vmin, double *vmax) const
 
int getNvar () const
 
void setNvar (int nvar)
 
int getNpgs () const
 
void setNpgs (int npgs)
 
int getNburn () const
 
void setNburn (int nburn)
 
int getNiter () const
 
void setNiter (int niter)
 
int getFlagOrder () const
 
void setFlagOrder (int flagOrder)
 
bool getOptionStats () const
 
void setOptionStats (int option_stats)
 
DbgetDb () const
 
int getDimension () const
 
int getRank (int ipgs, int ivar) const
 
VectorVectorDouble allocY () const
 
void storeResult (const VectorVectorDouble &y, int isimu, int ipgs)
 
int getSampleNumber () const
 
int getSampleRankNumber () const
 
int getSampleRank (int i) const
 
VectorInt calculateSampleRanks () const
 
void updateStats (const VectorVectorDouble &y, int ipgs, int iter, double amort=0.9)
 
bool isConstraintTight (int ipgs, int ivar, int iact, double *value) const
 
void statsInit ()
 
bool getFlagDecay () const
 
int getRelativeRank (int iech)
 
- Public Member Functions inherited from AStringable
 AStringable ()
 
 AStringable (const AStringable &r)
 
AStringableoperator= (const AStringable &r)
 
virtual ~AStringable ()
 
virtual void display (const AStringFormat *strfmt=nullptr) const final
 
virtual void display (int level) const final
 

Private Attributes

VectorDouble _covmat
 

Additional Inherited Members

- Protected Member Functions inherited from AGibbs
int _boundsCheck (int ipgs, int ivar, int iact, double *vmin, double *vmax)
 
void _printInequalities (int iact, int ivar, double simval, double vmin, double vmax) const
 
int _getRowNumberStats () const
 
int _getColNumberStats () const
 
int _getColRankStats (int ipgs, int ivar, int mode) const
 
void _displayCurrentVector (bool flag_init, const VectorVectorDouble &y, int isimu, int ipgs) const
 
const int * _getRanks () const
 

Constructor & Destructor Documentation

◆ GibbsUMulti() [1/3]

GibbsUMulti::GibbsUMulti ( )

◆ GibbsUMulti() [2/3]

GibbsUMulti::GibbsUMulti ( Db db,
Model model 
)

◆ GibbsUMulti() [3/3]

GibbsUMulti::GibbsUMulti ( const GibbsUMulti r)

◆ ~GibbsUMulti()

GibbsUMulti::~GibbsUMulti ( )
virtual

Member Function Documentation

◆ covmatAlloc()

int GibbsUMulti::covmatAlloc ( bool  verbose,
bool  verboseTimer = false 
)
overridevirtual

Establish the covariance matrix for Gibbs

Returns
Error returned code
Parameters
[in]verboseVerbose flag
[in]verboseTimerTrue to show elapse times

Implements AGibbs.

◆ operator=()

GibbsUMulti & GibbsUMulti::operator= ( const GibbsUMulti r)

◆ update()

void GibbsUMulti::update ( VectorVectorDouble y,
int  isimu,
int  ipgs,
int  iter 
)
overridevirtual

Perform one update of the Gibbs sampler

Parameters
[in]yGaussian vector
[in]isimuRank of the simulation
[in]ipgsRank of the GS
[in]iterRank of the iteration

Implements AGibbs.

Member Data Documentation

◆ _covmat

VectorDouble GibbsUMulti::_covmat
private

The documentation for this class was generated from the following files: