#### 01076113 DIGITAL SYSTEM FUNDAMENTALS IN PRACTICE 2566/1

ภาควิชาวิศวกรรมคอมพิวเตอร์ คณะวิศวกรรมศาสตร์ สถาบันเทคโนโลยีพระจอมเกล้าเจ้าคุณทหารลาดกระบัง

### การทดลองที่ 2 Logic-Gates and Truth Table

### <u>วัตถุประสงค์</u>

- 1. เพื่อให้นักศึกษาเข้าใจการทำงานของไอซีลอจิกเกตพื้นฐาน
- 2. เพื่อให้นักศึกษาฝึกใช้งานโปรแกรมทูลช่วยการออกแบบวงจรดิจิตอลเป็น
- 3. เพื่อให้นักศึกษาฝึกการต่อวงจรแบบ Combination Logic

### Logisim โปรแกรมจำลองการทำงานวงจรดิจิตอล

เป็นโปรแกรมที่ใช้ในการศึกษาและออกแบบวงจรดิจิตอล พัฒนาโดย Dr. Carl Burch สามารถ ใช้งานได้ ง่าย, เป็นโปรแกรมที่ช่วยเรียนรู้ และทดลองวงจร ดิจิตอล ที่นิยมใช้กันใน มหาวิทยาลัย ทั่วโลก โดยตัวโปรแกรมมี ขนาดเล็กและสามารถทำงานโดยไม่จำเป็นที่จะต้องติดตั้งโปรแกรม และสะดวกต่อการศึกษาเบื้องต้น โดย Logisim สามารถ Download ได้จาก https://sourceforge.net/projects/circuit/ วิธีการใช้งาน (สามารถดูได้จาก https://youtu.be/mCkkM-V7NUY)

| ส่วนที่ 1 : ทดลองการทำงานของวงจรที่สร้างขึ้น                     |  |
|------------------------------------------------------------------|--|
| วงจรที่ทดลองคือ Half adder circuit มี Truth table ตามช่างล่างนี้ |  |
| Input Output                                                     |  |
| A B S Co                                                         |  |
| 0 0 0 0                                                          |  |
| 0 1 1 0                                                          |  |
| 1 0 1 0                                                          |  |
| A B S Co<br>0 0 0 0<br>0 1 1 0<br>1 0 1 0<br>1 1 0 1             |  |

# แบบที่ 1 ทดลองสร้างการทำงานวงจรที่สร้างขึ้น

1. Click เลือก Gate ที่จะใช้งาน และนำมาวางที่หน้าจอ



2. สร้าง input pin และตั้งชื่อ



3. สร้าง output pin และตั้งชื่อ



4. เชื่อม input เข้า gate และ output ออกจาก gate



### 5. Click เพื่อทำการสวิตช์ค่า





# แบบที่ 2 ให้ Logisim สร้างวงจรจาก Truth Table ที่กำหนดมา

1. สร้าง input pin, output pin และตั้งชื่อ



2. Click ขวาที่ main และเลือก analyze circuit



3. Click เพื่อตรวจสอบค่า input และ output



4. Click เพื่อกำหนดค่า table ให้ครบทุกตัว



5. กด build circuit และเลือกรูปแบบ gate ที่ต้องการใช้ จากนั้นกด ok จะได้วงจรออกมา





## ไอซีลอจิกเกต

ภายในไอซีลอจิกเกตจะบรรจุเกตต่างๆ ได้แก่ AND, OR, NOT และ XOR เป็นต้น โดยไอซี ลอจิกเกตมี มากมายหลายชนิดและหลากหลายแบบ ในการทดลองนี้จะให้นักศึกษารู้จักไอซีลอจิก 6 ชนิดคือ

| ลำดับ | สัญลักษณ์/เบอร์ไอซี | Truth Table                               | รายละเอียด                                                                                                                                                             |
|-------|---------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | 7408                | a b y<br>0 0 0<br>0 1 0<br>1 0 0<br>1 1 1 | AND gate จากรูปมีสองอินพุต หนึ่ง เอาต์พุต ลักษณะของเอาต์พุตมีค่าเป็น "1" ก็ต่อเมื่อ อินพุตทั้งหมดเป็น "1" เท่านั้น กรณีอื่นๆ ค่า เอาต์พุตเป็น "0"                      |
| 2     | a<br>b<br>7432      | a b y<br>0 0 0<br>0 1 1<br>1 0 1<br>1 1 1 | OR gate จากรูปมีสองอินพุต หนึ่งเอาต์พุต ลักษณะของเอาต์พุต มีค่าเป็น "0" ก็ ต่อเมื่อ อินพุตทั้งหมดเป็น "0" เท่านั้น กรณีอื่นๆ ค่า เอาต์พุตเป็น "1"                      |
| 3     | 7404                | a y<br>0 1<br>1 0                         | NOT gate หรือ Inverter มีหนึ่งอินพุต<br>หนึ่ง เอาต์พุต ผลลัพธ์ของเอาต์พุตเป็นส่วน<br>กลับจาก อินพุต                                                                    |
| 4     | 7400 Y              | a b y<br>0 0 1<br>0 1 1<br>1 0 1<br>1 1 0 | NAND gate ลักษณะของสัญลักษณ์คล้าย กับ AND gate แต่ทางด้านเอาต์พุตเสมือน มี NOT gate เชื่อมต่ออยู่ภายใน ดังนั้น เอาต์พุตที่ได้มี ลักษณะเป็นส่วนกลับของ เป็น AND gate    |
| 5     | a<br>b<br>7402      | a b y<br>0 0 1<br>0 1 0<br>1 0 0<br>1 1 0 | NOR gate ลักษณะของสัญลักษณ์คล้าย<br>กับ OR gate แต่ทางด้านเอาต์พุตเสมือนมี<br>NOT gate เชื่อมต่ออยู่ภายใน ดังนั้น<br>เอาต์พุตที่ได้มี ลักษณะเป็นส่วนกลับของ<br>OR gate |

| ลำดับ | สัญลักษณ์/เบอร์ไอซี | Truth Table                               | รายละเอียด                                                                                                                                                                                                                    |
|-------|---------------------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6     | 7486                | a b y<br>0 0 0<br>0 1 1<br>1 0 1<br>1 1 0 | XOR gate ย่อมาจาก Exclusive-OR gate ใน รูปมีสองอินพุต หนึ่งเอาต์พุต ลักษณะ ของ เอาต์พุตมีค่าเป็น "1" ก็ต่อเมื่ออินพุต ไม่เข้าพวก และค่าเอาต์พุตเป็น "0" เมื่อ อินพุตทุกตัวเป็น "0" ทั้งหมด หรือ อินพุต ทุกตัวเป็น "1" ทั้งหมด |

#### ข้อควรทราบ

- 1. ก่อนลงมือทดลอง ต้องตรวจสอบความสมบูรณ์ด้านความปลอดภัย และการทำงานของอุปกรณ์ และไอซีเสมอ!
- 2. ขา VCC รับแรงดันที่ป้อนให้แก่ไอซีขนาด +5V ส่วนขา GND เป็นขากราวด์ต่อกับ 0V หากต่อ สลับขั้วไอซี อาจพังเสียหาย
- 3. ระดับลอจิก "0" (Low) มีแรงคันช่วง 0 0.5 V และระดับลอจิก "1" (High) มีแรงคันช่วง 2.5 5 V
- 4. ก่อนการต่อสายต้องตรวจสอบให้แน่ใจว่า ไอซีลอจิกเกตที่ใช้เป็นชนิดใด ขาหนึ่งอยู่ทิศทางใด โดย ตรวจสอบได้จากรูปที่ 1 รูปที่ 2 และรูปที่ 3
- 5. การถอดไอซีออกจากโพรโตบอร์ดให้ใช้ไขควงงัดด้านข้างของไอซีอย่างระมัดระวัง เพื่อป้องกัน ขาไอซีชำรุด และอุบัติเหตุบาดเจ็บจากขาไอซีทิ่มแทง



รูปที่ 1 โครงสร้างภายในของไอซีลอจิกเกต



รูปที่ 2 ไดอะแกรมแสดงตัวอย่างการต่อวงจร



รูปที่ 3 แสดงตัวอย่างการต่อวงจร

## ให้นักศึกษาอ่านคำอธิบายการใช้งาน Logic Gates ด้านบนให้เข้าใจ แล้วทำการทดลองด้านล่างต่อไปนี้

- 1. การทดลองเกี่ยวกับการใช้งาน Logic Gates
- 1.1 ให้นักศึกษาอ่านการทดลองทุกข้อก่อน แล้วคำนวณผลลัพธ์ที่น่าจะเกิดขึ้นตามทฤษฐีก่อนทำการ ทดลอง
- 1.2 ให้นักศึกษาต่อวงจรตามรูปด้านล่าง ภายในไอซีลอจิกเกตตัวนี้มี AND gate จำนวน 4 ชุด นักศึกษา สามารถใช้ชุดใดก็ได้โดยนักศึกษาต้องป้อนอินพุตที่ขา a และ b แล้วตรวจสอบค่าเอาต์พุตที่ขา y เมื่อ ต่อวงจร เสร็จให้ตรวจสอบความถูกต้องและบันทึกผลการทดลองลงตารางด้านล่างขวานี้





| Input |     | Output          | Output    |
|-------|-----|-----------------|-----------|
| ıı ıt | out | (Logic Trainer) | (Logisim) |
| а     | b   | Y               | Y         |
| 0     | 0   | 0               | Ø         |
| 0     | 1   | 0               | 0         |
| 1     | 0   | 0               | O         |
| 1     | 1   | 1               | 1         |

1.3 ให้นักศึกษาต่อวงจรแบบเดียวกับการทดลองที่ 1 แต่เปลี่ยน AND gate เป็นเกตอื่นๆ เมื่อต่อวงจร เสร็จ ให้ตรวจสอบความถูกต้องและบันทึกผลการทดลองลงตารางด้านล่างขวานี้



7432



| Input |   | Output<br>(Logic Trainer) | Output<br>(Logisim) |
|-------|---|---------------------------|---------------------|
| a     | b | Y                         | Υ                   |
| 0     | 0 | ٥                         | 0                   |
| 0     | 1 | 1                         | 1                   |
| 1     | 0 | 1                         | 1                   |
| 1     | 1 | 1                         | 1                   |



7404



| loout | Output          | Output    |
|-------|-----------------|-----------|
| Input | (Logic Trainer) | (Logisim) |
| a     | Y               | Υ         |
| 0     | 1               | 1         |
| 1     | 0               | 0         |





| Input |   | Output<br>(Logic Trainer) | Output<br>(Logisim) |  |
|-------|---|---------------------------|---------------------|--|
| a     | b | Υ                         | Υ                   |  |
| 0     | 0 | 1                         | 1                   |  |
| 0     | 1 | 1                         | 1                   |  |
| 1     | 0 | 1                         | 1                   |  |
| 1     | 1 | 0                         | 0                   |  |





| Inp | out | Output<br>(Logic Trainer) | Output<br>(Logisim) |
|-----|-----|---------------------------|---------------------|
| а   | b   | Υ                         | Υ                   |
| 0   | 0   | 1                         | 1                   |
| 0   | 1   | 0                         | 0                   |
| 1   | 0   | 0                         | 0                   |
| 1   | 1   | 0                         | 0                   |





| Input |   | Output<br>(Logic Trainer) | Output<br>(Logisim) |
|-------|---|---------------------------|---------------------|
| a     | b | Y                         | Y                   |
| 0     | 0 | 0                         | 0                   |
| 0     | 1 | 1                         | 1                   |
| 1     | 0 | 1                         | 1                   |
| 1     | 1 | O                         | 0                   |

1.4 ให้นักศึกษาต่อวงจรดังรูปด้านล่าง ซึ่งประกอบด้วยไอซีลอจิกเกตสองตัวเบอร์ 74LS86 กับ 74LS08 ทั้งนี้ต้องพิจารณาจากโครงสร้างภายในจากรูปที่ 1 เพื่อสร้างวงจรขึ้นเอง โดยนักศึกษาต้องป้อนอินพุตที่ ขา a และ b แล้ว บันทึกค่าเอาต์พุตที่ขา x และ y เมื่อต่อวงจรเสร็จให้ตรวจสอบความถูกต้องและบันทึก ผลการทดลองลง ตารางด้านล่างขวานี้



| Input |       | Output |                 | Output |       |
|-------|-------|--------|-----------------|--------|-------|
| 11.14 | Input |        | (Logic Trainer) |        | isim) |
| a     | b     | ×      | у               | ×      | у     |
| 0     | 0     | O      | O               | 0      | O     |
| 0     | 1     | 1      | 0               | 1      | 0     |
| 1     | 0     | 1      | 0               | 1      | 0     |
| 1     | 1     | O      | 1               | 0      | 1     |

- 2. การทดลองการต่อวงจรแบบ Combinational Logic
- 2.1 ให้นักศึกษาต่อวงจรตามรูปด้านล่างนักศึกษา โดยนักศึกษาต้องป้อนอินพุตที่ขา a, b และ c แล้ว ตรวจสอบค่าเอาต์พุตที่ขา y เมื่อ ต่อวงจรเสร็จให้ตรวจสอบความถูกต้องและบันทึกผลการทดลองลงตาราง ด้านล่าง



|   | Input |   |   |   |   | :put<br>isim) |
|---|-------|---|---|---|---|---------------|
| а | b     | С | × | у | × | у             |
| 0 | 0     | 0 | 1 | 1 | 1 | 1             |
| 0 | 0     | 1 | 0 | 1 | 0 | 1             |
| 0 | 1     | 0 | 1 | 0 | 1 | 0             |
| 0 | 1     | 1 | 0 | Ø | Ø | 0             |
| 1 | 0     | 0 | 1 | 1 | 1 | 1             |
| 1 | 0     | 1 | 0 | 1 | O | 1             |
| 1 | 1     | 0 | 0 | O | 0 | 0             |
| 1 | 1     | 1 | O | 0 | O | 0             |



|   | Input |   | Output<br>put (Logic Trainer) |   |   | :put<br>isim) |
|---|-------|---|-------------------------------|---|---|---------------|
| а | b     | С | ×                             | у | × | у             |
| 0 | 0     | 0 | 1                             | O | 1 | 0             |
| 0 | 0     | 1 | 1                             | 1 | 1 | 1             |
| 0 | 1     | 0 | 1                             | 0 | 1 | 0             |
| 0 | 1     | 1 | 0                             | 0 | 0 | 0             |
| 1 | 0     | 0 | 1                             | 0 | 1 | 0             |
| 1 | 0     | 1 | 0                             | 1 | Q | 1             |
| 1 | 1     | 0 | 1                             | 0 | 1 | 0             |
| 1 | 1     | 1 | 0                             | 0 | Ö | O             |

2.2 ให้นักศึกษาทำการทดลองโดยต่อวงจรสำหรับการแสดงผล 7 Segments ที่มีวงจร HEX DECODER บน Logic Trainer โดยใช้ขา output x และ y จากข้อ 2.1 โดย 1) ต่อหลักที่ 1-2 และ 2) ต่อหลักที่ 3-4

2.3 เชิญอาจารย์ หรือผู้คุมการทดลองตรวจ

# ใบตรวจการทดลองที่ 2

| วัน/เดือน/ปี                           | 🗌 กลุ่มเช้า 🔲 กลุ่มบ่าย 🔲 กลุ่มเย็น กลุ่มที่ |
|----------------------------------------|----------------------------------------------|
| รหัสนักศึกษา                           | ชื่อ-นามสกุล                                 |
| การตรวจการทดลอง                        |                                              |
| การทดลองข้อ 2 ลายเซ็นผู้ควบคุมการทดลอง | 1                                            |

หมายเหตุ ไม่รับ ใบตรวจการทดลองที่มีร่องรอยการแก้ไข ขูด ลบ ขีดฆ่า เปลี่ยนแปลงทุกชนิด