gstlearn  1.0.0
CCC
GibbsMultiMono Class Reference

#include <GibbsMultiMono.hpp>

Inheritance diagram for GibbsMultiMono:
AGibbs AStringable GibbsUMultiMono GibbsUPropMono

Public Member Functions

 GibbsMultiMono ()
 
 GibbsMultiMono (Db *db, std::vector< Model * > models, double rho)
 
 GibbsMultiMono (const GibbsMultiMono &r)
 
GibbsMultiMonooperator= (const GibbsMultiMono &r)
 
virtual ~GibbsMultiMono ()
 
ModelgetModels (int ivar) const
 
double getRho () const
 
int getVariableNumber () const
 
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)
 
- 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 void update (VectorVectorDouble &y, int isimu, int ipgs, int iter)=0
 
virtual int covmatAlloc (bool verbose, bool verboseTimer=false)=0
 
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

std::vector< Model * > _models
 
double _rho
 

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

◆ GibbsMultiMono() [1/3]

GibbsMultiMono::GibbsMultiMono ( )

◆ GibbsMultiMono() [2/3]

GibbsMultiMono::GibbsMultiMono ( Db db,
std::vector< Model * >  models,
double  rho 
)

◆ GibbsMultiMono() [3/3]

GibbsMultiMono::GibbsMultiMono ( const GibbsMultiMono r)

◆ ~GibbsMultiMono()

GibbsMultiMono::~GibbsMultiMono ( )
virtual

Member Function Documentation

◆ calculInitialize()

int GibbsMultiMono::calculInitialize ( VectorVectorDouble y,
int  isimu,
int  ipgs 
)
virtual

Initializes the Gibbs sampler for a set of inequalities

Returns
Error return code
Parameters
[in]yGaussian vector
[in]isimuRank of the simulation
[in]ipgsRank of the GS

Implements AGibbs.

◆ checkGibbs()

int GibbsMultiMono::checkGibbs ( const VectorVectorDouble y,
int  isimu,
int  ipgs 
)
virtual

Check/Show the facies against gaussian at wells

Returns
Error return code
Parameters
[in]yGaussian vector
[in]isimuRank of the simulation
[in]ipgsRank of the GS

Implements AGibbs.

◆ getModels()

Model* GibbsMultiMono::getModels ( int  ivar) const
inline

◆ getRho()

double GibbsMultiMono::getRho ( ) const
inline

◆ getSimulate()

double GibbsMultiMono::getSimulate ( VectorVectorDouble y,
double  yk,
double  sk,
int  ipgs,
int  ivar,
int  iact,
int  iter 
)
virtual

Generate a simulated value

Parameters
y: Gaussian vector
yk: Kriged value
sk: Standard deviation
ipgs: Rank of the current GS
ivar: Rank of the current Variable
iact: Rank of the target sample (relative)
iter: Rank of the iteration
Returns
Simulated value

Implements AGibbs.

◆ getVariableNumber()

int GibbsMultiMono::getVariableNumber ( ) const
inline

◆ operator=()

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

Member Data Documentation

◆ _models

std::vector<Model *> GibbsMultiMono::_models
private

◆ _rho

double GibbsMultiMono::_rho
private

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