gpt4 book ai didi

python - 对表达式执行简化时出现关键错误

转载 作者:行者123 更新时间:2023-12-01 04:21:48 26 4
gpt4 key购买 nike

当我尝试使用 sympy.simplify 对以下表达式执行简化时:

0.0625*v**2*cos(0.5*u)**2 + (-0.25*v*sin(0.5*u)*sin(u) + (0.5*v*cos(0.5*u) + 1)*cos(u))**2 + (-0.25*v*sin(0.5*u)*cos(u) - (0.5*v*cos(0.5*u) + 1)*sin(u))**2

我收到错误:

    /usr/local/lib/python2.7/dist-packages/sympy-0.7.7.dev0-py2.7.egg/sympy/simplify/fu.pyc in f(rv)
1323 key = cos(a*cc, evaluate=False)
1324 ccs.append(cc)
-> 1325 take = min(coss[key], take or coss[key])
1326 # update exponent counts
1327 for i in range(k):

KeyError: cos(1.0*u)

这里似乎有什么问题?这个表达本身看起来很简单。

编辑1:

为了清楚起见,这就是罪魁祸首:

simplify(expr)

其中 expr 是上面的表达式。

编辑2:

这是生成错误的代码:

from sympy import cos,sin, simplify
from sympy.abc import u,v
expr = 0.0625*v**2*cos(0.5*u)**2 + (-0.25*v*sin(0.5*u)*sin(u) + (0.5*v*cos(0.5*u) + 1)*cos(u))**2 + (-0.25*v*sin(0.5*u)*cos(u) - (0.5*v*cos(0.5*u) + 1)*sin(u))**2
simplify(expr)

最佳答案

用 cos(1.0*u) 替换 cos(u) 可以,但不要问我为什么......

expr = 0.0625*v**2*cos(0.5*u)**2 + (-0.25*v*sin(0.5*u)*sin(u) + (0.5*v*cos(0.5*u) + 1)*cos(1.0*u))**2 + (-0.25*v*sin(0.5*u)*cos(1.0*u) - (0.5*v*cos(0.5*u) + 1)*sin(u))**2

但是简化会返回相同的结果。我认为 sympy 不能将符号计算与 float 混合在一起。

expr = v**2*cos(u/2)**2/16 + (-v*sin(u/2)*sin(u)/4 + (v*cos(u/2)/2 + 1)*cos(u))**2 + (-v*sin(u/2)*cos(u)/4 - (v*cos(u/2)/2 + 1)*sin(u))**2

似乎有效,并返回:

v**2*cos(u/2)**2/4 + v**2/16 + v*cos(u/2) + 1

如果您想转换现有表达式:

import sympy
from sympy import cos,sin, simplify
from sympy.abc import u,v
import re
expr = 0.0625*v**2*cos(0.5*u)**2 + (-0.25*v*sin(0.5*u)*sin(u) + (0.5*v*cos(0.5*u) + 1)*cos(u))**2 + (-0.25*v*sin(0.5*u)*cos(u) - (0.5*v*cos(0.5*u) + 1)*sin(u))**2

def ratio_from_float(m):
a,b = float(m.group(0)).as_integer_ratio()
return '({0}/{1})'.format(a,b)

def convert(expr):
return sympy.expr.sympify(re.sub('\d+\.\d+',ratio_from_float,str(expr)))

print(simplify(convert(expr)))

关于python - 对表达式执行简化时出现关键错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33595476/

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