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

72 lines
1.3 KiB
C
Raw Normal View History

2011-12-12 15:29:51 +00:00
#ifndef HORUS_VARNODE_H
#define HORUS_VARNODE_H
2012-03-31 23:27:37 +01:00
#include <cassert>
#include <iostream>
2012-03-22 11:33:24 +00:00
#include "Horus.h"
2011-12-12 15:29:51 +00:00
using namespace std;
class VarNode
{
public:
VarNode (const VarNode*);
2012-03-31 23:27:37 +01:00
VarNode (VarId, unsigned, int = Constants::NO_EVIDENCE);
virtual ~VarNode (void) { };
unsigned varId (void) const { return varId_; }
2012-04-05 18:38:56 +01:00
unsigned range (void) const { return range_; }
2012-03-31 23:27:37 +01:00
int getEvidence (void) const { return evidence_; }
unsigned getIndex (void) const { return index_; }
void setIndex (unsigned idx) { index_ = idx; }
2011-12-12 15:29:51 +00:00
operator unsigned () const { return index_; }
2012-03-31 23:27:37 +01:00
bool hasEvidence (void) const
{
return evidence_ != Constants::NO_EVIDENCE;
}
2011-12-12 15:29:51 +00:00
bool operator== (const VarNode& var) const
{
2012-04-05 18:38:56 +01:00
assert (!(varId_ == var.varId() && range_ != var.range()));
2011-12-12 15:29:51 +00:00
return varId_ == var.varId();
}
bool operator!= (const VarNode& var) const
{
2012-04-05 18:38:56 +01:00
assert (!(varId_ == var.varId() && range_ != var.range()));
2011-12-12 15:29:51 +00:00
return varId_ != var.varId();
}
2012-03-31 23:27:37 +01:00
bool isValidState (int);
bool isValidState (const string&);
void setEvidence (int);
void setEvidence (const string&);
string label (void) const;
States states (void) const;
2011-12-12 15:29:51 +00:00
private:
2012-03-31 23:27:37 +01:00
VarId varId_;
2012-04-05 18:38:56 +01:00
unsigned range_;
2012-03-31 23:27:37 +01:00
int evidence_;
unsigned index_;
2011-12-12 15:29:51 +00:00
};
#endif // BP_VARNODE_H