如何在Python上求解三角方程

问题描述 投票:0回答:3

我正在尝试用 python 求解 3 个三角方程。我使用了 Sympy 库,但收到了诸如“TypeError: can't conversion expression to float”之类的错误

这是我的Python源代码:

from sympy import Symbol, solve, Eq
from math import*

# Robot Arm length
L1 = 0
L2 = 97.9
L3 = 120
L4 = 120
L5 = 184

# location
x = L1+L2+L3+L4+L5
y = 0
z = 0

x1 = Symbol('x1',real = True)
x2 = Symbol('x2',real = True)
x3 = Symbol('x3',real = True)

#trigonometric equations

e1= Eq(L1 - (5*sin(x1))/2 - L4*(cos(x1)*sin(x2)*sin(x3) - cos(x1)*cos(x2)*cos(x3)) - L5*(cos(x4)*(cos(x1)*sin(x2)*sin(x3) - cos(x1)*cos(x2)*cos(x3)) + sin(x4)*(cos(x1)*cos(x2)*sin(x3) + cos(x1)*cos(x3)*sin(x2))) + L2*cos(x1) + L3*cos(x1)*cos(x2) - x)
e2= Eq((5*cos(x1))/2 + L4*(cos(x2)*cos(x3)*sin(x1) - sin(x1)*sin(x2)*sin(x3)) + L5*(cos(x4)*(cos(x2)*cos(x3)*sin(x1) - sin(x1)*sin(x2)*sin(x3)) - sin(x4)*(cos(x2)*sin(x1)*sin(x3) + cos(x3)*sin(x1)*sin(x2))) + L2*sin(x1) + L3*cos(x2)*sin(x1) - y)
e3= Eq(-L4*(cos(x2)*sin(x3) + cos(x3)*sin(x2)) - L3*sin(x2) - L5*(cos(x4)*(cos(x2)*sin(x3) + cos(x3)*sin(x2)) + sin(x4)*(cos(x2)*cos(x3) - sin(x2)*sin(x3))) - z)

solve([e,e2,e3],x1,x2,x3)

x1 = degrees(x1)
x2 = degrees(x2)
x3 = degrees(x3)

print("degree values : ",x1,x2,x3)

我添加了我的错误消息:

enter image description here

谁能告诉我我应该更改代码中的哪一部分?

python math sympy equation-solving
3个回答
6
投票

from math import *
是这里的主要错误。函数
math.sin
math.cos
仅用于数值计算,不能给它们提供符号参数。任何数学函数都必须从 SymPy 导入才能在符号计算中使用它们。

指南:使用 SymPy 时,不要从

math
导入任何内容。将导入更改为

from sympy import *

将解决大部分问题。您仍然需要定义当前未定义的

x4


0
投票

如果没有看到完整的代码,我无法告诉你,但看起来 e3 行上的变量“x4”尚未在任何地方声明。


0
投票

在下面的行中,我认为拼写错误e应该重写e1

求解([e,e2,e3],x1,x2,x3)

© www.soinside.com 2019 - 2024. All rights reserved.