这样求解三角函数方程哪里出错了

img


为什么我这么写会运行不出结果来,是因为我写错了么?那如果我错了那应该怎么写

打个断点调试

【以下回答由 GPT 生成】

问题中的代码存在几处错误和潜在问题: 1. sin(-pi - jis + j6 - j4) 应该是 sin(-pi - j1s + j6 - j4),因为变量名写错了,应该是j1s而不是jis。 2. eplin1eplin2 应该是 ep_linlep_1in2,因为变量名写错了。 3. solutions = sp.solve((eplin1, eplin2), (r, j6)) 应该是 solutions = sp.solve((ep_linl, ep_1in2), (r, j6)),因为变量名写错了。 4. j6_sol.evalf() 应该是 j6_sol, 因为j6_sol已经是float类型了,不需要再使用evalf()函数。

为了修复这些问题,你可以按照以下步骤修改代码:

import sympy as sp
from sympy import pi, sin

j4, j5, j6, r = sp.symbols("j4 j5 j6 r")

jiao1 = input("输入角1: ")
jiao2 = input("输入角2: ")
jiao3 = input("输入角3: ")
biaozhunjuli = input("请输入半径R: ")

jl = int(jiao1)
j2 = int(jiao2)
j3 = int(jiao3)
R = int(biaozhunjuli)

j1s = pi * jl / 180
j2s = pi * j2 / 180
j3s = pi * j3 / 180

ep_linl = sp.Eq(R / sin(j1s), r / sin(-pi - j1s + j6 - j4))  # 修正变量名
ep_1in2 = sp.Eq(R / sin(j3s), r / sin(-pi - j3s + j6 - j5))  # 修正变量名

solutions = sp.solve((ep_linl, ep_1in2), (r, j6))  # 修正变量名

for r_sol, j6_sol in solutions:
    print("r =", r_sol.evalf())
    print("j6 =", j6_sol)  # 不需要再使用evalf()

以上就是修正后的代码。请尝试运行并检查输出是否符合预期。如果您还有其他问题,请随时提问。



【相关推荐】



如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^