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/VarNode.cpp

101 lines
1.7 KiB
C++
Raw Normal View History

2011-12-12 15:29:51 +00:00
#include <algorithm>
#include <sstream>
#include "VarNode.h"
#include "GraphicalModel.h"
using namespace std;
VarNode::VarNode (const VarNode* v)
{
2012-04-05 18:38:56 +01:00
varId_ = v->varId();
range_ = v->range();
evidence_ = v->getEvidence();
index_ = std::numeric_limits<unsigned>::max();
2011-12-12 15:29:51 +00:00
}
2012-04-05 18:38:56 +01:00
VarNode::VarNode (VarId varId, unsigned range, int evidence)
2011-12-12 15:29:51 +00:00
{
2012-04-05 18:38:56 +01:00
assert (range != 0);
assert (evidence < (int) range);
varId_ = varId;
range_ = range;
evidence_ = evidence;
index_ = std::numeric_limits<unsigned>::max();
2011-12-12 15:29:51 +00:00
}
bool
VarNode::isValidState (int stateIndex)
{
2012-04-05 18:38:56 +01:00
return stateIndex >= 0 && stateIndex < (int) range_;
2011-12-12 15:29:51 +00:00
}
bool
VarNode::isValidState (const string& stateName)
{
2012-03-31 23:27:37 +01:00
States states = GraphicalModel::getVarInformation (varId_).states;
return Util::contains (states, stateName);
2011-12-12 15:29:51 +00:00
}
void
VarNode::setEvidence (int ev)
{
2012-04-05 18:38:56 +01:00
assert (ev < (int) range_);
2011-12-12 15:29:51 +00:00
evidence_ = ev;
}
void
VarNode::setEvidence (const string& ev)
{
2012-03-31 23:27:37 +01:00
States states = GraphicalModel::getVarInformation (varId_).states;
2011-12-12 15:29:51 +00:00
for (unsigned i = 0; i < states.size(); i++) {
if (states[i] == ev) {
evidence_ = i;
return;
}
}
assert (false);
}
string
VarNode::label (void) const
{
if (GraphicalModel::variablesHaveInformation()) {
2012-03-31 23:27:37 +01:00
return GraphicalModel::getVarInformation (varId_).label;
2011-12-12 15:29:51 +00:00
}
stringstream ss;
ss << "x" << varId_;
return ss.str();
}
States
VarNode::states (void) const
{
if (GraphicalModel::variablesHaveInformation()) {
2012-03-31 23:27:37 +01:00
return GraphicalModel::getVarInformation (varId_).states;
2011-12-12 15:29:51 +00:00
}
States states;
2012-04-05 18:38:56 +01:00
for (unsigned i = 0; i < range_; i++) {
2011-12-12 15:29:51 +00:00
stringstream ss;
ss << i ;
states.push_back (ss.str());
}
return states;
}