# w=1800
# a+b=w
# a>b
# a:w=b:a约等于0.618
# 求a的值
#导入sbmpb
from sympy import *
#定义变量
a = Symbol('a')
b = Symbol('b')
print(solve([a+b-1800,a/1800-0.618,b/a-0.618],[a,b]))
由于浮点数计算的精度问题会导致方程无解
二元一次方程式的求解只需要两条方程,例如a:w(1800)=0.618,b:a=0.618可以确定a与b的值
我们将其代入代码进行计算
>>> from sympy import *
>>> a = Symbol('a')
>>> b = Symbol('b')
>>> print(solve([a/1800-618/1000,b/a-618/1000],[a,b]))
{a: 1112.40000000000, b: 687.463200000000}
此时已经得出唯一解a=1112.4,b=687.4632,并且a+b=1799.863,与a+b=1800有一定的误差;故将此唯一解代回a+b=1800方程时会否定该解,造成无解的现象。
所以说只需要删除三条方程中的任意一条即可。
??你不是解了吗
因题目要求中b/a约等于0.618.
from sympy import *
a = Symbol('a')
b = Symbol('b')
sol = solve([a/1800-0.618, a+b-1800], [a, b])
print(sol)
#{a: 1112.40000000000, b: 687.600000000000}
#验证
x,y=sol[a],sol[b]
print(y/x)
#0.618122977346278,符合条件要求。
哈哈