gpt4 book ai didi

z3 在这个方程组中失败

转载 作者:行者123 更新时间:2023-12-02 04:57:32 24 4
gpt4 key购买 nike

多年来我一直跟踪解决技术 - and I maintain a blog post关于将它们应用到一个特定的谜题——“穿越梯子”。

言归正传,无意中发现了z3,并尝试将其用于具体问题。我使用了 Python 绑定(bind),并这样写:

$ cat  laddersZ3.py
#!/usr/bin/env python
from z3 import *
a = Int('a')
b = Int('b')
c = Int('c')
d = Int('d')
e = Int('e')
f = Int('f')
solve(
a>0, a<200,
b>0, b<200,
c>0, c<200,
d>0, d<200,
e>0, e<200,
f>0, f<200,
(e+f)**2 + d**2 == 119**2,
(e+f)**2 + c**2 == 70**2,
e**2 + 30**2 == a**2,
f**2 + 30**2 == b**2,
a*d == 119*30,
b*c == 70*30,
a*f - 119*e + a*e == 0,
b*e - 70*f + b*f == 0,
d*e == c*f)

不幸的是,z3 报告...

$ python  laddersZ3.py
failed to solve

这个问题至少有这个整数解:a=34, b=50, c=42, d=105, e=16, f=40。

我做错了什么,还是这种方程组/范围限制超出了 z3 可以解决的范围?

在此先感谢您的帮助。

更新,5 年后:Z3 现在开箱即用地解决了这个问题。

最佳答案

如果将整数编码为实数,则可以使用 Z3 解决此问题,这将强制 Z3 使用非线性实数算术求解器。有关非线性整数与实数算术求解器的更多详细信息,请参见:How does Z3 handle non-linear integer arithmetic?

这是使用解决方案编码为实数的示例(z3py 链接:http://rise4fun.com/Z3Py/1lxH):

a,b,c,d,e,f = Reals('a b c d e f')
solve(
a>0, a<200,
b>0, b<200,
c>0, c<200,
d>0, d<200,
e>0, e<200,
f>0, f<200,
(e+f)**2 + d**2 == 119**2,
(e+f)**2 + c**2 == 70**2,
e**2 + 30**2 == a**2,
f**2 + 30**2 == b**2,
a*d == 119*30,
b*c == 70*30,
a*f - 119*e + a*e == 0,
b*e - 70*f + b*f == 0,
d*e == c*f) # yields [a = 34, b = 50, c = 42, d = 105, e = 16, f = 40]

虽然结果如您所述是整数,并且正如 Z3 发现的那样,但 Z3 显然需要使用真正的算术求解器来处理它。

或者,您可以保留声明为整数的变量,并根据引用帖子中的建议执行以下操作:

t = Then('purify-arith','nlsat')
s = t.solver()
solve_using(s, P)

其中 P 是约束的合取(z3py 链接:http://rise4fun.com/Z3Py/7nqN)。

关于z3 在这个方程组中失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17726916/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com