51#ifndef DOXYGEN_SHOULD_SKIP_THIS
66 _internal_prior_ = from._internal_prior_;
75 _internal_prior_ = std::move(from._internal_prior_);
90 std::stringstream msg;
92 <<
"' is not yet compatible with the score 'Log2Likelihood'.";
99 std::vector< double > N_ijk(this->
counter_.counts(idset,
true));
100 const bool informative_external_prior = this->
prior_->isInformative();
101 if (informative_external_prior) this->
prior_->addJointPseudoCount(idset, N_ijk);
105 if (idset.hasConditioningSet()) {
107 std::vector< double > N_ij(this->
marginalize_(idset[0], N_ijk));
114 for (
const auto n_ijk: N_ijk) {
115 if (n_ijk) {
score += n_ijk * std::log(n_ijk); }
117 for (
const auto n_ij: N_ij) {
118 if (n_ij) {
score -= n_ij * std::log(n_ij); }
134 for (
const auto n_ijk: N_ijk) {
136 score += n_ijk * std::log(n_ijk);
140 score -= N * std::log(N);
A class for storing a pair of sets of NodeIds, the second one corresponding to a conditional set.
the class for computing Log2-likelihood scores
ScoreLog2Likelihood & operator=(const ScoreLog2Likelihood &from)
copy operator
virtual double score_(const IdCondSet &idset) final
returns the score for a given IdCondSet
double score(const IdCondSet &idset)
returns the score for a given IdCondSet
virtual std::string isPriorCompatible() const final
indicates whether the prior is compatible (meaningful) with the score
Prior * prior_
the expert knowledge a priorwe add to the score
Score & operator=(const Score &from)
copy operator
RecordCounter counter_
the record counter used for the counts over discrete variables
const double one_log2_
1 / log(2)
std::vector< double > marginalize_(const NodeId X_id, const std::vector< double > &N_xyz) const
returns a counting vector where variables are marginalized from N_xyz
include the inlined functions if necessary
constexpr const char * priorTypeToString(PriorType e) noexcept
gum is the global namespace for all aGrUM entities
the class for computing Log2-likelihood scores
the class for computing Log2-Likelihood scores