gpt4 book ai didi

python - 难道 `sympy` 比 Mathematica 慢得多吗?

转载 作者:太空狗 更新时间:2023-10-30 01:06:57 29 4
gpt4 key购买 nike

我正在使用 Sympy 重现 Mathematica 结果,而我是后者的新手,所以我可能做错了。然而,我注意到一些使用 Mathematica 最多只需要一分钟的东西在 sympy 中会花费很长时间(阅读:我在一小时前开始后没有完成)。这适用于 Simplify()solve()。是我做错了什么,还是真的是这样?

我将附上我的solve() 案例:

import sympy as sp
from sympy import init_printing
init_printing()

p, r, c, p, y, Lambda = sp.symbols('p r c p y Lambda')

F = sp.Symbol('F')
eta1 = lambda p: 1/(1-sp.exp(-Lambda) * sp.exp(-Lambda)*(sp.exp(Lambda) - 1 - Lambda))
eta2 = lambda p: 1/(1-sp.exp(-Lambda)) * sp.exp(-Lambda)/(1-F) * (sp.exp(Lambda*(1- F)) - 1 - Lambda*(1-F))

eta = lambda p: 1 - eta1(p) + eta2(p)
etaOfR = sp.limit(eta(p), F, 1)

S = lambda p: eta(p)*y/p*(p-c)
SOfR = etaOfR*y/r*(r-c)
sp.solve(S(p)-SOfR, F)

对应的Mathematica代码:

ClearAll[r, p, lambda, a, A, c, eta, f, y, constant1, constant2, eta, \
etaOfR]
constant1[lambda_] := Exp[-lambda]/(1 - Exp[-lambda]);
constant2[lambda_] := constant1[lambda]*(Exp[lambda] - 1 - lambda);
eta[lambda_, f_] :=
1 - constant2[lambda] +
constant1[lambda]*(Exp[lambda*(1 - f)] - 1 - lambda*(1 - f)) ;
etaOfR[lambda_] := Limit[eta[lambda, f], f -> 1];
expression1[lambda_, f_] :=
y/p (p - c) eta[lambda, f] == y/r (r - c) etaOfR[lambda];

Solve[expression1[lambda, f], f] // FullSimplify

输出:

{{f -> (-(1 + lambda) p r + 
c (lambda p + r) + (c -
p) r ProductLog[-E^(((-c lambda p + (c (-1 + lambda) +
p) r)/((c - p) r)))])/(lambda (c - p) r)}}

最佳答案

正确的做法是:

from sympy import *
init_printing()
p, r, c, p, y, lam, f = symbols('p r c p y lambda f')
constant1 = exp(-lam) / (1 - exp(-lam))
constant2 = constant1 * (exp(lam) - 1 - lam)
eta = 1 - constant2 + constant1 * (exp(lam * (1-f)) - 1 - lam * (1 - f))
etaOfR = limit(eta, f, 1)
expression1 = Eq(y / p * (p - c) * eta,
y / r * (r - c) * etaOfR)
solve(expression1, f)

您还可以在此处查看笔记本: http://nbviewer.ipython.org/gist/jankoslavic/0ad7d5c2731d425dabb3

结果与 Mathematica 的结果相同(见最后一行)并且 Sympy 的性能相当。

关于python - 难道 `sympy` 比 Mathematica 慢得多吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34242675/

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