我在python中制作了一个快速简单的方程求解器,用于家庭分配,我需要为每个eps_komp计算sig_a的值,该值介于0到700之间。我用2个for循环完成了这个,第一个用于选择eps_komp值,第二个用于搜索0到700之间最接近的sig_a值,以使方程尽可能接近零。我用" delta"定义了允许的错误。 像二分法一样,它有类似的逻辑。这是代码:
eps_komp = [0.00012893048999999997,
0.018839115269999998,
0.01230539995,
0.022996934109999999,
-0.0037319012899999999,
0.023293921169999999,
0.0036927752099999997,
0.020621037629999998,
0.0063656587500000002,
0.020324050569999998]
Rm=700
sigma = np.linspace(0, Rm-0.01, Rm/0.01)
delta = 0.001
sig_a = []
for j in range(len(eps_komp)):
eps_j = eps_komp[j]
for i in range(len(sig)):
eps_j - sigma[i]/Emod - (sigma[i]/RO_K)**(1/RO_n) = diff
if diff <= delta:
sig_a.append(sigma[i])
eps_komp的值只是前10个,其中有更多但是我只给出了前10个例子。
现在我一直收到这个错误:
SyntaxError:无法分配给运营商
我知道它与错误的索引有关,但我无法看到问题......
如果有人可以提供帮助,对我来说意义重大。感谢。
卢卡
答案 0 :(得分:0)
将diff分配给它需要位于等号左侧的计算:
diff = eps_j - sigma[i]/Emod - (sigma[i]/RO_K)**(1/RO_n)