>백엔드 개발 >C++ >단정밀도 부동 소수점을 사용하여 배정밀도 산술을 에뮬레이션하는 방법은 무엇입니까?

단정밀도 부동 소수점을 사용하여 배정밀도 산술을 에뮬레이션하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-02 12:24:30742검색

 How to Emulate Double-Precision Arithmetic Using Single-Precision Floats?

부동 소수점을 사용하여 배정밀도 산술 에뮬레이션

특정 시나리오에서는 부동 소수점 지원이 제한된 임베디드 하드웨어 시스템에서 배정밀도 연산이 필요할 수 있습니다. -정밀 기능. 이는 단정밀도 부동 소수점 연산만을 사용하여 이를 달성하는 방법에 대한 의문을 제기합니다.

배정밀도 값을 에뮬레이션하기 위한 접근 방식은 두 개의 단정밀도 부동 소수점 튜플을 포함하는 구조체를 활용하는 것입니다. 이중의 높은 부분과 낮은 부분을 나타냅니다. 비교는 사전순 정렬을 사용하여 수행할 수 있습니다.

그러나 덧셈 작업에는 문제가 있습니다. 정확성을 보장하기 위해 추가 기준을 신중하게 고려해야 합니다. 중간 언더플로나 오버플로를 방지하려면 FLT_MAX(단정밀도 부동 소수점으로 표현할 수 있는 최대값)의 배수를 사용하는 것이 좋습니다.

캐리를 감지하려면 다음에서 두 부동 소수점의 합을 빼면 됩니다. 기대값. 결과가 0보다 작거나 같으면 캐리가 발생한 것입니다.

아래 참조는 GPU 아키텍처에서 단정밀도 부동 소수점을 사용하는 배정밀도 에뮬레이션 기술에 대한 귀중한 통찰력을 제공합니다.

  • https://hal.archives-ouvertes.fr/hal-00021443
  • http://andrewthall.org/papers/df64_qf128.pdf

위 내용은 단정밀도 부동 소수점을 사용하여 배정밀도 산술을 에뮬레이션하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.