"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,但没有看到所有细节,你的 else0,这是一个 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