abstract class AbstractStringTheory extends StringTheory
Abstract class defining relevant string operations as sorted functions/predicates
- Alphabetic
- By Inheritance
- AbstractStringTheory
- StringTheory
- Theory
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Instance Constructors
- new AbstractStringTheory()
Type Members
- class IllegalRegexException extends Exception
- class RegexExtractor extends AnyRef
Translator from atoms representing regexes in a goal to the corresponding term.
- class WordExtractor extends AnyRef
- class RichWord extends AnyRef
Helper class providing string infix operators
Helper class providing string infix operators
- Definition Classes
- StringTheory
Abstract Value Members
- abstract val CharSort: Sort
Sort representing characters
Sort representing characters
- Definition Classes
- StringTheory
- abstract val RegexSort: Sort
Sort representing regular expressions
Sort representing regular expressions
- Definition Classes
- StringTheory
- abstract val StringSort: Sort
Sort representing strings
Sort representing strings
- Definition Classes
- StringTheory
- abstract val _str_++: Predicate
The predicate corresponding to
str_++
The predicate corresponding to
str_++
- Definition Classes
- StringTheory
- abstract val _str_cons: Predicate
The predicate corresponding to
str_cons
The predicate corresponding to
str_cons
- Definition Classes
- StringTheory
- abstract val _str_empty: Predicate
The predicate corresponding to
str_empty
The predicate corresponding to
str_empty
- Definition Classes
- StringTheory
- abstract val alphabetSize: Int
- Definition Classes
- StringTheory
- abstract val asString: Decoder[String]
Translate a numeric value from a model to a string.
Translate a numeric value from a model to a string.
- Definition Classes
- StringTheory
- abstract val asStringPartial: Decoder[Option[String]]
Translate a numeric value from a model to a string.
Translate a numeric value from a model to a string.
- Definition Classes
- StringTheory
- abstract val axioms: Formula
Axioms defining the theory; such axioms are simply added as formulae to the problem to be proven, and thus handled using the standard reasoning techniques (including e-matching).
Axioms defining the theory; such axioms are simply added as formulae to the problem to be proven, and thus handled using the standard reasoning techniques (including e-matching).
- Definition Classes
- Theory
- abstract def char2Int(t: ITerm): ITerm
Convert a character term to an integer term
Convert a character term to an integer term
- Definition Classes
- StringTheory
- abstract val extraIndexedOps: Map[(String, Int), Either[IFunction, Predicate]]
- Definition Classes
- StringTheory
- abstract val extraOps: Map[String, Either[IFunction, Predicate]]
- Definition Classes
- StringTheory
- abstract val functionPredicateMapping: Seq[(IFunction, Predicate)]
Mapping of interpreted functions to interpreted predicates, used translating input ASTs to internal ASTs (the latter only containing predicates).
Mapping of interpreted functions to interpreted predicates, used translating input ASTs to internal ASTs (the latter only containing predicates).
- Definition Classes
- Theory
- abstract val functionalPredicates: Set[Predicate]
Information which of the predicates satisfy the functionality axiom; at some internal points, such predicates can be handled more efficiently
Information which of the predicates satisfy the functionality axiom; at some internal points, such predicates can be handled more efficiently
- Definition Classes
- Theory
- abstract val functions: Seq[IFunction]
Interpreted functions of the theory
Interpreted functions of the theory
- Definition Classes
- Theory
- abstract def int2Char(t: ITerm): ITerm
Convert an integer term to a character term
Convert an integer term to a character term
- Definition Classes
- StringTheory
- abstract def plugin: Option[Plugin]
Optionally, a plug-in implementing reasoning in this theory
Optionally, a plug-in implementing reasoning in this theory
- Definition Classes
- Theory
- abstract val predicateMatchConfig: PredicateMatchConfig
Information how interpreted predicates should be handled for e-matching.
Information how interpreted predicates should be handled for e-matching.
- Definition Classes
- Theory
- abstract val predicates: Seq[Predicate]
Interpreted predicates of the theory
Interpreted predicates of the theory
- Definition Classes
- Theory
- abstract val str_cons: IFunction
- Definition Classes
- StringTheory
- abstract val str_empty: IFunction
- Definition Classes
- StringTheory
- abstract val str_head: IFunction
- Definition Classes
- StringTheory
- abstract val str_tail: IFunction
- Definition Classes
- StringTheory
- abstract val totalityAxioms: Formula
Additional axioms that are included if the option
+genTotalityAxioms
is given to Princess.Additional axioms that are included if the option
+genTotalityAxioms
is given to Princess.- Definition Classes
- Theory
- abstract val triggerRelevantFunctions: Set[IFunction]
A list of functions that should be considered in automatic trigger generation
A list of functions that should be considered in automatic trigger generation
- Definition Classes
- Theory
Concrete Value Members
- final def !=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def ##: Int
- Definition Classes
- AnyRef → Any
- final def ==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
- final def asInstanceOf[T0]: T0
- Definition Classes
- Any
- def assignStringValues(facts: Conjunction, assignment: Map[Term, Seq[Int]], order: TermOrder): Conjunction
Augment goal facts with the given assignment of strings to terms.
Augment goal facts with the given assignment of strings to terms. At the moment this assumes that all string terms are constants.
- Attributes
- protected
- def breakCyclicEquations(goal: Goal): Option[Seq[Action]]
Check for cyclic word equations induced by
str_++
orstr_cons
, and break those.Check for cyclic word equations induced by
str_++
orstr_cons
, and break those. e.g., equations x = yz & y = ax -> z = eps & a = eps & y = ax Tarjan's algorithm is used to find all strongly connected components- Attributes
- protected
- val char_is_digit: MonoSortedPredicate
- Definition Classes
- AbstractStringTheory → StringTheory
- def clone(): AnyRef
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.CloneNotSupportedException]) @HotSpotIntrinsicCandidate() @native()
- val dependencies: Iterable[Theory]
Optionally, other theories that this theory depends on.
Optionally, other theories that this theory depends on. Specified dependencies will be loaded before this theory, but the preprocessors of the dependencies will be called after the preprocessor of this theory.
- Definition Classes
- Theory
- final def eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- def equals(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef → Any
- def evalFun(f: IFunApp): Option[ITerm]
Optionally, a function evaluating theory functions applied to concrete arguments, represented as constructor terms.
Optionally, a function evaluating theory functions applied to concrete arguments, represented as constructor terms.
- Definition Classes
- Theory
- def evalPred(p: IAtom): Option[Boolean]
Optionally, a function evaluating theory predicates applied to concrete arguments, represented as constructor terms.
Optionally, a function evaluating theory predicates applied to concrete arguments, represented as constructor terms.
- Definition Classes
- Theory
- def evaluatingSimplifier(t: IExpression): IExpression
A simplification function that applies the methods
evalFun
andevalPred
to some given expression (but not recursively).A simplification function that applies the methods
evalFun
andevalPred
to some given expression (but not recursively). This is used in theTheory.postSimplifiers
methods.- Definition Classes
- Theory
- def extend(order: TermOrder): TermOrder
Add the symbols defined by this theory to the
order
Add the symbols defined by this theory to the
order
- Definition Classes
- Theory
- def generateDecoderData(model: Conjunction): Option[TheoryDecoderData]
If this theory defines any
Theory.Decoder
, which can translate model data into some theory-specific representation, this function can be overridden to pre-compute required data from a model.If this theory defines any
Theory.Decoder
, which can translate model data into some theory-specific representation, this function can be overridden to pre-compute required data from a model.- Definition Classes
- Theory
- final def getClass(): Class[_ <: AnyRef]
- Definition Classes
- AnyRef → Any
- Annotations
- @HotSpotIntrinsicCandidate() @native()
- def hashCode(): Int
- Definition Classes
- AnyRef → Any
- Annotations
- @HotSpotIntrinsicCandidate() @native()
- def iPostprocess(f: IFormula, signature: Signature): IFormula
Optionally, a post-processor that is applied to formulas output by the prover, for instance to interpolants or the result of quantifier elimination.
Optionally, a post-processor that is applied to formulas output by the prover, for instance to interpolants or the result of quantifier elimination. This method will be applied to the formula after calling
Internal2Inputabsy
.- Definition Classes
- Theory
- def iPreprocess(f: IFormula, signature: Signature): (IFormula, Signature)
Optionally, a pre-processor that is applied to formulas over this theory, prior to sending the formula to a prover.
Optionally, a pre-processor that is applied to formulas over this theory, prior to sending the formula to a prover. This method will be applied very early in the translation process.
- Definition Classes
- Theory
- def int2String(t: ITerm): ITerm
Convert an integer term to a singleton string
Convert an integer term to a singleton string
- Definition Classes
- StringTheory
- val int_to_str: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- final def isInstanceOf[T0]: Boolean
- Definition Classes
- Any
- def isSoundForSat(theories: Seq[Theory], config: Theory.SatSoundnessConfig.Value): Boolean
Check whether we can tell that the given combination of theories is sound for checking satisfiability of a problem, i.e., if proof construction ends up in a dead end, can it be concluded that a problem is satisfiable.
Check whether we can tell that the given combination of theories is sound for checking satisfiability of a problem, i.e., if proof construction ends up in a dead end, can it be concluded that a problem is satisfiable.
- Definition Classes
- Theory
- val modelGenPredicates: Set[Predicate]
Optionally, a set of predicates used by the theory to tell the
PresburgerModelFinder
about terms that will be handled exclusively by this theory.Optionally, a set of predicates used by the theory to tell the
PresburgerModelFinder
about terms that will be handled exclusively by this theory. If a proof goal in model generation mode contains an atomp(x)
, forp
in this set, then thePresburgerModelFinder
will ignorex
when assigning concrete values to symbols.- Definition Classes
- Theory
- final def ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
- final def notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @HotSpotIntrinsicCandidate() @native()
- final def notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @HotSpotIntrinsicCandidate() @native()
- def postSimplifiers: Seq[(IExpression) => IExpression]
Optionally, simplifiers that are applied to formulas output by the prover, for instance to interpolants or the result of quantifier.
Optionally, simplifiers that are applied to formulas output by the prover, for instance to interpolants or the result of quantifier. Such simplifiers are invoked by
ap.parser.Simplifier
. By default, this list will only include theevaluatingSimplifier
.- Definition Classes
- Theory
- def postprocess(f: Conjunction, order: TermOrder): Conjunction
Optionally, a post-processor that is applied to formulas output by the prover, for instance to interpolants or the result of quantifier elimination.
Optionally, a post-processor that is applied to formulas output by the prover, for instance to interpolants or the result of quantifier elimination. This method will be applied to the raw formulas, before calling
Internal2Inputabsy
.- Definition Classes
- Theory
- def predefFunctions: List[MonoSortedIFunction]
- Attributes
- protected
- def predefPredicates: List[MonoSortedPredicate]
- Attributes
- protected
- def preprocess(f: Conjunction, order: TermOrder): Conjunction
Optionally, a pre-processor that is applied to formulas over this theory, prior to sending the formula to a prover.
Optionally, a pre-processor that is applied to formulas over this theory, prior to sending the formula to a prover.
- Definition Classes
- Theory
- val re_*: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_+: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_++: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_all: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_allchar: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_charrange: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_comp: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_diff: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_eps: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_from_str: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_inter: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_loop: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_none: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_opt: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_range: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_union: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val reducerPlugin: ReducerPluginFactory
Optionally, a plugin for the reducer applied to formulas both before and during proving.
Optionally, a plugin for the reducer applied to formulas both before and during proving.
- Definition Classes
- Theory
- val singleInstantiationPredicates: Set[Predicate]
When instantiating existentially quantifier formulas,
EX phi
, at most one instantiation is necessary provided that all predicates inphi
are contained in this set.When instantiating existentially quantifier formulas,
EX phi
, at most one instantiation is necessary provided that all predicates inphi
are contained in this set.- Definition Classes
- Theory
- val str_++: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_<: MonoSortedPredicate
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_<=: MonoSortedPredicate
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_at: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_char: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_contains: MonoSortedPredicate
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_from_char: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_from_code: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_head_code: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_in_re: MonoSortedPredicate
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_indexof: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_len: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_prefixof: MonoSortedPredicate
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_replace: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_replaceall: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_replaceallre: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_replacere: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_substr: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_suffixof: MonoSortedPredicate
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_to_code: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_to_int: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_to_re: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- implicit def string2Term(str: String): ITerm
Convert a string to a term
Convert a string to a term
- Definition Classes
- StringTheory
- final def synchronized[T0](arg0: => T0): T0
- Definition Classes
- AnyRef
- implicit def term2RichWord(t: ITerm): RichWord
Convert a term to a rich term, providing some infix operators
Convert a term to a rich term, providing some infix operators
- Definition Classes
- StringTheory
- def toString(): String
- Definition Classes
- AnyRef → Any
- lazy val transitiveDependencies: Iterable[Theory]
Dependencies closed under transitivity, i.e., also including the dependencies of dependencies.
Dependencies closed under transitivity, i.e., also including the dependencies of dependencies.
- Definition Classes
- Theory
- final def wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- final def wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException]) @native()
- final def wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
- object ConcreteRegex
Extractor to identify regular expressions that are completely defined, i.e., in which no sub-terms are left symbolic.
- object RegexExtractor
- object WordExtractor
Deprecated Value Members
- def finalize(): Unit
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.Throwable]) @Deprecated
- Deprecated
(Since version 9)