当前位置:  开发笔记 > 编程语言 > 正文

计算最接近的数字numpy

如何解决《计算最接近的数字numpy》经验,为你挑选了1个好方法。

我正在尝试将最接近的数字计算为0,但到目前为止无法得到我想要的数字.

我有一个非常简单的代码;

y = 0.0
x = 0.1
while (y + x > y):
    x = x/2.0
x*2

但我一直得到0.0作为输出.我怎样才能解决这个问题



1> 小智..:

我想你想继续分割,直到x变得如此之小,它变为零(浮点格式).在循环的最后一次迭代中,x最终变为零,循环条件变为假: 0.0(y) + 0.0(x) > 0.0(y).在最后一行,您尝试通过乘以2来检索x值.但是x已经为零,因此结果也为零.数学上是完全有意义的,但浮点值在那时已经为零.

为了保持最新的非零值,请使用第二个变量:

y = 0.0
x = 0.1
smallest_x = x

while (y + x > y):
    smallest_x = x
    x = x/2.0
x*2

或者,您可以事先检查x再次分割后是否为零:

y = 0.0
x = 0.1
while (y + x/2.0 > y):   //checking if the next division makes x to zero
    x = x/2.0
x*2

或采取不同的方法来获得最小的x:

x = 1.0
while (x/2.0 != 0):
    x = x/2.0

推荐阅读
Gbom2402851125
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有