2011-05-17 12:00:33 +01:00
|
|
|
#include <cstdlib>
|
2012-03-22 11:33:24 +00:00
|
|
|
|
2011-07-22 21:33:30 +01:00
|
|
|
#include <vector>
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
#include <iostream>
|
|
|
|
#include <sstream>
|
|
|
|
|
|
|
|
#include <YapInterface.h>
|
|
|
|
|
2012-03-31 23:27:37 +01:00
|
|
|
#include "ParfactorList.h"
|
2011-05-17 12:00:33 +01:00
|
|
|
#include "BayesNet.h"
|
2011-07-22 21:33:30 +01:00
|
|
|
#include "FactorGraph.h"
|
2012-03-31 23:27:37 +01:00
|
|
|
#include "FoveSolver.h"
|
2011-12-12 15:29:51 +00:00
|
|
|
#include "VarElimSolver.h"
|
|
|
|
#include "FgBpSolver.h"
|
|
|
|
#include "CbpSolver.h"
|
|
|
|
#include "ElimGraph.h"
|
2012-04-05 18:38:56 +01:00
|
|
|
#include "BayesBall.h"
|
2012-03-22 11:33:24 +00:00
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
2011-07-22 21:33:30 +01:00
|
|
|
|
2012-03-31 23:27:37 +01:00
|
|
|
typedef std::pair<ParfactorList*, ObservedFormulas*> LiftedNetwork;
|
|
|
|
|
2012-03-22 11:33:24 +00:00
|
|
|
|
2012-04-03 19:53:27 +01:00
|
|
|
Params readParameters (YAP_Term);
|
|
|
|
|
|
|
|
vector<unsigned> readUnsignedList (YAP_Term);
|
|
|
|
|
2012-03-31 23:27:37 +01:00
|
|
|
void readLiftedEvidence (YAP_Term, ObservedFormulas&);
|
2012-04-03 19:53:27 +01:00
|
|
|
|
2012-03-31 23:27:37 +01:00
|
|
|
Parfactor* readParfactor (YAP_Term);
|
2012-03-22 11:33:24 +00:00
|
|
|
|
|
|
|
|
2012-04-03 19:53:27 +01:00
|
|
|
|
|
|
|
vector<unsigned>
|
|
|
|
readUnsignedList (YAP_Term list)
|
|
|
|
{
|
|
|
|
vector<unsigned> vec;
|
|
|
|
while (list != YAP_TermNil()) {
|
|
|
|
vec.push_back ((unsigned) YAP_IntOfTerm (YAP_HeadOfTerm (list)));
|
|
|
|
list = YAP_TailOfTerm (list);
|
|
|
|
}
|
|
|
|
return vec;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-04-05 18:38:56 +01:00
|
|
|
|
2012-03-22 11:33:24 +00:00
|
|
|
int createLiftedNetwork (void)
|
|
|
|
{
|
|
|
|
Parfactors parfactors;
|
|
|
|
YAP_Term parfactorList = YAP_ARG1;
|
|
|
|
while (parfactorList != YAP_TermNil()) {
|
2012-03-31 23:27:37 +01:00
|
|
|
YAP_Term pfTerm = YAP_HeadOfTerm (parfactorList);
|
|
|
|
parfactors.push_back (readParfactor (pfTerm));
|
|
|
|
parfactorList = YAP_TailOfTerm (parfactorList);
|
|
|
|
}
|
2012-03-22 11:33:24 +00:00
|
|
|
|
2012-03-31 23:27:37 +01:00
|
|
|
// LiftedUtils::printSymbolDictionary();
|
|
|
|
if (Constants::DEBUG > 1) {
|
|
|
|
// Util::printHeader ("INITIAL PARFACTORS");
|
|
|
|
// for (unsigned i = 0; i < parfactors.size(); i++) {
|
|
|
|
// parfactors[i]->print();
|
|
|
|
// cout << endl;
|
|
|
|
// }
|
|
|
|
// parfactors[0]->countConvert (LogVar (0));
|
|
|
|
//parfactors[1]->fullExpand (LogVar (1));
|
|
|
|
Util::printHeader ("SHATTERED PARFACTORS");
|
|
|
|
}
|
|
|
|
|
|
|
|
ParfactorList* pfList = new ParfactorList (parfactors);
|
|
|
|
|
|
|
|
if (Constants::DEBUG > 1) {
|
|
|
|
pfList->print();
|
|
|
|
}
|
|
|
|
|
|
|
|
// read evidence
|
|
|
|
ObservedFormulas* obsFormulas = new ObservedFormulas();
|
|
|
|
readLiftedEvidence (YAP_ARG2, *(obsFormulas));
|
|
|
|
|
|
|
|
LiftedNetwork* net = new LiftedNetwork (pfList, obsFormulas);
|
|
|
|
YAP_Int p = (YAP_Int) (net);
|
|
|
|
return YAP_Unify (YAP_MkIntTerm (p), YAP_ARG3);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Parfactor* readParfactor (YAP_Term pfTerm)
|
|
|
|
{
|
|
|
|
// read dist id
|
|
|
|
unsigned distId = YAP_IntOfTerm (YAP_ArgOfTerm (1, pfTerm));
|
|
|
|
|
|
|
|
// read the ranges
|
|
|
|
Ranges ranges;
|
|
|
|
YAP_Term rangeList = YAP_ArgOfTerm (3, pfTerm);
|
|
|
|
while (rangeList != YAP_TermNil()) {
|
|
|
|
unsigned range = (unsigned) YAP_IntOfTerm (YAP_HeadOfTerm (rangeList));
|
|
|
|
ranges.push_back (range);
|
|
|
|
rangeList = YAP_TailOfTerm (rangeList);
|
|
|
|
}
|
|
|
|
|
|
|
|
// read parametric random vars
|
|
|
|
ProbFormulas formulas;
|
|
|
|
unsigned count = 0;
|
|
|
|
unordered_map<YAP_Term, LogVar> lvMap;
|
|
|
|
YAP_Term pvList = YAP_ArgOfTerm (2, pfTerm);
|
|
|
|
while (pvList != YAP_TermNil()) {
|
|
|
|
YAP_Term formulaTerm = YAP_HeadOfTerm (pvList);
|
|
|
|
if (YAP_IsAtomTerm (formulaTerm)) {
|
|
|
|
string name ((char*) YAP_AtomName (YAP_AtomOfTerm (formulaTerm)));
|
|
|
|
Symbol functor = LiftedUtils::getSymbol (name);
|
|
|
|
formulas.push_back (ProbFormula (functor, ranges[count]));
|
|
|
|
} else {
|
|
|
|
LogVars logVars;
|
|
|
|
YAP_Functor yapFunctor = YAP_FunctorOfTerm (formulaTerm);
|
|
|
|
string name ((char*) YAP_AtomName (YAP_NameOfFunctor (yapFunctor)));
|
|
|
|
Symbol functor = LiftedUtils::getSymbol (name);
|
|
|
|
unsigned arity = (unsigned) YAP_ArityOfFunctor (yapFunctor);
|
|
|
|
for (unsigned i = 1; i <= arity; i++) {
|
|
|
|
YAP_Term ti = YAP_ArgOfTerm (i, formulaTerm);
|
|
|
|
unordered_map<YAP_Term, LogVar>::iterator it = lvMap.find (ti);
|
|
|
|
if (it != lvMap.end()) {
|
|
|
|
logVars.push_back (it->second);
|
|
|
|
} else {
|
|
|
|
unsigned newLv = lvMap.size();
|
|
|
|
lvMap[ti] = newLv;
|
|
|
|
logVars.push_back (newLv);
|
2012-03-22 11:33:24 +00:00
|
|
|
}
|
|
|
|
}
|
2012-03-31 23:27:37 +01:00
|
|
|
formulas.push_back (ProbFormula (functor, logVars, ranges[count]));
|
2012-03-22 11:33:24 +00:00
|
|
|
}
|
2012-03-31 23:27:37 +01:00
|
|
|
count ++;
|
|
|
|
pvList = YAP_TailOfTerm (pvList);
|
|
|
|
}
|
2012-03-22 11:33:24 +00:00
|
|
|
|
2012-03-31 23:27:37 +01:00
|
|
|
// read the parameters
|
2012-04-03 19:53:27 +01:00
|
|
|
const Params& params = readParameters (YAP_ArgOfTerm (4, pfTerm));
|
2012-03-31 23:27:37 +01:00
|
|
|
|
|
|
|
// read the constraint
|
|
|
|
Tuples tuples;
|
|
|
|
if (lvMap.size() >= 1) {
|
|
|
|
YAP_Term tupleList = YAP_ArgOfTerm (5, pfTerm);
|
|
|
|
while (tupleList != YAP_TermNil()) {
|
|
|
|
YAP_Term term = YAP_HeadOfTerm (tupleList);
|
|
|
|
assert (YAP_IsApplTerm (term));
|
|
|
|
YAP_Functor yapFunctor = YAP_FunctorOfTerm (term);
|
|
|
|
unsigned arity = (unsigned) YAP_ArityOfFunctor (yapFunctor);
|
|
|
|
assert (lvMap.size() == arity);
|
|
|
|
Tuple tuple (arity);
|
|
|
|
for (unsigned i = 1; i <= arity; i++) {
|
|
|
|
YAP_Term ti = YAP_ArgOfTerm (i, term);
|
|
|
|
if (YAP_IsAtomTerm (ti) == false) {
|
|
|
|
cerr << "error: constraint has free variables" << endl;
|
|
|
|
abort();
|
2012-03-22 11:33:24 +00:00
|
|
|
}
|
2012-03-31 23:27:37 +01:00
|
|
|
string name ((char*) YAP_AtomName (YAP_AtomOfTerm (ti)));
|
|
|
|
tuple[i - 1] = LiftedUtils::getSymbol (name);
|
2012-03-22 11:33:24 +00:00
|
|
|
}
|
2012-03-31 23:27:37 +01:00
|
|
|
tuples.push_back (tuple);
|
|
|
|
tupleList = YAP_TailOfTerm (tupleList);
|
2012-03-22 11:33:24 +00:00
|
|
|
}
|
|
|
|
}
|
2012-03-31 23:27:37 +01:00
|
|
|
return new Parfactor (formulas, params, tuples, distId);
|
|
|
|
}
|
2012-03-22 11:33:24 +00:00
|
|
|
|
2012-03-31 23:27:37 +01:00
|
|
|
|
|
|
|
|
|
|
|
void readLiftedEvidence (
|
|
|
|
YAP_Term observedList,
|
|
|
|
ObservedFormulas& obsFormulas)
|
|
|
|
{
|
2012-03-22 11:33:24 +00:00
|
|
|
while (observedList != YAP_TermNil()) {
|
|
|
|
YAP_Term pair = YAP_HeadOfTerm (observedList);
|
|
|
|
YAP_Term ground = YAP_ArgOfTerm (1, pair);
|
|
|
|
Symbol functor;
|
|
|
|
Symbols args;
|
|
|
|
if (YAP_IsAtomTerm (ground)) {
|
|
|
|
string name ((char*) YAP_AtomName (YAP_AtomOfTerm (ground)));
|
|
|
|
functor = LiftedUtils::getSymbol (name);
|
|
|
|
} else {
|
|
|
|
assert (YAP_IsApplTerm (ground));
|
|
|
|
YAP_Functor yapFunctor = YAP_FunctorOfTerm (ground);
|
|
|
|
string name ((char*) (YAP_AtomName (YAP_NameOfFunctor (yapFunctor))));
|
|
|
|
functor = LiftedUtils::getSymbol (name);
|
|
|
|
unsigned arity = (unsigned) YAP_ArityOfFunctor (yapFunctor);
|
|
|
|
for (unsigned i = 1; i <= arity; i++) {
|
|
|
|
YAP_Term ti = YAP_ArgOfTerm (i, ground);
|
|
|
|
assert (YAP_IsAtomTerm (ti));
|
|
|
|
string arg ((char *) YAP_AtomName (YAP_AtomOfTerm (ti)));
|
|
|
|
args.push_back (LiftedUtils::getSymbol (arg));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
unsigned evidence = (unsigned) YAP_IntOfTerm (YAP_ArgOfTerm (2, pair));
|
|
|
|
bool found = false;
|
|
|
|
for (unsigned i = 0; i < obsFormulas.size(); i++) {
|
2012-03-31 23:27:37 +01:00
|
|
|
if (obsFormulas[i].functor() == functor &&
|
|
|
|
obsFormulas[i].arity() == args.size() &&
|
|
|
|
obsFormulas[i].evidence() == evidence) {
|
|
|
|
obsFormulas[i].addTuple (args);
|
2012-03-22 11:33:24 +00:00
|
|
|
found = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (found == false) {
|
2012-03-31 23:27:37 +01:00
|
|
|
obsFormulas.push_back (ObservedFormula (functor, evidence, args));
|
2012-03-22 11:33:24 +00:00
|
|
|
}
|
|
|
|
observedList = YAP_TailOfTerm (observedList);
|
2012-03-31 23:27:37 +01:00
|
|
|
}
|
2012-03-22 11:33:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
int
|
2012-03-22 11:33:24 +00:00
|
|
|
createGroundNetwork (void)
|
2011-05-17 12:00:33 +01:00
|
|
|
{
|
2012-04-05 18:38:56 +01:00
|
|
|
FactorGraph* fg = new FactorGraph();;
|
2012-04-03 19:53:27 +01:00
|
|
|
string factorsType ((char*) YAP_AtomName (YAP_AtomOfTerm (YAP_ARG1)));
|
|
|
|
cout << "factors type: '" << factorsType << "'" << endl;
|
|
|
|
|
|
|
|
YAP_Term factorList = YAP_ARG2;
|
|
|
|
while (factorList != YAP_TermNil()) {
|
2012-04-05 18:38:56 +01:00
|
|
|
YAP_Term factor = YAP_HeadOfTerm (factorList);
|
2012-04-03 19:53:27 +01:00
|
|
|
// read the var ids
|
|
|
|
VarIds varIds = readUnsignedList (YAP_ArgOfTerm (1, factor));
|
|
|
|
// read the ranges
|
|
|
|
Ranges ranges = readUnsignedList (YAP_ArgOfTerm (2, factor));
|
|
|
|
// read the parameters
|
|
|
|
Params params = readParameters (YAP_ArgOfTerm (3, factor));
|
|
|
|
// read dist id
|
|
|
|
unsigned distId = (unsigned) YAP_IntOfTerm (YAP_ArgOfTerm (4, factor));
|
2012-04-05 18:38:56 +01:00
|
|
|
fg->addFactor (Factor (varIds, ranges, params, distId));
|
2012-04-03 19:53:27 +01:00
|
|
|
factorList = YAP_TailOfTerm (factorList);
|
|
|
|
}
|
2012-04-05 18:38:56 +01:00
|
|
|
if (factorsType == "bayes") {
|
|
|
|
fg->setFromBayesNetwork();
|
2011-05-17 12:00:33 +01:00
|
|
|
}
|
2012-04-05 18:38:56 +01:00
|
|
|
fg->setIndexes();
|
|
|
|
|
|
|
|
YAP_Term evidenceList = YAP_ARG3;
|
|
|
|
while (evidenceList != YAP_TermNil()) {
|
|
|
|
YAP_Term evTerm = YAP_HeadOfTerm (evidenceList);
|
|
|
|
unsigned vid = (unsigned) YAP_IntOfTerm ((YAP_ArgOfTerm (1, evTerm)));
|
|
|
|
unsigned ev = (unsigned) YAP_IntOfTerm ((YAP_ArgOfTerm (2, evTerm)));
|
|
|
|
cout << vid << " == " << ev << endl;
|
|
|
|
assert (fg->getFgVarNode (vid));
|
|
|
|
fg->getFgVarNode (vid)->setEvidence (ev);
|
|
|
|
evidenceList = YAP_TailOfTerm (evidenceList);
|
2011-12-12 15:29:51 +00:00
|
|
|
}
|
2012-04-05 18:38:56 +01:00
|
|
|
|
|
|
|
YAP_Int p = (YAP_Int) (fg);
|
|
|
|
return YAP_Unify (YAP_MkIntTerm (p), YAP_ARG4);
|
2011-05-17 12:00:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-03-22 11:33:24 +00:00
|
|
|
Params
|
2012-04-03 19:53:27 +01:00
|
|
|
readParameters (YAP_Term paramL)
|
2012-03-22 11:33:24 +00:00
|
|
|
{
|
|
|
|
Params params;
|
|
|
|
while (paramL!= YAP_TermNil()) {
|
|
|
|
params.push_back ((double) YAP_FloatOfTerm (YAP_HeadOfTerm (paramL)));
|
|
|
|
paramL = YAP_TailOfTerm (paramL);
|
|
|
|
}
|
|
|
|
if (Globals::logDomain) {
|
|
|
|
Util::toLog (params);
|
|
|
|
}
|
|
|
|
return params;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
int
|
2012-03-22 11:33:24 +00:00
|
|
|
runLiftedSolver (void)
|
|
|
|
{
|
2012-03-31 23:27:37 +01:00
|
|
|
LiftedNetwork* network = (LiftedNetwork*) YAP_IntOfTerm (YAP_ARG1);
|
2012-03-22 11:33:24 +00:00
|
|
|
YAP_Term taskList = YAP_ARG2;
|
|
|
|
vector<Params> results;
|
2012-03-31 23:27:37 +01:00
|
|
|
ParfactorList pfListCopy (*network->first);
|
|
|
|
FoveSolver::absorveEvidence (pfListCopy, *network->second);
|
2012-03-22 11:33:24 +00:00
|
|
|
while (taskList != YAP_TermNil()) {
|
|
|
|
Grounds queryVars;
|
2012-03-31 23:27:37 +01:00
|
|
|
YAP_Term jointList = YAP_HeadOfTerm (taskList);
|
2012-03-22 11:33:24 +00:00
|
|
|
while (jointList != YAP_TermNil()) {
|
|
|
|
YAP_Term ground = YAP_HeadOfTerm (jointList);
|
|
|
|
if (YAP_IsAtomTerm (ground)) {
|
|
|
|
string name ((char*) YAP_AtomName (YAP_AtomOfTerm (ground)));
|
|
|
|
queryVars.push_back (Ground (LiftedUtils::getSymbol (name)));
|
|
|
|
} else {
|
|
|
|
assert (YAP_IsApplTerm (ground));
|
|
|
|
YAP_Functor yapFunctor = YAP_FunctorOfTerm (ground);
|
|
|
|
string name ((char*) (YAP_AtomName (YAP_NameOfFunctor (yapFunctor))));
|
|
|
|
unsigned arity = (unsigned) YAP_ArityOfFunctor (yapFunctor);
|
|
|
|
Symbol functor = LiftedUtils::getSymbol (name);
|
|
|
|
Symbols args;
|
|
|
|
for (unsigned i = 1; i <= arity; i++) {
|
|
|
|
YAP_Term ti = YAP_ArgOfTerm (i, ground);
|
|
|
|
assert (YAP_IsAtomTerm (ti));
|
|
|
|
string arg ((char *) YAP_AtomName (YAP_AtomOfTerm (ti)));
|
|
|
|
args.push_back (LiftedUtils::getSymbol (arg));
|
|
|
|
}
|
|
|
|
queryVars.push_back (Ground (functor, args));
|
|
|
|
}
|
|
|
|
jointList = YAP_TailOfTerm (jointList);
|
|
|
|
}
|
2012-03-31 23:27:37 +01:00
|
|
|
FoveSolver solver (pfListCopy);
|
2012-03-22 11:33:24 +00:00
|
|
|
if (queryVars.size() == 1) {
|
|
|
|
results.push_back (solver.getPosterioriOf (queryVars[0]));
|
|
|
|
} else {
|
2012-03-31 23:27:37 +01:00
|
|
|
results.push_back (solver.getJointDistributionOf (queryVars));
|
2012-03-22 11:33:24 +00:00
|
|
|
}
|
|
|
|
taskList = YAP_TailOfTerm (taskList);
|
|
|
|
}
|
|
|
|
|
|
|
|
YAP_Term list = YAP_TermNil();
|
|
|
|
for (int i = results.size() - 1; i >= 0; i--) {
|
|
|
|
const Params& beliefs = results[i];
|
|
|
|
YAP_Term queryBeliefsL = YAP_TermNil();
|
|
|
|
for (int j = beliefs.size() - 1; j >= 0; j--) {
|
|
|
|
YAP_Int sl1 = YAP_InitSlot (list);
|
|
|
|
YAP_Term belief = YAP_MkFloatTerm (beliefs[j]);
|
|
|
|
queryBeliefsL = YAP_MkPairTerm (belief, queryBeliefsL);
|
|
|
|
list = YAP_GetFromSlot (sl1);
|
|
|
|
YAP_RecoverSlots (1);
|
|
|
|
}
|
|
|
|
list = YAP_MkPairTerm (queryBeliefsL, list);
|
|
|
|
}
|
|
|
|
|
|
|
|
return YAP_Unify (list, YAP_ARG3);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-04-05 18:38:56 +01:00
|
|
|
void runVeSolver (FactorGraph* fg, const vector<VarIds>& tasks,
|
|
|
|
vector<Params>& results);
|
|
|
|
void runBpSolver (FactorGraph* fg, const vector<VarIds>& tasks,
|
|
|
|
vector<Params>& results);
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-03-22 11:33:24 +00:00
|
|
|
int
|
2012-03-31 23:27:37 +01:00
|
|
|
runGroundSolver (void)
|
2011-05-17 12:00:33 +01:00
|
|
|
{
|
2012-04-05 18:38:56 +01:00
|
|
|
FactorGraph* fg = (FactorGraph*) YAP_IntOfTerm (YAP_ARG1);
|
|
|
|
|
2012-03-22 11:33:24 +00:00
|
|
|
vector<VarIds> tasks;
|
2012-04-05 18:38:56 +01:00
|
|
|
YAP_Term taskList = YAP_ARG2;
|
2011-05-17 12:00:33 +01:00
|
|
|
while (taskList != YAP_TermNil()) {
|
2012-04-05 18:38:56 +01:00
|
|
|
tasks.push_back (readUnsignedList (YAP_HeadOfTerm (taskList)));
|
2011-05-17 12:00:33 +01:00
|
|
|
taskList = YAP_TailOfTerm (taskList);
|
|
|
|
}
|
|
|
|
|
2012-04-05 18:38:56 +01:00
|
|
|
fg->printGraphicalModel();
|
2012-03-22 11:33:24 +00:00
|
|
|
vector<Params> results;
|
2012-04-05 18:38:56 +01:00
|
|
|
if (Globals::infAlgorithm == InfAlgorithms::VE) {
|
|
|
|
runVeSolver (fg, tasks, results);
|
|
|
|
} else {
|
|
|
|
runBpSolver (fg, tasks, results);
|
2011-05-17 12:00:33 +01:00
|
|
|
}
|
2012-04-05 18:38:56 +01:00
|
|
|
cout << "results: " << results << endl;
|
2011-05-17 12:00:33 +01:00
|
|
|
YAP_Term list = YAP_TermNil();
|
|
|
|
for (int i = results.size() - 1; i >= 0; i--) {
|
2012-03-22 11:33:24 +00:00
|
|
|
const Params& beliefs = results[i];
|
2011-05-17 12:00:33 +01:00
|
|
|
YAP_Term queryBeliefsL = YAP_TermNil();
|
|
|
|
for (int j = beliefs.size() - 1; j >= 0; j--) {
|
2011-07-22 21:33:30 +01:00
|
|
|
YAP_Int sl1 = YAP_InitSlot (list);
|
|
|
|
YAP_Term belief = YAP_MkFloatTerm (beliefs[j]);
|
|
|
|
queryBeliefsL = YAP_MkPairTerm (belief, queryBeliefsL);
|
|
|
|
list = YAP_GetFromSlot (sl1);
|
|
|
|
YAP_RecoverSlots (1);
|
2011-05-17 12:00:33 +01:00
|
|
|
}
|
|
|
|
list = YAP_MkPairTerm (queryBeliefsL, list);
|
|
|
|
}
|
|
|
|
return YAP_Unify (list, YAP_ARG3);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-04-05 18:38:56 +01:00
|
|
|
void runVeSolver (
|
|
|
|
FactorGraph* fg,
|
|
|
|
const vector<VarIds>& tasks,
|
|
|
|
vector<Params>& results)
|
|
|
|
{
|
|
|
|
results.reserve (tasks.size());
|
|
|
|
for (unsigned i = 0; i < tasks.size(); i++) {
|
|
|
|
FactorGraph* mfg = fg;
|
|
|
|
if (fg->isFromBayesNetwork()) {
|
|
|
|
mfg = BayesBall::getMinimalFactorGraph (*fg, tasks[i]);
|
|
|
|
}
|
|
|
|
VarElimSolver solver (*mfg);
|
|
|
|
if (tasks[i].size() == 1) {
|
|
|
|
results.push_back (solver.getPosterioriOf (tasks[i][0]));
|
|
|
|
} else {
|
|
|
|
results.push_back (solver.getJointDistributionOf (tasks[i]));
|
|
|
|
}
|
|
|
|
if (fg->isFromBayesNetwork()) {
|
|
|
|
delete mfg;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void runBpSolver (
|
|
|
|
FactorGraph* fg,
|
|
|
|
const vector<VarIds>& tasks,
|
|
|
|
vector<Params>& results)
|
|
|
|
{
|
|
|
|
std::set<VarId> vids;
|
|
|
|
for (unsigned i = 0; i < tasks.size(); i++) {
|
|
|
|
Util::addToSet (vids, tasks[i]);
|
|
|
|
}
|
|
|
|
Solver* solver = 0;
|
|
|
|
FactorGraph* mfg = fg;
|
|
|
|
if (fg->isFromBayesNetwork()) {
|
|
|
|
mfg = BayesBall::getMinimalFactorGraph (
|
|
|
|
*fg, VarIds (vids.begin(),vids.end()));
|
|
|
|
}
|
|
|
|
if (Globals::infAlgorithm == InfAlgorithms::FG_BP) {
|
|
|
|
solver = new FgBpSolver (*mfg);
|
|
|
|
} else if (Globals::infAlgorithm == InfAlgorithms::CBP) {
|
|
|
|
CFactorGraph::checkForIdenticalFactors = false;
|
|
|
|
solver = new CbpSolver (*mfg);
|
|
|
|
} else {
|
|
|
|
cerr << "error: unknow solver" << endl;
|
|
|
|
abort();
|
|
|
|
}
|
|
|
|
solver->runSolver();
|
|
|
|
results.reserve (tasks.size());
|
|
|
|
for (unsigned i = 0; i < tasks.size(); i++) {
|
|
|
|
if (tasks[i].size() == 1) {
|
|
|
|
results.push_back (solver->getPosterioriOf (tasks[i][0]));
|
|
|
|
} else {
|
|
|
|
results.push_back (solver->getJointDistributionOf (tasks[i]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (fg->isFromBayesNetwork()) {
|
|
|
|
delete mfg;
|
|
|
|
}
|
|
|
|
delete solver;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-03-31 23:27:37 +01:00
|
|
|
int
|
|
|
|
setParfactorsParams (void)
|
|
|
|
{
|
|
|
|
LiftedNetwork* network = (LiftedNetwork*) YAP_IntOfTerm (YAP_ARG1);
|
|
|
|
ParfactorList* pfList = network->first;
|
|
|
|
YAP_Term distList = YAP_ARG2;
|
|
|
|
unordered_map<unsigned, Params> paramsMap;
|
|
|
|
while (distList != YAP_TermNil()) {
|
2012-04-05 18:38:56 +01:00
|
|
|
YAP_Term dist = YAP_HeadOfTerm (distList);
|
|
|
|
unsigned distId = (unsigned) YAP_IntOfTerm (YAP_ArgOfTerm (1, dist));
|
2012-03-31 23:27:37 +01:00
|
|
|
assert (Util::contains (paramsMap, distId) == false);
|
2012-04-03 19:53:27 +01:00
|
|
|
paramsMap[distId] = readParameters (YAP_ArgOfTerm (2, dist));
|
2012-03-31 23:27:37 +01:00
|
|
|
distList = YAP_TailOfTerm (distList);
|
|
|
|
}
|
|
|
|
ParfactorList::iterator it = pfList->begin();
|
|
|
|
while (it != pfList->end()) {
|
|
|
|
assert (Util::contains (paramsMap, (*it)->distId()));
|
|
|
|
// (*it)->setParams (paramsMap[(*it)->distId()]);
|
|
|
|
++ it;
|
|
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
setBayesNetParams (void)
|
|
|
|
{
|
|
|
|
BayesNet* bn = (BayesNet*) YAP_IntOfTerm (YAP_ARG1);
|
|
|
|
YAP_Term distList = YAP_ARG2;
|
|
|
|
unordered_map<unsigned, Params> paramsMap;
|
|
|
|
while (distList != YAP_TermNil()) {
|
|
|
|
YAP_Term dist = YAP_HeadOfTerm (distList);
|
|
|
|
unsigned distId = (unsigned) YAP_IntOfTerm (YAP_ArgOfTerm (1, dist));
|
|
|
|
assert (Util::contains (paramsMap, distId) == false);
|
2012-04-03 19:53:27 +01:00
|
|
|
paramsMap[distId] = readParameters (YAP_ArgOfTerm (2, dist));
|
2012-03-31 23:27:37 +01:00
|
|
|
distList = YAP_TailOfTerm (distList);
|
|
|
|
}
|
|
|
|
const BnNodeSet& nodes = bn->getBayesNodes();
|
|
|
|
for (unsigned i = 0; i < nodes.size(); i++) {
|
|
|
|
assert (Util::contains (paramsMap, nodes[i]->distId()));
|
|
|
|
nodes[i]->setParams (paramsMap[nodes[i]->distId()]);
|
|
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-12-12 15:29:51 +00:00
|
|
|
int
|
2012-03-22 11:33:24 +00:00
|
|
|
setExtraVarsInfo (void)
|
|
|
|
{
|
|
|
|
GraphicalModel::clearVariablesInformation();
|
|
|
|
YAP_Term varsInfoL = YAP_ARG2;
|
|
|
|
while (varsInfoL != YAP_TermNil()) {
|
|
|
|
YAP_Term head = YAP_HeadOfTerm (varsInfoL);
|
|
|
|
VarId vid = YAP_IntOfTerm (YAP_ArgOfTerm (1, head));
|
|
|
|
YAP_Atom label = YAP_AtomOfTerm (YAP_ArgOfTerm (2, head));
|
|
|
|
YAP_Term statesL = YAP_ArgOfTerm (3, head);
|
|
|
|
States states;
|
|
|
|
while (statesL != YAP_TermNil()) {
|
|
|
|
YAP_Atom atom = YAP_AtomOfTerm (YAP_HeadOfTerm (statesL));
|
|
|
|
states.push_back ((char*) YAP_AtomName (atom));
|
|
|
|
statesL = YAP_TailOfTerm (statesL);
|
|
|
|
}
|
|
|
|
GraphicalModel::addVariableInformation (vid,
|
|
|
|
(char*) YAP_AtomName (label), states);
|
|
|
|
varsInfoL = YAP_TailOfTerm (varsInfoL);
|
|
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
setHorusFlag (void)
|
2011-12-12 15:29:51 +00:00
|
|
|
{
|
|
|
|
string key ((char*) YAP_AtomName (YAP_AtomOfTerm (YAP_ARG1)));
|
|
|
|
if (key == "inf_alg") {
|
|
|
|
string value ((char*) YAP_AtomName (YAP_AtomOfTerm (YAP_ARG2)));
|
|
|
|
if ( value == "ve") {
|
2012-03-31 23:27:37 +01:00
|
|
|
Globals::infAlgorithm = InfAlgorithms::VE;
|
2011-12-12 15:29:51 +00:00
|
|
|
} else if (value == "bn_bp") {
|
2012-03-31 23:27:37 +01:00
|
|
|
Globals::infAlgorithm = InfAlgorithms::BN_BP;
|
2011-12-12 15:29:51 +00:00
|
|
|
} else if (value == "fg_bp") {
|
2012-03-31 23:27:37 +01:00
|
|
|
Globals::infAlgorithm = InfAlgorithms::FG_BP;
|
2011-12-12 15:29:51 +00:00
|
|
|
} else if (value == "cbp") {
|
2012-03-31 23:27:37 +01:00
|
|
|
Globals::infAlgorithm = InfAlgorithms::CBP;
|
2011-12-12 15:29:51 +00:00
|
|
|
} else {
|
|
|
|
cerr << "warning: invalid value `" << value << "' " ;
|
|
|
|
cerr << "for `" << key << "'" << endl;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
} else if (key == "elim_heuristic") {
|
|
|
|
string value ((char*) YAP_AtomName (YAP_AtomOfTerm (YAP_ARG2)));
|
|
|
|
if ( value == "min_neighbors") {
|
|
|
|
ElimGraph::setEliminationHeuristic (ElimHeuristic::MIN_NEIGHBORS);
|
|
|
|
} else if (value == "min_weight") {
|
|
|
|
ElimGraph::setEliminationHeuristic (ElimHeuristic::MIN_WEIGHT);
|
|
|
|
} else if (value == "min_fill") {
|
|
|
|
ElimGraph::setEliminationHeuristic (ElimHeuristic::MIN_FILL);
|
|
|
|
} else if (value == "weighted_min_fill") {
|
|
|
|
ElimGraph::setEliminationHeuristic (ElimHeuristic::WEIGHTED_MIN_FILL);
|
|
|
|
} else {
|
|
|
|
cerr << "warning: invalid value `" << value << "' " ;
|
|
|
|
cerr << "for `" << key << "'" << endl;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
} else if (key == "schedule") {
|
|
|
|
string value ((char*) YAP_AtomName (YAP_AtomOfTerm (YAP_ARG2)));
|
|
|
|
if ( value == "seq_fixed") {
|
|
|
|
BpOptions::schedule = BpOptions::Schedule::SEQ_FIXED;
|
|
|
|
} else if (value == "seq_random") {
|
|
|
|
BpOptions::schedule = BpOptions::Schedule::SEQ_RANDOM;
|
|
|
|
} else if (value == "parallel") {
|
|
|
|
BpOptions::schedule = BpOptions::Schedule::PARALLEL;
|
|
|
|
} else if (value == "max_residual") {
|
|
|
|
BpOptions::schedule = BpOptions::Schedule::MAX_RESIDUAL;
|
|
|
|
} else {
|
|
|
|
cerr << "warning: invalid value `" << value << "' " ;
|
|
|
|
cerr << "for `" << key << "'" << endl;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
} else if (key == "accuracy") {
|
|
|
|
BpOptions::accuracy = (double) YAP_FloatOfTerm (YAP_ARG2);
|
|
|
|
} else if (key == "max_iter") {
|
|
|
|
BpOptions::maxIter = (int) YAP_IntOfTerm (YAP_ARG2);
|
2012-03-22 11:33:24 +00:00
|
|
|
} else if (key == "use_logarithms") {
|
2011-12-12 15:29:51 +00:00
|
|
|
string value ((char*) YAP_AtomName (YAP_AtomOfTerm (YAP_ARG2)));
|
2012-03-22 11:33:24 +00:00
|
|
|
if ( value == "true") {
|
|
|
|
Globals::logDomain = true;
|
2011-12-12 15:29:51 +00:00
|
|
|
} else if (value == "false") {
|
2012-03-22 11:33:24 +00:00
|
|
|
Globals::logDomain = false;
|
|
|
|
} else {
|
|
|
|
cerr << "warning: invalid value `" << value << "' " ;
|
|
|
|
cerr << "for `" << key << "'" << endl;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
} else if (key == "order_factor_variables") {
|
|
|
|
string value ((char*) YAP_AtomName (YAP_AtomOfTerm (YAP_ARG2)));
|
|
|
|
if ( value == "true") {
|
|
|
|
FactorGraph::orderFactorVariables = true;
|
|
|
|
} else if (value == "false") {
|
|
|
|
FactorGraph::orderFactorVariables = false;
|
2011-12-12 15:29:51 +00:00
|
|
|
} else {
|
|
|
|
cerr << "warning: invalid value `" << value << "' " ;
|
|
|
|
cerr << "for `" << key << "'" << endl;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
cerr << "warning: invalid key `" << key << "'" << endl;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-03-22 11:33:24 +00:00
|
|
|
int
|
2012-04-03 19:53:27 +01:00
|
|
|
freeGroundNetwork (void)
|
2011-12-12 15:29:51 +00:00
|
|
|
{
|
2012-03-31 23:27:37 +01:00
|
|
|
delete (BayesNet*) YAP_IntOfTerm (YAP_ARG1);
|
2011-12-12 15:29:51 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-05-17 12:00:33 +01:00
|
|
|
int
|
2012-03-31 23:27:37 +01:00
|
|
|
freeParfactors (void)
|
2011-05-17 12:00:33 +01:00
|
|
|
{
|
2012-03-31 23:27:37 +01:00
|
|
|
LiftedNetwork* network = (LiftedNetwork*) YAP_IntOfTerm (YAP_ARG1);
|
|
|
|
delete network->first;
|
|
|
|
delete network->second;
|
|
|
|
delete network;
|
2011-05-17 12:00:33 +01:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
extern "C" void
|
|
|
|
init_predicates (void)
|
|
|
|
{
|
2012-04-03 11:58:21 +01:00
|
|
|
YAP_UserCPredicate ("create_lifted_network", createLiftedNetwork, 3);
|
2012-04-05 18:38:56 +01:00
|
|
|
YAP_UserCPredicate ("create_ground_network", createGroundNetwork, 4);
|
2012-04-03 11:58:21 +01:00
|
|
|
YAP_UserCPredicate ("run_lifted_solver", runLiftedSolver, 3);
|
|
|
|
YAP_UserCPredicate ("run_ground_solver", runGroundSolver, 3);
|
|
|
|
YAP_UserCPredicate ("set_parfactors_params", setParfactorsParams, 2);
|
|
|
|
YAP_UserCPredicate ("set_bayes_net_params", setBayesNetParams, 2);
|
|
|
|
YAP_UserCPredicate ("set_extra_vars_info", setExtraVarsInfo, 2);
|
|
|
|
YAP_UserCPredicate ("set_horus_flag", setHorusFlag, 2);
|
|
|
|
YAP_UserCPredicate ("free_parfactors", freeParfactors, 1);
|
2012-04-03 19:53:27 +01:00
|
|
|
YAP_UserCPredicate ("free_ground_network", freeGroundNetwork, 1);
|
2011-05-17 12:00:33 +01:00
|
|
|
}
|
|
|
|
|