"ValueError: Precision not allowed in integer format specifier" in f-string pops up even when using only floats
"ValueError: Precision not allowed in integer format specifier" in f-string pops up even when using only floats
我正在训练神经网络,但这不相关。唯一相关的信息是这一行:
print(f"{it*100/iters}%, Pos: ({Xcg:.4},{Ycg:.4}), Ideal position: ({Xcg:.4},{Xcg**2-Xcg:.4}), Rew: {c_reward:.3}, Ang: {ang:.3}, ε: {self.eps:.3}")
其中 Xcg、Ycg 和 ang 是浮点数(0. 或类似 0.5-0.5 的值,这也是一个浮点数);
c_reward 是用这个表达式计算的:
r = math.exp(-abs(posy-posx**2+posx))*math.sqrt(posx**2+posy**2)*abs(posx)/posx if posx!= 0 else 0
和self.eps是使用这个表达式计算的:
self.eps = 0.8 + 0.8 * math.exp(-0.001 * self.steps)
步长从 0 到 4000。因此,eps 也是一个浮点数。
其中 None 可能是浮点数。这里发生了什么?它也不会发生在 self.steps 的特定值,现在它看起来是随机的。
我至少可以看到一个 int
,但没有看到所有细节,你的 else
是 0
,这是一个 int
。需要为浮点数做 0.0
。
r = math.exp(-abs(posy-posx**2+posx))*math.sqrt(posx**2+posy**2)*abs(posx)/posx if posx!= 0 else 0.0
我正在训练神经网络,但这不相关。唯一相关的信息是这一行:
print(f"{it*100/iters}%, Pos: ({Xcg:.4},{Ycg:.4}), Ideal position: ({Xcg:.4},{Xcg**2-Xcg:.4}), Rew: {c_reward:.3}, Ang: {ang:.3}, ε: {self.eps:.3}")
其中 Xcg、Ycg 和 ang 是浮点数(0. 或类似 0.5-0.5 的值,这也是一个浮点数);
c_reward 是用这个表达式计算的:
r = math.exp(-abs(posy-posx**2+posx))*math.sqrt(posx**2+posy**2)*abs(posx)/posx if posx!= 0 else 0
和self.eps是使用这个表达式计算的:
self.eps = 0.8 + 0.8 * math.exp(-0.001 * self.steps)
步长从 0 到 4000。因此,eps 也是一个浮点数。
其中None 可能是浮点数。这里发生了什么?它也不会发生在 self.steps 的特定值,现在它看起来是随机的。
我至少可以看到一个 int
,但没有看到所有细节,你的 else
是 0
,这是一个 int
。需要为浮点数做 0.0
。
r = math.exp(-abs(posy-posx**2+posx))*math.sqrt(posx**2+posy**2)*abs(posx)/posx if posx!= 0 else 0.0