Difference between revisions of "Term Rewriting"
| (15 intermediate revisions by 2 users not shown) | |||
| Line 4: | Line 4: | ||
| * We do not impose any variable conditions, so a rewrite rule is a pair of arbitrary terms. | * We do not impose any variable conditions, so a rewrite rule is a pair of arbitrary terms. | ||
| − | * Identifiers must be valid SMT-LIB symbols (see [https://smt-lib.org/papers/smt-lib-reference-v2.6-r2021-05-12.pdf here, Sec. 3.2]), whereas CoCo uses a more liberal definition. Both simple and quoted symbols are allowed. As in SMT-LIB, simple symbols must not be equal to reserved words. In our case, the reserved words are: <pre>fun, rule, format, sort, theory, define-fun</pre> To ease parsing, we impose the following additional restrictions: | + | * Identifiers must be valid SMT-LIB symbols (see [https://smt-lib.org/papers/smt-lib-reference-v2.6-r2021-05-12.pdf here, Sec. 3.2]), whereas CoCo uses a more liberal definition. Both simple and quoted symbols are allowed. As in SMT-LIB, simple symbols must not be equal to reserved words. In our case, the reserved words are: <pre>fun, rule, format, sort, theory, define-fun, prule, ->, entrypoint, theory</pre> To ease parsing, we impose the following additional restrictions: | 
| ** Quoted identifiers must be non-empty. | ** Quoted identifiers must be non-empty. | ||
| ** Quoted identifiers must not contain whitespace, parantheses, or semicolons. | ** Quoted identifiers must not contain whitespace, parantheses, or semicolons. | ||
| ** All occurrences of the same identifier must be either quoted or unquoted. So <pre>(rule |a| |a|)</pre> is valid, but <pre>(rule a |a|)</pre> is invalid. | ** All occurrences of the same identifier must be either quoted or unquoted. So <pre>(rule |a| |a|)</pre> is valid, but <pre>(rule a |a|)</pre> is invalid. | ||
| + | ** Use sane identifiers. For example, <pre>a->a</pre> is a valid identifier, but it will cause confusion, so using it is a bad idea. | ||
| * Rules are annotated with optional costs, which are natural numbers. This allows, e.g., to model relative rewriting (by setting the cost of relative rules to 0). Categories may disallow costs. So rules are defined as follows: | * Rules are annotated with optional costs, which are natural numbers. This allows, e.g., to model relative rewriting (by setting the cost of relative rules to 0). Categories may disallow costs. So rules are defined as follows: | ||
| <pre> | <pre> | ||
| rule ::= ( rule term term cost? ) | rule ::= ( rule term term cost? ) | ||
| − | + | cost ::= :cost number | |
| </pre> | </pre> | ||
| Line 18: | Line 19: | ||
| == Termination == | == Termination == | ||
| − | All termination categories consider termination w.r.t. arbitrary start terms. | + | All termination categories except for "Integer Transition Systems" consider termination w.r.t. arbitrary start terms. | 
| === Relative Termination === | === Relative Termination === | ||
| Line 85: | Line 86: | ||
| * see [https://project-coco.uibk.ac.at/ARI/ctrs.php here] | * see [https://project-coco.uibk.ac.at/ARI/ctrs.php here] | ||
| * currently, we only support the condition-type ''oriented'' | * currently, we only support the condition-type ''oriented'' | ||
| + | |||
| + | ==== Integer Transition Systems ==== | ||
| + | |||
| + | Integer Transition Systems (ITSs) are [https://project-coco.uibk.ac.at/ARI/lctrs.php LCTRSs] with the following restrictions: | ||
| + | * The theory is always Ints. | ||
| + | * Rules must comply with the following grammar: | ||
| + | <pre> | ||
| + | rule ::= (rule lhs rhs (:guard term)? (:var (vars))?) | ||
| + | lhs  ::= (identifier identifier+) | ||
| + | rhs  ::= (identifier term+) | ||
| + | </pre> | ||
| + | Moreover, ITSs must declare one and only one entrypoint | ||
| + | <pre> | ||
| + | entrypoint ::= (entrypoint identifier) | ||
| + | </pre> | ||
| + | where the given identifier refers to a previously declared function symbol. | ||
| + | |||
| + | The goal is to prove termination w.r.t. all well-sorted startterms of the form | ||
| + | <pre> | ||
| + | (f c_1 ... c_k) | ||
| + | </pre> | ||
| + | where f is the entrypoint and c_1,...,c_k are constants from the theory Ints (i.e., integers or Booleans). | ||
| == Complexity == | == Complexity == | ||
| − | See [https://project-coco.uibk.ac.at/ARI/trs.php here] for all complexity categories. | + | See [https://project-coco.uibk.ac.at/ARI/trs.php here] for all complexity categories except for "Integer Transition Systems". | 
| === Runtime Complexity === | === Runtime Complexity === | ||
| Line 113: | Line 136: | ||
| * full rewriting | * full rewriting | ||
| + | |||
| + | === Complexity w.r.t. an entrypoint === | ||
| + | |||
| + | Here, we only consider basic start terms where the root symbol is the provided entrypoint. | ||
| + | |||
| + | ==== Integer Transition Systems ==== | ||
| + | |||
| + | * see the definition of ITSs for termination above | ||
Latest revision as of 08:19, 12 February 2025
General
We use an adaption of the ARI format, so TRSs are represented as S-Expressions (see here, Sec. 3.1). Our format differs from the format used at CoCo as follows:
- We do not impose any variable conditions, so a rewrite rule is a pair of arbitrary terms.
- Identifiers must be valid SMT-LIB symbols (see here, Sec. 3.2), whereas CoCo uses a more liberal definition. Both simple and quoted symbols are allowed. As in SMT-LIB, simple symbols must not be equal to reserved words. In our case, the reserved words are: fun, rule, format, sort, theory, define-fun, prule, ->, entrypoint, theory To ease parsing, we impose the following additional restrictions:- Quoted identifiers must be non-empty.
- Quoted identifiers must not contain whitespace, parantheses, or semicolons.
- All occurrences of the same identifier must be either quoted or unquoted. So (rule |a| |a|) is valid, but(rule a |a|) is invalid.
- Use sane identifiers. For example, a->a is a valid identifier, but it will cause confusion, so using it is a bad idea.
 
- Rules are annotated with optional costs, which are natural numbers. This allows, e.g., to model relative rewriting (by setting the cost of relative rules to 0). Categories may disallow costs. So rules are defined as follows:
rule ::= ( rule term term cost? ) cost ::= :cost number
In contrast to the former XTC format, the goal of the analysis is implicitly specified by the category.
Termination
All termination categories except for "Integer Transition Systems" consider termination w.r.t. arbitrary start terms.
Relative Termination
All categories for relative termination consider full rewriting. See here for the format of all categories for relative termination.
TRS Relative
- no further restrictions
SRS Relative
- just unary function symbols
Non-Relative Termination
All categories for non-relative termination disallow costs.
TRS Standard
- full rewriting
- see here
SRS Standard
- full rewriting
- just unary function symbols
- see here
TRS Contextsensitive
- context-sensitive rewriting
- see here
TRS Equational
Here, a theory may be added to declarations of function symbols.
fun ::= ( fun identifier number theory? ) theory ::= :theory [A | C | AC]
- full rewriting modulo associativity / commutativity / associativity and commutativity
TRS Innermost
- innermost rewriting
- see here
TRS Outermost
- outermost rewriting
- see here
TRS Conditional
- full conditional rewriting
- see here
- currently, we only support the condition-type oriented
TRS Conditional - Operational Termination
- TODO clarify the difference to TRS Conditional
- see here
- currently, we only support the condition-type oriented
Integer Transition Systems
Integer Transition Systems (ITSs) are LCTRSs with the following restrictions:
- The theory is always Ints.
- Rules must comply with the following grammar:
rule ::= (rule lhs rhs (:guard term)? (:var (vars))?) lhs ::= (identifier identifier+) rhs ::= (identifier term+)
Moreover, ITSs must declare one and only one entrypoint
entrypoint ::= (entrypoint identifier)
where the given identifier refers to a previously declared function symbol.
The goal is to prove termination w.r.t. all well-sorted startterms of the form
(f c_1 ... c_k)
where f is the entrypoint and c_1,...,c_k are constants from the theory Ints (i.e., integers or Booleans).
Complexity
See here for all complexity categories except for "Integer Transition Systems".
Runtime Complexity
All categories for runtime complexity consider basic start terms only.
Runtime Complexity Innermost
- innermost rewriting
Runtime Complexity Full
- full rewriting
Derivational Complexity
All categories for derivational complexity consider arbitrary start terms.
Derivational Complexity Innermost
- innermost rewriting
Derivational Complexity Full
- full rewriting
Complexity w.r.t. an entrypoint
Here, we only consider basic start terms where the root symbol is the provided entrypoint.
Integer Transition Systems
- see the definition of ITSs for termination above
