5. 부동소수점

2023. 4. 12. 21:59·컴퓨터 구조/Ch3. 컴퓨터 연산
Reference :
- 컴퓨터 구조 및 설계 MIPS EDITION [6판] / David A. Patterson / 한빛에듀
- 건국대학교 컴퓨터구조 강의 / 박능수 교수님
- https://developbear.tistory.com/ (김베어의 개발일지)

프로그래밍 언어는 부호있는 정수와 부호없는 정수뿐만 아니라 소수 부분을 갖는 수, 실수(reals)도 표현할 수 있어야 하고,

엄청나게 큰 값도 표현할 수 있어야 한다.

 

이 수들은 32비트 부호있는 정수로는 표현할 수 없다.


과학적 표기법과 정규화된 수, 부동소수점

우선 과학적 표기법과 정규화된 수에 대하여 알아보자.

 

과학적 표기법(scientific notation)은 소수점의 왼쪽에는 한 자리 수만이 나타나게 하는 표기법이다.

0.000000001 = 1.0 × 10^-9

3,155,760,000 = 3.15576 × 10^9

 

정규화된 수(normalized number)는 과학적 표기법으로 표현된 숫자 중에서 맨 앞에 0이 나오지 않는 수를 말한다.

즉, 선행하는 0이 없는 부동소수점 표기법으로 나타낸 수이며

0.1 × 10^-8과 10.0 × 10^-10은 정규화된 과학적 표기법이 아니다.

 

위에서의 예시는 십진수를 과학적 표기법으로 표현한 것이고, 이진수도 아래처럼 과학적 표기법으로 표시할 수 있다.

1.0 × 2^-1

 

이런 수를 지원하는 컴퓨터 연산은 부동소수점(floating point) 연산이라고 부른다.

이를 '부동'이라고 부르는 이유는 정수에서와 달리, 소수점의 위치가 고정되어 있지 않기 때문이다.

 

 

실수를 정규화된 형태의 표준 과학적 표기법으로 나타내면 다음과 같은 장점이 있다.

 

1. 부동소수점 숫자를 포함한 자료의 교환을 간단하게 한다.

2. 숫자가 항상 이런 형태로 표현됨을 알고 있기 때문에 부동소수점 산술 알고리즘이 간단해진다.

3. 불필요하게 선행되는 0을 소수점 오른쪽에 있는 실제의 숫자로 바꾸기 때문에

    한 워드 내에 저장할 수 있는 수의 정밀도를 증가시킨다.


부동소수점 표현

컴퓨터는 고정된 워드 크기를 사용하기 때문에

부동소수점 표현 방식에서는 소수부분(fraction)의 크기와 지수(exponent)의 크기 사이에서 타협점을 찾아야 한다.

 

 

소수부분의 크기를 증가시키면 소수부분으로 표현할 수 있는 수의 정밀도가 높아지고,

지수부분의 크기를 증가시키면 표현할 수 있는 수의 범위가 늘어난다.

 

좋은 설계에는 적당한 절충이 필요하다.

 

 

IEEE 754 FP Standard

 

현재 전 세계적으로 모든 컴퓨터에 사용되고 있는 IEEE 754 부동소수점 표준은 아래의 그림과 같다.

 

1. 단일 정밀도(single precision) 부동소수점

 

 

1개의 32비트 워드로 표현된 부동소수점 값이다. 보통 우리가 흔히 아는 float형을 말한다.

 

s는 부동소수점 수의 부호(0이면 양수, 1이면 음수),

지수는 8비트 지수 필드의 값이며(지수의 부호 포함), 소수부분은 23비트의 수이다.

 

 

2. 2배 정밀도(double precision) 부동소수점

 

 

2개의 32비트 워드로 표현된 부동소수점 값이다. 보통 우리가 흔히 아는 double형을 말한다.

 

여기서 지수는 11비트 지수 필드 값을 나타내며, 소수부분의 크기는 52비트이다.

 

 

* 정리

 


부동소수점 표현식은 다음과 같이 나타낼 수 있다.

 

 

* In binary :

 

S field

sign bit (양수이면 0, 음수이면 1)

less than, greater that, equal to 0 등의 테스트를 빠르게 할 수 있도록 부호 비트가 최상위 비트(MSB)에 놓이게 되었다.

 

F field

유효자리 부분에 더 많은 수를 담기 위해서

IEEE 754 표준은 정규화된 이진수의 가장 앞쪽 1비트를 생략하고 표현하지 않는다. (hidden bit)

(맨 앞의 1은 모든 정규표현식이 갖고 있으므로 생략해도 무관)

 

즉, 앞의 1을 제외한 소수 부분이 그대로 F field에 오는 것이다.

ex. 1.11 × 2^-100 → F field : 1100 0000 .... 0000

 

E field

지수를 유효자리 앞에 두면 부호가 같은 수를 비교할 때 지수가 큰 수가 지수가 작은 수보다 더 큰 정수처럼 보인다.

이는 부동소수점 수를 정수 비교 명령어로 정렬하는 일을 쉽게 해준다.

 

하지만 음수 지수는 숫자 정렬을 어렵게 만든다.

음수를 나타내기 위해 2의 보수법를 사용할 경우 지수가 음수이면 매우 큰 수처럼 보일 것이다.

 

따라서 가장 음수인 지수를 00...00, 가장 양수인 지수를 11...11으로 표현하기로 했으며,

이 방식을 바이어스된 표현법(biased notation)이라고 부른다.

 

bias는 실제 값을 구하기 위해 부호없이 표현된 수에서 빼야 하는 상수를 말한다.

단일 정밀도 표현 방식에서는 bias = 127, 2배 정밀도 표현 방식에서는 bias = 1023 이다.

 

E = e + bias

 

ex. 1.11 × 2^-100

→ E field in single precision : -100 + 127 = 27 즉, 00011011이 E에 오게 될 것이다.

→ E field in double precision : -100 + 1023 = 923 즉, 01110011011이 E에 오게 될 것이다.


(예시 문제 1)

-0.75를 부동소수점 표현 방식으로 표현해보자. (single, double 둘 다)

 

-0.75를 이진수로 변환하면 -0.11이다.

이를 정규화하면 다음과 같이 나타낼 수 있다.

 

S = 1

 

F = 1000 ... 0000 (1.1에서 일의 자리 1은 표현되지 않음)

 

E = -1 + bias

1) single : -1 + 127 = 126 = 011111110 (이진수)

2) double : -1 + 1023 = 1022 = 01111111110 (이진수)

 

따라서 -0.75를 부동소수점 표현 방식으로 표현하면 다음과 같다.

 

single precision : 1 011111110 1000 ... 0000 (F : 23비트)

double precision : 1 01111111110 1000 ... 0000 (F : 54비트)


(예시 문제 2)

single precision 표기로 나타낸 11000000101000...00은 어떤 수(x)를 나타낸 것인가?

 

우선 single이라고 했으므로, S 1비트 - E 8비트 - F 23비트로 쪼개서 보아야 한다.

1 10000001 01000 ... 00

 

S = 1 (음수)

 

F = 01000 ... 00

 

E = 10000001 (이진수) = 129

E = e + bias이므로 e = E - bias = 129 - 127 = 2

 

따라서 x는 다음과 같이 나타낼 수 있다.

 

즉, x는 -5.0이다.

 

IEEE 754 FP Normalized Form

 

정규화된 형식에서 E는 0000 0001(-126) ~ 1111 1110(127)의 범위를 갖는다.

 

따라서 정규화된 형식에서 부동소수점 표기로 표현할 수 있는 가장 큰 수와 가장 작은 수는 다음과 같다. (single precision)

* '1.'은 hidden bit을 나타낸 것

 

가장 큰 수 : 0 1111 1110 1.1111 1111 1111 1111 1111 111 

가장 작은 수 : 0 0000 0001 1.0000 0000 0000 0000 0000 000

 

0에 가장 가까운 수는 0 00000001 0000 ... 0000 또는 1 00000001 0000 ... 0000이 될 것이다.

 

그렇다면 0은 어떻게 표현할 수 있을까?

Normalized form에서는 정확히 표현이 불가하기 때문에 비정규화 형식(Denormalized form)을 사용한다.

 

 

Denormal Numbers

 

이는 Normal number보다 작은 수들을 표현하기 위함이다.

 

Denormalized form은 E field가 모두 0이거나 1인 표현식을 말하며

0 혹은 0에 아주 가까운 수들, 무한대인 수들, 또는 숫자가 아닌 수들(NaN)을 표현한다.

 

 

각 표현식은 다음과 같다.

 

* IEEE 754 FP Standard Encoding

 

E field가 모두 1이고 F field가 모두 0일 때는 무한인 수를 말하며,
E field가 모두 1이고 F field가 0이 아니면 숫자가 아님을 나타낸다. (Not a Number, NaN)

 


E field가 모두 0이면

정규화된 표현식처럼 1.~로 표현되는 것이 아니라 0.~으로 표현된다고 생각하면 된다. (hidden bit = 0)

 

비정규화된 표현에서 부동소수점 표현식은 다음과 같이 나타낼 수 있다.

 

 

single precision일 때 bias = 127이었으므로 1-bias = -126

double precision일 때 bias = 1023이었으므로 1-bias = -1022가 된다.

 

따라서 E field와 F field가 모두 0이 되는 순간, 진정한 0을 표현할 수 있는 것이다.

 

sign bit가 달라져도 0임을 유지하기 때문에 0의 표현에는 2가지가 있다.

1) 1 00000000 000 ... 00

2) 0 00000000 000 ... 00

 


비정규화된 표현으로도 표현할 수 없는 수들이 존재한다.

 

이런 수를 표현하려 할 때는 overflow 혹은 underflow의 오류가 난다.

* 오버플로우(overflow) : 숫자가 너무 커서 표현 불가

* 언더플로우(underflow) : 숫자가 너무 작아서 표현 불가

 

이 오류들은 single precision 대신 double precision을 사용하는 것을 통해 해결할 수 있다.

저작자표시

'컴퓨터 구조 > Ch3. 컴퓨터 연산' 카테고리의 다른 글

7. 부동소수점 덧셈과 곱셈  (0) 2023.05.02
6. 부동 소수점 반올림과 근사  (5) 2023.05.02
4. 나눗셈  (0) 2023.04.11
3. 곱셈  (0) 2023.04.11
2. 덧셈과 뺄셈  (0) 2023.04.11
'컴퓨터 구조/Ch3. 컴퓨터 연산' 카테고리의 다른 글
  • 7. 부동소수점 덧셈과 곱셈
  • 6. 부동 소수점 반올림과 근사
  • 4. 나눗셈
  • 3. 곱셈
smile blog
smile blog
건국대 첨단바이오공학부 & 컴퓨터공학부 BT & IT 기술로 희망을 꿈 꿉니당
  • smile blog
    스마일 블로그
    smile blog
  • 전체
    오늘
    어제
    • 분류 전체보기 (816)
      • 일상 생각들 (2)
      • 학과에 대해 (4)
        • 첨단바이오공학부 (4)
        • 컴퓨터공학부 (0)
      • -------- 프로젝트 -------- (0)
      • [DS] 토이 프로젝트 (1)
      • [Web, Game, XR] 토이 프로젝트 (11)
      • 경진대회 (1)
      • -------- 진로 -------- (0)
      • 생물정보학자 (18)
        • 데이터 과학이란? (0)
        • 되는 방법 (8)
        • 책 추천 (2)
        • 인강 (1)
        • 대학 (2)
        • 회사 (1)
        • 학원 (2)
        • 학회 (2)
      • 디지털 헬스케어 (72)
        • 방법 (8)
        • 생각들 (10)
        • 공부법 (4)
        • 책 추천 (2)
        • 학원 (2)
        • 참고 (2)
        • 대학 (3)
        • 회사 (3)
        • 인강 (2)
        • 게임 엔진들 (1)
        • 게임 프로그래머 개론 (2)
        • 게임 프로그래머 취업 전략 가이드 (7)
        • 취업 서류 (1)
        • 애정하는 게임들 (4)
        • XR 테크니컬 아티스트 (9)
        • 영화, 애니메이션 테크니컬 디렉터 (12)
      • -------- 기초 학문 -------- (0)
      • 생명과학 이야기 (2)
        • 대학 강의 (2)
      • 화학 이야기 (0)
      • 컴퓨터과학 이야기 (0)
      • 통계학 이야기 (0)
      • 수학 이야기 (1)
        • 공학 수학 (1)
      • 영어 이야기 (1)
      • 심리학 이야기 (7)
        • 현대인과 정신건강 (7)
      • -------- 컴퓨터 언어 -------- (0)
      • Python (3)
        • 나도코딩의 파이썬 입문 (1)
        • 파이썬 관련 정보 (1)
      • SQL (0)
      • C 언어 (32)
        • 혼자 공부하는 C언어 요약 (1)
        • [책 정리] 혼자 공부하는 C언어 (31)
      • C++ (33)
        • 명품 C++ 프로그래밍 요약 (1)
        • [책 정리] 명품 C++ 프로그래밍 (27)
        • C++ STL (0)
        • 뇌를 자극하는 C++ STL (5)
      • -------- 생명과학 -------- (0)
      • 생화학 (5)
        • 대학 강의 (5)
      • 분자세포생물학 (3)
        • 대학 강의 (3)
      • 유전자치료공학 (2)
        • 대학 강의 (2)
      • 생명정보학 (5)
        • 대학 강의 (5)
      • 약리학 (2)
        • 대학 강의 (2)
      • -------- 컴퓨터과학 -------- (0)
      • 자료구조와 알고리즘 (8)
        • 자료구조와 알고리즘의 정의 (3)
        • [책 정리] C언어로 쉽게 풀어쓴 자료구조 요약 (1)
        • [인강] 자료구조와 알고리즘 (2)
        • 코딩 테스트 대비하기! (1)
      • 컴퓨터 회로 (0)
      • 컴퓨터 구조 (43)
        • 컴퓨터 구조와 운영체제 요약 (1)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 구조 및 설계 (1)
        • Ch1. 컴퓨터 추상화 및 관련 기술 (8)
        • Ch2. 명령어 : 컴퓨터 언어 (11)
        • Ch3. 컴퓨터 연산 (8)
        • Ch4. 프로세서 (11)
        • Ch5. 메모리 계층구조 (3)
        • Ch6. 병렬 프로세서 : 클라이언트에서 클라우드까지 (0)
      • 시스템 프로그래밍 (15)
        • [책 정리] 시스템 프로그래밍 유닉스 & 리눅스 (0)
        • [인강] 리눅스 시스템 프로그래밍 (2)
        • 리눅스에서 코딩이란? (8)
        • 대학교 강의 정리 (5)
      • 운영체제 (0)
      • 컴퓨터 네트워크 (37)
        • 모두의 네트워크 요약 (1)
        • [책 정리] 모두의 네트워크 (10)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 네트워킹 하향식 접근 8판 (1)
        • Ch1. 컴퓨터 네트워크와 인터넷 (7)
        • Ch2. 애플리케이션 계층 (7)
        • Ch3. 트랜스포트 계층 (8)
        • Ch4. 네트워크 계층 : 데이터 평면 (3)
        • Ch5. 네트워크 계층 : 제어 평면 (0)
        • Ch6. 링크 계층과 근거리 네트워크 (0)
        • Ch7. 무선 및 이동 네트워크 (0)
        • Ch8. 컴퓨터 네트워크 보안 (0)
      • 데이터베이스 (1)
      • -------- 데이터과학 -------- (0)
      • 데이터 사이언스 (8)
        • 인강 (8)
      • 데이터 분석 (2)
        • 인강 (2)
      • 머신러닝 (2)
        • 대학 수업 (2)
      • 인공지능 (11)
        • 대학교 강의 정리 (10)
        • 인공지능 관련 정보 (1)
      • -------- +a -------- (0)
      • Visual Studio Community (7)
        • 설치법 (1)
        • 단축키 (1)
        • 오류 (5)
      • Visual Studio Code (0)
      • 노션 (1)
      • 깃허브 (7)
        • 깃허브 사용법 (5)
        • 유니티, 언리얼 & 깃허브 (1)
        • 깃허브 주의사항 (1)
      • 챗GPT 활용법 (0)
      • 기타 feat. 프로그래밍 (7)
        • 프로그래머로 살아남기 (5)
        • 코딩 vs 프로그래밍 (1)
        • 애플 비전 프로 (1)
      • 메타버스 (5)
      • -------- 예술 -------- (0)
      • 음악 (1)
      • 미술 (0)
      • -------- XR -------- (0)
      • 유니티 이야기 (23)
        • 레트로의 유니티 게임 프로그래밍 에센스 요약 (4)
        • 유니티 관련 정보 (1)
        • 유니티 디버깅 (13)
        • 유니티 인강 (3)
        • 대학교 게임 프로그래밍 강의 (2)
      • 언리얼 이야기 (0)
        • 인생 언리얼 교과서 요약 (0)
      • 컴퓨터 그래픽스 (6)
        • OpenGL (6)
      • 가상현실 & 증강현실 (4)
        • 유니티 vr (4)
      • HCI 와 UI UX (7)
        • [책 정리] HCI 개론 (6)
      • -------- Design -------- (0)
      • 캐릭터 (1)
        • 모델링 (0)
        • 리깅 (1)
      • 포토샵 (3)
      • 3ds Max (7)
      • Maya (9)
        • 블로그 (1)
        • 인강 (6)
        • 대학교 (2)
      • Blender (14)
        • 책 (1)
        • 인강 (7)
        • 기타 (3)
        • 대학교 (3)
      • 아트 작업물들 (2)
      • 에셋 사이트 (1)
      • -------- 건강관리 -------- (0)
      • 건강관리 ft. 정현 (12)
        • 목 디스크 (2)
        • 눈 관리 (2)
        • 일상생활 습관 (6)
        • 일상생활 꿀팁 (2)
        • 사무직 꿀팁 (0)
      • 헬스의 정석 ft. 정현 (28)
        • 헬스와 건강 (8)
        • 헬스 구체화 정보 (6)
        • 헬스 유튜버 (1)
        • 헬스 서적 (1)
        • 도전 바디프로필! (11)
        • 헬스장 패션 (1)
      • -------- etc -------- (0)
      • 진로 관련 잡다한 글들 (34)
        • 진도율 (9)
        • 진로 관련 글들 (15)
        • 학교 강의 관련 글들 (10)
      • 인생 꿀 Tip (23)
        • 컴퓨터 초기 설정 (9)
        • 원격 데스크톱 (1)
        • 노트북 발열 (1)
        • 전자기기 (2)
        • 중고기기 팔기 (1)
        • 아이패드 필기 어플 (1)
        • 에어팟 (1)
        • 커피 (1)
        • 맥북 (1)
        • lg 그램 (1)
        • 검색엔진에서 내 티스토리 검색 (1)
        • hELLO 다크 모드 없애기 (1)
        • 인터넷 연결 문제 (1)
        • 키보드 문제 해결 (1)
      • 유튜브 (3)
      • 청춘 그리고 추억 (1)
      • 인생 계획표 (2)
        • 2024년 2학기 (1)
        • 2024년 여름방학 (0)
        • 2024년 1학기 (0)
        • 2023년 겨울방학 (1)
      • 다양한 글들 (98)
        • C++ STL (6)
        • Win32 API (24)
        • PushPush 게임 (13)
        • 컴퓨터구조 (1)
        • 자료구조와 알고리즘 (50)
        • 게임의 정의 (3)
        • 영상 회사 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

    • Dream
    • 코딩을 시작한 이유
    • 나를 소개합니다!
    • 블로그 공부법
    • IT & 가치 있는 일들
  • 인기 글

  • 태그

    명령어
    인공지능
    유니티
    첨단바이오공학부
    생명공학
    C++ STL
    AI
    의생명공학
    자료구조
    연산자
    의생명공학과
    unity
    C언어
    코드잇
    리눅스 터미널
    컴퓨터 네트워크
    데이터사이언스
    알고리즘
    리눅스
    스택
    배열
    심리학
    건국대
    포인터
    함수
    데이터과학
    컴퓨터구조
    블렌더
    생물정보학
    C++
  • 최근 댓글

  • hELLO· Designed By정상우.v4.10.3
smile blog
5. 부동소수점
상단으로

티스토리툴바