230 likes | 541 Views
컴퓨터시스템구조 – 3 장 데이타의 표현. Prof. 강 의 성 순천대학교 컴퓨터교육과 http://nova.sunchon.ac.kr magasa@sunchon.ac.kr Tel. 061-750-3344. 3.1 데이타의 종류 – (1). 데이타의 분류 모든 자료는 2 진수로 변환되어 컴퓨터에 저장되고 , 처리된다 산술연산에 사용하는 숫자 데이터 처리에 사용하는 문자 특수 목적에 사용하는 기호 진법 10 진수의 표시
E N D
컴퓨터시스템구조 – 3장 데이타의 표현 Prof. 강 의 성 순천대학교 컴퓨터교육과 http://nova.sunchon.ac.kr magasa@sunchon.ac.kr Tel. 061-750-3344
3.1 데이타의 종류 – (1) • 데이타의 분류 모든 자료는 2진수로 변환되어 컴퓨터에 저장되고, 처리된다 • 산술연산에 사용하는 숫자 • 데이터 처리에 사용하는 문자 • 특수 목적에 사용하는 기호 • 진법 • 10진수의 표시 (724.5)10 = 7×102+2×101+4×100+5×10-1 • 2진수의 표시 (101101)2 = 1×25+0×24+1×23+1×22+0×21+1×20 (101101)2 = (45)10 • 8진수의 표시 (736.4)8 = 7×82+3×81+6×80+4×8-1 = (478.5)10 • 16진수의 표시 (F3)16 = 15×161+3×160 = (243)10
Cont’d – (2) • 진법변환 • (724.5)10 = (101001.1011)2 • (41)10 = (101001)2 • (0.6875)10 = (0.1011)2 • 2진화 8진수 (1 010 111 101 100 011)2 = (127543)8 • 2진화 16진수 • (1010 1111 0110 0011)2 = (AF60)16
10진수의 표시 • 10진수의 입력을 2진수로 바꾸어 산술연산을 수행한 다음에 연산결과를 10진수로 바꾸어 출력 • 경우에 따라서는 10진수를 2진화 10진수(BCD)의 형태로 직접 계산하는 것도 가능 • 2진화 10진수 • 4비트로 10진수 1자리를 표시
영자숫자 (alphanumeric)의 표시 • 코드(Code) • 데이타로 취급되는 문자, 기호도 코드화 • 10개의 숫자, 26개의 영어대문자, 특수기호 등의 32~64개를 문자로 표시하여 6비트가 필요 • 영어의 소문자까지 합쳐 7비트 필요 • 표준코드 • ASCII(American National Standard Code for Information Interchange) • <표 3-4>참조 • 숫자일 경우 상위 3비트 011을 제외하면 BCD와 같다 • ASCII코드가 단말기로 부터 컴퓨터로 들어오면 BCD코드로 바뀐다
3.2 보수 (Complement) – (1) • 보수(Complementary Number) 디지탈 컴퓨터에서 뺄셈연산과 논리계산에 사용된다 • r 진법 • 두 종류의 보수가 있다 • r의 보수 • (r-1)의 보수 • 2진수에서는 1의 보수와 2의 보수 • 10진수에서는 9의 보수와 10의 보수 • (r-1)의 보수 • n자리수의 수 N에 대한 보수는 (rn-1)-N 으로 정의 • 10진수에서 10n은 하나의 1과 뒤이은 n개의 0으로 구성되어 있고 10n-1은 n개의 9로 구성 • 9의 보수는 각 자리의 숫자를 9에서 뺀 것과 같다 • 예 546700에 대한 9의 보수는 999999-546700 = 453299 • 2진수의 보수 • r=2이고 r-1=1이므로 N에 대한 1의 보수는 (2n-1)-N이다 • 2진수에서 2n은 1과 뒤이은 n개의 0으로 구성되어 있으며 2n-1은 n개의 1로 구성 • 2진수에 대한 1의 보수는 각 자리의 숫자를 1에서 뺀 것과 같다 • 예 1011001에 대한 1의 보수는 0100110이다
Cont’d – (2) • r의 보수 • r진법의 n자리수의 N에 대한 r의 보수는 N≠0일때 rn-N이다 여기서 N=0일때는 0으로 정의된다 • r의 보수: (r-1)의 보수에 1을 더하면 된다 • rn-N=[(rn-1)-N]+1이 성립한다 • 10의 보수 예 2389에 대한 10의 보수는 7610+1=7611 • 2의 보수 예 101100에 대한 2의 보수는 010011+1=010100 • 소수점을 가진 숫자 N의 보수 • 소수점을 생략한 채로 각각 n또는 (r-1)의 보수를 구한다 • 이 보수의 적합한 위치에 소수점을 다시 붙이면 된다
부호없는 숫자의 뺄셈 • 디지탈 하드웨어로 뺄셈을 할 때는 보수를 이용하는 것이 효율적 • r진수의 부호없는 두 n자리수 사이의 뺄셈 M=N(N≠0)의 계산 • 피감수 M에 감수 N에 대한 r의 보수를 더한다 • M+(rn-N)=M-N+ rn • M≥N이라면 위의 합은 End 캐리 rn을 만들어 내고 이것을 무시하면 결과는 M-N이 된다 • M<N이라면 위의 합은 End 캐리를 만들지 않고 그 값을 rn -(N-M)이다 • 이것은 (N-M)에 대한 r의 보수이므로 이것에 대한 r의 보수를 취하고 그 앞에 뺄셈부호를 붙이면 결과를 얻을 수 있다
예) 72532-13250=59282 M은 72532 N에 대한 10의 보수 + 86750 합은 159282 End 캐리 105을 무시 -100000 답은 = 59282 예) M<N인 경우 13250-72532 = -59282 M은 13250 N에 대한 10의 보수 + 27468 합은 = 40718 예) 2진수에 대한 뺄셈 X = 1010100 Y = 1000011 a) X-Y의 계산 b) Y-X의 계산 X = 1010100 Y = 1000011 Y에 대한 2의 보수 +0111101 X에 대한 2의 보수 +0101100 합은 10010001 합은 1101111 End캐리 27은 무시 -10000000 답 X-Y =0010001 예제
3.3 고정 소수점의 표현 • 컴퓨터에서 수의 표현 • 컴퓨터에서는 하드웨어적인 제약으로 부호를 포함한 모든 것을 0과 1로 표현 • 숫자의 맨 왼쪽 비트를 부호비트로 정한다 • 0이면 부호를 양수, 1이면 부호를 음수로 표현 • 레지스터에 2진 소수점 숫자의 표현 • 고정 위치의 소수점 • 2진 소수점이 항상 동일한 위치에 존재 • 분수(가수)를 표현하기 위해서 레지스터의 맨 왼쪽에 소수점을 두는 것 • 정수를 표현하기 위해서 레지스터의 맨 오른쪽에 소수점을 두는 것 • 저장된 숫자를 분수 또는 소수로 취급 • 부동 위치의 소수점 • 첫번째 레지스터에 저장된 10진 소수점의 위치로 두번째 레지스터에 저장된 숫자를 표현
정수의 표현 • 음수의 표현 • 부호 절대값 표현 • 음수는 음수의 부호와 그 크기를 나타내는 절대값으로 구성 • (-14)를 8비트로 표현하면 (10001110)이 된다 • 부호화된 1의 보수 표현 • 음수의 표현은 음수에 대한 2진수 값을 1의 보수로 표현 • (-14)를 8비트로 표현하면 (11110001)이 된다 • 부호화된 2의 보수 표현 • 음수의 표현은 그 수에 대한 2진수의 값을 2의 보수로 표현 • (-14)를 8비트로 표현하면 (11110010)이 된다
산술가산 • 부호 절대값 표현에서 두수의 덧셈은 보통의 산술연산과 동일 • 두수의 부호가 동일하면 절대값을 더한 후 공통의 부호를 주고 • 두수의 부호가 다르면 절대값이 큰 수에서 작은 수를 빼고 큰 수의 부호를 붙인다 • 부호화된 2의 보수 표현에서는 비교와 뺄셈이 필요없고 덧셈과 보수화만으로 덧셈계산 • 먼저 부호를 포함하여 두수를 더한다 • 부호비트의 캐리는 무시 • 음수의 결과는 자동적으로 2의 보수형태로 만들어진다 • - 예) +6 00000110 -6 11111010 +13 00001101 +13 00001101 +19 00010011 +7 00000111 +6 00000110 -6 11111010 -13 11110011 -13 11110011 -7 11111001 -19 11101101
산술감산 • 음수가 2의 보수로 표현되어 있을 때 • 부호 비트를 포함한 감수의 2의 보수를 취한 다음 가산 • 부호비트까지 포함하여 가산 • 수식의 표현 (±A)-(-B) = (±A)+(+B) (±A)-(+B) = (±A)+(-B) • 예) (-6)-(-13) = +7를 2진수 계산하면 11111010 - 11110011 = 100000111 이 되고 여기서 00000111 (+7)이 된다
오버플로 (Overflow) • n자리의 두수를 가산해서 n+1자리의 합을 얻었을 때 오버플로 발생하였다고 함 • 디지탈 컴퓨터에서 레지스터를 포함한 모든 레지스터의 길이가 한정된 길이이기 때문에 오버플로가 발생할 수 있다 • 오버플로가 발생했을 경우 컴퓨터는 이를 검사하고 그에 대한 플립플롭을 세트한다 • 두수의 덧셈 후의 오버플로 검사 • 두수의 부호화 여부에 따라 달라진다 • 부호가 없는 수의 덧셈의 경우에 최상위 비트에서 End캐리가 발생하면 오버플로이고 • 부호가 있는 수의 덧셈의 경우에 부호비트도 숫자의 일부로 간주되어 결과만 보고서는 오버플로 판단 불가능 • 한 수가 양이고 다른 한 수가 음일 때는 간산 후 오버플로 발생않음 • 두수가 모두 양이거나 음일 때는 오버플로 발생 가능 • 마지막 2개의 캐리를 (XOR)하여 0이면 오버플로 발생하지 않은 경우이고 그 결과가 1이면 오버플로 발생한 경우이다
예제 • 예) 8비트 레지스터의 70과 80을 가산 레지스터의 최대용량은 (27-1)=127 레지스터의 최소용량은 (-27-1)=-128 • - 두수의 합은 150이므로 레지스터 용량 초과 • - 마지막 두개의 캐리를 찾아서 (XOR)하여 오버플로 체크 • Carries 0 1 Carries 1 0 • +70 01000110 -70 10111010 • +80 01010000 -80 10110000 • +150 10010110 -150 01101010
레지스터에 저장된 10진수를 표현하는 것은 십진 숫자를 나타내는 데 사용된 2진 코드방식에 따라 다르다 BCD로 표현된 4385 각 숫자마다 4개의 플립플롭이 사용되기 때문에 모두 16개의 플립플롭이 필요 2진 코드로 표현하면 0100 0011 1000 0101 BCD의 부호화된 10진수의 표현 2진수에서의 부호표현과 비슷 부호화 절대값 표현 부호화된 보수 표현 부호에 있어서 양수는 0, 음수는 9로 표현 덧셈 부호, 숫자를 포함한 모든 숫자를 더하고 End캐리를 무시 예) (+375)+(-240) = +135 0 375 (0000 0011 0111 0101) +9 760 (1001 0111 0110 0000) 0 135 (0000 0001 0011 0101) 두번째 맨왼쪽의 9는 음수표현이고 9760은 0240에 대한 10의 보수 덧셈은 BCD 가산기에서 수행된다 뺄셈 2진수에서와 같은 방법으로 감수에 대해 10의 보수를 취하고 이것을 피감수에 더하여 결과를 얻음 십진 고정 소수점의 표현
숫자의 부동 소수점 표현 가수 : 부호화된 고정소수점 숫자, 분수나 정수 모두 가능 지수 : 10진 또는 2진 소수점의 위치를 알려주는 부분 +6132.789를 부동소수점으로 표현 Fraction Exponent +0.6132789 +04 부동소수점의 표현 형식 m×re m:가수 e:지수 r:밑수 레지스터에는 가수와 지수만이 그 부호를 포함해서 저장 밑수와 가수의 소수점은 이미 가정되어 있는 것으로 간주 2진수의 부동소수점 표현 형식 밑수가 2 예) +1001.11을 8비트의 분수와 6비트의 지수로 표현 Fraction Exponent 01001110 000100 분수의 맨왼쪽 0은 양수임을 표시 분수의 소수점은 부호비트 바로 다음에 표시 지수부는 +4 2진수의 부동소수점 표현 형식 m×2e = +(.1001110)2 ×2+4 3.4 부동 소수점 표현 – (1)
Cont’d – (2) • 정규화(Normalization) • 가수의 최상위 비트가 0이 아닌 경우 • 정규화의 여부는 가수에서의 소수점의 위치와는 관계없이 최상위 비트값에 의해서만 결정 • 예) 8비트의 00011010은 정규화되지 않았다 이것을 정규화하기 위해서 쪽으로 3번 시프트한다 11010000×2-3 • 부동 소수점 숫자의 산술연산 • 연산이 복잡하고 시간이 많이 걸린다 • 하드웨어적으로 복잡하다 • 매우 큰 수와 매우 작은 수를 표현하기에 편리
3.5 기타 코드 – (1) • Gray Code • 한 숫자에서 다음 숫자로 올라갈 때 한 비트만이 변하는 특성을 갖는다 • 이 코드는 주로 제어계통에 사용된다
Cont’d – (2) • 기타 10진 코드 • 10진수 한 단위를 위해 최소 4비트가 필요하다 • 기타 영자숫자 코드 • 아스키 코드 • 2진 정보를 전송하기 위해 공통적으로 사용되는 표준 코드 • 각 문자는 7비트로 표시 • 8번째 비트로는 패리티(Parity)비트 • 128개의 문자를 포함 • EBCDIC(Extended BCD Interchange Code)코드 • IBM장비에 사용 • 각 문자는 8비트로 표시 • 9번째 비트는 패리티 비트
2진 정보를 전송할 때 외부잡음이 들어가면 1이 0으로, 0이 1로 변하여 에러가 생길 가능성이 있다 일반적으로 에러 검출방법은 패리티 비트를 사용 3.6 에러 검출 코드