class SeqStringTheory extends AbstractStringTheory
String theory implemented using a list ADT.
- Alphabetic
- By Inheritance
- SeqStringTheory
- AbstractStringTheory
- StringTheory
- Theory
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Type Members
- class IllegalRegexException extends Exception
- Definition Classes
- AbstractStringTheory
- class RegexExtractor extends AnyRef
Translator from atoms representing regexes in a goal to the corresponding term.
Translator from atoms representing regexes in a goal to the corresponding term.
- Definition Classes
- AbstractStringTheory
- class WordExtractor extends AnyRef
- Definition Classes
- AbstractStringTheory
- case class DecoderData(m: Map[IdealInt, Seq[IdealInt]]) extends TheoryDecoderData with Product with Serializable
- class RichWord extends AnyRef
Helper class providing string infix operators
Helper class providing string infix operators
- Definition Classes
- StringTheory
Value Members
- object ConcreteRegex
Extractor to identify regular expressions that are completely defined, i.e., in which no sub-terms are left symbolic.
Extractor to identify regular expressions that are completely defined, i.e., in which no sub-terms are left symbolic.
- Definition Classes
- AbstractStringTheory
- object RegexExtractor
- Definition Classes
- AbstractStringTheory
- object WordExtractor
- Definition Classes
- AbstractStringTheory
- 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
- val CharSort: ModSort
Sort representing characters
Sort representing characters
- Definition Classes
- SeqStringTheory → StringTheory
- val RegexSort: InfUninterpretedSort
Sort representing regular expressions
Sort representing regular expressions
- Definition Classes
- SeqStringTheory → StringTheory
- val StringSort: ADTProxySort
Sort representing strings
Sort representing strings
- Definition Classes
- SeqStringTheory → StringTheory
- val _str_++: Predicate
The predicate corresponding to
str_++
The predicate corresponding to
str_++
- Definition Classes
- SeqStringTheory → StringTheory
- val _str_cons: Predicate
The predicate corresponding to
str_cons
The predicate corresponding to
str_cons
- Definition Classes
- SeqStringTheory → StringTheory
- val _str_empty: Predicate
The predicate corresponding to
str_empty
The predicate corresponding to
str_empty
- Definition Classes
- SeqStringTheory → StringTheory
- val allAxioms: IFormula
- val alphabetSize: Int
- Definition Classes
- SeqStringTheory → StringTheory
- final def asInstanceOf[T0]: T0
- Definition Classes
- Any
- 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
- SeqStringTheory → StringTheory
- 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
- SeqStringTheory → StringTheory
- 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
- Definition Classes
- AbstractStringTheory
- val axioms: Conjunction
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
- SeqStringTheory → Theory
- val axioms1: Formula
- 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
- Definition Classes
- AbstractStringTheory
- def char2Int(t: ITerm): ITerm
Convert a character term to an integer term
Convert a character term to an integer term
- Definition Classes
- SeqStringTheory → StringTheory
- 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
- SeqStringTheory → 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
- val extraIndexedOps: Map[(String, Int), Either[IFunction, Predicate]]
- Definition Classes
- SeqStringTheory → StringTheory
- val extraOps: Map[String, Either[IFunction, Predicate]]
- Definition Classes
- SeqStringTheory → StringTheory
- val funPredMap: Map[IFunction, Predicate]
- val funPredicates: Seq[Predicate]
- val functionPredicateMapping: List[(MonoSortedIFunction, 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
- SeqStringTheory → Theory
- 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
- SeqStringTheory → Theory
- val functions: List[MonoSortedIFunction]
Interpreted functions of the theory
Interpreted functions of the theory
- Definition Classes
- SeqStringTheory → 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
- SeqStringTheory → 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
- SeqStringTheory → Theory
- def int2Char(t: ITerm): ITerm
Convert an integer term to a character term
Convert an integer term to a character term
- Definition Classes
- SeqStringTheory → StringTheory
- 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 intToStrAxioms: IFormula
- val int_to_str: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val int_to_str_help: MonoSortedIFunction
- 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
- SeqStringTheory → 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()
- val order: TermOrder
- def plugin: Some[Plugin]
Optionally, a plug-in implementing reasoning in this theory
Optionally, a plug-in implementing reasoning in this theory
- Definition Classes
- SeqStringTheory → Theory
- 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
- Definition Classes
- AbstractStringTheory
- def predefPredicates: List[MonoSortedPredicate]
- Attributes
- protected
- Definition Classes
- AbstractStringTheory
- 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
- SeqStringTheory → Theory
- val predicates: List[Predicate]
Interpreted predicates of the theory
Interpreted predicates of the theory
- Definition Classes
- SeqStringTheory → Theory
- 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
- SeqStringTheory → Theory
- val reDerivativeAxioms: IFormula
- val reDerivativeAxioms2: Formula
- val reMatchingAxioms: IFormula
- val reMatchingAxioms2: Formula
- val reNullableAxioms: IFormula
- val reSimpAxioms: IFormula
- 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_derivative_help: MonoSortedIFunction
- 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_matches_str_help: MonoSortedIFunction
- val re_none: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val re_nullable_help: MonoSortedIFunction
- 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 seqADT: ADT
- 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 strAtAxioms: IFormula
- val strIndexofAxioms: IFormula
- val strReplaceAxioms: IFormula
- val strSubstrAxioms: IFormula
- val strToIntAxioms: IFormula
- 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_cons: MonoSortedIFunction
- Definition Classes
- SeqStringTheory → StringTheory
- val str_contains: MonoSortedPredicate
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_empty: MonoSortedIFunction
- Definition Classes
- SeqStringTheory → StringTheory
- val str_from_char: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_from_code: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_head: MonoSortedIFunction
- Definition Classes
- SeqStringTheory → 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_indexof_help: MonoSortedIFunction
- 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_tail: MonoSortedIFunction
- Definition Classes
- SeqStringTheory → StringTheory
- val str_to_code: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_to_int: MonoSortedIFunction
- Definition Classes
- AbstractStringTheory → StringTheory
- val str_to_int_help: MonoSortedIFunction
- 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
- val totalityAxioms: Conjunction
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
- SeqStringTheory → Theory
- 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
- 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
- SeqStringTheory → Theory
- val upperBound: IdealInt
- 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])
Deprecated Value Members
- def finalize(): Unit
- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.Throwable]) @Deprecated
- Deprecated
(Since version 9)