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/GraphicalModel.h

68 lines
1.6 KiB
C
Raw Normal View History

2011-12-12 15:29:51 +00:00
#ifndef HORUS_GRAPHICALMODEL_H
#define HORUS_GRAPHICALMODEL_H
2012-03-22 11:33:24 +00:00
#include <sstream>
2011-12-12 15:29:51 +00:00
#include "VarNode.h"
2012-03-22 11:33:24 +00:00
#include "Distribution.h"
#include "Horus.h"
2011-12-12 15:29:51 +00:00
using namespace std;
2012-03-22 11:33:24 +00:00
2011-12-12 15:29:51 +00:00
struct VariableInfo
{
VariableInfo (string l, const States& sts)
{
label = l;
states = sts;
}
string label;
States states;
};
class GraphicalModel
{
public:
virtual ~GraphicalModel (void) {};
2011-12-12 15:29:51 +00:00
virtual VarNode* getVariableNode (VarId) const = 0;
virtual VarNodes getVariableNodes (void) const = 0;
virtual void printGraphicalModel (void) const = 0;
2011-12-12 15:29:51 +00:00
static void addVariableInformation (VarId vid, string label,
const States& states)
{
assert (varsInfo_.find (vid) == varsInfo_.end());
varsInfo_.insert (make_pair (vid, VariableInfo (label, states)));
}
static VariableInfo getVariableInformation (VarId vid)
{
assert (varsInfo_.find (vid) != varsInfo_.end());
return varsInfo_.find (vid)->second;
}
static bool variablesHaveInformation (void)
{
return varsInfo_.size() != 0;
}
static void clearVariablesInformation (void)
{
varsInfo_.clear();
}
2012-03-22 11:33:24 +00:00
static void addDistribution (unsigned id, Distribution* dist)
{
distsInfo_[id] = dist;
}
static void updateDistribution (unsigned id, const Params& params)
{
distsInfo_[id]->updateParameters (params);
}
2011-12-12 15:29:51 +00:00
private:
static unordered_map<VarId,VariableInfo> varsInfo_;
2012-03-22 11:33:24 +00:00
static unordered_map<unsigned,Distribution*> distsInfo_;
};
2011-12-12 15:29:51 +00:00
#endif // HORUS_GRAPHICALMODEL_H