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/horus/LiftedCircuit.h

230 lines
5.3 KiB
C
Raw Normal View History

#ifndef HORUS_LIFTEDCIRCUIT_H
#define HORUS_LIFTEDCIRCUIT_H
#include "LiftedWCNF.h"
2012-10-24 21:22:49 +01:00
enum CircuitNodeType {
OR_NODE,
AND_NODE,
SET_OR_NODE,
SET_AND_NODE,
INC_EXC_NODE,
LEAF_NODE,
SMOOTH_NODE,
TRUE_NODE,
2012-10-30 12:41:00 +00:00
COMPILATION_FAILED_NODE
2012-10-24 21:22:49 +01:00
};
class CircuitNode
{
public:
CircuitNode (const Clauses& clauses, string explanation = "")
: clauses_(clauses), explanation_(explanation) { }
const Clauses& clauses (void) const { return clauses_; }
Clauses clauses (void) { return clauses_; }
2012-10-30 12:41:00 +00:00
virtual double weight (void) const = 0;
string explanation (void) const { return explanation_; }
private:
Clauses clauses_;
string explanation_;
};
2012-10-24 21:22:49 +01:00
class OrNode : public CircuitNode
{
public:
2012-10-24 21:22:49 +01:00
OrNode (const Clauses& clauses, string explanation = "")
: CircuitNode (clauses, explanation),
2012-10-24 21:22:49 +01:00
leftBranch_(0), rightBranch_(0) { }
double weight (void) const;
2012-10-24 21:22:49 +01:00
CircuitNode** leftBranch (void) { return &leftBranch_; }
CircuitNode** rightBranch (void) { return &rightBranch_; }
private:
2012-10-24 21:22:49 +01:00
CircuitNode* leftBranch_;
CircuitNode* rightBranch_;
};
2012-10-24 21:22:49 +01:00
class AndNode : public CircuitNode
{
public:
2012-10-24 21:22:49 +01:00
AndNode (const Clauses& clauses, string explanation = "")
: CircuitNode (clauses, explanation),
2012-10-24 21:22:49 +01:00
leftBranch_(0), rightBranch_(0) { }
AndNode (
const Clauses& clauses,
CircuitNode* leftBranch,
CircuitNode* rightBranch,
string explanation = "")
: CircuitNode (clauses, explanation),
leftBranch_(leftBranch), rightBranch_(rightBranch) { }
AndNode (
CircuitNode* leftBranch,
CircuitNode* rightBranch,
string explanation = "")
: CircuitNode ({}, explanation),
leftBranch_(leftBranch), rightBranch_(rightBranch) { }
double weight (void) const;
2012-10-24 21:22:49 +01:00
CircuitNode** leftBranch (void) { return &leftBranch_; }
CircuitNode** rightBranch (void) { return &rightBranch_; }
private:
2012-10-24 21:22:49 +01:00
CircuitNode* leftBranch_;
CircuitNode* rightBranch_;
};
class SetOrNode : public CircuitNode
{
public:
SetOrNode (const Clauses& clauses, string explanation = "")
: CircuitNode (clauses, explanation), follow_(0) { }
double weight (void) const;
CircuitNode** follow (void) { return &follow_; }
private:
CircuitNode* follow_;
};
class SetAndNode : public CircuitNode
{
public:
SetAndNode (unsigned nrGroundings, const Clauses& clauses)
2012-10-30 00:21:10 +00:00
: CircuitNode (clauses, " IPG"), nrGroundings_(nrGroundings),
follow_(0) { }
double weight (void) const;
CircuitNode** follow (void) { return &follow_; }
private:
unsigned nrGroundings_;
CircuitNode* follow_;
};
2012-10-30 00:21:10 +00:00
class IncExcNode : public CircuitNode
{
public:
2012-10-30 00:21:10 +00:00
IncExcNode (const Clauses& clauses)
: CircuitNode (clauses), plus1Branch_(0),
plus2Branch_(0), minusBranch_(0) { }
2012-10-30 12:41:00 +00:00
double weight (void) const;
2012-10-30 00:21:10 +00:00
CircuitNode** plus1Branch (void) { return &plus1Branch_; }
CircuitNode** plus2Branch (void) { return &plus2Branch_; }
CircuitNode** minusBranch (void) { return &minusBranch_; }
private:
2012-10-30 00:21:10 +00:00
CircuitNode* plus1Branch_;
CircuitNode* plus2Branch_;
CircuitNode* minusBranch_;
};
class LeafNode : public CircuitNode
{
public:
LeafNode (const Clause& clause) : CircuitNode ({clause}) { }
double weight (void) const;
2012-10-24 21:22:49 +01:00
};
class SmoothNode : public CircuitNode
{
public:
SmoothNode (const Clauses& clauses) : CircuitNode (clauses) { }
double weight (void) const;
};
class TrueNode : public CircuitNode
{
public:
2012-10-30 00:21:10 +00:00
TrueNode (void) : CircuitNode ({}) { }
double weight (void) const;
};
2012-10-30 12:41:00 +00:00
class CompilationFailedNode : public CircuitNode
{
public:
2012-10-30 12:41:00 +00:00
CompilationFailedNode (const Clauses& clauses) : CircuitNode (clauses) { }
double weight (void) const;
};
class LiftedCircuit
{
public:
LiftedCircuit (const LiftedWCNF* lwcnf);
2012-10-24 21:22:49 +01:00
void smoothCircuit (void);
double getWeightedModelCount (void) const;
2012-10-24 21:22:49 +01:00
void exportToGraphViz (const char*);
private:
void compile (CircuitNode** follow, Clauses& clauses);
bool tryUnitPropagation (CircuitNode** follow, Clauses& clauses);
bool tryIndependence (CircuitNode** follow, Clauses& clauses);
bool tryShannonDecomp (CircuitNode** follow, Clauses& clauses);
2012-10-30 00:21:10 +00:00
bool tryInclusionExclusion (CircuitNode** follow, Clauses& clauses);
bool tryIndepPartialGrounding (CircuitNode** follow, Clauses& clauses);
bool tryIndepPartialGroundingAux (Clauses& clauses, ConstraintTree& ct,
vector<unsigned>& indices);
bool tryGrounding (CircuitNode** follow, Clauses& clauses);
2012-10-24 21:22:49 +01:00
TinySet<LiteralId> smoothCircuit (CircuitNode* node);
void createSmoothNode (const TinySet<LiteralId>& lids,
CircuitNode** prev);
2012-10-24 21:22:49 +01:00
CircuitNodeType getCircuitNodeType (const CircuitNode* node) const;
2012-10-24 21:22:49 +01:00
void exportToGraphViz (CircuitNode* node, ofstream&);
2012-10-30 14:31:52 +00:00
void printClauses (const CircuitNode* node, ofstream&,
string extraOptions = "");
string escapeNode (const CircuitNode* node) const;
CircuitNode* root_;
const LiftedWCNF* lwcnf_;
};
#endif // HORUS_LIFTEDCIRCUIT_H
2012-10-24 21:22:49 +01:00