如何解决即使仅使用浮点数,f-string 中的“ValueError: Precision not allowed in integer format specifier”也会弹出
我正在训练神经网络,但这无关紧要。唯一相关的信息是这一行:
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)
steps 从 0 到 4000。所以,eps 也是一个浮点数。
这些都不可能是浮点数。这里发生了什么?它也不会在 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
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。