Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

String theory support #165

Draft
wants to merge 65 commits into
base: main
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 17 commits
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
183449f
Add string sort to core
raf-nr Dec 3, 2024
25db759
Add regex sort to core
raf-nr Dec 3, 2024
3b52e78
Add string and regex sorts to context
raf-nr Dec 3, 2024
6815d4d
Implement string literal's expr and decl
raf-nr Dec 3, 2024
e98b386
Implement regex literal's expr and decl
raf-nr Dec 3, 2024
c52235a
Implement strings concatenation
raf-nr Dec 3, 2024
2bdb945
Implement strings length expr and decl
raf-nr Dec 3, 2024
779b5c2
Implement expr and decl for translation string to a regex
raf-nr Dec 3, 2024
4b8d5ad
Implement regular expressions concatenation
raf-nr Dec 3, 2024
0099dc3
Implement regular expressions union
raf-nr Dec 3, 2024
ce1a550
Implement regular expressions intersection
raf-nr Dec 3, 2024
743b758
Implement regular expressions difference and Kleene closure
raf-nr Dec 3, 2024
3a1c7c1
Implement regular expressions Kleene cross
raf-nr Dec 3, 2024
5a139cd
Implement prefixOf and suffixOf strings' operations
raf-nr Dec 3, 2024
fd259a5
Implement operation to check whether a string belongs to a regex
raf-nr Dec 4, 2024
2a500d7
Implement operations for comparing strings
raf-nr Dec 4, 2024
d771e78
Implement regular expression complement operation
raf-nr Dec 4, 2024
c8cb6bf
Fix imports
raf-nr Dec 4, 2024
844db59
Add regular expression constants
raf-nr Dec 4, 2024
4182e5a
Implement operation to make regex optional
raf-nr Dec 4, 2024
79b6f20
Implement strings' contains operation
raf-nr Dec 4, 2024
0837aa9
Describe operations on strings and regex that have not yet been imple…
raf-nr Dec 8, 2024
45bd801
Syntactic sugar for comparing string expressions
raf-nr Dec 8, 2024
f9da6a6
Syntactic sugar for strings and regex concatenation
raf-nr Dec 8, 2024
ee0ff54
Syntactic sugar for strings literals and length expr
raf-nr Dec 8, 2024
eb068cc
Syntactic sugar for suffixOf, prefixOf, contains operations
raf-nr Dec 8, 2024
1b38d12
Syntactic sugar for inRegex, toRegex operations
raf-nr Dec 8, 2024
f42d7eb
Implement replace operations for strings
raf-nr Dec 8, 2024
01a57ef
Implement regex range operation
raf-nr Dec 8, 2024
1d22225
Implement operations, that maps strings to and from integers
raf-nr Dec 8, 2024
4363af9
Implement strings' replace operations based on regex
raf-nr Dec 8, 2024
7cfad2e
Implement remaining operations on strings and transformers for strings
raf-nr Dec 9, 2024
98f82c9
Describe and implement transformers interfaces for regex
raf-nr Dec 9, 2024
8e0fafb
Add string and regex declarations in visitor
raf-nr Dec 9, 2024
889642f
Add exceptions that Bitwuzla does not support string theory
raf-nr Dec 9, 2024
c8958dc
Add string theory to KTheory class
raf-nr Dec 9, 2024
c5b9f7e
Fix str name in KTheory class
raf-nr Dec 9, 2024
2e2286d
Implement string and regex sorts cvc5 internalizer
raf-nr Dec 9, 2024
eac27d5
Add string and regex expressions internalizer for cvc5
raf-nr Dec 10, 2024
3dc16f8
Add cvc5 internalizer for substrings and indexOf expressions
raf-nr Dec 10, 2024
62b1a6a
Implement converter from cvc5 to ksmt
raf-nr Dec 10, 2024
811d531
Implement string/regex methods for cvc5 uninterpreted sort collector
raf-nr Dec 10, 2024
97bead4
Add exceptions that Yices does not support string theory
raf-nr Dec 10, 2024
b3ecd8a
Fix typo in exceptions' messages
raf-nr Dec 10, 2024
81ac05f
Fix yices solver configuration after adding string theory
raf-nr Dec 11, 2024
ca8bff6
Delete regex literal expression
raf-nr Dec 11, 2024
b54264f
Fix string theory name in KTheory class
raf-nr Dec 11, 2024
6daeecc
Change the names of classes and methods, do the code formatting
raf-nr Dec 12, 2024
ce19526
Update sort visitor implementation for theory requirement
raf-nr Dec 12, 2024
c9e2e19
Add string and regex sorts to z3 sort internalizer
raf-nr Dec 12, 2024
07bdf4b
Implement z3 internalizer some methods for strings
raf-nr Dec 12, 2024
18d690d
Add string literals printer with quotes
raf-nr Dec 12, 2024
3e7f8bd
Implement toLower, toUpper and reverse string operations
raf-nr Dec 12, 2024
a124b8b
Add string and regex default values
raf-nr Dec 14, 2024
ceb95a2
Fix bug with regex constants in cvc5
raf-nr Dec 14, 2024
9c2e89b
Add string and regex sorts serializer and deserializer
raf-nr Dec 17, 2024
1e31092
Add string and regex expressions serializer/deserializer
raf-nr Dec 17, 2024
17d40f5
Partially implement z3 string internalizer/converter
raf-nr Dec 17, 2024
8f0921e
Fully implement z3 converter
raf-nr Dec 18, 2024
d16f8d9
Implement regex power and loop operations
raf-nr Dec 18, 2024
57db57a
Fix regex power and loop expr deserializer
raf-nr Dec 18, 2024
4f3c819
Add stubs in symfpu visitors
raf-nr Dec 18, 2024
0c22147
Fix typo in z3 converter
raf-nr Dec 19, 2024
dbb8531
Describe functions for further simplification of expressions
raf-nr Dec 19, 2024
a865074
Fix cvc5 sort converter
raf-nr Dec 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
408 changes: 408 additions & 0 deletions ksmt-core/src/main/kotlin/io/ksmt/KContext.kt

Large diffs are not rendered by default.

103 changes: 103 additions & 0 deletions ksmt-core/src/main/kotlin/io/ksmt/decl/Regex.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,103 @@
package io.ksmt.decl

import io.ksmt.KContext
import io.ksmt.expr.KApp
import io.ksmt.expr.KExpr
import io.ksmt.sort.KRegexSort

class KRegexLiteralDecl internal constructor(
ctx: KContext,
val value: String
) : KConstDecl<KRegexSort>(ctx, value, ctx.mkRegexSort()) {
override fun apply(args: List<KExpr<*>>): KApp<KRegexSort, *> = ctx.mkRegexLiteral(value)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}

class KRegexConcatDecl internal constructor(
ctx: KContext,
) : KFuncDecl2<KRegexSort, KRegexSort, KRegexSort>(
ctx,
name = "concat",
resultSort = ctx.mkRegexSort(),
ctx.mkRegexSort(),
ctx.mkRegexSort()
) {
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)

override fun KContext.apply(
arg0: KExpr<KRegexSort>,
arg1: KExpr<KRegexSort>
): KApp<KRegexSort, *> = mkRegexConcatNoSimplify(arg0, arg1)
}

class KRegexUnionDecl internal constructor(
ctx: KContext,
) : KFuncDecl2<KRegexSort, KRegexSort, KRegexSort>(
ctx,
name = "union",
resultSort = ctx.mkRegexSort(),
ctx.mkRegexSort(),
ctx.mkRegexSort()
) {
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)

override fun KContext.apply(
arg0: KExpr<KRegexSort>,
arg1: KExpr<KRegexSort>
): KApp<KRegexSort, *> = mkRegexUnionNoSimplify(arg0, arg1)
}

class KRegexIntersectionDecl internal constructor(
ctx: KContext,
) : KFuncDecl2<KRegexSort, KRegexSort, KRegexSort>(
ctx,
name = "intersect",
resultSort = ctx.mkRegexSort(),
ctx.mkRegexSort(),
ctx.mkRegexSort()
) {
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)

override fun KContext.apply(
arg0: KExpr<KRegexSort>,
arg1: KExpr<KRegexSort>
): KApp<KRegexSort, *> = mkRegexIntersectionNoSimplify(arg0, arg1)
}

class KRegexKleeneClosureDecl internal constructor(
ctx: KContext
) : KFuncDecl1<KRegexSort, KRegexSort>(ctx, "closure", ctx.mkRegexSort(), ctx.mkRegexSort()) {
override fun KContext.apply(arg: KExpr<KRegexSort>): KApp<KRegexSort, KRegexSort> = mkRegexKleeneClosureNoSimplify(arg)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}

class KRegexKleeneCrossDecl internal constructor(
ctx: KContext
) : KFuncDecl1<KRegexSort, KRegexSort>(ctx, "kleene_cross", ctx.mkRegexSort(), ctx.mkRegexSort()) {
override fun KContext.apply(arg: KExpr<KRegexSort>): KApp<KRegexSort, KRegexSort> = mkRegexKleeneCrossNoSimplify(arg)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}

class KRegexDifferenceDecl internal constructor(
ctx: KContext,
) : KFuncDecl2<KRegexSort, KRegexSort, KRegexSort>(
ctx,
name = "diff",
resultSort = ctx.mkRegexSort(),
ctx.mkRegexSort(),
ctx.mkRegexSort()
) {
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)

override fun KContext.apply(
arg0: KExpr<KRegexSort>,
arg1: KExpr<KRegexSort>
): KApp<KRegexSort, *> = mkRegexDifferenceNoSimplify(arg0, arg1)
}

class KRegexComplementDecl internal constructor(
ctx: KContext
) : KFuncDecl1<KRegexSort, KRegexSort>(ctx, "comp", ctx.mkRegexSort(), ctx.mkRegexSort()) {
override fun KContext.apply(arg: KExpr<KRegexSort>): KApp<KRegexSort, KRegexSort> = mkRegexComplementNoSimplify(arg)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}
123 changes: 123 additions & 0 deletions ksmt-core/src/main/kotlin/io/ksmt/decl/String.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@
package io.ksmt.decl

import io.ksmt.KContext
import io.ksmt.expr.KApp
import io.ksmt.expr.KExpr
import io.ksmt.sort.KBoolSort
import io.ksmt.sort.KIntSort
import io.ksmt.sort.KRegexSort
import io.ksmt.sort.KStringSort

class KStringLiteralDecl internal constructor(
ctx: KContext,
val value: String
) : KConstDecl<KStringSort>(ctx, value, ctx.mkStringSort()) {
override fun apply(args: List<KExpr<*>>): KApp<KStringSort, *> = ctx.mkStringLiteral(value)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}

class KStringConcatDecl internal constructor(
ctx: KContext,
) : KFuncDecl2<KStringSort, KStringSort, KStringSort>(
ctx,
name = "concat",
resultSort = ctx.mkStringSort(),
ctx.mkStringSort(),
ctx.mkStringSort()
) {
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)

override fun KContext.apply(
arg0: KExpr<KStringSort>,
arg1: KExpr<KStringSort>
): KApp<KStringSort, *> = mkStringConcatExprNoSimplify(arg0, arg1)
}

class KStringLenDecl internal constructor(
ctx: KContext
) : KFuncDecl1<KIntSort, KStringSort>(ctx, "len", ctx.mkIntSort(), ctx.mkStringSort()) {
override fun KContext.apply(arg: KExpr<KStringSort>): KApp<KIntSort, KStringSort> = mkStringLenNoSimplify(arg)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}

class KStringToRegexDecl internal constructor(
ctx: KContext
) : KFuncDecl1<KRegexSort, KStringSort>(ctx, "to_regex", ctx.mkRegexSort(), ctx.mkStringSort()) {
override fun KContext.apply(arg: KExpr<KStringSort>): KApp<KRegexSort, KStringSort> = mkStringToRegexNoSimplify(arg)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}

class KStringInRegexDecl internal constructor(
ctx: KContext,
) : KFuncDecl2<KBoolSort, KStringSort, KRegexSort>(
ctx,
name = "in_regex",
resultSort = ctx.mkBoolSort(),
ctx.mkStringSort(),
ctx.mkRegexSort()
) {
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)

override fun KContext.apply(
arg0: KExpr<KStringSort>,
arg1: KExpr<KRegexSort>
): KApp<KBoolSort, *> = mkStringInRegexNoSimplify(arg0, arg1)
}

class KSuffixOfDecl internal constructor(
ctx: KContext,
) : KFuncDecl2<KBoolSort, KStringSort, KStringSort>(
ctx,
name = "suffix_of",
resultSort = ctx.mkBoolSort(),
ctx.mkStringSort(),
ctx.mkStringSort()
) {
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)

override fun KContext.apply(
arg0: KExpr<KStringSort>,
arg1: KExpr<KStringSort>
): KApp<KBoolSort, *> = mkSuffixOfNoSimplify(arg0, arg1)
}

class KPrefixOfDecl internal constructor(
ctx: KContext,
) : KFuncDecl2<KBoolSort, KStringSort, KStringSort>(
ctx,
name = "prefix_of",
resultSort = ctx.mkBoolSort(),
ctx.mkStringSort(),
ctx.mkStringSort()
) {
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)

override fun KContext.apply(
arg0: KExpr<KStringSort>,
arg1: KExpr<KStringSort>
): KApp<KBoolSort, *> = mkPrefixOfNoSimplify(arg0, arg1)
}

class KStringLtDecl internal constructor(ctx: KContext) :
KFuncDecl2<KBoolSort, KStringSort, KStringSort>(ctx, "stringLt", ctx.mkBoolSort(), ctx.mkStringSort(), ctx.mkStringSort()) {
override fun KContext.apply(arg0: KExpr<KStringSort>, arg1: KExpr<KStringSort>): KApp<KBoolSort, *> = mkStringLtNoSimplify(arg0, arg1)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}

class KStringLeDecl internal constructor(ctx: KContext) :
KFuncDecl2<KBoolSort, KStringSort, KStringSort>(ctx, "stringLe", ctx.mkBoolSort(), ctx.mkStringSort(), ctx.mkStringSort()) {
override fun KContext.apply(arg0: KExpr<KStringSort>, arg1: KExpr<KStringSort>): KApp<KBoolSort, *> = mkStringLeNoSimplify(arg0, arg1)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}

class KStringGtDecl internal constructor(ctx: KContext) :
KFuncDecl2<KBoolSort, KStringSort, KStringSort>(ctx, "stringGt", ctx.mkBoolSort(), ctx.mkStringSort(), ctx.mkStringSort()) {
override fun KContext.apply(arg0: KExpr<KStringSort>, arg1: KExpr<KStringSort>): KApp<KBoolSort, *> = mkStringGtNoSimplify(arg0, arg1)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}

class KStringGeDecl internal constructor(ctx: KContext) :
KFuncDecl2<KBoolSort, KStringSort, KStringSort>(ctx, "stringGe", ctx.mkBoolSort(), ctx.mkStringSort(), ctx.mkStringSort()) {
override fun KContext.apply(arg0: KExpr<KStringSort>, arg1: KExpr<KStringSort>): KApp<KBoolSort, *> = mkStringGeNoSimplify(arg0, arg1)
override fun <R> accept(visitor: KDeclVisitor<R>): R = visitor.visit(this)
}
Loading