Rust로 작성해 보는 컴퓨터 구조 (6) - NOR 게이트
NOR 게이트
NOR 게이트를 모델링하는 과정은 NAND 게이트를 모델링하는 과정과 완전히 같다. 당연히 NOR는 NOT-OR의 약자다. 그러므로 진리표도 OR 게이트 진리표의 반대다.
입력 A | 입력 B | 출력 |
---|---|---|
0 | 0 | 1 |
0 | 1 | 0 |
1 | 0 | 0 |
1 | 1 | 0 |
NOR 게이트의 진리표는 위 표와 같다. 아래 그림은 NOR 게이트의 회로도 심볼이다.
NAND 게이트와 구성이 같다. OR 게이트 앞에 인버터가 붙은 모습이다. 이 모양 그대로 모델 코드를 만들면 된다.
{caption="gates.rs | NOR 게이트 모델 추가"} use crate::transistor; // ... 생략 ... pub struct NorGate { orgate: OrGate, inv: NotGate, } // ... 생략 ... impl NorGate { pub fn new() -> NorGate { NorGate{ orgate: OrGate::new(), inv: NotGate::new(), } } } // ... 생략 ... impl GateInterfaces for NorGate { fn proc(&mut self, input_a: bool, input_b: bool) -> bool { return self.inv.proc(self.orgate.proc(input_a, input_b)) } }
앞 장과 중복되는 코드는 생략했다. 코드는 앞 장의 NAND 게이트 모델 코드를 복사해서 이름을 바꾸고 NorGate 구조체의 멤버 변수를 OrGate 객체로 바꾼것 뿐이다. 기본 틀은 NAND 게이트 모델과 동일하므로 내부에 포함하는 게이트 객체만 바꾸면 NOR 게이트 구현이 끝난다.
테스트 방법도 앞 장과 동일하다.
{caption="main.rs | NOR 모델 테스트"} mod transistor; mod gates; use gates::GateInterfaces; fn main() { //... 생략 ... let mut nor_gate = gates::NorGate::new(); println!("Test NOR Gate, (0, 0) -> {}", nor_gate.proc(false, false)); println!("Test NOR Gate, (0, 1) -> {}", nor_gate.proc(false, true)); println!("Test NOR Gate, (1, 0) -> {}", nor_gate.proc(true, false)); println!("Test NOR Gate, (1, 1) -> {}", nor_gate.proc(true, true)); }
코드를 복사해 붙이고 이름만 NOR로 바꾸면 된다. 빌드하고 실행한다.
... 생략 ...
Test OR Gate, (0, 0) -> false
Test OR Gate, (0, 1) -> true
Test OR Gate, (1, 0) -> true
Test OR Gate, (1, 1) -> true
... 생략 ...
Test NOR Gate, (0, 0) -> true
Test NOR Gate, (0, 1) -> false
Test NOR Gate, (1, 0) -> false
Test NOR Gate, (1, 1) -> false
테스트 출력 결과가 NOR 게이트와 일치한다. 그리고 OR 게이트의 출력과 비교하면 반대값이다. 이렇게 NOR 게이트 모델 구현을 완료했다.
첨부 | 파일 크기 |
---|---|
nor-gate-symbol.png | 4.88 KB |
댓글
간단히 인버터에 OR 게이트를 연결하는 것으로
간단히 인버터에 OR 게이트를 연결하는 것으로 구현했습니다.
self.inv.proc(self.orgate.proc(input_a, input_b))
이 코드가 인버터에 입력으로 OR 게이트의 출력을 넣는 코드입니다.
쉽죠?
----------------------
얇은 사 하이얀 고깔은 고이 접어서 나빌레라
댓글 달기