SMT-RAT
24.02
Toolbox for Strategic and Parallel Satisfiability-Modulo-Theories Solving
|
Implements the theory of equalities and uninterpreted functions. More...
#include <Uninterpreted.h>
Public Member Functions | |
UninterpretedTheory (ParserState *state) | |
FormulaT | coupleBooleanVariables (carl::Variable v, carl::UVariable uv) |
bool | declareVariable (const std::string &name, const carl::Sort &sort, types::VariableType &result, TheoryError &errors) |
Declare a new variable with the given name and the given sort. More... | |
bool | handleITE (const FormulaT &ifterm, const types::TermType &thenterm, const types::TermType &elseterm, types::TermType &result, TheoryError &errors) |
Resolve an if-then-else operator. More... | |
bool | handleFunctionInstantiation (const carl::UninterpretedFunction &f, const std::vector< types::TermType > &arguments, types::TermType &result, TheoryError &errors) |
bool | handleDistinct (const std::vector< types::TermType > &, types::TermType &, TheoryError &errors) |
Resolve a distinct operator. More... | |
bool | functionCall (const Identifier &identifier, const std::vector< types::TermType > &arguments, types::TermType &result, TheoryError &errors) |
Resolve another unknown function call. More... | |
virtual bool | resolveSymbol (const Identifier &, types::TermType &, TheoryError &errors) |
Resolve a symbol that was not declared within the ParserState. More... | |
template<typename T , typename Builder > | |
FormulaT | expandDistinct (const std::vector< T > &values, const Builder &neqBuilder) |
virtual bool | instantiate (const types::VariableType &, const types::TermType &, types::TermType &, TheoryError &errors) |
Instantiate a variable within a term. More... | |
virtual bool | refreshVariable (const types::VariableType &, types::VariableType &, TheoryError &errors) |
virtual bool | declareQuantifiedTerm (const std::vector< std::pair< std::string, carl::Sort >> &, const carl::FormulaType &, const types::TermType &, types::TermType &, TheoryError &errors) |
Resolve a quantified term. More... | |
Static Public Member Functions | |
static void | addSimpleSorts (qi::symbols< char, carl::Sort > &) |
Initialize the global symbol table for simple sorts. More... | |
static void | addConstants (qi::symbols< char, types::ConstType > &) |
Initialize the global symbol table for constants. More... | |
Data Fields | |
std::map< types::TermType, carl::UTerm > | mInstantiatedArguments |
carl::Sort | mBoolSort |
carl::UVariable | mTrue |
carl::UVariable | mFalse |
ParserState * | state |
Implements the theory of equalities and uninterpreted functions.
Definition at line 13 of file Uninterpreted.h.
smtrat::parser::UninterpretedTheory::UninterpretedTheory | ( | ParserState * | state | ) |
Definition at line 37 of file Uninterpreted.cpp.
|
inlinestaticinherited |
Initialize the global symbol table for constants.
Definition at line 115 of file AbstractTheory.h.
|
inlinestaticinherited |
Initialize the global symbol table for simple sorts.
Definition at line 111 of file AbstractTheory.h.
|
inline |
|
inlinevirtualinherited |
Resolve a quantified term.
Reimplemented in smtrat::parser::ArithmeticTheory.
Definition at line 103 of file AbstractTheory.h.
|
virtual |
Declare a new variable with the given name and the given sort.
Reimplemented from smtrat::parser::AbstractTheory.
Definition at line 47 of file Uninterpreted.cpp.
|
inlineinherited |
|
virtual |
Resolve another unknown function call.
Reimplemented from smtrat::parser::AbstractTheory.
Definition at line 161 of file Uninterpreted.cpp.
|
virtual |
Resolve a distinct operator.
Reimplemented from smtrat::parser::AbstractTheory.
Definition at line 152 of file Uninterpreted.cpp.
bool smtrat::parser::UninterpretedTheory::handleFunctionInstantiation | ( | const carl::UninterpretedFunction & | f, |
const std::vector< types::TermType > & | arguments, | ||
types::TermType & | result, | ||
TheoryError & | errors | ||
) |
Definition at line 93 of file Uninterpreted.cpp.
|
virtual |
Resolve an if-then-else operator.
Reimplemented from smtrat::parser::AbstractTheory.
Definition at line 61 of file Uninterpreted.cpp.
|
inlinevirtualinherited |
Instantiate a variable within a term.
Reimplemented in smtrat::parser::BitvectorTheory, and smtrat::parser::ArithmeticTheory.
Definition at line 84 of file AbstractTheory.h.
|
inlinevirtualinherited |
Reimplemented in smtrat::parser::BitvectorTheory.
Definition at line 88 of file AbstractTheory.h.
|
inlinevirtualinherited |
Resolve a symbol that was not declared within the ParserState.
This might be a symbol that actually uses indices, for example bitvector constants.
Reimplemented in smtrat::parser::BitvectorTheory.
Definition at line 53 of file AbstractTheory.h.
carl::Sort smtrat::parser::UninterpretedTheory::mBoolSort |
Definition at line 15 of file Uninterpreted.h.
carl::UVariable smtrat::parser::UninterpretedTheory::mFalse |
Definition at line 17 of file Uninterpreted.h.
std::map<types::TermType, carl::UTerm> smtrat::parser::UninterpretedTheory::mInstantiatedArguments |
Definition at line 14 of file Uninterpreted.h.
carl::UVariable smtrat::parser::UninterpretedTheory::mTrue |
Definition at line 16 of file Uninterpreted.h.
|
inherited |
Definition at line 37 of file AbstractTheory.h.