왜 GHCi가 아래에 잘못된 답변을합니까?
GHCi
λ> ((-20.24373193905347)^12)^2 - ((-20.24373193905347)^24)
4.503599627370496e15
파이썬 3
>>> ((-20.24373193905347)**12)**2 - ((-20.24373193905347)**24)
0.0
업데이트 Haskell의 (^) 기능을 다음과 같이 구현합니다.
powerXY :: Double -> Int -> Double
powerXY x 0 = 1
powerXY x y
| y < 0 = powerXY (1/x) (-y)
| otherwise =
let z = powerXY x (y `div` 2)
in if odd y then z*z*x else z*z
main = do
let x = -20.24373193905347
print $ powerXY (powerXY x 12) 2 - powerXY x 24 -- 0
print $ ((x^12)^2) - (x ^ 24) -- 4.503599627370496e15
내 버전이 @WillemVanOnsem에서 제공 한 것보다 더 정확하지는 않지만 적어도이 특정 사례에 대한 정답을 이상하게 제시합니다.
파이썬은 비슷합니다.
def pw(x, y):
if y < 0:
return pw(1/x, -y)
if y == 0:
return 1
z = pw(x, y//2)
if y % 2 == 1:
return z*z*x
else:
return z*z
# prints 0.0
print(pw(pw(-20.24373193905347, 12), 2) - pw(-20.24373193905347, 24))
2.243746917640863e31 - 2.2437469176408626e31
작은 반올림 오류가있는 것을 계산 하여 증폭됩니다. 취소 문제인 것 같습니다.
a^24
는 대략2.2437e31
이므로 이것을 생성하는 반올림 오류가 있습니다.