aGrUM  0.20.3
a C++ library for (probabilistic) graphical models
gum::GTestPolicy< GUM_SCALAR > Class Template Reference

<agrum/tools/multidim/core/testPolicies/GTestPolicy.h> More...

#include <GTestPolicy.h>

+ Inheritance diagram for gum::GTestPolicy< GUM_SCALAR >:
+ Collaboration diagram for gum::GTestPolicy< GUM_SCALAR >:

Public Member Functions

Constructor/Destrcutor
 GTestPolicy ()
 Constructor. More...
 
virtual ~GTestPolicy ()
 Destructor. More...
 
void * operator new (size_t s)
 Allocators and Deallocators redefinition. More...
 
void operator delete (void *p)
 Constructor. More...
 
Observation insertion
void addObservation (Idx iattr, GUM_SCALAR ivalue)
 Comptabilizes the new observation. More...
 
Test methods
bool isTestRelevant () const
 Returns true if enough observation were made so that the test can be relevant. More...
 
void computeScore () const
 Computes the GStat of current variable according to the test. More...
 
double score () const
 Returns the performance of current variable according to the test. More...
 
double secondaryscore () const
 Returns a second criterion to severe ties. More...
 
Fusion Methods
void add (const GTestPolicy< GUM_SCALAR > &src)
 Performs the merging of current GTestPolicy instance with given instance. More...
 
const ContingencyTable< Idx, GUM_SCALAR > & ct () const
 Returns contingency table (needed for the merging of GTestPolicy instances) More...
 
Miscelleanous Methods
std::string toString () const
 
Observation methods
Idx nbObservation () const
 Comptabilizes the new observation. More...
 
Fusion Methods
void add (const ITestPolicy< GUM_SCALAR > &src)
 

Protected Member Functions

bool isModified_ () const
 

Detailed Description

template<typename GUM_SCALAR>
class gum::GTestPolicy< GUM_SCALAR >

<agrum/tools/multidim/core/testPolicies/GTestPolicy.h>

G implements a test policy that follows the G statistic

Definition at line 53 of file GTestPolicy.h.

Constructor & Destructor Documentation

◆ GTestPolicy()

template<typename GUM_SCALAR >
gum::GTestPolicy< GUM_SCALAR >::GTestPolicy ( )
inline

Constructor.

Definition at line 63 of file GTestPolicy.h.

63  : ITestPolicy< GUM_SCALAR >(), _conTab_(), _GStat_(0) {
64  GUM_CONSTRUCTOR(GTestPolicy);
65  }
ContingencyTable< Idx, GUM_SCALAR > _conTab_
The contingency table used to keeps records of all observation.
Definition: GTestPolicy.h:169
GTestPolicy()
Constructor.
Definition: GTestPolicy.h:63

◆ ~GTestPolicy()

template<typename GUM_SCALAR >
virtual gum::GTestPolicy< GUM_SCALAR >::~GTestPolicy ( )
inlinevirtual

Destructor.

Definition at line 70 of file GTestPolicy.h.

70  {
71  GUM_DESTRUCTOR(GTestPolicy);
72  ;
73  }
GTestPolicy()
Constructor.
Definition: GTestPolicy.h:63

Member Function Documentation

◆ add() [1/2]

template<typename GUM_SCALAR >
void gum::GTestPolicy< GUM_SCALAR >::add ( const GTestPolicy< GUM_SCALAR > &  src)

Performs the merging of current GTestPolicy instance with given instance.

Definition at line 106 of file GTestPolicy_tpl.h.

References gum::Set< Key, Alloc >::emplace().

106  {
108  _conTab_ += src.ct();
109  }
ContingencyTable< Idx, GUM_SCALAR > _conTab_
The contingency table used to keeps records of all observation.
Definition: GTestPolicy.h:169
void add(const ITestPolicy< GUM_SCALAR > &src)
Definition: ITestPolicy.h:139
+ Here is the call graph for this function:

◆ add() [2/2]

template<typename GUM_SCALAR >
void gum::ITestPolicy< GUM_SCALAR >::add ( const ITestPolicy< GUM_SCALAR > &  src)
inlineinherited

Definition at line 139 of file ITestPolicy.h.

References gum::ITestPolicy< GUM_SCALAR >::_isModified_.

139  {
140  _isModified_ = true;
141  _nbObs_ += src.nbObservation();
142  }
bool _isModified_
Booleans indicating if we have to re eval test.
Definition: ITestPolicy.h:168

◆ addObservation()

template<typename GUM_SCALAR >
void gum::GTestPolicy< GUM_SCALAR >::addObservation ( Idx  iattr,
GUM_SCALAR  ivalue 
)
virtual

Comptabilizes the new observation.

Reimplemented from gum::ITestPolicy< GUM_SCALAR >.

Definition at line 45 of file GTestPolicy_tpl.h.

References gum::Set< Key, Alloc >::emplace().

45  {
47  _conTab_.add(iattr, ivalue);
48  }
virtual void addObservation(Idx attr, GUM_SCALAR value)
Comptabilizes the new observation.
Definition: ITestPolicy.h:89
void add(GUM_SCALAR_A valueA, GUM_SCALAR_B valueB)
Increments the number of sample for case( iattr, ivalue )
ContingencyTable< Idx, GUM_SCALAR > _conTab_
The contingency table used to keeps records of all observation.
Definition: GTestPolicy.h:169
+ Here is the call graph for this function:

◆ computeScore()

template<typename GUM_SCALAR >
void gum::GTestPolicy< GUM_SCALAR >::computeScore ( ) const
virtual

Computes the GStat of current variable according to the test.

Reimplemented from gum::ITestPolicy< GUM_SCALAR >.

Definition at line 59 of file GTestPolicy_tpl.h.

References gum::Set< Key, Alloc >::emplace().

59  {
61  _GStat_ = 0;
62 
63  // Itération sur l'axe 1 du tableau
64  for (auto attrIter = _conTab_.attrABeginSafe(); attrIter != _conTab_.attrAEndSafe();
65  ++attrIter) {
66  // Mise en cache de valeur utile
67  double semiExpected = (double)(attrIter.val()) / (double)this->nbObservation();
68 
69  // Itération sur l'axe 2 du tableau
70  for (auto valIter = _conTab_.attrBBeginSafe(); valIter != _conTab_.attrBEndSafe();
71  ++valIter) {
72  // Récupération de la valeur en cellule
73  Idx cell = _conTab_.joint(attrIter.key(), valIter.key());
74  if (cell < 5) continue;
75 
76  // Récupération de la valeur en axe 2
77  double expected = semiExpected * (double)valIter.val();
78 
79  _GStat_ += 2 * cell * log(cell / expected);
80  }
81  }
82  }
virtual void computeScore() const
Recomputes the statistic from the beginning.
Definition: ITestPolicy.h:116
HashTableConstIteratorSafe< GUM_SCALAR_B, Idx > attrBEndSafe() const
Increments the number of sample for case( iattr, ivalue )
ContingencyTable< Idx, GUM_SCALAR > _conTab_
The contingency table used to keeps records of all observation.
Definition: GTestPolicy.h:169
Idx joint(GUM_SCALAR_A valueA, GUM_SCALAR_B valueB) const
Returns the number of samples for case (iattr, ivalue)
HashTableConstIteratorSafe< GUM_SCALAR_A, Idx > attrAEndSafe() const
Increments the number of sample for case( iattr, ivalue )
HashTableConstIteratorSafe< GUM_SCALAR_A, Idx > attrABeginSafe() const
Returns the number of samples for line iattr.
HashTableConstIteratorSafe< GUM_SCALAR_B, Idx > attrBBeginSafe() const
Returns the number of samples for column ivalue.
Idx nbObservation() const
Comptabilizes the new observation.
Definition: ITestPolicy.h:97
+ Here is the call graph for this function:

◆ ct()

template<typename GUM_SCALAR >
const ContingencyTable< Idx, GUM_SCALAR >& gum::GTestPolicy< GUM_SCALAR >::ct ( ) const
inline

Returns contingency table (needed for the merging of GTestPolicy instances)

Definition at line 145 of file GTestPolicy.h.

145 { return _conTab_; }
ContingencyTable< Idx, GUM_SCALAR > _conTab_
The contingency table used to keeps records of all observation.
Definition: GTestPolicy.h:169

◆ isModified_()

template<typename GUM_SCALAR >
bool gum::ITestPolicy< GUM_SCALAR >::isModified_ ( ) const
inlineprotectedinherited

Definition at line 164 of file ITestPolicy.h.

References gum::ITestPolicy< GUM_SCALAR >::_isModified_.

164 { return _isModified_; }
bool _isModified_
Booleans indicating if we have to re eval test.
Definition: ITestPolicy.h:168

◆ isTestRelevant()

template<typename GUM_SCALAR >
bool gum::GTestPolicy< GUM_SCALAR >::isTestRelevant ( ) const
inlinevirtual

Returns true if enough observation were made so that the test can be relevant.

Implements gum::ITestPolicy< GUM_SCALAR >.

Definition at line 108 of file GTestPolicy.h.

108  {
109  return (this->nbObservation() > 20 && this->nbObservation() > _conTab_.attrASize() * 5);
110  }
ContingencyTable< Idx, GUM_SCALAR > _conTab_
The contingency table used to keeps records of all observation.
Definition: GTestPolicy.h:169
Idx nbObservation() const
Comptabilizes the new observation.
Definition: ITestPolicy.h:97
Idx attrASize() const
Returns the number of samples for line iattr.

◆ nbObservation()

template<typename GUM_SCALAR >
Idx gum::ITestPolicy< GUM_SCALAR >::nbObservation ( ) const
inlineinherited

Comptabilizes the new observation.

Definition at line 97 of file ITestPolicy.h.

97 { return _nbObs_; }

◆ operator delete()

template<typename GUM_SCALAR >
void gum::GTestPolicy< GUM_SCALAR >::operator delete ( void *  p)
inline

Constructor.

Definition at line 80 of file GTestPolicy.h.

80  {
82  }
void deallocate(void *pDeallocatedObject, const size_t &objectSize)
Deallocates an object.
GTestPolicy()
Constructor.
Definition: GTestPolicy.h:63
static SmallObjectAllocator & instance()

◆ operator new()

template<typename GUM_SCALAR >
void* gum::GTestPolicy< GUM_SCALAR >::operator new ( size_t  s)
inline

Allocators and Deallocators redefinition.

Definition at line 78 of file GTestPolicy.h.

void * allocate(const size_t &objectSize)
Allocates a block.
static SmallObjectAllocator & instance()

◆ score()

template<typename GUM_SCALAR >
double gum::GTestPolicy< GUM_SCALAR >::score ( ) const
virtual

Returns the performance of current variable according to the test.

Implements gum::ITestPolicy< GUM_SCALAR >.

Definition at line 88 of file GTestPolicy_tpl.h.

References gum::Set< Key, Alloc >::emplace().

88  {
89  if (this->isModified_()) computeScore();
90  // std::cout << this->toString() << std::endl;
91  double score
93  return score;
94  }
void computeScore() const
Computes the GStat of current variable according to the test.
Idx attrBSize() const
Returns the number of samples for column ivalue.
ContingencyTable< Idx, GUM_SCALAR > _conTab_
The contingency table used to keeps records of all observation.
Definition: GTestPolicy.h:169
bool isModified_() const
Definition: ITestPolicy.h:164
static double probaChi2(double x, Size df)
computes the probability of chi2 value (used by the cache)
Definition: chiSquare.cpp:114
double score() const
Returns the performance of current variable according to the test.
Idx attrASize() const
Returns the number of samples for line iattr.
+ Here is the call graph for this function:

◆ secondaryscore()

template<typename GUM_SCALAR >
double gum::GTestPolicy< GUM_SCALAR >::secondaryscore ( ) const
virtual

Returns a second criterion to severe ties.

Implements gum::ITestPolicy< GUM_SCALAR >.

Definition at line 100 of file GTestPolicy_tpl.h.

References gum::Set< Key, Alloc >::emplace().

100  {
101  if (this->isModified_()) computeScore();
102  return _GStat_;
103  }
void computeScore() const
Computes the GStat of current variable according to the test.
bool isModified_() const
Definition: ITestPolicy.h:164
+ Here is the call graph for this function:

◆ toString()

template<typename GUM_SCALAR >
std::string gum::GTestPolicy< GUM_SCALAR >::toString ( ) const
inline

Definition at line 156 of file GTestPolicy.h.

156  {
157  std::stringstream ss;
158  ss << ITestPolicy< GUM_SCALAR >::toString() << "\t\t\tContingency Table : " << std::endl
159  << _conTab_.toString() << std::endl
160  << "\t\t\tGStat : " << _GStat_ << std::endl
161  << "\t\t\tGStat : " << this->secondaryscore() << std::endl;
162  return ss.str();
163  }
std::string toString() const
ContingencyTable< Idx, GUM_SCALAR > _conTab_
The contingency table used to keeps records of all observation.
Definition: GTestPolicy.h:169
double secondaryscore() const
Returns a second criterion to severe ties.

Member Data Documentation

◆ _conTab_

template<typename GUM_SCALAR >
ContingencyTable< Idx, GUM_SCALAR > gum::GTestPolicy< GUM_SCALAR >::_conTab_
private

The contingency table used to keeps records of all observation.

Definition at line 169 of file GTestPolicy.h.

◆ _GStat_

template<typename GUM_SCALAR >
double gum::GTestPolicy< GUM_SCALAR >::_GStat_
mutableprivate

Definition at line 170 of file GTestPolicy.h.


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