50#ifndef DOXYGEN_SHOULD_SKIP_THIS
55 template <
typename GUM_SCALAR >
57 const BayesNet< GUM_SCALAR >* priorbn) :
58 Prior(learning_db), _prior_bn_(priorbn) {
59 GUM_CONSTRUCTOR(DirichletPriorFromBN)
63 template <
typename GUM_SCALAR >
64 DirichletPriorFromBN< GUM_SCALAR >::DirichletPriorFromBN(
const DirichletPriorFromBN& from) :
65 Prior(from), _prior_bn_(from._prior_bn_) {
66 GUM_CONS_CPY(DirichletPriorFromBN)
70 template <
typename GUM_SCALAR >
71 DirichletPriorFromBN< GUM_SCALAR >::DirichletPriorFromBN(DirichletPriorFromBN&& from) noexcept :
72 Prior(std::move(from)), _prior_bn_(std::move(from._prior_bn_)) {
73 GUM_CONS_MOV(DirichletPriorFromBN)
77 template <
typename GUM_SCALAR >
78 DirichletPriorFromBN< GUM_SCALAR >* DirichletPriorFromBN< GUM_SCALAR >::clone()
const {
79 return new DirichletPriorFromBN(*
this);
84 template <
typename GUM_SCALAR >
85 DirichletPriorFromBN< GUM_SCALAR >::~DirichletPriorFromBN() {
86 GUM_DESTRUCTOR(DirichletPriorFromBN)
90 template <
typename GUM_SCALAR >
91 DirichletPriorFromBN< GUM_SCALAR >&
92 DirichletPriorFromBN< GUM_SCALAR >::operator=(
const DirichletPriorFromBN& from) {
94 Prior::operator=(from);
95 _prior_bn_ = from._prior_bn_;
101 template <
typename GUM_SCALAR >
102 DirichletPriorFromBN< GUM_SCALAR >&
103 DirichletPriorFromBN< GUM_SCALAR >::operator=(DirichletPriorFromBN&& from) {
105 Prior::operator=(std::move(from));
106 _prior_bn_ = from._prior_bn_;
113 template <
typename GUM_SCALAR >
114 INLINE
PriorType DirichletPriorFromBN< GUM_SCALAR >::getType()
const {
115 return PriorType::DirichletPriorType;
120 template <
typename GUM_SCALAR >
121 INLINE
bool DirichletPriorFromBN< GUM_SCALAR >::isInformative()
const {
122 return (this->weight_ != 0.0);
126 template <
typename GUM_SCALAR >
127 INLINE
void DirichletPriorFromBN< GUM_SCALAR >::setWeight(
const double weight) {
128 Prior::setWeight(weight);
132 template <
typename GUM_SCALAR >
134 DirichletPriorFromBN< GUM_SCALAR >::addJointPseudoCount(
const IdCondSet& idset,
135 std::vector< double >& counts) {
136 if (this->weight_ == 0.0)
return;
137 const auto [X, Y] = idset.toNodeSets();
140 for (
auto i = std::size_t(0); i < idset.size(); i++) {
141 Ijoint.
add(_prior_bn_->variable(idset.ids()[i]));
144 _addCountsForJoint_(Ijoint, X + Y, counts);
148 template <
typename GUM_SCALAR >
149 INLINE
void DirichletPriorFromBN< GUM_SCALAR >::addConditioningPseudoCount(
150 const IdCondSet& idset,
151 std::vector< double >& counts) {
152 if (this->weight_ == 0.0)
return;
153 const auto [X, Y] = idset.toNodeSets();
155 for (
auto i = idset.nbLHSIds(); i < idset.size(); i++)
156 Ijoint.
add(_prior_bn_->variable(idset.ids()[i]));
157 _addCountsForJoint_(Ijoint, Y, counts);
160 template <
typename GUM_SCALAR >
161 void DirichletPriorFromBN< GUM_SCALAR >::_addCountsForJoint_(Instantiation& Ijoint,
162 const NodeSet& joint,
163 std::vector< double >& counts) {
164 const auto size = counts.size();
165 if (size != Ijoint.domainSize())
167 "The size of counts ("
168 << size <<
") does not match with the size of the asked prior (" << joint
169 <<
" : " << Ijoint.domainSize() <<
")")
172 counts[0] += weight_;
176 LazyPropagation lazy(_prior_bn_);
178 Tensor< GUM_SCALAR > p;
179 if (joint.size() == 1) {
180 const auto& target = *joint.begin();
181 lazy.addTarget(target);
182 lazy.makeInference();
183 p = lazy.posterior(target);
185 lazy.addJointTarget(joint);
186 lazy.makeInference();
187 p = lazy.jointPosterior(joint);
189 if (weight_ != 1) p.scale(weight_);
192 for (
auto i = std::size_t(0); i < size; ++i) {
193 counts[i] += p[Ijoint];
A dirichlet priori: computes its N'_ijk from a bayesian network.
Exception base for argument error.
Class for assigning/browsing values to tuples of discrete variables.
void add(const DiscreteVariable &v) final
Adds a new variable in the Instantiation.
The class representing a tabular database as used by learning tasks.
DirichletPriorFromBN(const DatabaseTable &learning_db, const BayesNet< GUM_SCALAR > *priorbn)
default constructor
the base class for all a priori
#define GUM_ERROR(type, msg)
include the inlined functions if necessary