python 优化求解器_python – 加速SymPy方程求解器

你只需要解决一次方程式.之后,您将获得表单的等式:

> a = f_1(kp1,kp2)

> b = f_2(kp1,kp2)

> ……

所以你可以简单地计算a,…,e依赖于kp1和kp2.例如,求解第一,第三和第四方程给出:

> b:-a 2.6

> e:2.0 * kp2 *(5.0 * a – 13.0)/(5.0 * a * kp2 – 5.0 * a – 13.0 * kp2),

> d:10.0 * a /( – 5.0 * a * kp2 5.0 * a 13.0 * kp2)

在我的电脑上解决所有五个方程式太慢了,但如果它给你一个表达式,你只需要插入(替换)kp1和kp2的值,你就不必再次求解方程式了.如需替换,请查看sympy documentation.

所以你的循环应该是这样的:

solutions = sympy.solve(eqs, exclude=[kp1, kp2])

for data_kp1, data_kp2 in data:

for key, eq in solutions:

solution = eq.subs([(kp1, data_kp1), (kp2, data_kp2)])

final_solutions.append("{key}={solution}".format(key=key, solution=solution))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值