2

timeitの統計によると、これが私のプログラムで最も時間がかかるコードです。[-1.0、1.0]間隔のfloatを符号なし整数[0、2**32]に変換するのは汚い関数です。どうすれば加速できfloatToIntますか?

piece = []
rng = range(32)
for i in rng:
    piece.append(1.0/2**i)

def floatToInt(x):
    n = x + 1.0
    res = 0
    for i in rng:
        if n >= piece[i]:
            res += 2**(31-i)
            n -= piece[i]

    return res
4

1 に答える 1

4

明らかなものを試しましたか?

def floatToInt(x):
    return int((x+1.0) * (2**31))
于 2010-03-23T12:53:20.940 に答える