我正在尝试使用Z3来解决使用Z3 C#API的字符串约束。
到目前为止,我已经研究过示例,但Z3似乎只支持基于数字的代数表达式,例如:
x > 0
y = x + 1
y < 3
可以使用z3 c#API表示为:
using (Context ctx = new Context())
{
Expr x = ctx.MkConst("x", ctx.MkIntSort());
Expr y = ctx.MkConst("y", ctx.MkIntSort());
Expr zero = ctx.MkNumeral(0, ctx.MkIntSort());
Expr one = ctx.MkNumeral(1, ctx.MkIntSort());
Expr three = ctx.MkNumeral(3, ctx.MkIntSort());
Solver s = ctx.MkSolver();
s.Assert(ctx.MkAnd(ctx.MkGt((ArithExpr)x, (ArithExpr)zero), ctx.MkEq((ArithExpr)y,
ctx.MkAdd((ArithExpr)x, (ArithExpr)one)), ctx.MkLt((ArithExpr)y, (ArithExpr)three)));
Console.WriteLine(s.Check());
Model m = s.Model;
foreach (FuncDecl d in m.Decls)
Console.WriteLine(d.Name + " -> " + m.ConstInterp(d));
Console.ReadLine();
}
有没有办法评估基于字符串的表达式,例如:
string S1;
string S2:
string S3;
S3=S1+S2;
任何有关基于字符串的约束的帮助都将受到赞赏。
答案 0 :(得分:1)
Z3本身不支持字符串作为原始数据类型。 你可以试试z3-str(https://github.com/z3str/Z3-str)。
新加坡国立大学还有S3系统,如ccs 2014所述。
答案 1 :(得分:0)
请注意,Z3 现在支持 String 类型,但有一些限制。此处参考:Z3 solver for string based constraints