게이트 회로로 이해하는 컴퓨터 연산

1. Computer

  • 컴퓨터(computer)는 계산을 하는 기계이다. 그런데 어떻게 계산을 수행하는 것일까?
    • 컴퓨터는 수 많은 트랜지스터로 구성된 "Gate Circuit"을 이용하여 논리 연산과 산술 연산을 수행한다.

2. 연산 (Operation)

2.1. Basic

  • 전류가 흐르면(ON) 전구가 켜지고, 흐르지 않으면(OFF) 꺼진다.
※ 전류를 흐르게 만드는 전자는 실제 물리적으로는 (–)에서 (+)로 이동한다. 그러나 전자의 존재를 알지 못했던 당시, 프랭클린이 ‘전하가 (+)에서 (–)로 움직인다’고 정의한 규칙이 오랫동안 사용되면서, 오늘날에도 전류의 방향은 관례적으로 (+)에서 (–)로 흐르는 것으로 표현한다.

2.2. Transistor

  • 그런데, 반도체(Semiconductor)라는 것은 전기를 흐르게도 할 수 있고, 흐르지 않게도 할 수 있다.
  • 대표적으로 트랜지스터(Transistor)는 이러한 반도체의 특성을 이용하여 전류의 흐름을 제어할수 있다.

2.3. Gate

  • 트랜지스터(Transistor)를 이용하여 기본 AND, OR, NOT, NOR, XOR 연산을 구현할 수 있다.
  • 이것을 Gate Circuit라고 하며, 이러한 여러 게이트를 조합하여 복잡한 디지털 논리 회로(Circuit)를 구성한다.

👉 circuitjs-gate

2.3.1. AND Gate

  • X, Y가 모두 ON 일때 ON


2.3.2. OR Gate

  • X, Y 중 하나라도 ON 일때 ON

2.3.3. NOT Gate

  • X가 OFF 일때 ON

2.3.4. NOR Gate

  • X, Y가 모두 OFF 일때 ON


2.3.5. XOR Gate

  • X, Y가 다를때 ON


3. 가산기 (Adder)

  • 가산기는 더하기를 수행하는 회로(Circuit)이다.
  • 컴퓨터의 CPU는 수많은 가산기를 기반으로 구현되어 있으며, 모든 연산의 기본이 된다.
    • 곱셈은 더하기를 여러 번 반복한 것이고, 뺄셈은 보수(complement)를 이용한 덧셈으로 처리되며, 나눗셈은 뺄셈을 반복하여 수행된다.

[출처] Intel - The Transistor, Explained

※ 보수(補數, complement): 수학적으로 기준값에서 모자란 만큼 채워주는 수를 말한다.

  • 컴퓨터에서는 뺄셈을 더하기로 바꾸기 위해 보수를 사용한다. 즉, 뺄셈 A - B 를 덧셈 A + (B의 2의 보수) 로 바꾸어 계산한다.
    • 1의 보수 (One’s complement): 비트를 뒤집은 값
    • 2의 보수 (Two’s complement): 1의 보수 +1을 더한 값

5 - 3 = ?

※ 0011 (3) → 1100 (3의 1의 보수) → 1101 (3의 2의 보수)
0101 (5) + 1101 (3의 2의 보수) ------- 10010 ∴ 5bit 중 맨 앞(overflow) 1bit 버림 → 0010 (2)

3.1. 반가산기 (Half Adder)

  • 2 개의 bit를 더하는 회로

3.2. 전가산기 (Full Adder)

  • 3 개의 bit를 더하는 회로

3.3. 가산기 예제

  10 (2)
+ 11 (3)
------
 101 (5)

👉 circuitjs-adder

3.3.1. 첫 번째 자리

Half Adder

A(0), B(1)  →  S=1, C=0

📟 1

3.3.2. 두 번째 자리

Full Adder

A(1), B(1), C(0)  →  S=0, C=1

📟 0

3.3.3. 세 번째 자리

Full Adder

A(0), B(0), C(1)  →  S=1, C=0

📟 1

3.3.4. 결과

1 0 1