2011-12-12 15:29:51 +00:00
|
|
|
#ifndef HORUS_SHARED_H
|
|
|
|
#define HORUS_SHARED_H
|
2011-05-17 12:00:33 +01:00
|
|
|
|
|
|
|
#include <cmath>
|
|
|
|
#include <cassert>
|
2011-12-12 15:29:51 +00:00
|
|
|
#include <limits>
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
#include <vector>
|
|
|
|
#include <unordered_map>
|
|
|
|
|
2011-07-22 21:33:30 +01:00
|
|
|
#include <iostream>
|
|
|
|
#include <fstream>
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
#define DISALLOW_COPY_AND_ASSIGN(TypeName) \
|
|
|
|
TypeName(const TypeName&); \
|
|
|
|
void operator=(const TypeName&)
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
class VarNode;
|
|
|
|
class BayesNet;
|
2011-05-17 12:00:33 +01:00
|
|
|
class BayesNode;
|
2011-07-22 21:33:30 +01:00
|
|
|
class Factor;
|
2011-12-12 15:29:51 +00:00
|
|
|
class FgVarNode;
|
|
|
|
class FgFacNode;
|
|
|
|
class SpLink;
|
|
|
|
class BpLink;
|
|
|
|
|
|
|
|
typedef double Param;
|
|
|
|
typedef vector<Param> ParamSet;
|
|
|
|
typedef unsigned VarId;
|
|
|
|
typedef vector<VarId> VarIdSet;
|
|
|
|
typedef vector<VarNode*> VarNodes;
|
|
|
|
typedef vector<BayesNode*> BnNodeSet;
|
|
|
|
typedef vector<FgVarNode*> FgVarSet;
|
|
|
|
typedef vector<FgFacNode*> FgFacSet;
|
|
|
|
typedef vector<Factor*> FactorSet;
|
|
|
|
typedef vector<string> States;
|
|
|
|
typedef vector<unsigned> Ranges;
|
|
|
|
typedef vector<unsigned> DConf;
|
|
|
|
typedef pair<unsigned, unsigned> DConstraint;
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
|
2011-07-22 21:33:30 +01:00
|
|
|
// level of debug information
|
2011-05-17 12:00:33 +01:00
|
|
|
static const unsigned DL = 0;
|
|
|
|
|
2011-07-22 21:33:30 +01:00
|
|
|
static const int NO_EVIDENCE = -1;
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
// number of digits to show when printing a parameter
|
2011-07-22 21:33:30 +01:00
|
|
|
static const unsigned PRECISION = 5;
|
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
static const bool COLLECT_STATISTICS = false;
|
2011-05-17 12:00:33 +01:00
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
static const bool EXPORT_TO_GRAPHVIZ = false;
|
|
|
|
static const unsigned EXPORT_MINIMAL_SIZE = 100;
|
2011-07-22 21:33:30 +01:00
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
static const double INF = -numeric_limits<Param>::infinity();
|
|
|
|
|
|
|
|
|
|
|
|
namespace NumberSpace {
|
|
|
|
enum ns {
|
|
|
|
NORMAL,
|
|
|
|
LOGARITHM
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
extern NumberSpace::ns NSPACE;
|
|
|
|
|
|
|
|
|
|
|
|
namespace InfAlgorithms {
|
|
|
|
enum InfAlgs
|
2011-07-22 21:33:30 +01:00
|
|
|
{
|
2011-12-12 15:29:51 +00:00
|
|
|
VE, // variable elimination
|
|
|
|
BN_BP, // bayesian network belief propagation
|
|
|
|
FG_BP, // factor graph belief propagation
|
|
|
|
CBP // counting bp solver
|
|
|
|
};
|
|
|
|
extern InfAlgs infAlgorithm;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
namespace BpOptions
|
|
|
|
{
|
|
|
|
enum Schedule {
|
|
|
|
SEQ_FIXED,
|
|
|
|
SEQ_RANDOM,
|
|
|
|
PARALLEL,
|
|
|
|
MAX_RESIDUAL
|
2011-07-22 21:33:30 +01:00
|
|
|
};
|
|
|
|
extern Schedule schedule;
|
|
|
|
extern double accuracy;
|
|
|
|
extern unsigned maxIter;
|
2011-12-12 15:29:51 +00:00
|
|
|
extern bool useAlwaysLoopySolver;
|
2011-07-22 21:33:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
namespace Util
|
2011-05-17 12:00:33 +01:00
|
|
|
{
|
2011-12-12 15:29:51 +00:00
|
|
|
void toLog (ParamSet&);
|
|
|
|
void fromLog (ParamSet&);
|
|
|
|
void normalize (ParamSet&);
|
|
|
|
void logSum (Param&, Param);
|
|
|
|
void multiply (ParamSet&, const ParamSet&);
|
|
|
|
void multiply (ParamSet&, const ParamSet&, unsigned);
|
|
|
|
void add (ParamSet&, const ParamSet&);
|
|
|
|
void add (ParamSet&, const ParamSet&, unsigned);
|
|
|
|
void pow (ParamSet&, unsigned);
|
|
|
|
Param pow (Param, unsigned);
|
|
|
|
double getL1Distance (const ParamSet&, const ParamSet&);
|
|
|
|
double getMaxNorm (const ParamSet&, const ParamSet&);
|
|
|
|
unsigned getNumberOfDigits (int);
|
|
|
|
bool isInteger (const string&);
|
|
|
|
string parametersToString (const ParamSet&, unsigned = PRECISION);
|
|
|
|
BayesNet* generateBayesianNetworkTreeWithLevel (unsigned);
|
|
|
|
vector<DConf> getDomainConfigurations (const VarNodes&);
|
|
|
|
vector<string> getJointStateStrings (const VarNodes&);
|
|
|
|
double tl (Param v);
|
|
|
|
double fl (Param v);
|
|
|
|
double multIdenty();
|
|
|
|
double addIdenty();
|
|
|
|
double withEvidence();
|
|
|
|
double noEvidence();
|
|
|
|
double one();
|
|
|
|
double zero();
|
2011-05-17 12:00:33 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
|
|
|
|
inline void
|
|
|
|
Util::logSum (Param& x, Param y)
|
2011-05-17 12:00:33 +01:00
|
|
|
{
|
2011-12-12 15:29:51 +00:00
|
|
|
// x = log (exp (x) + exp (y)); return;
|
|
|
|
assert (isfinite (x) && finite (y));
|
|
|
|
// If one value is much smaller than the other, keep the larger value.
|
|
|
|
if (x < (y - log (1e200))) {
|
|
|
|
x = y;
|
|
|
|
return;
|
2011-05-17 12:00:33 +01:00
|
|
|
}
|
2011-12-12 15:29:51 +00:00
|
|
|
if (y < (x - log (1e200))) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
double diff = x - y;
|
|
|
|
assert (isfinite (diff) && finite (x) && finite (y));
|
|
|
|
if (!isfinite (exp (diff))) { // difference is too large
|
|
|
|
x = x > y ? x : y;
|
|
|
|
} else { // otherwise return the sum.
|
|
|
|
x = y + log (static_cast<double>(1.0) + exp (diff));
|
|
|
|
}
|
|
|
|
}
|
2011-05-17 12:00:33 +01:00
|
|
|
|
2011-07-22 21:33:30 +01:00
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
|
|
|
|
inline void
|
|
|
|
Util::multiply (ParamSet& v1, const ParamSet& v2)
|
|
|
|
{
|
|
|
|
assert (v1.size() == v2.size());
|
|
|
|
for (unsigned i = 0; i < v1.size(); i++) {
|
|
|
|
v1[i] *= v2[i];
|
2011-07-22 21:33:30 +01:00
|
|
|
}
|
2011-12-12 15:29:51 +00:00
|
|
|
}
|
2011-05-17 12:00:33 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
inline void
|
|
|
|
Util::multiply (ParamSet& v1, const ParamSet& v2, unsigned repetitions)
|
|
|
|
{
|
|
|
|
for (unsigned count = 0; count < v1.size(); ) {
|
|
|
|
for (unsigned i = 0; i < v2.size(); i++) {
|
|
|
|
for (unsigned r = 0; r < repetitions; r++) {
|
|
|
|
v1[count] *= v2[i];
|
|
|
|
count ++;
|
2011-07-22 21:33:30 +01:00
|
|
|
}
|
|
|
|
}
|
2011-12-12 15:29:51 +00:00
|
|
|
}
|
|
|
|
}
|
2011-07-22 21:33:30 +01:00
|
|
|
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
inline void
|
|
|
|
Util::add (ParamSet& v1, const ParamSet& v2)
|
|
|
|
{
|
|
|
|
assert (v1.size() == v2.size());
|
|
|
|
for (unsigned i = 0; i < v1.size(); i++) {
|
|
|
|
v1[i] += v2[i];
|
|
|
|
}
|
|
|
|
}
|
2011-05-17 12:00:33 +01:00
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
|
|
|
|
|
|
|
|
inline void
|
|
|
|
Util::add (ParamSet& v1, const ParamSet& v2, unsigned repetitions)
|
|
|
|
{
|
|
|
|
for (unsigned count = 0; count < v1.size(); ) {
|
|
|
|
for (unsigned i = 0; i < v2.size(); i++) {
|
|
|
|
for (unsigned r = 0; r < repetitions; r++) {
|
|
|
|
v1[count] += v2[i];
|
|
|
|
count ++;
|
2011-05-17 12:00:33 +01:00
|
|
|
}
|
|
|
|
}
|
2011-12-12 15:29:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
|
|
|
|
inline double
|
|
|
|
Util::tl (Param v)
|
|
|
|
{
|
|
|
|
return NSPACE == NumberSpace::NORMAL ? v : log(v);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline double
|
|
|
|
Util::fl (Param v)
|
|
|
|
{
|
|
|
|
return NSPACE == NumberSpace::NORMAL ? v : exp(v);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline double
|
|
|
|
Util::multIdenty() {
|
|
|
|
return NSPACE == NumberSpace::NORMAL ? 1.0 : 0.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline double
|
|
|
|
Util::addIdenty()
|
|
|
|
{
|
|
|
|
return NSPACE == NumberSpace::NORMAL ? 0.0 : INF;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline double
|
|
|
|
Util::withEvidence()
|
|
|
|
{
|
|
|
|
return NSPACE == NumberSpace::NORMAL ? 1.0 : 0.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline double
|
|
|
|
Util::noEvidence() {
|
|
|
|
return NSPACE == NumberSpace::NORMAL ? 0.0 : INF;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline double
|
|
|
|
Util::one()
|
|
|
|
{
|
|
|
|
return NSPACE == NumberSpace::NORMAL ? 1.0 : 0.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline double
|
|
|
|
Util::zero() {
|
|
|
|
return NSPACE == NumberSpace::NORMAL ? 0.0 : INF;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
struct NetInfo
|
|
|
|
{
|
|
|
|
NetInfo (unsigned size, bool loopy, unsigned nIters, double time)
|
|
|
|
{
|
|
|
|
this->size = size;
|
|
|
|
this->loopy = loopy;
|
|
|
|
this->nIters = nIters;
|
|
|
|
this->time = time;
|
|
|
|
}
|
|
|
|
unsigned size;
|
|
|
|
bool loopy;
|
|
|
|
unsigned nIters;
|
|
|
|
double time;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
struct CompressInfo
|
|
|
|
{
|
|
|
|
CompressInfo (unsigned a, unsigned b, unsigned c, unsigned d, unsigned e)
|
|
|
|
{
|
|
|
|
nGroundVars = a;
|
|
|
|
nGroundFactors = b;
|
|
|
|
nClusterVars = c;
|
|
|
|
nClusterFactors = d;
|
|
|
|
nWithoutNeighs = e;
|
|
|
|
}
|
|
|
|
unsigned nGroundVars;
|
|
|
|
unsigned nGroundFactors;
|
|
|
|
unsigned nClusterVars;
|
|
|
|
unsigned nClusterFactors;
|
|
|
|
unsigned nWithoutNeighs;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Statistics
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
static unsigned getSolvedNetworksCounting (void);
|
|
|
|
static void incrementPrimaryNetworksCounting (void);
|
|
|
|
static unsigned getPrimaryNetworksCounting (void);
|
|
|
|
static void updateStatistics (unsigned, bool, unsigned, double);
|
|
|
|
static void printStatistics (void);
|
|
|
|
static void writeStatisticsToFile (const char*);
|
|
|
|
static void updateCompressingStatistics (
|
|
|
|
unsigned, unsigned, unsigned, unsigned, unsigned);
|
2011-05-17 12:00:33 +01:00
|
|
|
|
|
|
|
private:
|
2011-12-12 15:29:51 +00:00
|
|
|
static string getStatisticString (void);
|
|
|
|
|
|
|
|
static vector<NetInfo> netInfo_;
|
2011-07-22 21:33:30 +01:00
|
|
|
static vector<CompressInfo> compressInfo_;
|
2011-12-12 15:29:51 +00:00
|
|
|
static unsigned primaryNetCount_;
|
2011-05-17 12:00:33 +01:00
|
|
|
};
|
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
#endif // HORUS_SHARED_H
|
2011-05-17 12:00:33 +01:00
|
|
|
|