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

70 lines
1.3 KiB
C
Raw Normal View History

2011-12-12 15:29:51 +00:00
#ifndef HORUS_CBP_H
#define HORUS_CBP_H
2012-04-05 23:00:48 +01:00
#include "BpSolver.h"
2011-12-12 15:29:51 +00:00
#include "CFactorGraph.h"
class Factor;
class CbpSolverLink : public SpLink
{
public:
CbpSolverLink (FacNode* fn, VarNode* vn, unsigned idx, unsigned count)
: SpLink (fn, vn), index_(idx), nrEdges_(count),
2012-04-10 20:43:08 +01:00
pwdMsg_(vn->range(), LogAware::one()) { }
2011-12-12 15:29:51 +00:00
unsigned index (void) const { return index_; }
2012-04-10 20:43:08 +01:00
unsigned nrEdges (void) const { return nrEdges_; }
2012-03-31 23:27:37 +01:00
2012-04-10 20:43:08 +01:00
const Params& poweredMessage (void) const { return pwdMsg_; }
2012-03-31 23:27:37 +01:00
2011-12-12 15:29:51 +00:00
void updateMessage (void)
{
2012-04-10 20:43:08 +01:00
pwdMsg_ = *nextMsg_;
2011-12-12 15:29:51 +00:00
swap (currMsg_, nextMsg_);
2012-04-16 21:45:52 +01:00
msgSended_ = true;
2012-04-10 20:43:08 +01:00
LogAware::pow (pwdMsg_, nrEdges_);
2011-12-12 15:29:51 +00:00
}
private:
unsigned index_;
2012-04-10 20:43:08 +01:00
unsigned nrEdges_;
Params pwdMsg_;
2011-12-12 15:29:51 +00:00
};
2012-04-05 23:00:48 +01:00
class CbpSolver : public BpSolver
2011-12-12 15:29:51 +00:00
{
public:
static vector<int> counts;
2012-04-10 20:43:08 +01:00
CbpSolver (const FactorGraph& fg);
2012-03-31 23:27:37 +01:00
2011-12-12 15:29:51 +00:00
~CbpSolver (void);
void printSolverFlags (void) const;
2012-04-10 20:43:08 +01:00
2012-03-31 23:27:37 +01:00
Params getPosterioriOf (VarId);
2011-12-12 15:29:51 +00:00
2012-03-31 23:27:37 +01:00
Params getJointDistributionOf (const VarIds&);
2011-12-12 15:29:51 +00:00
2012-03-31 23:27:37 +01:00
private:
2012-04-10 15:00:18 +01:00
2012-03-31 23:27:37 +01:00
void createLinks (void);
2011-12-12 15:29:51 +00:00
2012-03-31 23:27:37 +01:00
void maxResidualSchedule (void);
2012-04-10 15:00:18 +01:00
void calculateFactor2VariableMsg (SpLink*);
2012-03-31 23:27:37 +01:00
Params getVar2FactorMsg (const SpLink*) const;
2012-04-10 15:00:18 +01:00
2012-03-31 23:27:37 +01:00
void printLinkInformation (void) const;
2011-12-12 15:29:51 +00:00
2012-04-10 20:43:08 +01:00
CFactorGraph* cfg_;
2011-12-12 15:29:51 +00:00
};
#endif // HORUS_CBP_H