This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
yap-6.3/packages/CLPBN/clpbn/bp/CbpSolver.h

59 lines
1.2 KiB
C
Raw Normal View History

2011-12-12 15:29:51 +00:00
#ifndef HORUS_CBP_H
#define HORUS_CBP_H
#include "FgBpSolver.h"
#include "CFactorGraph.h"
class Factor;
class CbpSolverLink : public SpLink
{
public:
CbpSolverLink (FgFacNode* fn, FgVarNode* vn, unsigned c) : SpLink (fn, vn)
{
edgeCount_ = c;
poweredMsg_.resize (vn->nrStates(), Util::one());
}
void updateMessage (void)
{
poweredMsg_ = *nextMsg_;
swap (currMsg_, nextMsg_);
msgSended_ = true;
Util::pow (poweredMsg_, edgeCount_);
}
2012-03-22 11:33:24 +00:00
unsigned getNumberOfEdges (void) const { return edgeCount_; }
const Params& getPoweredMessage (void) const { return poweredMsg_; }
2011-12-12 15:29:51 +00:00
private:
2012-03-22 11:33:24 +00:00
Params poweredMsg_;
2011-12-12 15:29:51 +00:00
unsigned edgeCount_;
};
class CbpSolver : public FgBpSolver
{
public:
CbpSolver (FactorGraph& fg) : FgBpSolver (fg) { }
~CbpSolver (void);
2012-03-22 11:33:24 +00:00
Params getPosterioriOf (VarId);
Params getJointDistributionOf (const VarIds&);
2011-12-12 15:29:51 +00:00
private:
void initializeSolver (void);
void createLinks (void);
void maxResidualSchedule (void);
2012-03-22 11:33:24 +00:00
Params getVar2FactorMsg (const SpLink*) const;
2011-12-12 15:29:51 +00:00
void printLinkInformation (void) const;
CFactorGraph* lfg_;
};
#endif // HORUS_CBP_H