목차
?높은 심도가 무조건 좋은거다?
그렇지 않다. 연산 형식이 다른 두 형태의 심도를 같이 비교하면 안된다.
정수형과 부동소수형의 장단점
일단 숫자 데이터 연산의 형식에는 정수형(Integer)과 부동소수형(Floating Point)이 있고, 서로 사용하는 연산기가 다르다. 정수형의 장점은 빠른 계산이 가능하다는 점, 하지만 표현할 수 있는 숫자의 범위가 적다는 점이고
부동소수형의 장점은 글자수(bit)에 비해서 표현할 수 있는 숫자의 범위가 매우 크다는 점이지만, 실제 숫자 표현의 자릿수와 소수점 표현에 대한 자리수의 복잡한 표현으로 이루어지기 때문에, 계산방식이 다소 느려진다는 점. 그리고 오차가 다소 발생할 수 있다는 점이 그 단점이다.1)
각 데이터 형식의 표현 범위
부동소수점 연산의 정밀성 손실
부동소수 연산의 정밀성 손실 문제를 구체적인 예시로 설명해보겠습니다.
예를 들어, 우리가 다음과 같은 두 개의 부동소수를 더한다고 가정해봅시다:
- 0.1 x 10-20
- 0.2 x 10-20
이 두 부동소수를 더하면 우리는 0.3 x 10-20이 나와야 한다고 예상할 수 있습니다. 그러나 컴퓨터에서는 부동소수점을 표현할 때 소수점 이하의 정밀도에 한계가 있기 때문에 정확한 결과를 얻기 어렵습니다.
실제로 컴퓨터에서 이러한 덧셈을 수행하면 다음과 같은 결과가 나올 수 있습니다:
- 0.1 x 10-20를 표현할 때 발생하는 정밀성 손실로 인해 실제로는 0.10000000000000000000005 x 10-20 정도로 저장될 수 있습니다.
- 0.2 x 10-20도 마찬가지로 정밀성 손실로 인해 0.20000000000000000000004 x 10-20 정도로 저장될 수 있습니다.
따라서 이 두 수를 더하면 0.30000000000000000000009 x 10-20 정도의 값이 나올 수 있습니다. 이것은 우리가 원했던 0.3 x 10-20과 약간 다른 값이며, 부동소수점 연산의 정밀성 손실로 인해 발생한 것입니다.2)
이러한 예시를 통해, 부동소수 연산에서의 정밀성 손실이 어떻게 발생하는지 좀 더 구체적으로 이해할 수 있습니다.
이러한 오차는 금융 분야에서의 시간, 금액 계산이나, 공학에서의 정밀 계산이 필요한 분야에서는 큰 오류를 범할 수 있지만, 그래픽 분야 또는 오디오 분야에서는 큰 문제가 되지 않습니다. 그래서, 그래픽 카드에서 쓰이는 GPU에서는 거의 부동소수형 연산자를 가진 칩을 사용하고, 오디오 쪽에서는 최근 부동소수형 DSP 칩들이 레이턴시가 짧아진 제품들이 나오면서3) 부동소수형 연산칩을 사용하는 경향이 있습니다.
디지털 콘솔은 왜 정수형 연산자를 쓰는가?
디지털 콘솔들 중에서 내부 DSP의 연산형식이, 48bit, 56bit 등인 제품들은 정수형 DSP 연산 형식으로 나온 제품들이고 연산 레이턴시 부분에서 이득을 보기위해 채택한 DSP 정수형 연산자를 쓰기 때문이다. 이 제품들의 해상도는 32 bit 부동소수형 DSP 보다 해상도 면에서는 떨어지는 것이다.하지만 정수가 연산 속도4)가 빠르므로 레이턴시 부분에서 유리하기 때문에 아직도 디지털 콘솔 중엔 정수형 DSP를 쓰는 제품이 많이 있다.
결론
위에서 볼 수 있듯이 32 bit 부동소수가 표현할수 있는 숫자 범위는 정수형 표현과 비교하면 128 bit가 와도 상대가 안될 정도로 높으므로 48, 56bit 정수형 등과 같은 정수형 연산자들과 비교한다면 32bit 부동소수형은 거의 아날로그에 가깝다고 생각해도 무리가 아니다.5)
[공지]회원 가입 방법
[공지]글 작성 및 수정 방법