Uploaded by Thuong Nguyen

dhcn.bai-giang-ky-thuat-so---ths.-nguyen-trong-hai,-271-trang - [cuuduongthancong.com]

advertisement
BOÄ GIAÙO DUÏC & ÑAØO TAÏO
TRÖÔØNG ÑAÏI HOÏC KYÕ THUAÄT COÂNG NGHEÄ
THAØNH PHOÁ HOÀ CHÍ MINH
BAØI GIAÛNG
KYÕ THUAÄT SOÁ
Ths. NGUYEÃN TROÏNG HAÛI
LÖU HAØNH NOÄI BOÄ
05/2006
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
MUÏC LUÏC
TOÅNG QUAN .................................................................................................... Trang 1
CHÖÔNG 1. HEÄ THOÁNG SOÁ ÑEÁM ........................................................................... 4
1.1. Cô soá – chuyeån ñoåi cô soá..................................................................................4
1.2. Caùc boä maõ hoùa soá heä möôøi thoâng duïng ..........................................................14
CHÖÔNG 2. ÑAÏI SOÁ BOOLEAN VAØ CAÙC COÅNG LOGIC .................................. 24
2.1. Khaùi nieäm veà logic hai traïng thaùi ...................................................................24
2.2. Baûng söï thaät ....................................................................................................24
2.3. Caùc pheùp toaùn cô baûn .....................................................................................25
2.4. Moâ taû caùc maïch logic theo phöông phaùp ñaïi soá .............................................25
2.5. Thöïc hieän caùc maïch logic töø bieåu thöùc Boolean.............................................25
2.6. Coång NOR vaø NAND .....................................................................................26
2.7. Pheùp toaùn XOR vaø pheùp toaùn töông ñöông ....................................................27
2.8. Caùc ñònh lyù cô baûn cuûa ñaïi soá Boolean...........................................................27
2.9. Logic döông vaø aâm .........................................................................................31
2.10. Caùc haøm cô baûn vaø phöông phaùp bieåu dieãn ..................................................23
2.11. Toái thieåu haøm logic baèng bìa K ....................................................................38
CHÖÔNG 3. MAÏCH LOGIC TOÅ HÔÏP ..................................................................... 45
3.1. Giôùi thieäu ........................................................................................................45
3.2. Thieát keá maïch logic toå hôïp .............................................................................45
3.3. Kyõ thuaät cöïc tieåu Quine-Mc Cluskey .............................................................47
3.4. Thieát keá maïch khoâng söû duïng baûng söï thaät ....................................................49
3.5. Maïch giaûi maõ ..................................................................................................53
3.6. Maïch maõ hoùa ..................................................................................................59
3.7. Boä choïn keânh..................................................................................................62
3.8. Boä phaân keânh..................................................................................................65
3.9. Maïch soá hoïc ....................................................................................................67
3.10. Maïch chuyeån maõ .........................................................................................69
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
CHÖÔNG 4. HEÄ TUAÀN TÖÏ....................................................................................... 74
4.1. Toång quan .......................................................................................................74
4.2. Caùc phaàn töû hai traïng thaùi beàn........................................................................75
4.3. FlipFlop...........................................................................................................76
4.4. FlipFlop duøng xung clock................................................................................79
4.5. Caùc öùng duïng cuûa FlipFlop.............................................................................83
4.6. Maùy traïng thaùi ..............................................................................................104
4.7. Löu ñoà maùy traïng thaùi ..................................................................................105
4.8. Boä nhôù baùn daãn .............................................................................................116
4.9. ROM – thieát keá heä thoáng soá duøng ROM ......................................................118
4.10. PLD toå hôïp ..................................................................................................127
4.11. PLD tuaàn töï.................................................................................................132
4.12. Caùc PLD tuaàn töï khaùc .................................................................................135
CHÖÔNG 5. CAÙC HOÏ VI MAÏCH SOÁ..................................................................... 146
5.1. Toång quan .....................................................................................................146
5.2. Caùc ñaëc tröng cuûa vi maïch soá .......................................................................146
5.3. Hoï RTL .........................................................................................................148
5.4. Hoï DTL.........................................................................................................148
5.5. Hoï TTL .........................................................................................................148
5.6. Caùc ñaëc ñieåm cuûa hoï TTL chuaån..................................................................149
5.7. Hoï TTL caûi tieán ............................................................................................150
5.8. Hoï TTL vôùi ngoõ ra cöïc thu hôû ......................................................................150
5.9. Hoï TTL ba traïng thaùi ....................................................................................151
5.10. Maïch logic MOS .........................................................................................151
5.11. Hoï CMOS ...................................................................................................151
5.12. Moät soá vi maïch thoâng duïng ........................................................................152
CHÖÔNG 6. GIAO TIEÁP TÖÔNG TÖÏ - SOÁ ........................................................... 153
6.1. Bieán ñoåi ADC ...............................................................................................153
6.2. Bieán ñoåi DAC ...............................................................................................160
PHUÏ LUÏC A. TRA CÖÙU CAÙC IC THOÂNG DUÏNG..............................................167
PHUÏ LUÏC B. COÂNG CUÏ CAD TRONG THIEÁT KEÁ SOÁ .....................................251
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Tổng quan
TOÅNG QUAN
Caùc heä thoáng soá thöôøng söû duïng roäng raõi trong tính toaùn vaø xöû lyù data nhö trong
caùc heä thoáng ñieàu khieån, trong thoâng tin, vaø trong ño löôøng vì caùc heä thoáng soá coù
khaû naêng chính xaùc cao hôn caùc heä thoáng töông töï.
Trong moät heä thoáng soá, caùc tín hieäu vaät lyù coù theå xem nhö caùc giaù trò rôøi raïc, trong
khi ôû heä thoáng töông töï caùc ñaïi löôïng naøy thay ñoåi lieân tuïc.
Ví dụ, ñieän aùp ngoõ ra cuûa moät heä thoáng soá coù theå ñöôïc bieán ñoåi sao cho ngoõ ra chæ
coù 2 giaù trò 0 vaø 1, trong khi ñieän aùp ngoõ ra töø heä thoáng töông töï coù giaù trò thay ñoåi
trong khoaûng töø Vmin ñeán Vmax
Do caùc heä thoáng soá laøm vieäc vôùi caùc ñaïi löôïng rôøi raïc, trong nhieàu tröôøng hôïp coù
theå ñöôïc thieát keá vôùi keát quaû ngoõ vaøo vaø ngoõ ra moät caùch chính xaùc.
Ví dụ, neáu nhaân 2 soá goàm 5 chöõ soá söû duïng boä nhaân digital thì keát quaû laø moät soá coù
10 chöõ soá chính xaùc caû 10. Noùi caùch khaùc, ngoõ ra cuûa boä nhaân analog coù theå coù moät
khoaûng sai soá (%) tuøy thuoäc vaøo ñoä chính xaùc cuûa caùc thaønh phaàn thieát laäp neân boä
nhaân.
Thieát keá cuûa caùc heä thoáng soá coù theå chia ra 3 phaàn:
Thiết kế
hệ thống
•
Thiết kế
Logic
Thiết kế
Mạch
Thiết kế hệ thống (system design) bao goàm vieäc chia nhoû moät heä thoáng lôùn
thaønh caùc heä thoáng con vaø chæ roõ caùc ñaëc tính cuûa moãi heä thoáng con. Ví dụ, thieát
keá heä thoáng cuûa moät maùy tính soá bao goàm vieäc chæ ra soá vaø daïng cuûa caùc ñôn vò
nhôù, ñôn vò toaùn hoïc, caùc thieát bò vaøo ra cuõng nhö vieäc keát noái vaø ñieàu khieån
cuûa caùc heä thoáng con naøy v.v...
•
Thiết kế logic (logic design) bao goàm vieäc xaùc ñònh laøm theá naøo ñeå keát noái caùc
khoái logic cô baûn ñeå hình thaønh haøm ñaëc bieät.
•
Thiết kế mạch bao goàm vieäc chæ ra caùc keát noái beân trong cuûa caùc thaønh phaàn
nhö ñieän trôû, diode, transistor ñeå hình thaønh moät coång, flipflop hoaëc caùc khoái
logic khaùc. Haàu heát caùc thieát keá maïch hieän taïi ñöôïc thöïc hieän döôùi daïng maïch
tích hôïp duøng coâng cuï thieát keá vôùi söï trôï giuùp cuûa maùy tính ñeå taïo caùc keát noái
trong giöõa caùc thaønh phaàn treân moät chip silicon.
Nhieàu heä thoáng con coù daïng chuyeån maïch nhö sau:
Inputs
X1
X2
Switching
Network
Xm
Z1
Z2
Outputs
Zn
Trang 1
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Tổng quan
Moät maïng chuyeån maïch coù moät hay nhieàu ngoõ vaøo vaø moät hay nhieàu ngoõ ra, 2 loaïi
switching network thoâng thöôøng laø:
•
Mạch tổ hợp, trong ñoù caùc tín hieäu ngoõ ra chæ leä thuoäc vaøo traïng thaùi ngoõ
vaøo hieän taïi (khoâng leä thuoäc vaøo giaù trò ngoõ vaøo tröôùc ñoù).
•
Mạch tuần tự, caùc ngoõ ra seõ tuøy thuoäc caû giaù trò tröôùc ñoù vaø giaù trò hieän taïi
cuûa ngoõ vaøo. Noùi caùch khaùc, ñeå xaùc ñònh ngoõ ra cuûa maïch tuaàn töï, moät
chuoãi caùc ngoõ vaøo phaûi ñöôïc xaùc ñònh. Maïch tuaàn töï ñöôïc goïi laø maïch coù
nhôù vì noù phaûi nhôù moät soá traïng thaùi tröôùc ñoù cuûa ngoõ vaøo, trong khi maïch
toå hôïp thì khoâng coù nhôù. Toång quaùt, maïch tuaàn töï laø keát hôïp cuûa moät maïch
toå hôïp vôùi caùc phaàn töû nhôù.
Caùc khoái cô baûn söû duïng trong caùc maïch toå hôïp laø caùc cổng logic. Khi thieát keá
logic, phaûi xaùc ñònh laøm theá naøo keát noái caùc coång naøy ñeå bieán ñoåi caùc tín hieäu ngoõ
vaøo thaønh caùc tín hieäu ngoõ ra mong muoán.
Moái quan heä giöõa caùc tín hieäu ngoõ vaøo vaø ngoõ ra phaûi ñöôïc moâ taû toaùn hoïc, trong
thieát keá soá goïi laø đại số Boolean.
Các bước thiết kế một mạch tổ hợp
•
Thieát laäp moät baûng moâ taû moái quan heä giöõa ngoõ ra vaø toå hôïp ngoõ vaøo
•
Thieát laäp bieåu thöùc logic toaùn hoïc moâ taû caùc ngoõ ra nhö moät haøm cuûa caùc
ngoõ vaøo.
•
Ruùt goïn bieåu thöùc logic moâ taû ngoõ ra duøng moät soá phöông phaùp thoâng duïng
nhö bìa Karnaugh, Quine-McCluskey v.v...
•
Thöïc hieän maïch
Caùc phaàn töû nhôù cô baûn trong thieát keá maïch tuaàn töï laø caùc FlipFlop. Caùc flipflop coù
theå ñöôïc keát noái vôùi caùc coång ñeå hình thaønh moät maïch tuaàn töï.
Các bước thiết kế một mạch tuần tự
•
Thieát laäp moät baûng moâ taû moái quan heä giöõa ngoõ ra hieän taïi vaø ngoõ ra keá
tieáp.
•
Thieát laäp bieåu thöùc logic toaùn hoïc moâ taû caùc ngoõ vaøo cuûa flipflop nhö moät
haøm cuûa caùc ngoõ ra.
•
Ruùt goïn bieåu thöùc logic moâ taû ngoõ vaøo duøng moät soá phöông phaùp thoâng
duïng nhö bìa Karnaugh, Quine-McCluskey v.v...
•
Thöïc hieän maïch
Phaân tích moät caùch toång quaùt veà caùc maïch tuaàn töï thöôøng duøng caùc giản đồ thời
gian, máy trạng thái và graph.
Phần tử chuyển mạch duøng trong caùc heä thoáng soá thöôøng laø caùc phaàn töû 2 traïng
thaùi, ngoõ ra chæ coù 2 giaù trò rôøi raïc khaùc nhau. Ví dụ relay, diode, transistor... Hai
traïng thaùi cuûa relay laø ñoùng vaø môû tuøy thuoäc vaøo nguoàn cung caáp cho cuoän daây.
Trang 2
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Tổng quan
Hai traïng thaùi cuûa diode laø traïng thaùi daãn vaø khoâng daãn. Hai traïng thaùi cuûa
transistor laø baõo hoøa vaø taét, vì vaäy thöôøng duøng caùc soá nhò phaân trong caùc heä thoáng
soá.
Baát cöù caùc thieát keá logic soá naøo cuõng coù theå ñöôïc thöïc hieän nhôø PLD
(Programmable Logic Design). PLD laø teân goïi toång quaùt cuûa moät IC soá maø coù theå
laäp trình ñöôïc ñeå thöïc hieän caùc haøm logic khaùc nhau vaø laø moät chip chöùa caùc caáu
truùc maïch coù qui luaät cho pheùp ngöôøi thieát keá taïo caùc öùng duïng cuï theå
Quá trình thiết kế PLD như sau
Ý tưởng
Trình soạn
thảo mạch
Trình soạn
thảo văn bản
Trình biên dịch
và mô phỏng
Kit nạp IC
Moät soá coâng cuï phaàn meàm hoã trôï trong thieát keá soá: MAX+PLUS II, ABEL,
SYNARYO...
Moät soá ngoân ngöõ moâ taû phaàn cöùng: ABEL, VHDL, AHDL,...
Trang 3
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
CHƯƠNG 1. HỆ THỐNG SỐ ĐẾM
1.1.
CƠ SỐ - CHUYỂN ĐỔI CƠ SỐ
1.1.1. Khái niệm
Baát cöù moät soá nguyeân döông R (R>1) ñeàu coù theå ñöôïc choïn laøm cô soá cho moät
heä thoáng soá.
Neáu heä thoáng coù cô soá R thì caùc soá töø 0 ñeán (R-1) ñöôïc söû duïng.
Ví duï: neáu R=8 thì caùc chöõ soá caàn thieát laø 0,1,2,3,4,5,6,7.
Caùc heä thoáng cô soá thoâng duïng trong kyõ thuaät soá:
•
Thaäp phaân (cô soá 10).
•
Nhò phaân (cô soá 2).
•
Baùt phaân (cô soá 8).
•
Thaäp luïc phaân (cô soá 16).
Một hệ thống với cơ số R được biểu diễn dưới dạng
(…a3a2a1a0 a-1a-2a-3…)R
Phần
nguyên
Phần thập
phân
Khai trieån theo haøm muõ cuûa R.
N =(a3a2a1a0a-1a-2a-3)R
= a3.R3 + a2.R2 + a1.R1 + a0.R0 + a-1.R-1 + a-2.R-2 + a-3.R-3
Vôùi caùc cô soá lôùn hôn 10 thì caàn phaûi theâm caùc kyù hieäu ñeå bieåu hieän caùc soá lôùn
hôn 10. Ví duï heä thaäp luïc phaân (hex) coù cô soá 16 thì A bieåu thò 10, B bieåu thò
11,…, F bieåu thò 15.
Đổi giữa các cơ số
Phần nguyên và phần thập phân được đổi một cách riêng biệt
Phần nguyên được đổi bằng cách sử dụng phép chia lặp cho cơ số mới và sử
dụng chuỗi các số dư phát sinh để tạo ra số mới. Phép tính số học được thực
hiện trên các số hạng của cơ số cũ
Phần thập phân được đổi bằng cách nhân lặp lại cho cơ số mới, sử dụng các
số nguyên được tạo ra để biểu thị phân số được chuyển đổi, phép tính số
học được thực hiện trên các cơ số cũ
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 4
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
Ví dụ: Biến đổi phần nguyên trong hệ cơ số 10 sang hệ cơ số R
N = (anan-1…a2a1a0)R = an.Rn + an-1.Rn-1 + … + a2.R2 + a1.R1 + a0
Neáu chia N cho R, nhaän ñöôïc soá dö laø a0
a
N
= an.Rn-1 + an-1.Rn-2 + … + a2.R1 + a1 + 0 = Q1 + soá dö a0
R
R
Chia Q1 cho R
Q1
a
= an.Rn-2 + an-1.Rn-3 + … + a3.R1 + a2 + 1 = Q2 + soá dö a1
R
R
Quaù trình treân ñöôïc thöïc hieän tieáp tuïc cho ñeán khi tìm ñöôïc taát caû caùc heä soá an
Ví dụ: Biến đổi phần thập phân của hệ cơ số 10 sang hệ cơ số R
F = (a-1a-2a-3…a-m)R
= a-1.R-1 + a-2.R-2 + a-3.R-3 +… + a-m.R-m
Nhaân F vôùi R
FR = a-1 + a-2.R-1 + a-3.R-2 +… + a-m.R-m+1 = a-1 + F1
Vôùi a-1 laø phaàn nguyeân, F1 laø phaàn leû cuûa pheùp nhaân
Tieáp tuïc nhaân R vôùi F1
F1.R = a-2 + a-3.R-1 + a-4.R-2 + … + a-m.R-m+2 = a-2 + F2
Tieáp tuïc quaù trình cho ñeán khi xaùc ñònh heát caùc heä soá a-m
Biến đổi giữa 2 cơ số không phải là cơ số 10 có thể thực hiện dễ dàng bằng cách
đầu tiên biến đổi sang cơ số 10 rồi biến đổi tiếp từ cơ số 10 sang cơ số mới.
1.1.2. Hệ thập phân (hệ cơ số 10)
Heä thaäp phaân ñöôïc keát hôïp bôûi 10 chöõ soá: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9
Moät chöõ soá trong heä thaäp phaân ñöôïc bieåu dieãn theo caùc soá muõ cuûa 10.
Troïng soá
103 102 101 100
5
MSD
3
4
6
10-1 10-2
,
Ñieåm thaäp
phaân
7 2
LSD
Soá mang troïng soá lôùn nhaát goïi laø MSD (most significant digit)
Soá mang troïng soá nhoû nhaát goïi laø LSD (least significant digit)
Ví dụ: Soá 5346,72 bieåu dieãn nhö sau:
5346,72 = 5.103 + 3.102 + 4.10 + 6 + 7.10-1 + 2.10-2
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 5
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
•
Chương 1
Ñeám trong heä thaäp phaân:
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
100
101
102
103
104
105
106
107
108
109
99
Toång quaùt vôùi N chöõ soá coù theå ñeám ñöôïc 10N soá khaùc nhau, bao goàm caû soá 0. Soá
thaäp phaân lôùn nhaát laø 10N – 1.
1.1.3. Hệ nhị phân (hệ cơ số 2)
Heä nhò phaân duøng hai chöõ soá 0, 1.
Moät soá trong heä nhò phaân ñöôïc bieåu dieãn theo soá muõ cuûa 2.
Troïng soá
23
22 21 20 2-1 2-2 2-3
1 0
MSB
1 1 1 0 1
Ñieåm nhò
phaân
LSB
Moät chöõ soá nhò phaân goïi laø bit.
Chuoãi 4 bit nhò phaân goïi laø nibble.
Chuoãi 8 bit goïi laø byte.
Chuoãi 16 bit goïi laø word.
Chuoãi 32 bit goïi laø double word.
Chöõ soá nhò phaân beân phaûi nhaát cuûa chuoãi bit goïi laø bit coù yù nghóa nhoû nhaát (least
significant bit – LSB)
Chöõ soá nhò phaân beân traùi nhaát cuûa chuoãi bit goïi laø bit coù yù nghóa lôùn nhaát (most
significant bit – MSB).
Thöôøng duøng chöõ B cuoái chuoãi bit ñeå xaùc ñònh ñoù laø soá nhò phaân.
Ví dụ: Soá 1011,101B bieåu dieãn giaù trò soá:
1011,101B = 1.23 + 0.22 + 1.21 +1.20 + 1.2-1 + 0.2-2 + 1.2-3
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 6
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
•
Chương 1
Ñeám trong heä nhò phaân
Xeùt boä ñeám 4 bit, baét ñaàu vôùi taát caû caùc bit = 0
Troïng soá
23 = 8
22 = 4
21 = 2
20 = 1
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
0
0
0
0
1
1
1
1
0
0
0
0
1
1
1
1
0
0
1
1
0
0
1
1
0
0
1
1
0
0
1
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
Cuõng nhö trong heä thaäp phaân, neáu duøng N bit seõ ñeám ñöôïc 2N laàn.
•
Chuyeån soá nhò phaân thaønh soá thaäp phaân:
Phương pháp: Coäng troïng soá caùc bit 1
Ví dụ: 1011,11B = 1.23 + 0.22 + 1.21 + 1 + 1.2-1 + 1.2-2 = 11,75
•
Chuyeån soá thaäp phaân thaønh soá nhò phaân:
Phương pháp:
Phaàn nguyeân: Chia 2, nhôù laïi soá dö
Phaàn thaäp phaân: Nhaân 2, nhôù laïi phaàn nguyeân
Ví dụ: Chuyeån (25)10 ra soá nhò phaân
25
= 12
2
12
=6
2
6
=3
2
3
=1
2
1
=0
2
+ soá dö 1
+ soá dö 0
+ soá dö 0
+ soá dö 1
+ soá dö 1
MSB
25 =
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
LSB
1
1
0
0
Trang 7
https://fb.com/tailieudientucntt
1
Bài Giảng Kỹ Thuật Số
Chương 1
Ví dụ: Chuyeån (0,625)10 thaønh soá nhò phaân
0,625 × 2 = 1,25
0,25
× 2 = 0,5
0,5
× 2 = 1,0
0,625 = 0,101B
1.1.4. Các phép toán số học trên số nhị phân
Caùc pheùp toaøn soá hoïc treân soá nhò phaân chuû yeáu vaãn gioáng caùc pheùp toaùn treân soá
thaäp phaân, ngoaïi tröø pheùp coäng vaø pheùp nhaân thì ñôn giaûn hôn.
Baûng pheùp coäng cho soá nhò phaân
0+0=0
0+1=1
1+0=1
1+1=0
nhôù 1 cho soá haïng keá tieáp
Ví dụ: coäng 1310 vôùi 1110 döôùi daïng nhò phaân
1111
← caùc soá nhôù
1310 = 1101
1110 = 1011
11000 =2410
Baûng pheùp tröø cho soá nhò phaân
0-0=0
0-1=1
möôïn 1 töø soá haïng keá tieáp
1-0=1
1-1=0
Möôïn1 töø 1 coät töông ñöông vôùi vieäc tröø 1 taïi coät ñoù
Ví dụ:
(a)
1
← (möôïn 1 töø coät thöù 3)
11101
- 10011
1010
(b)
1111 ← (möôïn)
10000
11
1101
Baûng pheùp nhaân cho soá nhò phaân
0x0=0
0x1=0
1x0=0
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 8
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
1x1=1
Ví dụ: Nhaân 1310 vôùi 1110 ôû daïng nhò phaân
1101
1011
1101
1101
0000
1101
10001111 =14310
Ñoái vôùi maùy tính, pheùp nhaân ñöôïc thöïc hieän baèng phöông phaùp coäng vaø dòch
traùi:
-
Thaønh phaàn ñaàu tieân cuûa toång seõ chính laø soá bò nhaân neáu nhö LSB cuûa soá
nhaân laø 1. Ngöôïc laïi, LSB cuûa soá nhaân baèng 0 thì thaønh phaàn naøy baèng 0.
-
Moãi thaønh phaàn thöù i keá tieáp seõ ñöôïc tính töông töï vôùi ñieàu kieän laø phaûi dòch
traùi soá bò nhaân i bit.
-
Keát quaû caàn tìm chính laø toång caùc thaønh phaàn noùi treân.
Pheùp chia cho soá nhò phaân
Pheùp chia caùc soá nhò phaân cuõng töông töï nhö ñoái vôùi caùc soá thaäp phaân.
Ví dụ: 30/6
11110
110
011
000
110
110
0
110
101
Töông töï nhö ñoái vôùi pheùp nhaân, ta coù theå duøng pheùp tröø vaø pheùp dòch phaûi cho
ñeán khi khoâng theå thöïc hieän pheùp tröø ñöôïc nöõa.
1.1.5. Số có dấu - không dấu
Heä thoáng soá ñöôïc chia laøm 2 loaïi: khoâng daáu vaø coù daáu.
Trong heä thoáng coù daáu: ñeå bieåu thò soá nhò phaân coù daáu thöôøng söû duïng bit MSB
ñeå chæ daáu: bit 0 chæ soá döông, bit 1 chæ soá aâm, caùc bit coøn laïi ñeå chæ ñoä lôùn
Nhö vaäy, neáu ta duøng 8 bit ñeå bieåu dieãn thì seõ thu ñöôïc 256 toå hôïp öùng vôùi caùc
giaù trò 0..255 (soá khoâng daáu) hay –127.. –0 +0 … +127 (soá coù daáu).
Tuy nhieân, khoâng ñôn giaûn laø cöù thay ñoåi bit MSB baèng 1 ñeå bieåu dieãn giaù trò
aâm, ví duï nhö 01000001 (+65) thaønh 11000001 (-65), caùc pheùp tính soá hoïc seõ
khoâng coøn ñuùng.
Giaù trò aâm ñöôïc moâ taû döôùi daïng soá buø 2.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 9
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
Soá buø 2 (2’s component)
Soá buø 2 cuûa moät soá nhò phaân xaùc ñònh baèng caùch laáy ñaûo caùc bit roài coäng theâm 1.
Ví dụ: Trong heä thoáng coù daáu 8bit
Soá +65 bieåu dieãn laø: 0100 0001
Soá buø 2 cuûa +65 laø: 1011 1110 + 1 = 1011 1111. (– 65)
Nhöng neáu ñoåi ngöôïc 1011 1111 sang thaäp phaân seõ khoâng nhaän ñöôïc -65. Ñeå
xaùc ñònh giaù trò tuyeät ñoái cuûa moät soá nhò phaân aâm, thöïc hieän laïi caùc böôùc treân
-65
10111111
ñaûo bit
01000000
coäng 1
1
+65
01000001
Thöû laïi baèng caùch laáy toång cuûa +65 vaø –65, keát quaû phaûi baèng 0
+65
-65
00
01000001
+10111111
(1)00000000
Trong pheùp coäng vôùi soá buø 2, ta boû qua bit nhôù cuoái cuøng bôûi vì coù moät bit gaùn
cho bit daáu neân keát quaû vaãn ñuùng
Khi bieåu dieãn theo soá buø 2, neáu söû duïng 8 bit ta seõ coù caùc giaù trò soá thay ñoåi töø
-128 ..127.
Pheùp tröø thoâng qua soá buø 2
Ngoaøi caùch tröø nhö treân, ta cuõng coù theå thöïc hieän pheùp tröø thoâng qua soá buø 2 cuûa
soá tröø: A-B=A+(-B)
VD:
0110 1101
- 0011 0001
Soá buø 1
→
1
Nhôù
0110 1101
+ 1100 1111
0011 1100
1100 1110 + 1 = 1100 1111 (Soá buø 2)
Keát quaû 0011 1100, Bit MSB = 0 cho bieát keát quaû laø soá döông.
Xeùt khoaûng thay ñoåi sau
+3
00000011
+2
00000010
+1
00000001
0
00000000
-1
11111111
-2
11111110
-3
11111101
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 10
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
Thaáy raèng caùc bit 0 ôû soá nhò phaân aâm bieåu thò giaù trò thaäp phaân cuûa noù: tính giaù
trò cuûa caùc bit 0 theo vò trí gioáng nhö vôùi bit 1, coäng caùc giaù trò laïi vaø coäng 1.
1.1.6. Hệ bát phân (hệ cơ số 8)
Heä baùt phaân ñöôïc keát hôïp bôûi 8 chöõ soá: 0, 1, 2, 3, 4, 5, 6, 7.
Vò trí cuûa moãi chöõ soá coù troïng soá nhö sau:
84
83
82
81
80
8-1
8-2
8-3
8-4
8-5
Ñieåm baùt phaân
¾ Ñeám trong heä baùt phaân
0
10
1
11
2
12
3
4
5
6
66
7
67
70
71
72
277
300
Vôùi N chöõ soá baùt phaân, ta coù theå ñeám töø 0 ñeán 8N-1, 8N laàn ñeám khaùc nhau.
¾ Chuyeån soá baùt phaân sang soá thaäp phaân:
Ví dụ: (24.6)8 = 2.81 + 4.80 + 6.8-1 =(20.75)10
¾ Chuyeån soá thaäp phaân sang baùt phaân:
Ví dụ: ñoåi (266)10 sang heä baùt phaân
266
= 33
8
+ soá dö 2
33
= 4 + soá dö 1
8
4
= 0 + soá dö 4
8
26610 =
4128
Ví dụ: Chuyeån 0,3125 thaønh soá baùt phaân
0,3125 × 8 = 2.5
0,5
× 8 = 4.0
( 0,3125 = 0,248 )
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 11
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
¾ Chuyeån soá baùt phaân sang soá nhò phaân:
Phương pháp: Bieán ñoåi moãi chöõ soá baùt phaân sang 3 bit nhò phaân töông öùng
Soá Octal
Soá nhò phaân
töông ñöông
0
000
1
001
2
010
3
011
4
100
5
101
6
110
7
111
Ví dụ: Bieán ñoåi (472)8 sang soá nhò phaân nhö sau:
4
↓
100
7
↓
111
2
↓
010
Vaäy (472)8 chuyeån sang nhò phaân laø 100111010B.
¾ Chuyeån soá nhò phaân sang soá baùt phaân.
Phương pháp: nhoùm töøng 3 bit baét ñaàu taïi LSB, sau ñoù chuyeån moãi nhoùm
naøy sang soá baùt phaân töông öùng (theo baûng chuyeån ñoåi ôû treân).
Ví dụ: chuyeån 100111010B sang soá baùt phaân
100111010
↓
(4
↓
7
↓
2)8
Tröôøng hôïp caùc soá nhò phaân khoâng ñuû thaønh 1 nhoùm 3 bits, ta theâm 1 hoaëc 2
soá 0 veà beân traùi cuûa MSB.
Ví dụ: chuyeån 11010110 sang soá baùt phaân
011010110
↓
(3
↓
2
↓
6)8
¾ Lôïi ích cuûa heä baùt phaân
Vieäc deã daøng chuyeån töø heä baùt phaân sang nhò phaân vaø ngöôïc laïi laøm cho heä
baùt phaân raát coù lôïi trong vieäc ruùt ngaén caùc soá nhò phaân lôùn. Trong maùy tính,
caùc soá nhò phaân naøy khoâng phaûi luoân luoân bieåu hieän moät con soá maø thöôøng
bieåu thò döôùi daïng maõ mang thoâng tin, ví duï:
• döõ lieäu baèng soá thöïc
• caùc soá töông öùng vôùi caùc vò trí (ñòa chæ) trong boä nhôù
• maõ leänh
• maõ bieåu thò soá hoïc vaø caùc ñaëc ñieåm khaùc
• moät noùm caùc bit bieåu hieän traïng thaùi cuûa caùc thieát bò trong vaø ngoaøi
maøy tính
Khi giaûi quyeát moät löôïng lôùn caùc soá nhò phaân vôùi nhieàu bit, thöôøng duøng caùc
soá döôùi daïng baùt phaân hôn laø nhò phaân ñeå taêng ñoä tieän lôïi, maëc duø caùc maïch
soá vaø caùc heä thoáng soá laøm vieäc hoaøn toaøn treân soá nhò phaân.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 12
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
Ví dụ: Chuyeån soá 11710 sang heä baùt phaân roài chuyeån sang heä nhò phaân
Giaûi
177
= 22
8
+ soá dö 1
22
=2
8
+ soá dö 6
2
=0
8
+ soá dö 2
Vaäy (177)10 =(261)8 = (10110001)2
Phöông phaùp chuyeån soá thaäp phaân thaønh soá nhò phaân naøy thöôøng nhanh hôn
vieäc chuyeån thaúng töø thaäp phaân sang nhò phaân, ñaëc bieät ñoái vôùi caùc soá lôùn.
Cuõng nhö vaäy ñoái vôùi vieäc chuyeån ngöôïc laïi töø nhò phaân sang thaäp phaân
baèng caùch chuyeån sang soá baùt phaân
1.1.7. Hệ thập lục phân (hệ cơ số 16)
Trong heä thoáng naøy, ta duøng caùc soá 0..9 vaø caùc kí töï A..F ñeå bieåu dieãn cho moät
giaù trò soá (töông öùng vôùi 10 ñeán 15 trong heä 10). Thoâng thöôøng, ta duøng chöõ H ôû
cuoái ñeå xaùc ñònh ñoù laø soá thaäp luïc phaân.
Heä thaäp luïc phaân
0
1
2
3
4
5
6
7
8
9
A
B
C
D
E
F
Heä thaäp phaân
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Heä nhò phaân
0000
0001
0010
0011
0100
0101
0110
0111
1000
1001
1010
1011
1100
1101
1110
1111
¾ Ñeám trong heä thaäp luïc phaân (hex)
Khi ñeám trong heä thaäp luïc phaân moãi chöõ soá taêng töø 0 ñeán F sau ñoù veà 0 vaø
chöõ soá coù troïng soá lôùn hôn keá tieáp seõ taêng leân 1.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 13
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
0
10
20
9
A
B
C
D
E
F
19
1A
FF
100
1E
1F
6FF
700
¾ Chuyeån soá hex sang thaäp phaân
Ví dụ:
35616 = 3.162 + 5.161 + 6.160 = 85410
¾ Chuyeån soá hex sang nhò phaân
Phương pháp: moãi chöõ soá hex ñöôïc bieán ñoåi thaønh soá nhò phaân 4 bit töông
öùng.
Ví dụ:
9F216 =
9
F
2
↓
↓
↓
1001 1111 0010
¾ Chuyeån ñoåi soá nhò phaân sang soá hex
Phương pháp: caùc bit nhò phaân ñöôïc nhoùm vaøo nhoùm 4 bit töø LSB, moãi
nhoùm 4 bit ñöôïc bieán ñoåi sang soá hex töông öùng. Neáu soá bit khoâng ñuû 4, thì
coäng theâm bit 0 vaøo MSB.
Ví dụ:
11101001102 = 0 0 1 1 1 0 1 0 0 1 1 0 = 3A616
3
A
6
Ví dụ: Chuyeån (378)10 sang soá hex roài chuyeån sang soá nhò phaân, nhaän xeùt
Ví dụ: Chuyeån B2F16 sang baùt phaân
1.2.
CÁC BỘ MÃ HÓA SỐ HỆ MƯỜI THÔNG DỤNG
Khi caùc soá, maãu töï hoaëc caùc töø words ñöôïc bieåu thò döôùi daïng moät nhoùm caùc kyù
hieäu khaùc, ta noùi raèng chuùng ñöôïc maõ hoùa vaø nhoùm kyù töï ñoù ñöôïc goïi laø moät
maõ.
Moät trong nhöõng maõ thoâng duïng nhaát laø maõ Morse, chuùng bao goàm caùc chaám vaø
gaïch ñeå bieåu hieän caùc maãu töï hay caùc chöõ caùi.
Baát cöù soá thaäp phaân naøo cuõng coù theå ñöôïc moâ taû baèng soá nhò phaân töông öùng,
moät nhoùm caùc soá nhò phaân 0 vaø 1 coù theå ñöôïc xem laø moät maõ cho soá thaäp phaân.
Khi moät soá thaäp phaân ñöôïc moâ taû baèng soá nhò phaân töông öùng vôùi noù, ngöôøi ta
goïi laø maõ nhò phaân tröïc tieáp (straight binary code)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 14
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
Taát caû caùc heä thoáng soá duøng moät soá daïng caùc soá nhò phaân cho vieäc thöïc thi beân
trong, nhöng caùc töø beân ngoaøi thì thöôøng laø thaäp phaân, nghóa laø coù moät söï bieán
ñoåi thöôøng xuyeân töø thaäp phaân sang nhò phaân, söï bieán ñoåi töø thaäp phaân sang nhò
phaân coù theå chieám moät khoaûng thôøi gian laâu vaø phöùc taïp ñoái vôùi moät soá lôùn. Vì
lyù do ñoù, vieäc maõ hoùa caùc soá thaäp phaân baèng caùch keát hôïp moät vaøi chöùc naêng
cuûa caû heä thoáng thaäp phaân vaø nhò phaân ñöôïc söû duïng trong caùc tình huoáng.
1.2.1. Mã BCD (Binary-Coded-Decimal Code)
Neáu moãi chöõ soá cuûa soá thaäp phaân ñöôïc moâ taû baèng soá nhò phaân töông öùng vôùi
noù, keát quaû ta ñöôïc 1 maõ goïi laø maõ BCD, vì chöõ soá thaäp phaân lôùn nhaát laø 9, caàn
4 bit ñeå maõ hoùa.
Caùc soá 8,4,2,1 ñöôïc goïi laø troïng soá cuûa maõ vaø ñöôïc goïi laø maõ BCD 8-4-2-1.
Ñoâi khi troïng soá 8-4-2-1 toû ra khoâng thuaän tieän trong tính toaùn, moät soá troïng soá
khaùc cuõng ñöôïc söû duïng nhö 2-4-2-1, 5-4-2-1, 7-4-2-1…
Thập
phân
0
1
2
3
4
5
6
7
8
9
8
0
0
0
0
0
0
0
0
1
1
Trọng số
4 2
0 0
0 0
0 1
0 1
1 0
1 0
1 1
1 1
0 0
0 0
1
0
1
0
1
0
1
0
1
0
1
7
0
0
0
0
0
0
0
1
1
1
MÃ BCD
Trọng số
Trọng số
4 2 1 2 4 2
0 0 0 0 0 0
0 0 1 0 0 0
0 1 0 0 0 1
0 1 1 0 0 1
1 0 0 0 1 0
1 0 1 1 0 1
1 1 0 1 1 0
0 0 0 1 1 0
0 0 1 1 1 1
0 1 0 1 1 1
1
0
1
0
1
0
0
0
1
0
1
5
0
0
0
0
0
1
1
1
1
1
Trọng số
1 2
0 0
0 0
0 1
0 1
1 0
0 0
0 0
0 1
0 1
1 1
1
0
1
0
1
0
0
1
0
1
1
Löu yù raèng caùc loaïi maõ 5-1-2-1 vaø 2-4-2-1 laø khoâng duy nhaát trong khi maõ 8-42-1 vaø 7-4-2-1 laïi duy nhaát
Ví dụ: Soá thaäp phaân 874 chuyeån sang töông ñöông nhò phaân nhö sau:
hoaëc
8
↓
1000
1011
1011
7
↓
0111
1010
1101
3
↓
0011
0011
0110
(thaäp phaân)
(BCD 8-4-2-1)
(BCD 5-1-2-1)
(BCD 5-1-2-1)
Moät laàn nöõa, moãi chöõ soá thaäp phaân ñöôïc bieán ñoåi tröïc tieáp sang soá nhò phaân
töông öùng, löu yù raèng 4 bit luoân ñöôïc duøng cho moãi chöõ soá thaäp phaân
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 15
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
Trong baøi giaûng naøy laáy maõ BCD 8-4-2-1 laøm ví du. Maõ BCD bieåu thò moãi chöõ
soá cuûa soá thaäp phaân baèng soá nhò phaân 4 bit, söû duïng caùc soá nhò phaân 4 bit töø
0000 ñeán 1001, khoâng söû duïng caùc soá 1010, 1011, 1100, 1101, 1110 vaø 1111.
Ví dụ: Bieán ñoåi 0110100000111001 (BCD 8-4-2-1) sang giaù trò thaäp phaân
Giải
Chia soá BCD thaønh caùc nhoùm 4 bit vaø bieán ñoåi sang thaäp phaân
0110
1000 0011 1001 = 6839
So saùnh BCD vaø nhò phaân. Moät ñieàu quan troïng laø maõ BCD khoâng gioáng nhö
maõ nhò phaân tröïc tieáp. Maõ nhò phaân tröïc tieáp bieán ñoåi soá thaäp phaân sang nhò
phaân trong khi maõ BCD bieán ñoåi moãi chöõ soá trong soá thaäp phaân sang nhò phaân.
Xeùt ví duï bieán ñoåi 137 sang maõ nhò phaân tröïc tieáp vaø sang BCD 8-4-2-1 nhö sau:
13710 = 100010012
(nhò phaân)
13710 = 0001 0011 0111 (BCD 8-4-2-1)
Maõ BCD caàn 12 bit trong khi maõ nhò phaân tröïc tieáp chæ caàn 8 bit ñeå bieåu thò soá
137. Maõ BCD caàn nhieàu bit hôn laø bôûi vì BCD khoâng duøng heát caùc khaû naêng cuûa
caùc nhoùm 4 bit vaø vì vaäy coù phaàn naøo ñoù khoâng hieäu quaû.
Öu ñieåm chính cuûa BCD laø deã daøng chuyeån sang thaäp phaân. Chæ phaûi nhôù caùc
nhoùm maõ 4bit cho caùc soá thaäp phaân töø 0 ñeán 9. Söï deã daøng chuyeån ñoåi naøy ñaëc
bieät quan troïng theo quan ñieåm veà phaàn cöùng vì trong moät heä thoáng soá, noù laø
caùc maïch logic ñeå taïo neân söï chuyeån ñoåi sang vaø töø thaäp phaân
1.2.2. Các phép toán số học với mã BCD
Cộng BCD
Coäng hai soá BCD coù ñieåm khaùc so vôùi coäng hai soá nhò phaân. Khi toång cuûa moãi
soá haïng BCD ≤ 9 thì toång ñoù laø keát quaû cuoái cuøng
Ví dụ,
01010011 (53)
00100101 (25)
01111000 (78)
Khi toång hai soá nhò phaân ≥ 9 thì toång phaûi ñöôïc coäng theâm 6 vaø nhôù 1 leân haøng
BCD coù nghóa cao hôn
Ví dụ,
0001 0111 (17)
0010 0101 (25)
0011 1100 Keát quaû ≥ 9
0110 (6)
0100 0010 (42)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 16
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
Trừ BCD
Gioáng quy luaät tröø soá nhò phaân nhieàu bit, neáu soá bò tröø nhoû hôn soá tröø thì phaûi
möôïn 1 ôû haøng coù nghóa lôùn hôn (gioáng tröø thaäp phaân)
0101 0101 (55)
0001 1000 (18)
0100
0001
0011
⇒
1111
1000
0111
Möôïn 1
(37)
Biểu diễn số BCD âm
Gioáng heä nhò phaân, ñeå bieåu dieãn soá aâm trong heä nhò phaân thöôøng duøng soá buø 2,
ñeå bieåu dieãn soá BCD aâm thöôøng duøng soá buø 10.
Soá buø 10 baèng soá buø 9 coäng 1
Bit taän cuøng beân traùi laø bit daáu: 1 cho soá aâm vaø 0 cho soá döông
Ví dụ,
+ 342
+
- 342
0 342
Soá döông
1 657
Soá buø 9 cuûa 342
1
1 658
Soá buø 10 cuûa 342
1.2.3. Mã quá 3 (excess-3code)
Maõ quaù 3 ñöôïc hình thaønh baèng caùch coäng theâm 3 ñôn vò vaøo maõ BCD 8421.
Ví dụ: bieán ñoåi 48 sang maõ quaù 3
4
+3
7
↓
0111
8
+3
11
↓
1011
Coäng 3 cho moãi chöõ soá
Chuyeån sang maõ nhò phaân 4 bit
Baûng lieät keâ maõ BCD vaø maõ quaù 3 töông öùng vôùi caùc chöõ soá thaäp phaân.
Thaäp phaân
0
1
2
3
4
5
6
7
8
9
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
BCD
0000
0001
0010
0011
0100
0101
0110
0111
1000
1001
Maõ quaù 3
0011
0100
0101
0110
0111
1000
1001
1010
1011
1100
Trang 17
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
1.2.4. Mã Gray
Maõ Gray naèm trong nhoùm maõ thay ñoåi cöïc tieåu minimun-change codes, ôû ñoù chæ
1 bit trong nhoùm maõ thay ñoåi ôû khi ñi töø böôùc naøy qua böôùc khaùc.
Maõ Gray laø maõ khoâng coù troïng soá, nghóa laø moïi vò trí cuûa bit trong nhoùm maõ
khoâng ñöôïc gaùn troïng soá naøo. Vì vaäy, maõ Gray khoâng phuø hôïp vôùi caùc bieåu thöùc
soá hoïc nhöng phuø hôïp vôùi caùc thieát bò öùng duïng vaøo/ra & moät soá daïng bieán ñoåi
analog - digital
Baûng chuyeån ñoåi maõ Gray töø soá thaäp phaân (0 ñeán 15) vôùi maõ nhò phaân tröïc tieáp
Thaäp phaân
0
1
2
3
4
5
6
7
Nhò phaân
0000
0001
0010
0011
0100
0101
0110
0111
Maõ Gray
0000
0001
0011
0010
0110
0111
0101
0100
Thaäp phaân
8
9
10
11
12
13
14
15
Nhò phaân
1000
1001
1010
1011
1100
1101
1110
1111
Maõ Gray
1100
1101
1111
1110
1010
1011
1001
1000
1.2.5. Mã Johnson
Maõ naøy söû duïng naêm chöõ soá nhò phaân ñeå bieåu dieãn caùc chöõ soá heä möôøi.
Phương pháp: Khi chuyeån sang soá tieáp theo maõ seõ thay chöõ soá 0 baèng chöõ soá
1, baét ñaàu töø phaùi sang traùi, cho ñeán khi ñaït 11111 thì seõ baét ñaàu thay theá daàn
chöõ soá 1 baèng chöõ soá 0 vaø cuõng theo chieàu töø phaûi sang traùi
Hệ 10
Mã Johnson
J4
J3
J2
J1
J0
0
0
0
0
0
0
1
0
0
0
0
1
1
1
0
0
0
2
1
1
1
0
0
3
1
1
1
1
0
4
1
1
1
1
1
5
0
1
1
1
1
6
0
0
1
1
1
7
0
0
0
1
1
8
0
0
0
0
1
9
Ngoaøi ra coøn duøng caùc loaïi maõ coù chöõ soá lôùn hôn nhö 8 hoaëc 10 chöõ soá, nhöôïc
ñieåm cuûa caùc loaïi maõ naøy laø ñoä daøi töø maõ lôùn neân chieám nhieàu thôøi gian trong
keânh thoâng tin nhöng öu ñieåm laø coù theå phaùt hieän sai vaø trong nhieàu tröôøng hôïp
coøn coù theå söûa sai, vì vaäy thöôøng goïi laø maõ choáng nhieãu (noäi dung naøy naèm
trong lyù thuyeát thoâng tin)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 18
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
1.2.6. Các mã Alphanumeric (mã theo chữ cái và con số)
Ngoaøi caùc döõ lieäu soá, moät maùy tính phaûi coù khaû naêng xöû lyù caùc coâng tin khoâng
soá. Noùi caùch khaùc, moät maùy tính phaûi nhaän ra caùc maõ bieåu thò caùc kyù töï cuûa chöõ
caùi, caùc daáu chaám, vaø caùc kyù töï ñaëc bieät khaùc. Caùc maõ naøy ñöôïc goïi laø maõ
alphanumeric. Moät maõ alphanumeric hoaøn taát bao goàm 26 chöõ caùi thöôøng, 26
chöõ caùi hoa, 10 chöõ soá, 7 chaám caâu, vaø töø 20 ñeán 40 kyù töï khaùc, nhö +, /, #, %,
*,v.v…. Coù theå noùi raèng maõ alphanumeric bieåu thò taát caû caùc kyù töï khaùc nhau vaø
caùc haøm tuøy thuoäc vaøo chuaån baøn phím cuûa maùy tính hay maùy ñaùnh chöõ
Maõ ASCII. Maõ alphanumeric duøng roäng raõi hieän nay laø maõ ASCII (American
Standard Code for Information Interchange), söû duïng haàu heát trong caùc maùy vi
tính, trong caùc theá heä maùy tính lôùn (mainframe). Maõ ASCII laø moät maõ 7 bit vaø vì
vaäy noù coù 27 = 128 nhoùm maõ. Ñieàu naøy thì ñuû ñeå bieåu thò taát caû caùc kyù töï baøn
phím chuaån cuõng nhö caùc haøm ñieàu khieån nhö (RETURN) vaø (LINEFEED)
Kyù töï
A
B
C
D
E
F
G
H
I
J
K
L
M
N
O
P
Q
R
S
T
U
V
W
X
ASCII
100 0001
100 0010
100 0011
100 0100
100 0101
100 0110
100 0111
100 1000
100 1001
100 1010
100 1011
100 1100
100 1101
100 1110
100 1111
101 0000
101 0001
101 0010
101 0011
101 0100
101 0101
101 0110
101 0111
101 1000
Octal
101
102
103
104
105
106
107
110
111
112
113
114
115
116
117
120
121
122
123
124
125
126
127
130
Hex
41
42
43
44
45
46
47
48
49
4A
4B
4C
4D
4E
4F
50
51
52
53
54
55
56
57
58
Kyù töï
Y
Z
0
1
2
3
4
5
6
7
8
9
Blank
.
(
+
$
*
)
/
=
RETURN
LINEFEED
ASCII
101 1001
101 1010
011 0000
011 0001
011 0010
011 0011
011 0100
011 0101
011 0110
011 0111
011 1000
011 1001
010 0000
010 1110
010 1000
010 1011
010 0100
010 1010
010 1001
010 1101
0101111
010 1100
011 1101
000 1101
0001010
Octal
131
132
060
061
062
063
064
065
066
067
070
071
040
056
050
053
044
052
051
055
057
054
075
015
012
Hex
59
5A
30
31
32
33
34
35
36
37
38
39
20
2E
28
2B
24
2A
29
2D
2F
2C
3D
0D
0A
Ví dụ: Thoâng ñieäp ñöôïc maõ hoùa trong ASCII nhö sau
1001000
Giải Keát quaû theo HEX laø 48
1000101
1001100
1010000
45
4C
50
Theo baûng ASCII, bieán ñoåi HEX sang kyù töï laø H E L P
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 19
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
Maõ ASCII thöôøng duøng trong caùc boä truyeàn caùc thoâng tin alphanumeric giöõa
moät maùy tính vaø caùc thieát bò vaøo ra nhö thieát bò video hay printer. Maùy tính cuõng
söû duïng noù ñeå löu tröõ caùc thoâng tin nhö caùc daïng leänh.
Ñeå coù theå bieåu dieãn theâm nhieàu kyù töï khaùc (kyù hieäu khoâng phaûi laø chöõ La Ting
nhö α, β, χ, δ…) maõ ASCII ñöôïc theâm 1bit nöõa ñeå coù maõ ASCII 8bit dieãn taû ñöôïc
256 kyù töï, ñaây laø maõ ASCII môû roäng (Extended ASCII)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 20
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 1
Bài tập chương 1
1.1. Đổi các số nhị phân sau sang số thập phân:
a.
10110
b.
10001101
c.
100100001001
d.
1111010111
e.
10111111
1.2. Đổi các giá trị thập phân sau sang nhị phân:
a.
37
b.
14
c.
189
d.
205
e.
2313
f.
511
1.3. Giá trị thập phân lớn nhất của số nhị phân 8 bit là bao nhiêu,16 bit là bao
nhiêu
1.4. Đổi các số bát phân sang số thập phân tương ứng:
a.
743
b.
36
c.
3777
d.
257
e.
1204
1.5. Đổi các số thập phân sau sang số bát phân:
a.
59
b.
372
c.
919
d.
65,535
e.
255
1.6. Đổi các số bát phân ở 1.4 thành số nhị phân.
1.7. Đổi các số nhị phân ở 1.1 thành số bát phân.
1.8. Hãy liệt kê các số bát phân liên tục từ 1658 đến 2008.
1.9.Khi các số thập phân lớn, để đổi sang nhị phân, trước tiên ta đổi sang bát
phân, sau đó đổi số bát phân thành số nhị phân. Hãy dùng cách này đổi số
231310 thành số nhị phân và so sánh với cách đổi dùng ở bài 1.2.
1.10. Đổi các giá trị hex sau thành số thập phân:
a.
92
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 21
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
b.
1A6
c.
37FD
e.
2C0
f.
7FF
Chương 1
1.11. Đổi các giá trị thập phân sau sang Hex:
a.
75
b.
314
c.
2048
d.
25,619
e.
4095
1.12. Đổi các giá trị nhị phân ở bài 1.1sang thập lục phân.
1.13. Đổi các giá trị Hex ở bài 1.10 sang nhị phân.
1.14.Trong máy vi tính, địa chỉ các vị trí ô nhớ được biểu diễn ở dạng thập lục
phân. Địa chỉ này là những số liên tục mà nó nhận dạng mỗi mạch nhớ
a. Một máy tính cụ thể có thể chứa 1 số 8 bit trong mỗi vị trí nhớ. Nếu các
địa chỉ ô nhớ nằm trong khoảng từ 000016 đến FFFF16, có bao nhiêu vị
trí nhớ?
b. Một bộ vi xử lý có 4096 vị trí nhớ thì khoảng địa chỉ Hex mà bộ vi xử lý
này dùng là gì ?.
1.15. Hãy liệt kê những số hex trình tự từ 280 đến 2A0.
1.16. Hãy mã hóa các số thập phân sau thành số BCD:
a.
47
b.
962
c.
187
d.
42,689.627
e.
1204
1.17. Cần bao nhiêu bit để thể hiện các số thập phân trong khoảng từ 0 đến 999
dùng mã nhị phân chuẩn, mã BCD?
1.18. Đổi những số BCD sau thành số thập phân:
a.
10010110101010010
b.
000110000100
c.
0111011101110101
d.
010010010010
1.19. Hãy thể hiện phát biểu sau "X = 25/Y" bằng mã ASCII, có kèm theo một bit
chẵn lẻ.
1.20. Hãy thêm bit chẵn lẻ vào mã ASCII ở bài 1.19 và đưa kết quả về số Hex.
1.21. Các nhóm mã dưới đây được truyền đi, hãy thêm bit chẵn lẻ cho mỗi nhóm:
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 22
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
a.
10110110
b.
00101000
c.
11110111
Chương 1
1.22. Hãy đổi số thập phân sau thành mã BCD, sau đó đổi sang số BCD âm:
a.
74
b.
38
c.
165
d.
9201
1.23. Trong hệ thống số, số thập phân từ 000 đến 999 được thể hiện ở dạng mã
BCD. Một bit chẵn lẻ lẻ cũng được đích kèm ở cuối mỗi nhóm mã. Hãy kiểm tra
các nhóm mã bên dưới và giả sử rằng mỗi một mã được truyền từ vị trí này đến vị
trí khác. Một vài nhóm có chứa lỗi. Giả sử không quá 2 lỗi trong mỗi nhóm. Hãy
xác định nhóm mã nào có 1 lỗi đơn và nhóm mã nào có 1 lỗi kép:
a.
100101011000
b.
0100011101100
c.
011110000011
d.
1000011000101
1.24. Thực hiện các sự chuyển đổi dưới đây. Trong số đó, có thể thử 1 cách tốt
nhất trong nhiều cách đã khảo sát.
a.
(1417)10 = (……………………….……..)2
b.
(-255)10 = (………………………………)2
c.
(1110101000100111)2 =(……………………………)10
e.
(2497)10 = (……………………………..)8
g.
(235)8 = (……………………………)10
i.
(7A9)16 = (…………………………….)10
k.
(1600,123)10 = (………………………………………)16
m.
(865)10 =( …………………………………….)BCD
n.
(100101000111)BCD = (……………………………….)10
1.25. Thể hiện giá trị thập phân 37 theo những cách sau:
a.
Biến đổi thẳng nhị phân
b.
BCD
c.
ASCII
d.
Bát phân
e.
Hex
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 23
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
CHƯƠNG 2.
ĐẠI SỐ BOOLEAN VÀ CÁC CỔNG LOGIC
2.1.
KHÁI NIỆM VỀ LOGIC HAI TRẠNG THÁI
Pheùp toaùn cô baûn trong thieát keá logic caùc heä thoáng soá laø ñaïi soá Boolean. Ñaïi soá
Boolean coù nhieàu öùng duïng khaùc nhau bao goàm lyù thuyeát taäp hôïp vaø logic toaùn,
vì taát caû caùc phaàn töû chuyeån maïch veà cô baûn ñeàu laø caùc phaàn töû hai traïng thaùi
(nhö diode, transistor), cho neân seõ taäp trung khaûo saùt tröôøng hôïp ñaïi soá Boolean
vôùi söï thay ñoåi giaû söû chæ ôû 1 trong 2 giaù trò. Ñaïi soá Boolean söû duïng 2 giaù trò
naøy xem nhö ñaïi soá veà chuyeån maïch.
Phaàn naøy söû duïng caùc bieán Boolean nhö X hoaëc Y… ñeå bieåu dieãn ngoõ vaøo hoaëc
ngoõ ra cuûa maïch chuyeån maïch, moãi bieán coù theå laáy 1 trong hai giaù trò. Kyù hieäu
“0” vaø “1” ñöôïc duøng ñeå ñaïi dieän cho hai giaù trò khaùc nhau naøy. Vì vaäy, neáu X
laø bieán chuyeån maïch hay bieán Boolean thì hoaëc X=0, hoaëc X=1
Maëc duø kyù hieäu “0” vaø “1” gioáng nhö soá nhò phaân, nhöng khoâng phaûi nhö vaäy.
Ñaây chæ laø 2 kyù töï ñaïi dieän cho 2 giaù trò cuûa bieán chuyeån maïch vaø ñöôïc xem laø
möùc logic, moät soá vò duï veà caùc hieän töôïng maø möùc logic ñaïi dieän nhö sau
LOGIC 0
Sai
Taét
Möùc ñieän aùp thaáp
Khoâng
Môû maïch
LOGIC 1
Ñuùng
Môû
Möùc ñieän aùp cao
Coù
Ñoùng maïch
Vì chæ coù hai giaù trò, neân ñaïi soá Boolean töông ñoái deã daøng hôn so vôùi ñaïi soá
thoâng thöôøng. ÔÛ ñaïi soá Boolean, khoâng coù phaân soá, thaäp phaân, caên baäc hai, caên
baäc ba, logarit, soá aûo, v.v. Ñaïi soá Boolean chæ coù 3 pheùp toaùn cô baûn: coäng (OR),
nhaân (AND) vaø laáy buø (NOT).
2.2.
BẢNG SỰ THẬT
Baûng söï thaät (Truth Table) moâ taû caùc ñaùp öùng ngoõ ra cuûa maïch logic öùng vôùi
caùc toå hôïp khaùc nhau taïi ngoõ vaøo.
Ví dụ
A
B
Maïng
chuyeån
maïch
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
A
X
B
C
Maïng
chuyeån
maïch
A
B
X
C
D
Trang 24
https://fb.com/tailieudientucntt
Maïng
chuyeån
maïch
X
Bài Giảng Kỹ Thuật Số
Chương 2
Caùc baûng söï thaät tieâu bieåu öùng vôùi caùc maïng chuyeån maïch treân nhö sau:
Ngoõ vaøo Ngoõ ra
↓ ↓
↓
A
0
0
1
1
B
0
1
0
1
X
?
?
?
?
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
C
0
1
0
1
0
1
0
1
A
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
X
?
?
?
?
?
?
?
?
B
0
0
0
0
1
1
1
1
0
0
0
0
1
1
1
1
C
0
0
1
1
0
0
1
1
0
0
1
1
0
0
1
1
D
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
X
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
?
ÔÛ moãi baûng söï thaät, caùc toå hôïp möùc logic 0 vaø 1 ñoái vôùi ngoõ vaøo (A, B, C, D)
ñöôïc theå hieän beân traùi, möùc logic ôû ngoõ ra X ñöôïc theå hieän beân phaûi
Löu yù, neáu coù 2 ngoõ vaøo thì coù 4 khaû naêng xaûy ra, töông töï 8 khaû naêng cho 3 ngoõ
vaøo vaø 16 khaû naêng cho 4 ngoõ vaøo. Seõ coù 2N khaû naêng xaûy ra ñoái vôùi N ngoõ vaøo.
Taát caû caùc toå hôïp ngoõ vaøo ñöôïc theå hieän theo chuoãi ñeám nhò phaân.
2.3.
CÁC PHÉP TOÁN CƠ BẢN
2.3.1. Phép toán OR và cổng OR
Goïi A vaø B laø 2 bieán logic ñoäc laäp. Khi A vaø B keát hôïp qua pheùp toaùn OR, keát
quaû x ñöôïc moâ taû nhö sau:
X=A+B
Trong bieåu thöùc naøy, daáu “+” khoâng coù nghóa laø pheùp coäng thuaàn tuùy. Noù laø
pheùp toaùn OR, keát quaû cuûa pheùp toaùn OR ñöôïc cho trong baûng söï thaät sau:
A
0
0
1
1
B
0
1
0
1
X=A+B
0
1
1
1
A
Y=A+B
B
Coång OR
Keát luaän
•
Pheùp toaùn OR seõ coù keát quaû baèng 1 neáu moät hay nhieàu bieán ngoõ vaøo
baèng 1
•
Coång OR chæ coù moät ngoõ ra vaø coù theå coù nhieàu hôn hai ngoõ vaøo
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 25
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
A
0
0
0
0
1
1
1
1
Kyù hieäu vaø baûng söï thaät cho coång OR 3 ngoõ vaøo
A
B
C
X=A+B+C
B
0
0
1
1
0
0
1
1
C
0
1
0
1
0
1
0
1
X=A+B+C
0
1
1
1
1
1
1
1
Ví dụ
Xaùc ñònh daïng soùng ngoõ ra coång OR khi ngoõ vaøo A, B thay ñoåi theo giaûn ñoà sau:
1
A 0
A
Out
B
B
2.3.2. Phép toán AND và cổng AND
Neáu hai bieán logic A vaø B ñöôïc keát hôïp qua pheùp AND, keát quaû laø:
X= A.B
Baûng söï thaät cuûa pheùp nhaân 2 bieán A vaø B nhö sau:
A
0
0
1
1
B
0
1
0
1
X=A.B
0
0
0
1
A
B
X = AB
Coång AND
Keát luaän
•
Pheùp toaùn AND seõ coù keát quaû baèng 0 neáu moät hay nhieàu bieán ngoõ vaøo
baèng 0
•
Coång AND chæ coù moät ngoõ ra vaø coù theå coù nhieàu hôn hai ngoõ vaøo
Ví duï AND 3 ngoõ vaøo coù baûng söï thaät nhö sau
A
B
C
X = ABC
Coång AND
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
Trang 23
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
C
0
1
0
1
0
1
0
1
X = ABC
0
0
0
0
0
0
0
1
Bài Giảng Kỹ Thuật Số
Chương 2
Ví dụ
Xaùc ñònh daïng soùng ngoõ ra cuûa coång AND öùng vôùi caùc ngoõ vaøo nhö sau
`
A
A
B
B
X = AB
Trong ví duï naøy thaáy raèng, ngoõ ra x seõ baèng vôùi ngoõ vaøo A khi B ôû möùc logic 1.
Vì vaäy ta coù theå xem ngoõ vaøo B nhö ngoõ vaøo ñieàu khieån, noù cho pheùp daïng
soùng ôû ngoõ vaøo A xuaát hieän ôû ngoõ ra hay khoâng. Trong tröôøng hôïp naøy coång
AND ñöôïc duøng nhö moät maïch cho pheùp, vaø ñaây laø öùng duïng raát quan troïng cuûa
coång AND vaø seõ ñöôïc khaûo saùt sau.
2.3.3. Phép toán NOT và cổng NOT
Neáu bieán A ñöôïc ñöa qua pheùp toaùn NOT, keát quaû x seõ laø:
X= A
Ta coù 1 = 0 vaø 0 = 1 , baûng söï thaät cho pheùp toaùn NOT nhö sau:
A
0
1
A
X= A
1
0
X=A
Coång NOT
Coång NOT chæ coù moät ngoõ vaøo vaø moät ngoõ ra
2.4.
MÔ TẢ CÁC MẠCH LOGIC THEO PHƯƠNG PHÁP ĐẠI SỐ
Baát cöù moät maïch logic naøo cuõng coù theå ñöôïc moâ taû baèng caùch söû duïng caùc pheùp
toaùn Boolean ñaõ ñeà caäp ôû treân (coång OR, AND vaø NOT laø nhöõng khoái cô baûn
trong moät heä thoáng soá).
Ví dụ, xeùt maïch sau
A
B
A.B
C
X = A.B + C
Maïch coù 3 ngoõ vaøo A, B vaø C vaø moät ngoõ ra x. Söû duïng caùc bieåu thöùc Boolean
cho moãi coång ta xaùc ñònh ñöôïc bieåu thöùc ngoõ ra x = AB + C.
Ví dụ
A
B
A+B
C
X = (A+B).C
Trang 24
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
Ví dụ xaùc ñònh haøm ngoõ ra cuûa maïch sau
A
B
(a)
A
B
C
D
(b)
2.5.
THỰC HIỆN CÁC MẠCH LOGIC TỪ BIỂU THỨC BOOLEAN
Ví dụ thöïc hieän bieåu thöùc sau: y = AC+BC+ABC
AC
A
C
B
B
BC
y=AC+BC+ABC
C
A
ABC
B
C
Ví dụ veõ sô ñoà maïch thöïc hieän bieåu thöùc sau: x= AB+BC
(
)
Ví dụ veõ sô ñoà maïch thöïc hieän bieåu thöùc x = ABC A+D söû duïng caùc coång coù soá
ngoõ vaøo nhoû hôn 3
2.6.
CỔNG NOR VÀ CỔNG NAND
Coång NAND vaø coång NOR ñöôïc duøng raát roäng raõi trong caùc maïch soá. Thöïc söï
caùc coång naøy ñeàu ñöôïc keát hôïp töø caùc pheùp toùan cô baûn AND, OR vaø NOT.
2.6.1. Cổng NOR
Coång NOR hoïat ñoäng gioáng nhö hai coång OR vaø NOT maéc noái tieáp nhö hình veõ
vaø bieåu thöùc ngoõ ra laø x= A+B , baûng söï thaät nhö sau:
OR
NOR
X= A+B
A
A
0
0
1
1
B
0
1
0
1
A+B
0
1
1
1
A+B
1
0
0
0
B
Kyù hieäu ñaûo
X= A+B
A
B
Ngoõ ra coång NOR laø ñaûo vôùi ngoõ ra coång OR
Trang 25
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
Ví dụ, xaùc ñònh daïng soùng ngoõ ra cuûa coång NOR öùng vôùi ngoõ vaøo nhö sau
1
A 0
A
B
B
2.6.2. Cổng NAND
Coång NAND töông ñöông vôùi AND coäng vôùi NOT, ngoõ ra cuûa NAND seõ laø
x= AB , baûng söï thaät cho nhö sau:
A
0
0
1
1
B
0
1
0
1
AND
NAND
AB
0
0
0
1
AB
X= A+B
A
B
1
1
1
0
Kyù hieäu ñaûo
X= A+B
A
B
Ngoõ ra coång NAND laø ñaûo vôùi ngoõ ra coång AND
Ví dụ, xaùc ñònh daïng soùng ngoõ ra cuûa coång NAND öùng vôùi ngoõ vaøo nhö sau
A
A
X
B
B
Ví duï, thöïc hieän maïch logic coù bieåu thöùc nhö sau: x = AB(C + D) chæ duøng
coång NOR vaø NAND
Ví dụ xaùc ñònh möùc logic ngoõ ra cuûa ví duï treân vôùi A=B=C=1 vaø D=0
2.7.
PHÉP TOÁN XOR (Exclusive-OR) và phép toán tương đương
2.7.1. Phép toán XOR và cổng XOR
Pheùp toaùn XOR (kyù hieäu ⊕) coù baûng söï thaät nhö sau:
X
0
0
1
1
Y
0
1
0
1
X⊕Y
0
1
1
0
X
X⊕Y
Y
Cổng XOR
Töø baûng söï thaät thaáy raèng X ⊕ Y =1 khi X≠ Y vaø X ⊕ Y =0 khi X= Y
Bieåu thöùc toaùn cuûa pheùp toaùn XOR: X ⊕ Y = XY+YX
Trang 26
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
2.7.2. Phép toán tương đương và cổng XNOR
Pheùp toùan töông ñöông (kyù hieäu ≡) coù baûng söï thaät nhö sau:
X
0
0
1
1
Y
0
1
0
1
X≡Y
1
0
0
1
X
X⊕Y
Y
Cổng XNOR
Töø baûng söï thaät thaáy raèng X ≡ Y = 0 khi X≠ Y vaø X ≡ Y = 1 khi X= Y
Bieåu thöùc toaùn: X ≡ Y = X ⊕ Y = XY + X.Y
2.8.
CÁC ĐỊNH LÝ CƠ BẢN CỦA ĐẠI SỐ BOOLEAN
(1) X . 0 = 0
(5) X + 0 = X
(2) X . 1 = X
(6) X + 1 =1
(3) X . X = X
(7) X + X = X
(8) X + X = 1
(4) X . X = 0
2.8.1. Phép giao hoán, kết hợp và phân phối
(9)
X+Y=Y+X
(10)
X.Y=Y.X
(11)
X + (Y + Z) = (X + Y) + Z = X + Y + Z
(12)
X(YZ) = (XY)Z = XYZ
(13)
X(Y + Z) = XY + XZ
(14)
(W + X)(Y + Z) = WY + XY + WZ + XZ
(15)
X + XY = X
(vì X(1+Y) = X)
(16)
X + XY = X + Y
(vì X + X Y = (X + Y)(X + X ))
(17)
(X + Y)(X + Y ) = X
2.8.2. Định lý DeMorgan
(18)
X + Y = X.Y
(19)
( X.Y) = X + Y
2.8.3. Định lý Consensus
(20)
XY + XZ + YZ = XY + XZ
(21)
( X + Y)( X + Z)(Y + Z) = ( X + Y)( X + Z)
2.8.4. Các định lý cho phép tóan XOR
(22)
X⊕0=X
Trang 27
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
(23)
X⊕1= X
(24)
X⊕X=0
(25)
X⊕ X =1
(26)
X ⊕ Y = Y ⊕ X (Giao hoaùn)
(27)
(X ⊕ Y) ⊕ Z = X ⊕ (Y ⊕ Z) = X ⊕ Y ⊕ Z (Keát hôïp)
(28)
X(Y ⊕ Z) = XY ⊕ XZ (Phaân phoái)
(29)
( X ⊕ Y) = X ⊕ Y = X ⊕ Y = XY + X.Y
Ví dụ, ruùt goïn bieåu thöùc y = A BD + A B.D
Giải. y = A B(D + D) , söû duïng ñònh lyù (8): D + D = 1
y = A B.1 = A B
Ví dụ, Ruùt goïn bieåu thöùc x = ACD + ABCD
Ví dụ Ruùt goïn bieåu thöùc z = (A + C).(B + D)
Ví dụ Thöïc hieän maïch logic vôùi bieåu thöùc ngoõ ra z = A + B + C chæ duøng coång
NAND vaø coång ñaûo
Ví dụ Ruùt goïn bieåu thöùc a.b+ac+bc+bc+ab
Ví dụ Ruùt goïn bieåu thöùc (a+b+c)(a+b+d)(b+c+d)
2.8.5. Các phép biến đổi trên cổng NAND và NOR
Taát caû caùc bieåu thöùc Boolean ñeàu coù theå ñöôïc thöïc hieän thoâng qua caùc coång OR,
AND vaø NOT. Tuy nhieân, ñeå thöïc hieän caùc bieåu thöùc logic maø chæ duøng 1 loaïi
coång NAND (hay coång NOR), ta seõ bieán ñoåi coång NAND (hay coång NOR) ñeå
thöïc hieän caùc pheùp toaùn AND, OR, NOT nhö sau
Thực hiện các phép toán bằng cổng NAND
A
x = A.A = A
x=AB
A
B
A
x = A.B = A + B
B
Trang 28
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
Thực hiện các phép toán bằng cổng NOR
A
x =A+A=A
A
x=A+B
B
A
x = A + B = A.B
B
Ví dụ. Thieát keá maïch thöïc hieän bieåu thöùc x=AB+CD, sao cho duøng ít IC nhaát.
Giaû söû coù caùc IC sau
14
13
12
11
10
9
8
Vcc 14
13
12
11
10
9
8
7408
7400
1
2
3
4
5
6
1
7
Vcc 14
2
3
4
5
6
7
GND
13
12
11
10
9
8
7432
1
2
3
4
5
6
7
GND
2.8.6. Biểu diễn qua lại giữa các cổng
ÔÛ treân ñaõ khaûo saùt 5 loaïi coång logic (AND, OR, NOT, NAND, NOR) vaø caùc kyù
hieäu chuaån ñeå bieåu dieãn chuùng treân moät maïch logic. Maëc duø vaäy moät soá maïch
cuõng söû duïng theâm moät soá caùch bieåu dieãn khaùc nhö sau:
Trang 29
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
AB
A
AND
B
A
B
A+B
A
B
AB
A
B
A+B
A
A
OR
NAND
A
B
A + B = AB
A
B
A.B = A + B
A + B = AB
A
B
NOR A
A.B = A + B
B
NOT
A
A
Khái nhiệm về mức logic tích cực.
A
A tích cực
mức 1
Ví dụ,
A
B
A
A
A tích cực
mức 0
A tích cực
cạnh lên
AB
A
A tích cực
cạnh xuống
A + B = AB
A
B
(b)
(a)
ÔÛ coång NAND (a) coù theå dieãn giaûi: Ngoõ ra tích cöïc ôû möùc thaáp chæ khi A vaø B ôû
möùc cao
ÔÛ coång NAND (b): Ngoõ ra tích cöïc ôû möùc cao khi A hoaëc B ôû möùc thaáp
Ví duï, dieãn giaûi yù nghóa ngoõ ra Z theo caùc ngoõ vaøo ABCD sau
`
A
B
Z
C
D
(a)
Trang 30
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
A
B
Z
C
D
(b)
A
B
Z
C
D
(c)
¾ Löu yù: khi hoaùn chuyeån caùc coång, moät nguyeân lyù chung laø: Keát noái ngoõ ra
ñaûo cuûa coång naøy vaøo ngoõ vaøo ñaûo cuûa coång kia (hình b), vaø ngoû ra khoâng
ñaûo cuûa coång naøy naøo ngoõ ra khoâng ñaûo cuûa coång kia (hình c)
2.9.
LOGIC DƯƠNG VÀ LOGIC ÂM
ÖÙng vôùi ñieàu kieän hoïat ñoäng bình thöôøng, ñieän aùp cung caáp cho caùc ngoõ vaøo cuûa
coång logic ñöôïc haïn cheá ñeå coù ñöôïc moät trong hai giaù trò 0 vaø 1. Khi möùc ñieän
aùp ngoõ vaøo ñuùng cung caáp cho moät coång logic thì ñieän aùp ngoû ra seõ nhaän moät
trong hai giaù trò.
Logic döông: Möùc ñieän aùp cao trong hai möùc ñieän aùp bieåu thò möùc logic 1 vaø
möùc ñieän aùp thaáp trong hai möùc ñieän aùp bieåu thò möùc logic 0
Logic aâm: Möùc ñieän aùp thaáp trong hai möùc ñieän aùp bieåu thò möùc logic 1 vaø möùc
ñieän aùp cao trong hai möùc ñieän aùp bieåu thò möùc logic 0
Ví duï cho coång logic vaø quan heä giöõa ngoõ vaøo vaø ngoõ ra nhö sau:
E1
Coång
Logic
E2
E3
E1
0
0
0
0
+V
+V
+V
+V
E2
0
0
+V
+V
0
0
+V
+V
E3
0
+V
0
+V
0
+V
0
+V
E0
E0
0
0
0
0
0
0
0
+V
Trang 31
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
Baûng traïng thaùi logic döông ñöôïc moâ taû nhö sau
E1
0
0
0
0
1
1
1
1
E2
0
0
1
1
0
0
1
1
E3
0
1
0
1
0
1
0
1
E0
0
0
0
0
0
0
0
1
Thaáy raèng E0 = 1 neáu E1, E2 vaø E3 = 1, nghóa laø: E0 = E1E2E3
Töø ñoù thaáy raèng, coång treân töông ñöông vôùi coång AND cho maïch logic döông
Neáu chuyeån baûng traïng thaùi sang logic aâm, ñöôïc nhö sau
E1
1
1
1
1
0
0
0
0
E2
1
1
0
0
1
1
0
0
E3
1
0
1
0
1
0
1
0
E0
1
1
1
1
1
1
1
0
E0 = 1 neáu E1 hoaëc E2 hoaëc E3 = 1, nghóa laø: E0 = E1+E2+E3
Töø ñoù thaáy raèng, coång treân töông ñöông vôùi coång OR cho maïch logic aâm
Neáu coù moät haøm ñoái vôùi maïch logic döông, deã daøng xaùc ñònh haøm cho maïch ñoù
nhöng öùng vôùi logic aâm baèng caùch aùp duïng ñònh lyù logic aâm
Định lý logic âm
Neáu moät maïch toå hôïp coù haøm F quan heä giöõa ngoõ ra vaø ngoõ vaøo theo logic
döông, thì maïch toå hôïp ñoù seõ coù haøm ñoái ngaãu vôùi haøm F khi ngoõ vaøo vaø ngoõ ra
ñöôïc ñònh nghóa theo logic aâm baèng caùch bieán ñoåi AND thaønh OR vaø ngöôïc laïi
Ví dụ. Xeùt maïch toå hôïp sau:
A
G
B
C
Giaû söû haøm G ñöôïc ñònh nghóa theo logic döông laø
G= ABC + A.BC
Trang 32
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
thì haøm G ñònh nghóa theo logic aâm seõ laø
G = ( ABC + A.BC )D = ( A + B + C)(A + B + C)
Ví dụ. ÖÙng duïng ñònh lyù logic aâm, tìm ñoái ngaãu cuûa haøm XOR
2.10. CÁC HÀM CƠ BẢN CỦA ĐẠI SỐ BOOLEAN VÀ CÁC PHƯƠNG PHÁP
BIỂU DIỄN
2.10.1.
Hàm logic cơ bản
Moät haøm y=f(x1, x2, …, xn) vôùi caùc bieán x1, x2, …, xn chæ nhaän hai giaù trò 0 hoaëc 1
vaø haøm y cuõng chæ nhaän hai giaù trò 0 hoaëc 1 ñöôïc goïi laø haøm logic
(1) Hàm logic một biến: y=f(x)
Vì bieán x seõ nhaän moät trong hai giaù trò: 0 hoaëc 1, neân haøm y coù 4 khaû naêng hay
thöôøng goïi laø 4 haøm y0, y1, y2, y3, vaø baûng chaân lyù nhö sau:
Haøm khoâng
Haøm ñaûo
Baûng chaân lyù
x
0
1
y0 0
0
y1 1
0
Haøm laëp
Haøm ñôn vò
y2
y3
Teân haøm
0
1
Thuaät toùan logic
y0 = 0
Haøm luoân baèng 0
y1 = x
y2 = x
y3 = 1
y3= x + x
1
1
Ghi chuù
Haøm luoân baèng 1
(2) Haøm logic hai bieán y=f(x1, x2)
Vôùi hai bieán logic x1, x2, moãi bieán nhaän hai giaù trò laø 0, 1, nhö vaäy coù 16 toå hôïp
logic taïo thaønh 16 haøm. Baûng toùm taét 16 haøm töø y0 – y15
Teân haøm
Baûng chaân trò
1 1 0 0
1 0 1 0
0 0 0 0
0 0 0 1
Thuaät toaùn logic
Haøm khoâng
Haøm Piec
x1
x2
y0
y1
Haøm caám x1
y2
0 0
1
0
Y 2= x 1 x 2
Haøm ñaûo x1
y3
0 0
1
1
Y3 = x 1
Haøm caám x2
y4
0 1
0
0
Y 4= x 2 x 1
Haøm ñaûo x2
y5
0 1
0
1
Y5 = x 2
Haøm XOR
y6
0 1
1
0
Y6= x 1 x 2 + x 1 .x 2
Haøm Cheffer
y7
0 1
1
1
Y 7= x 1 + x 2 = x 1 x 2
Haøm AND
Haøm XNOR
y8
y9
1 0
1 0
0
0
0
1
Y8 = x1x2
Y9 = x1x2 + x 1 .x 2
Haøm laëp theo x2
Haøm keùo theo x2
y10 1 0
y11 1 0
1
1
0
1
y10 = x2
Y11= x 1 +x2
Y0 = 0
Y1= x 1 .x 2 = x 1 + x 2
Trang 33
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Ghi
Chuù
Bài Giảng Kỹ Thuật Số
Chương 2
Haøm laëp theo x1
Haøm keùo theo x1
y12 1 1
y13 1 1
0
0
0
1
y12= x1
y13= x1+ x 2
Haøm OR
Haøm ñôn vò
y14 1 1
y15 1 1
1
1
0
1
y14 = x1 + x2
y15=1
(3) Hàm logic n biến y=f(x1, x2,…, xn)
Vôùi haøm logic n bieán, moãi bieán nhaän moät trong hai giaù trò 0 hoaëc 1 neân ta coù 2n
toå hôïp bieán, moãi toå hôïp bieán laïi nhaän hai giaù trò 0 hoaëc 1, do vaäy soá haøm logic
n
taát caû laø 2 2 . Vôùi 1 bieán coù 4 khaû naêng taïo haøm, vôùi 2 bieán coù 16 khaû naêng taïo
haøm, vôùi 3 bieán coù 256 khaû naêng taïo haøm, nhö vaäy khi soá bieán taêng thì soá haøm
coù khaû naêng taïo thaønh raát lôùn. Tuy nhieân taát caû khaû naêng naøy ñeàu ñöôïc bieåu
hieän qua caùc khaû naêng toång logic, tích logic vaø nghòch ñaûo logic cuûa caùc bieán.
Trong taát caû caùc haøm ñöôïc taïo thaønh, ñaëc bieät chuù yù ñeán haøm toång chuaån vaø
haøm tích chuaån.
Haøm toång chuaån laø haøm chöùa toång caùc tích maø moãi tích coù ñuû taát caû caùc bieán
cuûa haøm.
Haøm tích chuaån laø haøm chöùa tích caùc toång maø moåi toång ñeàu coù ñuû taát caû caùc
bieán cuûa haøm
2.10.2.
Các phương pháp biểu diễn hàm logic
(1) Phương pháp biểu diễn thành bảng
ÔÛ ñaây caùc giaù trò cuûa haøm phuï thuoäc vaøo caùc bieán ñöôïc trình baøy trong moät baûng
goïi laø baûng söï thaät.
Ví dụ. moät haøm 2 bieán vôùi giaù trò haøm ñaõ cho ñöôïc bieåu dieãn thaønh baûng nhö
sau:
Giá trị thập phân
X1
của tổ hợp biến
X2
Y
0
0
0
1
1
0
1
X
2
1
0
0
3
1
1
1
Ghi chuù: daáu X laø giaù trò haøm khoâng xaùc ñònh (coù theå 0 hay 1)
Öu ñieåm cuûa caùch bieåu dieãn haøm baèng baûng laø deã nhìn, ít nhaàm laãn.
Nhöôïc ñieåm cuûa phöông phaùp naøy laø coàng keành, ñaëc bieät khi soá bieán lôùn
(2) Phương pháp hình học
ÔÛ ñaây mieàn xaùc ñònh cuûa haøm ñöôïc bieåu dieãn trong khoâng gian n chieàu. Moãi toå
hôïp bieán ñöôïc bieåu dieãn thaønh 1 ñieåm ôû trong khoâng gian ñoù, öùng vôùi moãi ñieåm
seõ ghi 1 giaù trò cuûa haøm. Hai ñieåm naèm treân cuøng moät truïc chæ khaùc nhau bôûi söï
thay ñoåi giaù trò cuûa moät bieán.
Trang 34
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
Sau ñaây minh hoïa caùch bieåu dieãn haøm logic 1 bieán, 2, 3 bieán döôùi daïng hình hoïc
1
0
x1
x
(a)
001
x2
x2
100
000
11
00
111
011
x1
10
110
010
101
x3
(c)
01
(b)
(3) Phương pháp biểu thức đại số
Moät haøm logic n bieán baát kyø bao giôø cuõng coù theå bieåu dieãn thaønh haøm toång
chuaån ñaày ñuû vaø tích chuaån ñaày ñuû
Cách viết hàm dưới dạng tổng chuẩn đầy đủ
•
Chæ quan taâm ñeán toå hôïp bieán maø haøm coù giaù trò baèng 1. Soá laàn haøm
baèng 1 seõ chính laø soá tích (minterm) cuûa caùc toå hôïp bieán
•
Trong moãi tích, caùc bieán coù giaù trò baèng 1 ñöôïc giöõ nguyeân, coøn caùc bieán
coù giaù trò baèng 0 thì ñöôïc laáy giaù trò ñaûo
•
Haøm toång chuaån ñaày ñuû seõ laø toång caùc tích ñoù
Ví dụ,
Thöù töï toå hôïp bieán
0
1
2
3
4
5
6
7
A
B
C
F
0
0
0
0
1
1
1
1
0
0
1
1
0
0
1
1
0
1
0
1
0
1
0
1
0
0
1
1
0
0
0
1
Minterm
→
→
ABC
ABC
→
ABC
Vaäy F =ΣABC (2,3,7) = ABC + ABC + ABC
Cách viết hàm dưới dạng tích chuẩn đầy đủ
•
Chæ quan taâm ñeán toå hôïp bieán maø haøm coù giaù trò baèng 0. Soá laàn haøm
baèng 0 seõ chính laø soá toång (maxterm) cuûa caùc toå hôïp bieán
•
Trong moãi toång caùc bieán coù giaù trò 0 ñöôïc giöõ nguyeân, coøn caùc bieán coù
giaù trò 1 ñöôïc laáy ñaûo.
•
Haøm tích chuaån ñaày ñuû seõ laø tích caùc toång ñoù
Trang 35
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
Ví dụ,
Thöù töï toå hôïp bieán
0
1
2
3
Vaäy
A
B
f
0
0
1
1
0
1
0
1
0
1
0
0
Maxterm
A+B
A+B
A+B
f= ΠAB(0,2,3) = (A+B) ( A+B )( A+B )
(4) Phương pháp biểu diễn bằng bìa Karnaugh
•
Ñeå bieåu dieãn haøm logic n bieán, caàn thaønh laäp moät baûng coù 2n oâ, moãi oâ
töông öùng vôùi moät toå hôïp bieán. Ñaùnh soá thöù töï cuûa caùc oâ trong baûng
töông öùng vôùi giaù trò cuûa toå hôïp bieán
•
Caùc oâ caïnh nhau hoaëc ñoái xöùng nhau chæ cho pheùp khaùc nhau veà giaù trò
cuûa moät bieán
•
Trong caùc oâ ghi giaù trò cuûa haøm töông öùng vôùi giaù trò cuûa toå hôïp bieán ñoù
Mô tả hàm f hai biến bằng bìa Karnaugh
f
B
A=0, B=0
A=0, B=1
A
0
1
0
A=1, B=0
1
A=1, B=1
Moãi moät oâ vuoâng bieåu dieãn moät minterm cuûa haøm f neáu noù coù giaù trò 1, vaø bieåu
dieãn moät maxterm neáu coù giaù trò 0. Ñoïc giaù trò minterm, maxterm naøy gioáng nhö
ñoái vôùi baûng söï thaät
Ví dụ, Haøm f ñöôïc bieåu dieãn baèng baûng söï thaät vaø baèng bìa Karnaugh nhö sau
A
0
0
1
1
B
0
1
0
1
f
1
1
0
0
f
B
A
f
0
1
0
1
0
1
1
0
B
A.B
AB
Töø bìa Karnaugh ta cuõng coù theå vieát laïi haøm f = A.B + AB
Trang 36
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
A
0
1
0
1
0
1
1
0
Bài Giảng Kỹ Thuật Số
Chương 2
Mô tả hàm f ba biến bằng bìa Karnaugh
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
C
0
1
0
1
0
1
0
1
f
0
0
1
1
1
0
1
0
f
A
0
1
00
0
1
01
0
0
11
1
0
10
1
1
BC
ABC=110
thì f=1
Lưu ý: caùc oâ caïnh nhau hoaëc ñoái xöùng nhau chæ cho pheùp khaùc nhau veà giaù trò
cuûa moät bieán
Mô tả hàm f 4 biến bằng bìa Karnaugh
Ví dụ, Moâ taû haøm f(a,b,c,d) = acd + ab + d
f
ab
00
01
11
10
00
1
1
1
1
01
1
1
1
1
11
0
1
1
1
10
0
1
0
0
cd
Mô tả hàm f 5 biến bằng bìa Karnaugh
Moät bìa 5 bieán coù theå ñöôïc xaây döïng treân khoâng gian 3 chieàu baèng caùch ñaët moät
bìa 4 bieán treân moät bìa thöù hai. Soá haïng lôùp döôùi ñöôïc ñaùnh soá töø 0 ñeán 15, soá
haïng ôû lôùp treân ñöôïc ñaùnh soá töø 16 ñeán 31. Vì vaäy soá haïng nhoùm döôùi chöùa A
vaø soá haïng nhoùm treân chöùa A
f
A
1/0
BC
00
DE
00
01
11
A.B.CDE
10
01
16
1
28
1
1
0
17
4
21
19
23
1
3
22
1
2
1 12
1
5
1
113
18
19
27
1
11
26
30
6
1
15
7
1
1
25
31
1
10
24
29
1
18
11
20
14
10
Trang 37
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
A.BCDE
Bài Giảng Kỹ Thuật Số
Chương 2
Ngoaøi ra ta coù theå moâ taû haøm 5 bieán nhö sau:
A=0
f
BC
00
DE
A=1
01
11
11
10
11
01
00
00
0
2
6
4
5
7
3
1
01
8
10
14
12
13
15
11
9
11
24
26
30
28
29
21
27
25
10
16
18
22
20
21
23
19
17
Mô tả hàm f 6 biến bằng bìa Karnaugh
f
ABC
000
001
011
010
110
111
101
100
000
0
1
3
2
6
7
5
4
001
8
9
11
10
14
15
13
12
011
24
25
27
26
30
21
29
28
010
16
17
19
18
22
33
21
20
110
48
49
51
50
54
55
53
52
111
56
57
59
58
62
63
61
60
101
40
41
43
42
46
47
45
44
100
32
33
35
34
38
39
37
36
DEF
2.11. TỐI THIỂU HÓA HÀM LOGIC BẰNG BÌA KARNAUGH
Các bước thực hiện
Bước 1. Bieåu dieãn haøm ñaõ cho thaønh baûng Karnaugh
Bước 2. Xaùc ñònh nhoùm caùc tích cöïc tieåu hoaëc caùc toång cöïc tieåu (nhoùm 2k oâ keá caän
hoaëc ñoái xöùng vôùi ñieàu kieän trong moãi nhoùm phaûi coù ít nhaát 1 oâ chöa ñöôïc nhoùm bôûi
caùc nhoùm khaùc)
Bước 3. Trong moãi nhoùm, caùc bieán coù giaù trò gioáng nhau thì giöõ laïi, caùc bieán coù giaù
trò khaùc nhau thì ñôn giaûn, sau ñoù vieát haøm keát quaû theo toång hoaëc theo tích
Trang 38
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
Ví dụ, tích cực tiểu 2 ô kế cận
x
C
C
0
1
AB
1
0
AB
(a)
0
0
0
0
A.B
A.B
x
A.B
A.B
x=ABC+ABC = BC
AB
AB
C
C
0
1
0
0
(b)
0
X
0
0
C.D
CD
0
0
0
1
0
0
X
0
(d)
x=ABC+ABC = AB
Ví dụ, ruùt goïn bìa K sau
x
C
C
1
0
AB
0
1
AB
(c)
X
X
0
0
A.B
A.B
x
A.B
A.B
AB
AB
CD CD
1
1
0
0
0
0
0
X
Ví dụ, tích cực tiểu 4 ô kế cận
x
C
C
0
0
AB
X
0
AB
(a)
1
X
1
1
A.B
A.B
x
C.D
CD
0
0
1
0
0
0
1
0
(b)
A.B
A.B
x=C
AB
AB
CD CD
X
0
0
0
x=AB
X
1
0
0
Ví dụ, ruùt goïn bìa K sau
x
A.B
A.B
AB
AB
C.D
1
0
0
X
x
CD CD
0
0
0
1
1
0
X
1
0
0
0
0
(c)
x
CD
A.B
A.B
AB
AB
A.B
A.B
AB
AB
C.D
CD
1
0
0
1
0
1
0
X
(e)
C.D
CD
0
0
X
1
0
0
0
0
(d)
CD CD
X
1
0
0
0
1
X
1
CD CD
0
1
0
0
0
0
X X
Trang 39
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
Ví dụ, tích cực tiểu 8 ô kế cận
x
x
C.D
CD
0
1
1
0
0
1
1
0
(a)
A.B
A.B
AB
AB
CD CD
X
0
1
1 x=B
X
1
X
0
Ví dụ, ruùt goïn bìa K sau
x
C.D
CD
1
X
0
1
1
0
0
1
(c)
A.B
A.B
AB
AB
A.B
A.B
AB
AB
C.D
CD
1
X
1
1
1
X
1
1
(b)
C.D
CD
1
1
1
1
0
0
0
0
(d)
CD CD
0
0 x= C
0
X
0
0
0
0
x
CD CD
1
0
0
1
A.B
A.B
1
X
0
1
AB
AB
CD CD
0
1
0
1
0
1
0
1
Trang 40
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
Bài tập chương 2
2.1. Vẽ dạng sóng ngõ ra cho mạch hình sau
(A)
(A)
(B)
(C)
(B)
X
(C)
2.2. Giả sử ngõ vào A (bài 2.1) = 0, vẽ dạng sóng ngõ ra.
2.3. Giả sử ngõ vào A (bài 2.1) = 1, vẽ dạng sóng ngõ ra.
2.4. Có bao nhiêu tổ hợp ngõ vào của cổng OR 5 ngõ vào làm cho ngõ ra ở
mức cao?
2.5. Thay đổi cổng OR ở bài 2.1 thành cổng AND
a. Vẽ sóng ngõ ra
b. Vẽ sóng ngõ ra nếu ngõ vào A nối mass
c. Vẽ sóng ngõ ra nếu ngõ vào A nối +5V
2.6. Thêm cổng đảo ở ngõ ra của cổng OR (bài 2.1). Vẽ dạng sóng tại ngõ ra
của cổng đảo.
2.7. Viết biểu thức Boolean cho ngõ ra X. Xác định gia trị của X ứng với các
điều kiện ngõ vào có thể và liệt kê các giá trị vào bảng sự thật.
A
B
X
C
2.8. Làm lại với các yêu cầu tương tự bài 2.7
A
B
C
X
D
Trang 41
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
2.9. Xác định bảng sự thật đầy đủ cho mạch ở bài 2.8 bằng cách tìm mức
logic hiện điện tại ngõ ra ứng với mỗi sự kết hợp của ngõ vào.
2.10. Thay cổng OR thành cổng AND, cổng AND thành cổng OR ở bài 2.8,
viết biểu thức ngõ ra.
2.11. Ứng với mỗi biểu thức bên dưới, xây dựng mạch logic tương ứng,
dùng cổng AND, OR, cổng đảo
a. x = AB(C + D )
b. z = ( A + B + CD E ) + BC D
c. y = ( M + N ) + PQ
d. x = W + PQ
e. z = MN ( P + N )
2.12. Vẽ dạng sóng ngõ ra
(A)
(A)
(B)
(C)
(B)
X
(C)
2.13. Làm lại bài 2.12 với cổng NAND
2.14. Viết biểu thức ngõ ra cho mạch sau và xác định bảng sự thật
A
B
X
C
2.15. Thay đổi mạch điện được xây dựng trong bài 2.15 chỉ dùng cổng NAND
2.16. Hoàn tất các biểu thức sau
a. A + 1 =
b. A . A =
c. B . B =
d. C + C =
e. X . 0 =
f. D . 1 =
g. D + 0 =
h. C + C =
i. G + GF =
j. y + wy =
Trang 42
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
2.17. Đơn giản biểu thức sau
a. x = ABC + AC
b. y = (Q + R ) Q + R
(
)
c. w = ABC + ABC + A
d. q = RST R + S + T
(
)
e. x = ABC + ABC + ABC + ABC + ABC
f.
(
)(
)
z = B +C B +C A+ B +C
g. x=(M+N)(M+P)(N+P)
h. z=ABC+ABC+BCD
i. y = C + D + AC D + ABC + ABCD + AC D
(
)
2.18. Hãy chứng minh định lý DeMorgan bằng tất cả các cách có thể.
2.19. Đơn giản biểu thức bên dưới dùng định lý DeMorgan:
a. ABC
b. A+BC
c. ABCD
d. A(B+C)D
e. (M+N)(M+N)
f.
ABCD
2.20. Trình bày cách tạo cổng NAND 2 ngõ vào từ cổng NOT 2 ngõ vào.
2.21. Trình bày cách tạo cổng NOR 2 ngõ vào từ cổng NAND 2 ngõ vào.
2.22. Hoàn tất bảng sự thật cho mạch sau
A
B
X
C
D
E
2.23. Chỉ ra cách thực hiện x = A BC bằng 1 cổng NOR 2 ngõ vào và 1 cổng
NAND 2 ngõ vào.
2.24. Thực hiện biểu thức Y = ABCD sử dụng các cổng NAND 2 ngõ vào.
Trang 43
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 2
2.25 Rút gọn bìa Karnaugh sau
A.B
A.B
AB
AB
A.B
A.B
AB
AB
C.D
CD
0
X
0
0
0
1
1
0
(a)
C.D
CD
X
0
1
0
1
1
X
0
(c)
CD CD
0
1
X
1
1
0
0
0
A.B
A.B
AB
AB
C.D
CD
0
1
1
0
0
1
1
0
(b)
CD CD
CD CD
0
X
1
1
0
1
0
0
2.26 Rút gọn hàm bài 2.17 dùng bìa Karnaugh
Trang 44
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
1
1
0
0
0
1
0
0
Bài Giảng Kỹ Thuật Số
Chương 3
CHƯƠNG 3. MẠCH LOGIC TỔ HỢP
3.1. GIỚI THIỆU
Chöông 2 ñaõ khaûo saùt caùc pheùp toaùn cuûa taát caû caùc coång logic vaø vieäc söû duïng ñaïi
soá Boolean ñeå moâ taû vaø phaân tích caùc maïch keát hôïp töø caùc coång logic. Caùc maïch
naøy ñöôïc goïi laø maïch logic toå hôïp, vì möùc logic ngoõ ra chæ phuï thuoäc vaøo toå hôïp
logic ngoõ vaøo hieän taïi.
Moät maïch toå hôïp thì khoâng coù ñaëc tính nhôù
Caùc phöông phaùp toái thieåu hoùa thöôøng ñöôïc söû duïng trong thieát keá soá laø:
•
Söû duïng caùc ñònh lyù cuûa ñaïi soá Boolean
•
Caùc kyõ thuaät duøng bìa (Karnaugh, Quine Mc. Cluskey)
Mô hình mạch tổ hợp với n đầu vào và m đầu ra
X1
X2
MẠCH TỔ
HỢP
Xn
Y1
Y2
Ym
3.2. THIẾT KẾ MẠCH LOGIC TỔ HỢP
3.2.1. Các bước thiết kế mạch logic tổ hợp
•
ÖÙng vôùi moãi toå hôïp ngoõ vaøo, ñaët caùc möùc logic ngoõ ra theo yeâu caàu thieát keá, taát
caû caùc khaû naêng ngoõ ra cuûa moät maïch logic coù theå ñöôïc bieåu dieãn thoâng qua
baûng söï thaät.
•
Töø baûng söï thaät suy ra bieåu thöùc Boolean cho maïch caàn thieát keá
•
Ruùt goïn bieåu thöùc Boolean
•
Chuyeån bieåu thöùc Boolean thaønh maïch toå hôïp
Ví dụ,
Thieát keá moät maïch logic 3 ngoõ vaøo, A, B, C vôùi yeâu caàu: ngoõ ra seõ ôû möùc cao khi coù ít
nhaát 2 ngoõ vaøo ôû möùc cao
Giải.
Bước 1. Thieát laäp moät baûng söï thaät, coù taát caû 8 khaû naêng ñoái vôùi ngoõ vaøo. Döïa vaøo
yeâu caàu baøi toaùn, ngoõ ra seõ ôû möùc 1 khi coù 2 hay 3 ngoõ vaøo ôû möùc 1, caùc tröôøng hôïp
coøn laïi ngoõ ra ôû möùc 0.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 45
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
Chương 3
C
0
1
0
1
0
1
0
1
X
0
0
0
1
0
1
1
1
Minterm
A.BC
A BC
ABC
ABC
Bước 2. Vieát bieåu thöùc ngoõ ra döôùi daïng minterm (cho moãi tröôøng hôïp X=1)
X = A.BC + ABC + ABC + ABC
Bước 3. Coù theå vieát laïi
X=ABC+ABC+ABC+ABC+ABC+ABC
Nhoùm caùc soá haïng laïi vôùi nhau
X=BC(A+A)+AC(B+B)+AB(C+C)=BC+AC+AB
Bước 4. Bieåu thöùc ngoõ ra ñöôïc thöïc hieän nhö sau:
74LS08
B
C
A
B
A
X
X
1
C
74LS08
74LS08
Hình (a)
Hình (b)
Ngöôøi ta cuõng co theå bieán ñoåi bieåu thöùc treân thaønh x=C(B + A) + AB, vaø maïch logic
ñöôïc thöïc hieän nhö hình (b)
Maïch (b) coù phaàn ñôn giaûn hôn vì chæ söû duïng caùc coång 2 ngoõ vaøo thay vì phaûi söû
duïng coång OR 3 ngoõ vaøo nhö maïch (a). Treân thöïc teá ngöôøi thieát keá vaãn choïn maïch
(a) bôûi vì nhieàu lyù do, moät trong nhöõng lyù do laø tín hieäu ngoõ vaøo A, B ôû maïch (b)
phaûi qua 3 coång logic tröôùc khi ñöôïc ñöa ra ngoõ ra. Ñieàu naøy coù theå aûnh höôûng raát
lôùn trong moät heä thoáng soá toác ñoä cao.
Ví dụ, Thieát keá moät maïch logic 4 ngoõ vaøo, A, B, C, D (trong ñoù A öùng vôùi MSB, vaø
D öùng vôùi LSB) vôùi yeâu caàu ngoõ ra seõ ôû möùc cao khi giaù trò thaäp phaân cuûa caùc ngoõ
vaøo ABCD > 610
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 46
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
3.2.2. Một số điểm quan trọng khi thực hiện thiết kế cuối cùng
Trong caùc ví duï veà thieát keá treân, caùc maïch ñöôïc thöïc hieän thoâng qua caùc coång AND
vaø OR, trong ñoù moät hay nhieàu coång AND laùi moät coång OR do vieäc bieåu dieãn haøm
döôùi daïng minterm. Khi bieåu dieãn haøm döôùi daïng minterm ta coù theå deã daøng
chuyeån ñoåi caùc coång logic thaønh moät coång NAND duy nhaát (löu yù xem laïi phaàn
chuyeån ñoåi ñaõ khaûo saùt ôû chöông 2), bôûi vì coång NAND laø coång logic coù ñaùp öùng
nhanh nhaát trong hoï logic TTL, ñaây laø moät ñaëc tính quan troïng caàn phaûi löu yù.
Ví dụ, bieán ñoåi maïch cuûa 2 ví duï treân duøng coång NAND
B
C
B
C
A
X
A
74LS08
3.3. KỸ THUẬT CỰC TIỂU QUINE-Mc CLUSKEY
Caùc heä thoáng soá hieän ñaïi ñöôïc thieát keá baèng caùch söû duïng caùc thieát bò logic phöùc
taïp, do ñoù ñoøi hoûi moät kyõ thuaät toái hieåu hoùa haøm logic vôùi söï hoã trôï cuûa maùy tính
thay vì laøm baèng tay vôùi caùc yeâu caàu:
•
Coù khaû naêng xöû lyù moät soá lôùn caùc bieán
•
Khoâng phuï thuoäc vaøo khaû naêng cuûa ngöôøi duøng trong vieäc nhaän bieát caùc phaàn töû
nguyeân toá
•
Ñaûm baûo bieåu thöùc ñöôïc cöïc tieåu hoùa
•
Phuø hôïp cho giaûi phaùp baèng maùy tính
Phương pháp:
Bước 1. Chuyển hàm về dạng minterm
Bước 2. Sắp xếp các số hạng minterm của hàm theo từng nhóm có chung số bit 1
Bước 3. Áp dụng định lý A+A =1 cho 2 minterm chỉ sai khác nhau 1 bit 1. Lặp lại
cho đến khi nhóm xong các minterm
Bước 4. Quan sát bảng các nguyên tố cơ bản được rút gọn, xác định cột chỉ chứa một
minterm
Bước 5. Viết hàm dưới dạng tổng chuẩn rút gọn của các minterm đó
Ví dụ. Ruùt goïn haøm Boolean sau duøng phöông phaùp Quin McCluskey
Y=∑ ABCD (0,1,2,3,5,7,8,9,11,14)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 47
https://fb.com/tailieudientucntt
X
Bài Giảng Kỹ Thuật Số
Chương 3
Bước 2.
Nhoùm
(soá bit 1)
1
Minterm
1
2
8
3
5
9
7
11
14
2
3
A
0
0
1
0
0
1
0
1
1
Caùc bieán
B
C
0
0
0
1
0
0
0
1
1
0
0
0
1
1
0
1
1
1
D
1
0
0
1
1
1
1
1
0
A
0
0
0
0
0
1
0
0
1
1
Caùc bieán
B
C
0
0
0
0
0
0
0
0
0
0
1
0
0
1
0
1
1
0
1
1
D
0
0
1
1
1
1
1
1
1
0
Bước 3. Nhoùm caùc minterm chæ sai khaùc 1 bit
Nhoùm
1
2
3
4
Minterm
0,1
0,2
0,8
1,3
1,5
1,9
2,3
8,9
3,7
3,11
5,7
9,11
14
Laëp laïi böôùc 3, tieáp tuïc nhoùm caùc minterm chæ sai khaùc 1 bit
Nhoùm
1
2
3
Nguyeân toá
cô baûn
AB
0,1,2,3
0,1,8,9
A
0
-
Caùc bieán
B
C
0
0
0
D
-
1,3,5,7
1,3,9,11
0
-
0
-
1
1
AD
14
1
1
1
0
ABCD
Minterm
BC
BD
Bước 4. Quan saùt caùc nguyeân toá vaø tìm caùc coät chæ chöùa moät gaïch cheùo (kyù hieäu
⊗)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 48
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Caùc
nguyeân toá
Chương 3
Caùc soá thaäp
phaân
Caùc minterm
0
1
2
3
5
7
8
9
11
14
⊗
ABCD
14
AB
0,1,2,3
X
X
BC
0,1,8,9
X
X
AD
1,3,5,7
X
X
BD
1,3,9,11
X
X
⊗
X
⊗
⊗
X
⊗
X
⊗
Thaáy raèng, taát caû caùc nguyeân toá ñeàu coù ⊗, ñaây laø caùc minterm ñaõ cöïc tieåu hoùa, vaäy
haøm cuoái cuøng laø
Y= ABCD + A B + B C + A D + B D
Ví dụ. Ruùt goïn haøm Boolean sau duøng phöông phaùp Quin McCluskey
Y=∏ ABCD (2,4,5,6,10,12,13,14)
3.4. THIẾT KẾ MẠCH KHÔNG SỬ DỤNG BẢNG SỰ THẬT
Moät soá baøi toaùn thieát keá ñoâi khi coù theå giaûi quyeát tröïc tieáp maø khoâng qua caùc böôùc
thieát keá treân, ñoái vôùi nhöõng baøi toaùn naøy ñoøi hoûi phaûi hieåu roõ nhöõng pheùp toaùn
logic, caùc coång logic vaø caùc tính chaát cuûa coång logic. Xeùt moät vaøi ví duï sau ñaây
3.4.1. Mạch so sánh số nhị phân 2 bit
Bài toán
x1
x0
Mạch
y1
y0
sánh
so
z
Thieát keá maïch sao cho ngoõ ra seõ ôû möùc cao khi
x1x0 = y1y0
Giaûi.
Coù theå giaûi baøi toaùn baèng caùch laäp baûng söï thaät
roài ruùt goïn haøm
Tuy nhieân, neáu ta xeùt ñeán ñaëc ñieåm cuûa pheùp
toaùn töông ñöông hay coång XNOR (ngoõ ra seõ ôû
möùc cao neáu 2 ngoõ vaøo baèng nhau) ta seõ thaáy
vaán ñeà caàn giaûi quyeát seõ ñôn giaûn hôn nhieàu.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
x1
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
x0
0
0
0
0
1
1
1
1
0
0
0
0
1
1
1
1
Trang 49
https://fb.com/tailieudientucntt
y1
0
0
1
1
0
0
1
1
0
0
1
1
0
0
1
1
y0
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
z
1
0
0
0
0
1
0
0
0
0
1
0
0
0
0
1
Bài Giảng Kỹ Thuật Số
Chương 3
Coát loõi cuûa baøi toaùn laø so saùnh x0 vôùi y0 vaø x1 vôùi y1, ta seõ coù maïch nhö sau:
X1
X0
Z
Y1
74LS08
Y0
3.4.2. Mạch tạo và kiểm tra chẵn lẻ
Khi truyeàn döõ lieäu töø maùy phaùt sang maùy thu, coù nhieàu caùch ñeå kieåm tra loãi trong
khi truyeàn, moät trong nhöõng caùch ñôn giaûn nhaát laø theâm 1 bit vaøo döõ lieäu ñöôïc
truyeàn ñi, bit ñoù goïi laø bit chaün leû (parity bit).
Parity bit coù hai giaù trò 0 hay 1 tuøy thuoäc vaøo soá bit 1 coù trong nhoùm maõ. coù hai
phöông phaùp taïo bit parity.
Phương pháp parity chẵn
Giaù trò cuûa bit parity ñöôïc choïn sao cho toång caùc chöõ soá 1 trong nhoùm maõ laø soá
chaün.
Neáu soá bit 1 trong nhoùm maõ laø leû thì bit parity theâm vaøo laø 1
Neáu soá bit 1 trong nhoùm maõ laø chaün thì bit parity theâm vaøo laø 0
Ví duï maõ ASCII cuûa chöõ C laø 1000011, nhoùm maõ naøy coù 3 bit 1 vì vaäy seõ ñaët theâm
parity bit laø 1 ñeå sao cho nhoùm maõ taïo ra coù soá bit 1 laø chaün (4 bit 1)
11000011
Bit parity theâm vaøo
maõ ASCII cuûa chöõ A laø 1000001, bit parity theâm vaøo seõ laø bit 0 (01000001)
Maïch taïo Parity chaün döïa treân phöông phaùp so saùnh soá bit 1
D3
D2
D1
D0
Parity (P)
To Receiver
Ngoõ ra coång XOR ôû möùc cao khi soá bit 1 ôû ngoõ vaøo laø leû
Ta coù theå thieát keá maïch duøng baûng söï thaät vaø keát quaû cuõng gioáng nhö treân
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 50
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
Phương pháp Parity lẻ
Giaù trò cuûa bit parity ñöôïc choïn sao cho toång caùc chöõ soá 1 trong nhoùm maõ laø soá leû.
Neáu soá bit 1 trong nhoùm maõ laø leû thì bit parity theâm vaøo laø 0
Neáu soá bit 1 trong nhoùm maõ laø chaün thì bit parity theâm vaøo laø 1
Ví duï maõ ASCII cuûa chöõ C laø 1000011, nhoùm maõ naøy coù 3 bit 1 vì vaäy seõ ñaët theâm
parity bit laø 0 ñeå sao cho nhoùm maõ taïo ra coù soá bit 1 laø leû
01000011
Bit parity theâm vaøo
maõ ASCII cuûa chöõ A laø 1000001, bit parity theâm vaøo seõ laø bit 1 (11000001)
Mạch kiểm tra chẵn lẻ
Maïch kieåm tra chaün töông töï nhö maïch phaùt parity chaün, cuõng döïa treân nguyeân lyù
cuûa coång XOR, ngoõ ra seõ ôû möùc cao neáu caùc ngoõ vaøo coù soá bit 1 laø chaün. Nghóa laø
khi ngoõ ra ôû möùc 1: khoâng coù loãi, khi ngoõ ra ôû möùc 0: coù loãi trong khi truyeàn. Maïch
nhö hình sau
P
D3
D2
D1
D0
Error (E)
0=no error
1=error
Maïch chæ kieåm tra caùc bit goác coù bò loãi hay khoâng chöù khoâng bieát ñöôïc bit naøo loãi
trong tröôøng hôïp phaùt hieän ñöôïc loãi
3.4.3. Mạch cho phép/cấm
Moãi coång logic cô baûn coù theå ñöôïc söû duïng ñeå ñieàu khieån cho pheùp hoaëc khoâng cho
pheùp caùc tín hieäu ñi qua coång ñoù.
ÔÛ ñaây ta söû duïng moät ngoõ vaøo laøm chaân ñieàu khieån cho pheùp hoaëc caám, ngoõ coøn laïi
caáp tín hieäu
Control
Control
Cổng
logic
Không
thay đổi
trạng thái
Traïng thaùi caám (ñoùng coång)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Cổng
logic
Traïng thaùi cho pheùp (môû coång)
Trang 51
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
Ví dụ,
Thieát keá maïch logic cho pheùp tín hieäu ñi qua chæ khi hai ngoõ ñieàu khieån B vaø C ñeàu
ôû möùc cao, caùc tröôøng hôïp coøn laïi ngoõ ra ôû möùc thaáp
Giải.
A
B
C
X
74LS11
Ví dụ
Thieát keá maïch logic cho pheùp tín hieäu ñi qua chæ khi 2 ngoõ vaøo ñieàu khieån coù möùc
logic khaùc nhau.
Ví dụ,
Thieát keá maïch logic vôùi tín hieäu ngoõ vaøo taïi A, ñieàu khieån taïi B, ngoõ ra X vaø Y nhö
sau:
Khi B=1 ngoõ ra X = A, Y = 0
Khi B=0 ngoõ ra X = 0, Y= A
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 52
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
3.5.
Chương 3
MẠCH GIẢI MÃ (Decoder)
Laø maïch logic giaûi maõ N-bit nhò phaân ngoõ vaøo thaønh M ñöôøng ngoõ ra, chæ duy nhaát
moät ñöôøng ngoõ ra ôû möùc tích cöïc öùng vôùi moät toå hôïp N-bit ngoõ vaøo. Goïi boä giaûi
maõ laø boä phaùt hieän maõ
O0
O1
O2
A0
N
input
A1
A2
Decoder
M
output
OM-1
AN-1
Moät soá maïch giaûi maõ khoâng söû duïng heát taát caû caùc khaû naêng cuûa ngoõ vaøo, vì vaäy
öùng vôùi toå hôïp ngoõ vaøo khoâng söû duïng thì khi thieát keá khoâng coù ngoõ ra naøo tích cöïc
3.5.1. Mạch giải mã 3 sang 8
Maïch coù 3 ngoõ vaøo vaø 8 ngoõ ra, coøn ñöôïc goïi laø maïch giaûi maõ nhò phaân sang octal
(binary to octal decoder), vôùi ngoõ ra tích cöïc möùc 1, coù baûng söï thaät nhö sau
Bảng sự thật
C
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
A
0
1
0
1
0
1
0
1
Q0
1
0
0
0
0
0
0
0
Q1
0
1
0
0
0
0
0
0
Q2
0
0
1
0
0
0
0
0
Q3
0
0
0
1
0
0
0
0
Q4
0
0
0
0
1
0
0
0
Q5
0
0
0
0
0
1
0
0
Q6
0
0
0
0
0
0
1
0
Q7
0
0
0
0
0
0
0
1
Q0 = C.B.A
Q0 = C.B.A
Q1 = C.B.A
Q2 = C.BA
A
(LSB)
Q1 = C.B.A
Q3 = C.BA
Q4 = CB.A
Q2 = C.BA
B
Q3 = C.BA
Q5 = CB.A
Q6 = CB.A
Q7 = CBA
C
(MSB)
Q4 = CB.A
Q5 = CB.A
Tröôøng hôïp ngoõ ra
tích cöïc möùc 0 laøm
töông töï
Q6 = CB.A
Q7 = CBA
Trang 53
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
3.5.2. Ngõ vào cho phép
Ña soá caùc boä giaûi maõ ñeàu coù moät hoaëc nhieàu ngoõ vaøo cho pheùp ñeå ñieàu khieån hoaït
ñoäng cuûa boä giaûi maõ.
Ví dụ, xeùt boä giaûi maõ ôû treân, keát noái moãi coång AND ngoõ ra vôùi chaân ñieàu khieån cho
pheùp chung ENABLE. Khi ENABLE=1, cho pheùp coång AND hoaït ñoäng bình thöôøng
ôû cheá ñoä giaûi maõ, khi ENABLE ôû möùc thaáp ngoõ ra cuûa caùc coång AND ñöôïc ñaët ôû
möùc 0, nghóa laø maïch cho pheùp giaûi maõ öùng vôùi ngoõ ENABLE=1 vaø khoâng cho
pheùp öùng vôùi ENABLE=0
3.5.3. Giải mã 3 sang 8 dùng IC74LS138
G2A
G2B
G1
Output
0
0
1
Ngoõ ra tích cöïc theo maõ cuûa A2A1A0
1
x
x
Khoâng giaûi maõ, ngoõ ra ôû möùc cao
x
1
x
Khoâng giaûi maõ, ngoõ ra ôû möùc cao
x
x
0
Khoâng giaûi maõ, ngoõ ra ôû möùc cao
(MSB) A2
A1
A
B
C
G1
G2A
G2B
74LS138
G2A G2B G1
A0 (LSB)
74LS11
Y7
Y6
Y5
Y4
Y3
Y2
Y1
Ví dụ
Xaùc ñònh ngoõ ra naøo cuûa 74LS138 tích cöïc öùng vôùi caùc ngoõ vaøo nhö sau:
G2A = 0; G2B = G1=1 ; A2 = A1 = 1 ; A0 = 0
G2A = G2B = 0 ; G1=1 ; A2 = 0 ; A1 = A0 = 1
Trang 54
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Y0
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
Bài Giảng Kỹ Thuật Số
Chương 3
3.5.4. Ghép các bộ giải mã liên tầng
Coù theå gheùp caùc boä giaûi maõ lieân taàng ñeå coù theå giaûi maõ ñöôïc töø maõ lôùn hôn.
Ví dụ, keát hôïp 2 boä giaûi maõ 3 sang 8 ñeå taïo thaønh 1 boä giaûi maõ 4 sang 16
A0
A1
A2
A
B
C
HI
G1
G2A
G2B
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
DEC0
DEC1
DEC2
DEC3
DEC4
DEC5
DEC6
DEC7
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
DEC8
DEC9
DEC10
DEC11
DEC12
DEC13
DEC14
DEC15
74LS138
A
B
C
A3
EN
G1
G2A
G2B
74LS138
EN=0 cho pheùp maïch giaûi hoaït ñoäng
Ñoái vôùi caùc boä giaûi maõ lôùn hôn, coù theå theâm vaøo 1 boä giaûi maõ nhö sau
A0
A1
A2
A
B
C
G1
G2A
G2B
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
DEC0
DEC1
DEC2
DEC3
DEC4
DEC5
DEC6
DEC7
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
DEC8
DEC9
DEC10
DEC11
DEC12
DEC13
DEC14
DEC15
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
DEC16
DEC17
DEC18
DEC19
DEC20
DEC21
DEC22
DEC23
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
DEC24
DEC25
DEC26
DEC27
DEC28
DEC29
DEC30
DEC31
74LS138
A
B
C
G1
G2A
G2B
EN3
A3
A4
G
A
B
Y0
Y1
Y2
Y3
A
B
C
G1
G2A
G2B
74LS139A
A
B
C
EN1
EN2
G1
G2A
G2B
Ví dụ
Söû duïng 4 IC 74LS138 vaø moät coång ñaûo, thieát keá maïch giaûi maõ 5 sang 32
Trang 55
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
3.5.5. Sử dụng bộ giải mã tạo các minterm
Caùc ngoõ ra cuûa boä giaûi maõ (ôû cheá ñoä cho pheùp) töông öùng vôùi caùc minterm cuûa caùc
ngoõ vaøo.
Ví dụ caùc minterm cuûa caùc ngoõ ra 74LS138 nhö sau Y 0 = C.B.A , Y1 = C.BA , v.v.
Neáu moät haøm logic coù caùc minterm nhö ngoõ ra cuûa boä giaûi maõ thì ta coù theå söû duïng
boä giaûi maõ ñoù ñeå xaây döïng haøm treân
Ví dụ
Xeùt haøm F =
∑
X ,Y , Z
(0,2,3,5) = X .Y .Z + X Y Z + X YZ + X Y Z
Coù theå thieát laäp haøm nhö sau:
Z
Y
X
A
B
C
HI
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
G1
G2A
G2B
F
74LS20
74LS138
Quaù trình thieát keá coù theå choïn caùch thieát keá naøy hoaëc caùch thieát keá khaùc tuøy thuoäc
vaøo toác ñoä, giaù thaønh ... Giaûi phaùp söû duïng boä giaûi maõ raát thuaän tieän vì coù theå deã
daøng thay ñoåi caùc minterm. Ngoaøi ra coù theå thieát keá nhieàu haøm logic ngoõ ra, ví duï
söû duïng boä giaûi maõ vaø coång NAND thöïc hieän caùc haøm sau
F=
∑
X ,Y , Z
(2,4,5) , G =
∑
X ,Y , Z
(0,1,3) , H =
∑
X ,Y , Z
(3,6,7)
74LS138
Z
Y
X
F
A
B
C
HI
Y0
Y1
Y2
Y3
Y4
G1 Y5
G2B Y6
G2A Y7
74LS10
G
H
3.5.6. Giải mã 7 đoạn
Boä giaûi maõ 7 ñoaïn coù 4 ngoõ vaøo theo maõ BCD vaø 7 ngoõ ra öùng
vôùi maõ 7 ñoaïn
Boä hieån thò 7 ñoaïn coù theå laø LED 7 ñoaïn hoaëc baèng tinh theå loûng
(LCD liquid– crystal display) ñöôïc söû duïng trong caùc maùy tính
tay hieån thò giaù trò thaäp phaân. LED 7 ñoaïn coù 2 loaïi: loaïi anode
chung vaø loaïi cathode chung
Trang 56
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
a
f
b
g
e
c
d
Bài Giảng Kỹ Thuật Số
Chương 3
+Vcc
a
a
b
b
c
c
d
d
e
e
f
f
g
g
LED 7 ñoaïn Cathode chung
LED 7 ñoaïn Anode chung
Ví dụ
74LS49 coù ngoõ ra tích cöïc möùc cao,
LED töông öùng laø cathode chung nhö
hình beân
Bảng sự thật của 74LS49 (tra phần
phụ lục)
BI OA
OB
OC
A OD
B OE
C OF
D OG
74LS49
Ví dụ:
74LS47 vôùi ngoõ ra tích cöïc möùc thaáp, söû duïng LED töông öùng laø cathode chung nhö
sau
HI
BI/RBO
A
RBI
LT
B
C
A
D
B
E
C
F
D
G
74LS47
Tính toaùn caùc giaù trò ñieän trôû baèng coâng thöùc sau
R=
VCC − VLED
I LED
VLED khoaûng 2,7V, ILED khoaûng 10mA, vaäy R = 230 Ω
LED tinh thể lỏng LCD
LCD hoaït ñoäng vôùi möùc ñieän aùp thaáp (khoaûng 3 ñeán
15VRMS) taàn soá hoaït ñoäng thaáp (25 ñeán 60hz) vaø doøng
cung caáp raát beù vaø cuõng ñöôïc theå hieän 7 ñoaïn gioáng nhö
LED 7 ñoaïn
a
b
c
d
e
f
g
Blackblane
Trang 57
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
Ñieän aùp ac caàn ñeà laøm töøng ñoaïn saùng laø ñieän aùp giöõa ñoaïn ñoù vôùi blackblane.
Giöõa segment vaø blackblane hình thaønh moät ñieän dung. Taàn soá thaáp nhaát cuûa ñieän
aùp ac laø 25hz
LCD söû duïng doøng ít hôn LED vaø thöôøng ñöôïc söû duïng ôû caùc thieát bò duøng pin nhö
maùy tính… vaø noù caàn theâm nguoàn naêng löôïng ngoaøi laø aùnh saùng ñeå coù theå thaáy ñöôïc.
Ñeå laùi moät LCD, theo nguyeân taéc 1 segment seõ saùng khi coù moät ñieän aùp ac ñaët giöõa
segment vaø blackblane, vaø segment seõ taét khi khoâng coù aùp ac naøy. Ñeå coù moät ñieän
aùp ac ngöôøi ta taïo ra moät soùng vuoâng nhö sau
Control
Segmen
40hz signal
4070
Blackblane
Phöông phaùp ñeå laùi moät LCD 7 ñoaïn nhö sau
4070
A
B
C
D
A
B
C
D
E
F
G
LT
BI
LE
4511
LCD
40hz
Blackblane
3.5.7. Giải mã BCD sang 10 dùng IC74LS42
Caùch thieát keá maïch giaûi maõ BCD sang thaäp phaân thì töông töï
nhö caùch thieát keá maïch 3 sang 8 (xem nhö moät baøi taäp veà
nhaø).
IC giaûi maõ BCD sang thaäp phaân: 74LS42 baûng söï thaät tra phaàn
phuï luïc
Y0
Y1
Y2
B Y3
Y4
C Y5
Y6
D Y7
Y8
Y9
A
74LS42
Trang 58
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
3.6.
Chương 3
MAÏCH MAÕ HOÙA (ENCODER)
Ngöôïc vôùi quaù trình giaûi maõ laø quaù trình maõ hoùa vaø ñöôïc thöïc hieän bôûi maïch logic
maõ hoùa. Chæ moät ngoõ vaøo cuûa boä maõ hoùa ñöôïc tích cöïc, vaø töø maõ N-bit ngoõ ra tuøy
thuoäc vaøo ngoõ vaøo naøo ñöôïc tích cöïc
N
input
A0
O0
A1
O1
Encoder
A2
M
O2
AN-1
output
OM-1
3.6.1. Maõ hoùa 8 sang 3 (octal sang nhò phaân)
Baûng sö thaät vaø maïch logic cho maïch maõ hoùa octal – binary vôùi ngoõ vaøo tích cöïc
möùc thaáp
A0
x
x
x
x
x
x
x
x
A1
1
0
1
1
1
1
1
1
8
input
A2
1
1
0
1
1
1
1
1
A3
1
1
1
0
1
1
1
1
A4
1
1
1
1
0
1
1
1
A5
1
1
1
1
1
0
1
1
A6
1
1
1
1
1
1
0
1
A7
1
1
1
1
1
1
1
0
A0
A1
A2
A3
A4
A5
A6
A7
Q2
0
0
0
0
1
1
1
1
Q1
0
0
1
1
0
0
1
1
Q0
0
1
0
1
0
1
0
1
Q0 LSB
Q1
Q2 MSB
Löu yù raèng A0 khoâng keát noái trong maïch vì ngoõ ra boä maõ hoùa maëc ñònh baèng 000
khi khoâng coù ngoõ vaøo naøo tích cöùc möùc thaáp
Ví dụ
Xaùc ñònh caùc ngoõ ra cuûa boä giaûi maõ treân khi A3 =A5 =0
3.6.2. Maõ hoùa öu tieân
Töø ví duï treân thaáy raèng khi coù 2 ngoõ vaøo tích cöïc cuøng luùc ñoái vôùi moät boä maõ hoùa
ñôn giaûn seõ daãn ñeán keát quaû khoâng mong muoán.
Trang 59
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
Ñeå traùnh tình traïng treân, thöôøng söû duïng boä maõ hoùa öu tieân. Khi coù 2 hay nhieàu ngoõ
vaøo cuøng tích cöïc thì ngoõ ra seõ töông öùng vôùi ngoõ vaøo coù ñoä öu tieân cao nhaát.
Ví dụ
Khi A3 =A5 =0 thì ngoõ ra eõ töông öùng vôùi A5 nghóa laø 101.
Xeùt moät heä thoáng vôùi 2n ngoõ vaøo, moãi ngoõ vaøo bieåu thò cho moät yeâu caàu cuûa moät
thieát bò nhö sau:
REQ 1
REQ 2
REQ 3
Request
for service
Request
encoder
Requestor’s
number
REQ N
Ñaây laø moät caáu truùc thöôøngñöôïc söû duïng trong moät heä thoáng con input/output cuûa
boä vi xöû lyù, ôû ñaây caùc ngoõ vaøo laø caùc yeâu caàu ngaét.
Ñeå giaûi baøi toaùn öu tieân ñoái vôùi caùc ngoõ vaøo nghóa laø khi coù nhieàu yeâu caàu cuøng moät
luùc, ta vieát bieåu thöùc logic cho ngoõ ra cuûa boä maõ hoùa öu tieân.
Ví dụ
Vôùi maïch maõ hoùa öu tieân 8-3 nhö sau
I0
1
x
x
x
x
x
x
x
I1
0
1
x
x
x
x
x
x
I2
0
0
1
x
x
x
x
x
I3
0
0
0
1
x
x
x
x
I4
0
0
0
0
1
x
x
x
I5
0
0
0
0
0
1
x
x
I6
0
0
0
0
0
0
1
x
I7
0
0
0
0
0
0
0
1
A2
0
0
0
0
1
1
1
1
A1
0
0
1
1
0
0
1
1
A0
0
1
0
1
0
1
0
1
Ñònh nghóa 8 bieán trung gian H0 ñeán H7 nhö sau:
H7 = I7
H6 = I6I7
H5 = I5I6.I7
…
H0 = I0.I1.I2.I3.I4.I5.I6.I7
Töø bieåu thöùc trung gian, vieát laïi bieåu thöùc ngoõ ra nhö sau:
A2 = H4 + H5 + H6 + H7
A1 = H2 + H3 + H6 + H7
A0 = H1 + H3 + H5 + H7
Trang 60
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
74148 laø boä maõ hoùa öu tieân octal to binary
I7 coù ñoä öu tieân cao nhaát.
74LS148 coù hai ngoõ ra GS vaø E0.
Ngoõ GS (Group Select) tích cöïc möùc 0 khi maïch hoaït
ñoäng ôû cheá ñoä maõ hoùa vaø coù 1 trong soá caùc ngoõ vaøo
ñang tích cöïc. E0 (enable output) tích cöïc möùc 0 khi EI
tích cöïc möùc 0 vaø khoâng coù ngoõ vaøo naøo tích cöïc.
IN0
IN1
IN2
IN3
IN4
IN5
IN6
IN7
EI
A0
A1
A2
GS
E0
74LS148
Ví dụ
Söû duïng 74LS148 thieát keá maïch maõ hoùa öu tieân 32 ngoõ vaøo, 5bit ngoõ ra: RA4 ñeán
RA0
74147 laø boä maõ hoùa öu tieân 10 ñöôøng sang BCD
Khi khoâng coù ngoõ vaøo naøo ñöôïc taùc ñoäng, ngoõ ra seõ laø
1111, vì ngoõ ra laø ngoõ ra ñaûo neân ñaûo cuûa 1111 laø 0000,
giaù trò BCD laø 0 neân IC 74LS147 khoâng coù ngoõ vaøo IN0,
khi ngoõ vaøo IN9 ôû möùc thaáp, thì ngoõ ra töông öùng laø
0110, ñaûo laïi 1001 töông öùng vôùi maõ BCD laø 9.
Vì caùc ngoõ ra laø ñaûo cho neân ñeå coù ñöôïc maõ BCD ñuùng
ôû ngoõ ra ngöôøi ta theâm caùc coång ñaûo cho moãi ngoõ ra
IN1
IN2
A
IN3
IN4
B
IN5
IN6
C
IN7
IN8
D
IN9
74LS147
Maõ hoùa baøn phím
HI
S0
S1
74LS04
S2
S3
IN1
IN2
IN3
IN4
IN5
IN6
IN7
IN8
IN9
S4
S5
S6
S7
A
B
C
BCD
D
74LS147
S8
S9
Caùc phím coù theå laø baøn phím töø 0 ñeán 9 trong maùy tính. Khi moät phím ñöôïc nhaán, ngoõ
ra seõ laø maõ BCD cuûa phím nhaán ñoù. Khi coù 2 phím ñöôïc nhaán cuøng luùc thì phím ngoõ ra
seõ laø maõ BCD cuûa phím öu tieân cao nhaát
Trang 61
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
3.7. BOÄ CHOÏN KEÂNH (MULTIPLEXERS)
Moät boä choïn keânh töông töông vôùi boä chuyeån maïch soá, noù keát noái data töø n nguoàn
khaùc nhau. Ngoõ ra seõ choïn moät trong caùc nguoàn data ngoõ vaøo tuøy thuoäc vaøo caùc ngoõ
löïa choïn
Multiplexer
Enable
Select
EN
s
s
s
n data
sources
SEL
s
D1
s
D0
s
D1
s
Y
s
s
D0
Data
output
Dn-1
Data
output
Dn-1
Selector Enable
Vôùi 2n ngoõ vaøo thì caàn n bit select
3.7.1. Maïch choïn keânh 2 ngoõ vaøo cô baûn
Select
0
1
I1
Output
Z=I0
Z=I1
74LS08
I0
Z=I0 .S+I1.S
Z
74LS32
1
74LS04
3.7.2. Maïch choïn keânh 4 ngoõ vaøo
S
I0
S1
S0
Output
0
0
Z=I0
0
1
Z=I1
1
0
Z=I2
1
1
Z=I3
74LS11
74LS04
I1
Z
I2
1
I3
SELECT S1
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
S0
Trang 62
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
3.7.3. Maïch choïn keânh 8 ngoõ vaøo 74LS151
74LS151
G
1
0
0
0
0
0
0
0
0
C
x
0
0
0
0
1
1
1
1
B
x
0
0
1
1
0
0
1
1
A
x
0
1
0
1
0
1
0
1
G
Y
0
D0
D1
D2
D3
D4
D5
D6
D7
D0
D1 Y
D2
D3
D4
D5 W
D6
D7
A
B
C
W= Y
Ví dụ
Duøng 2 IC 74ls151 vaø 1 coång ñaûo, moät coång OR thieát keá maïch choïn keânh 16 ngoõ
vaøo, 1 ngoõ ra vaø 4 ngoõ select S0, S1, S2, S3
3.7.4. Maïch choïn keânh 2 nhoùm ngoõ vaøo 74LS157
1A
1B
2A
2B
3A
3B
4A
4B
74LS157 chöùa 2 nhoùm ngoõ vaøo nhö hình sau
G
A /B
X
0
1
1
0
0
1Y
2Y
3Y
4Y
0
1A
1B
0
2A
2B
0
3A
3B
0
4A
4B
1Y
2Y
3Y
4Y
A/B
G
74LS157
3.7.5. Caùc öùng duïng cuûa maïch choïn keânh
Caùc boä choïn keânh coù nhieàu öùng duïng khaùc nhau trong caùc heä thoáng soá.
Caùc öùng duïng bao goàm: choïn data, hoïat ñoäng tuaàn töï, chuyeån ñoåi song song sang
noái tieáp, taïo daïng soùng, taïo caùc haøm logic... phaàn naøy seõ ñeà caäp ñeán moät soá öùng
duïng, moät soá coøn laïi seõ ñöôïc xeùt ñeán ôû caùc chöông sau
Mạch tạo hàm logic
Ví dụï. Thöïc hieän baûng söï thaät sau söû duïng multiplexer
C
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
A
0
1
0
1
0
1
0
1
Z
0
1
1
0
0
0
0
1
Các biến
ngõ vào
G C B A D7D6D5D4D3D2D1D0
74LS151
Y=Z
Z=A.B.C+ABC+ABC
Z=A.B.C+ABC+ABC
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
HI
Trang 63
https://fb.com/tailieudientucntt
W
Bài Giảng Kỹ Thuật Số
Chương 3
Mux coù theå ñöôïc duøng ñeå thöïc hieän caùc haøm logic tröïc tieáp töø baûng söï thaät maø
khoâng caàn ñôn giaûn hoaù haøm logic. Khi söû duïng Mux vaøo muïc ñích naøy, caùc ngoõ
select ñöôïc söû duïng nhö caùc bieán logic vaø moãi ngoõ vaøo data ñöôïc noái vôùi möùc 1 hay
0 sao cho thoûa maõn baûng söï thaät.
Định hướng data
MUX coù theå ñònh höôùng data töø nhieàu nguoàn data thaønh 1 nguoàn ñích.
Ví dụ, söû duïng 74LS157 ñeå choïn vaø hieån thò noäi dung cuûa hai boä ñeám BCD.
Counter 1
BCD
counter
Counter 2
Clock 1
BCD
counter
Clock 2
BCD
counter
BCD
counter
select
display
G A/B 4B
2B 4A 2A
3B 1B 3A 1A
G A/B 4B
2B 4A 2A
3B 1B 3A 1A
74LS157
4Y 3Y 2Y 1Y
4Y 3Y 2Y 1Y
74LS157
74LS47
D
C
G F
B
A
LT RBI RB0
E D C B A
D
C
G F
B
A
LT RBI RB0
74LS47
E D C B A
Moãi boä ñeám bao goàm 2 soá ñeám BCD. Khi select=1, ngoõ ra cuûa boä ñeám 1 seõ hieån thò
leân LED 7 ñoaïn, khi select=0, ngoõ ra cuûa boä ñeám 2 seõ hieån thò leân LED 7 ñoaïn.
Baèng caùch naøy, noäi dung cuûa caùc boä ñeám seõ ñöôïc hieån thò thoâng qua ngoõ select.
Maïch ñònh höôùng naøy thöôøng ñöôïc öùng duïng trong caùc ñoàng hoà ñieän töû soá, ôû ñoù coù
caùc boä ñeám vaø caùc thanh ghi nhö giaây, phuùt, giôø, thaùng, vaø baùo thöùc, v.v… Moät maïch
MUX nhö treân seõ cho pheùp caùc data khaùc nhau ñöôïc hieån thò leân treân maøn hình coù
soá LED hieån thò laø giôùi haïn
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 64
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
Muïc ñích cuûa kyõ thuaät Multiplex laø ñeà chia seû thôøi gian hieån thò giöõa hai hay nhieàu
boä ñeám, vaø ñieàu quan troïng hôn nöõa laø tieát kieäm ñöôïc naêng löôïng, bôûi vì moät löôïng
lôùn caùc boä giaûi maõ vaø LED hieån thò seõ tieâu toán moät doøng lôùn
Tuy nhieân kyõ thuaät naøy cuõng coù nhöôïc ñieåm laø noäi dung cuûa caùc boä ñeám chæ hieån thò
1 laàn taïi moät thôøi ñieåm, tuy nhieân trong nhieàu öùng duïng, ñieàu naøy coù theå boû qua
Mạch chuyển đổi song song sang nối tiếp (parallel to serial converter)
Nhieàu heä thoáng soá xöû lyù caùc data nhò phaân ôû daïng song song (xöû lyù caùc bit ñoàng
thôøi) vì toác ñoä xöû lyù nhanh hôn. Khi data ñöôïc truyeàn treân moät khaûng caùch xa, giaûi
phaùp truyeàn song song seõ caàn ñeán moät löôïng daây noái lôùn. Vì lyù do naøy, caùc data nhò
phaân hoaëc caùc thoâng tin ôû daïng song song ñöôïc chuyeån thaønh daïng noái tieáp tröôùc
khi ñöôïc truyeàn treân moät khoaûng caùch xa. Moät phöông phaùp ñeå bieán ñoåi song song
sang noái tieáp laø söû duïng boä Multiplexer nhö sau:
Mạch
đếm
3 bit
X0
X1
X2
X3
X4
X5
X6
X7
D0
D1
D2
D3
D4
D5
D6
D7
W
Y
Z
A
B
C
G
74LS151
Moät boä ñeám 3 bit ñöôïc söû duïng ñeå cung caáp caùc bit maõ choïn CBA töø 000 ñeán 111,
baèng caùch naøy ngoõ ra cuûa Mux seõ choïn töøng keânh Xi theo moãi xung clock, ví duï,
xung clock ñaàu tieân CBA = 000 ngoõ ra seõ laø X0, xung clock thöù hai CBA = 001 ngoõ
ra seõ laø X1, cöù nhö theá ngoõ ra Z seõ laø caùc ngoõ vaøo nhö ôû daïng noái tieáp
X7X6X5X4X3X2X1X0 vôi X0 laø LSB ñöôïc truyeàn tröôùc vaø X7 laø MSB ñöôïc truyeàn
cuoái cuøng
3.8. MAÏCH PHAÂN KEÂNH (DEMULTIPLEXERS)
DeMux
Enable
Select
s
EN
s
SEL
O0
Data
Intput
s
O1
On-1
s
s
s
s
CuuDuongThanCong.com
O1
s
Data
intput
`On-1
s
Selector
GV: Nguyễn Trọng Hải
O0
Trang 65
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
Maïch phaân keânh ngöôïc laïi vôùi maïch choïn keânh. DeMUX coù moät ngoõ vaøo vaø nhieàu
ngoõ ra. Ngoõ vaøo ñieàu khieån choïn (select) seõ xaùc ñònh ngoõ ra maø ngoõ vaøo seõ ñöôïc
truyeàn ñeán
3.8.1. Maïch phaân keânh 1 sang 8
S2
0
0
0
0
1
1
1
1
Select
S1
0
0
1
1
0
0
1
1
S0
0
1
0
1
0
1
0
1
Y7
0
0
0
0
0
0
0
In
Y6
0
0
0
0
0
0
In
0
Y5
0
0
0
0
0
In
0
0
Output
Y4 Y3
0
0
0
0
0
0
0
In
In
0
0
0
0
0
0
0
Y2
0
0
In
0
0
0
0
0
Y1
0
In
0
0
0
0
0
0
Y0
In
0
0
0
0
0
0
0
Töø baûng söï thaät vieát ñöôïc caùc bieåu thöùc ngoõ ra nhö sau
Y7 = In.(S 2 S1S 0 ) , Y6 = In.(S 2 S1 S 0 ) , Y5 = In.(S 2 S1S 0 ) , …
Y0
S2
Y1
S1
S0
Y7
In
3.8.2. Maïch phaân keânh 1 sang 8 vaø maïch choïn xung clock duøng 74LS138
Phaàn tröôùc ñaõ khaûo saùt 74LS138 laøm nhieäm vuï giaûi maõ, ñeán ñaây seõ tieáp tuïc öùng
duïng 74LS138 laøm boä phaân keânh data vaø maïch choïn xung clock
S0
S1
S2
DATA
HI
A
B
C
G1
G2A
G2B
S0
S1
S2
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
HI
74LS138
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
A
B
C
G1
G2A
G2B
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
74LS138
Trang 66
https://fb.com/tailieudientucntt
Shift Register
Counter
Bài Giảng Kỹ Thuật Số
Chương 3
3.8.3. Maïch choïn xung clock
Coù raát nhieàu öùng duïng döïa vaøo nguyeân lyù DeMUX. Sau ñaây söû duïng 74LS138 laøm
boä choïn clock
3.9. MAÏCH SOÁ HOÏC
3.10.1.
Maïch coäng baùn phaàn
A
0
0
1
1
B
0
1
0
1
S
0
1
1
0
COUT
0
0
0
1
A
S
A
B
B COUT
S
Cout
S=AB+AB
COUT = AB
3.10.2.
CIN
0
0
0
0
1
1
1
1
Maïch coäng toaøn phaàn
A
0
0
1
1
0
0
1
1
B
0
1
0
1
0
1
0
1
S
0
1
1
0
1
0
0
1
COUT
0
0
0
1
0
1
1
1
A
B
Cin
A
B
S
S
Cout
CIN COUT
Ví dụ, Thieát keá maïch coäng toaøn phaàn töø maïch coäng baùn phaàn
Ví dụ, Thieát keá maïch coäng hai soá nhò phaân 4 bit (a3a2a1a0 + b3b2b1b0 =S4S3S2S1S0 )
töø maïch coäng baùn phaàn vaø toaøn phaàn
IC cộng toàn phần
Cin Cout
B
S
A
74LS183
Cộng toàn phần 1 bit
A4 Cout
A3
S4
A2
A1
S3
B4
B3
S2
B2
B1
Cin S1
74LS83
Cộng toàn phần 4 bit
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 67
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
3.10.3.
Chương 3
Maïch coäng nhìn tröôùc soá nhôù
ÔÛ maïch coäng nhieàu bit, pheùp coäng haøng cao hôn caàn soá nhôù laàn coäng haøng keá tröôùc.
Thôøi gian trì hoaõn naøy laø lôùn ñoái vôùi caùc pheùp tính nhanh. Ñeå khaéc phuïc phaûi theâm
maïch logic ñeå taïo tröïc tieáp soá nhôù goïi laø maïch coäng nhìn tröôùc soá nhôù (toác ñoä coäng
ñoäc laäp vôùi soá bit)
Goïi
Pi =A i ⊕ Bi
Pi
A
B
Gi =A iBi
S
⇒ phöông trình coäng toaøn phaàn
Ci
Si =Pi ⊕ Ci-1
Gi
Ci-1
Ci =Gi +PC
i i-1
Ñeå hieåu roõ yù nghóa cuûa coäng nhìn tröôùc soá nhôù, vieát phöông trình C0, C1, C2, C3 vaø
nhaän xeùt caùc bieán logic chöùa trong caùc phöông trình ñoù (xem nhö moät baøi taäp)
3.10.4.
Maïch coäng BCD
Ñoái vôùi maïch coäng BCD, neáu ñaàu ra toång khoâng phaûi laø soá BCD thì keát quaû phaûi
ñöôïc coäng theâm 6
BCD BCD
A
B
A3 A2A1A0 B3 B2B1B0
Cin
C4
S3 S2S1S0
A3 A2A1A0 B3 B2B1B0
Cin
C4
S3 S2S1S0
BCD
thứ hai
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
BCD
thứ nhất
Trang 68
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
3.10. MAÏCH CHUYEÅN MAÕ
Maïch chuyeån ñoåi maõ thay ñoåi döõ lieäu nhò phaân töø daïng naøy sang daïng khaùc
Ví dụ,
•
BCD - LED 7 ñoaïn
•
BCD – nhò phaân
•
Nhò phaân – BCD
•
Nhò phaân – Gray
•
Gray – nhò phaân
3.10.5.
Maïch chuyeån ñoåi BCD sang nhò phaân
Bước 1. Xaùc ñònh soá bit nhò phaân cho maïch chuyeån ñoåi.
Ví dụ, ñeå chuyeån ñoåi 2 chöõ soá BCD caàn 7bit nhò phaân, vì giaù trò lôùn nhaát 99 cuûa
BCD ñoåi sang nhò phaân laø 1100011
Bước 2. Tính toång cuûa caùc soá nhò phaân töông ñöông vôùi bit 1 (theo troïng soá cuûa maõ
BCD)
Ví dụ, (52)10 coù maõ BCD laø 01010010, toång nhò phaân laø
80
0
40
1
20
0
10
1
8
0
4
0
2
1
1
0
Troïng soá BCD
BCD
0000010
0001010
0101000
0110100
(maõ nhò phaân cho 2)
(maõ nhò phaân cho 10)
(maõ nhò phaân cho 40)
(maõ nhò phaân cho 52)
Bước 3. Xaây döïng maïch söû duïng maïch coäng nhò phaân
Ví dụ, Baûng coäng cho soá BCD coù 2 chöõ soá
Maõ nhò phaân töông ñöông
Bit BCD
Troïng soá
b6
b5
b4
b3
b2
b1
A0
1
0
0
0
0
0
0
B0
2
0
0
0
0
0
1
4
0
0
0
0
1
0
C0
D0
8
0
0
0
1
0
0
A1
10
0
0
0
1
0
1
B1
20
0
0
1
0
1
0
40
0
1
0
1
0
0
C1
D1
80
1
0
1
0
0
0
Vaäy
b0 = A0; b1 = B0 + A1; b2 = C0 + B1; b3 = D0 + A1 + C1;
b4 = B1 + D1; b5 = C1; b6 = D1;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 69
https://fb.com/tailieudientucntt
b0
1
0
0
0
0
0
0
0
Bài Giảng Kỹ Thuật Số
Chương 3
D1 C1 B1 A1 D0 C0 B0 A0
A3 A2A1A0 B3 B2B1B0
Cin
C4
B3 B2B1B0
S3 S2S1S0
A3 A2 A1A0 B3 B2B1B0
Cin
C4
B3 B2 B1B0
S3 S2S1S0
b6
b5
b4
b3
b2
b1
b0
IC 74184. Chuyeån maõ BCD sang nhò phaân
Các
đầu
vào
BCD
từ
00
đến
39
A0
B0
C0
D0
A1
B1
b0
A
B
C
D
E
G
Y1
Y2
Y3
Y4
Y5
Y6
Y7
Y8
b1
b2
b3
b4
b5
Các
đầu
ra nhị
phân
A
B
C
D
1
Các
đầu
vào
BCD
Y1
Y2
Y3
Y4
Y5
Y6
Y7
Y8
A
B
C
D
E
G
TA
TB
TC
TD
Các
đầu
bù 10
của
BCD
74184
74184
Ví dụ, Tra baûng hoïat ñoäng cuûa 74184, ñöa ra sô ñoà noái daây chuyeån maõ BCD sang
maõ buø 9 cuûa noù
Ví dụ, Töø 2 IC 74184, thieát keá maïch ñoåi moät soá BCD 2 chöõ boá sang 7bit nhò phaân
3.10.6.
Maïch chuyeån ñoåi nhò phaân sang BCD
Các
đầu
vào
nhị
phân
6 bit
b0
b1
b2
b3
b4
b5
A0
A
B
C
D
E
G
Y1
Y2
Y3
Y4
Y5
Y6
B0
C0
D0
A1
B1
C1
Các
đầu
ra
BCD
74185
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 70
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
Bài tập chương 3
3.1. Đơn giản mạch sau dùng đại số Boolean
M
N
O
X
3.2. Thiết kế mạch điện logic tương ứng với bảng sự thật sau
A
B
C
Y
0
0
0
1
0
0
1
0
0
1
0
1
0
1
1
1
1
0
0
1
1
0
1
0
1
1
0
0
1
1
1
1
3.3. Thiết kế mạch điện logic có 3 ngõ vào A, B và C.Ngõ ra ở mức HIGH chỉ khi
có 2 ngõ vào là mức LOW.
3.4. Một số nhị phân 4 bit được ký hiệu là A3A2A1A0, với A0 là bit LSB, thiết kế
mạch logic mà ngõ ra ở mức HIGH khi các số nhị phân lớn hơn 0010 và nhỏ
hơn 1000.
3.5. Thực thi mạch điện ở bài 3.3 dùng tất cả là cổng NAND
3.6. Thực thi mạch điện ở bài 3.4 dùng tất cả là cổng NAND
3.7. Một bộ đếm BCD với ngõ ra 4 bit mã BCD hiển thị số xung được đưa vào bộ
đếm. Thí dụ, sau 4 xung, ngõ ra của bộ đếm là DCBA = 01002 = 410. Bộ đếm
Reset về 0000 tại xung thứ 10 và bắt đầu đếm trở lại. Nói cách khác, ngõ ra
DCBA không bao giờ biểu diễn giá trị lớn hơn 10012 = 910. Hãy thiết kế mạch
logic với ngõ ra ở mức HIGH khi đếm số 2, 3, 9.
D
BCD
Counter
C
B
A
Logic
circuit
X
3.8. Hình sau biểu diễn 4 công tắc trong mạch điều khiển máy copy. Thông
thường các công tắc này mở (open). Khi có giấy đi qua công tắc thì đóng
(close). Công tắc 1 và 4 không thể đóng (close) tại cùng 1 thời điểm. Hãy thiết
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 71
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
kế 1 mạch logic với ngõ ra mức HIGH khi 2 công tắc hay nhiều hơn cùng
đóng.
+5V
SW1
SW2
SW3
SW4
+5V
+5V
+5V
Logic
circuit
X
3.9. Hình sau thể hiện mạch nhân hai số nhị phân 2 bit x1x0 và y1y0, ngõ ra là số
nhị phân z3z2z1z0 tương đương với tích đại số của 2 số ngõ vào. Hãy thiết kế
mạch logic cho mạch nhân.
X1
Z3 MSB
X0
Z2
Multiplier
circuit
Y1
Z1
Z0 LSB
Y0
3.10. Một mã BCD được truyền tới thiết bị nhận ở xa, các bit là A3A2A1A0, với A3
là bit MSB. Mạch nhận gồm 1 mạch phát hiện lỗi BCD để kiểm tra mã nhận.
Thiết kế mạch kiểm tra tạo mức HIGH nếu có bất kỳ điều kiện lỗi nào xảy ra.
3.11. Thiết kế mạch logic với điều kiện: tín hiệu ngõ vào A đến ngõ ra Y chỉ khi
ngõ vào điều khiển B ở mức LOW và ngõ vào điều khiển C ở mức HIGH, các
trường hợp còn lại ngõ ra ở mức LOW.
3.12. Thiết kế mạch logic điều khiển sự đi qua của 1 tín hiệu A theo các yêu cầu
sau:
1. Ngõ ra X = A khi ngõ vào điều khiển B và C giống nhau.
2. X duy trì mức HIGH khi B và C khác nhau.
3.13. Thiết kế mạch logic có yêu cầu cho ở hình sau.
A1
Multiplexer
A0
Z
S
0
1
Z
A0
A1
S
3.14. Trong máy tính, bộ vi xử lý (microprocessor unit = MPU) luôn được kết nối
với 1 trong các phần sau: (1) bộ nhớ truy cập ngẫu nhiên (RAM = randomaccess memory), lưu trữ các chương trình và dữ liệu mà nó có thể được thay
đổi 1 cách nhanh chóng; (2) bộ nhớ chỉ đọc (read-only memory), lưu trữ các
chương trình và dữ liệu mà không khi nào thay đổi; (3) thiết bị vào ra bên
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 72
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 3
ngoài (I/O) chẳng hạn như keyboard, máy in. Khi thực thi 1 chương trình,
MPU sẽ tạo ra một mã địa chỉ mà nó chọn loại thiết bị (RAM,ROM or I/O)
muốn thực thi. Hình sau chỉ ra 1 cách kết nối tiêu biểu ở đó MPU xuất ra 1 mã
địa chỉ 8 bit A15-A8. Thực ra MPU xuất ra 1 mã địa chỉ 16 bit, nhưng các bit
thấp A7-A0 không dùng cho quá trình chọn thiết bị. Mã địa chỉ được cấp tới 1
mạch logic để tạo ra các tín hiệu chọn thiết bị RAM, ROM, và I/O.
A15
A14
A13
A12
A11
A10
RAM
A9
A8
I/O
ROM
MPU
Phân tích mạch và xác định những điều sau:
(a) Khoảng địa chỉ A15-A8 mà nó tích cực RAM
(b) Khoảng địa chỉ A15-A8 mà nó tích cực I/O
(c) Khoảng địa chỉ A15-A8 mà nó tích cực ROM
Hãy biểu diễn các địa chỉ ở nhị phân và hex.
3.15. Cho haøm Boolean sau: Y =
∏
DCBA
(3,5,6,11,12,13,14,15) + d (4,7,8,9)
a). Ruùt goïn haøm Y, bieåu dieãn haøm Y duøng coång logic
b). Töø haøm Y ruùt goïn, bieán ñoåi laïi maïch logic duøng toaøn coång NOR
c). Thöïc hieän haøm Y duøng MUX 8 sang 1 (74LS151)
3.16. Cho haøm Boolean sau: Y =
∑
ABC
(0,1,4) + d (3,6)
a). Ruùt goïn haøm Y, bieåu dieãn haøm Y duøng coång logic
b). Töø haøm Y ruùt goïn, bieán ñoåi laïi maïch logic duøng toaøn coång NAND
c). Thöïc hieän haøm Y duøng giaûi maõ 3 sang 8 (74LS138)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 73
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
CHÖÔNG 4. HEÄ TUAÀN TÖÏ
4.1.
TOÅNG QUAN
Maïch logic tuaàn töï laø maïch coù caùc ngoõ ra tuøy thuoäc khoâng chæ vaøo traïng thaùi
hieän taïi cuûa caùc ngoõ vaøo maø coøn tuøy thuoäc vaøo moät chuoãi caùc ngoõ vaøo tröôùc ñoù.
Vieäc moâ taû moät maïch tuaàn töï baèng caùch laäp baûng quan heä ngoõ ra laø moät haøm
cuûa chuoãi caùc ngoõ vaøo töø caùc traïng thaùi tröôùc ñoù ñeán traïng thaùi hieän taïi thöôøng
thì khoâng thuaän tieän hay khoâng theå thöïc hieän ñöôïc.
Traïng thaùi cuûa moät maïch tuaàn töï laø moät söï taäp hôïp caùc bieán traïng thaùi maø giaù trò
cuûa noù taïi baát cöù moät thôøi ñieåm naøo ñeàu chöùa ñöïng taát caû caùc thoâng tin veà caùc
traïng thaùi tröôùc ñoù ñeå giaûi thích caùc taùc ñoäng sau ñoù cuûa maïch
Caùc bieán traïng thaùi khoâng caàn phaûi coù yù nghóa vaät lyù tröïc tieáp, vaø thöôøng coù
nhieàu caùch choïn chuùng ñeå moâ taû moät maïch tuaàn töï ñaõ cho.
Trong caùc maïch logic soá, caùc bieán traïng thaùi coù giaù trò nhò phaân töông öùng vôùi
tín hieäu logic naøo ñoù trong maïch. Moät maïch vôùi n bieán traïng thaùi nhò phaân seõ coù
2n traïng thaùi xaûy ra, vaø 2n luoân laø giaù trò giôùi haïn, vì vaäy maïch tuaàn töï cuõng
thöôøng goïi laø maùy traïng thaùi giôùi haïn (finite-state machines)
Thôøi ñieåm ñeå caùc traïng thaùi cuûa haàu heát caùc maïch tuaàn töï thay ñoåi ñöôïc quyeát
ñònh bôûi xung clock. Hình sau minh hoïa caùc sô ñoà thôøi gian vaø caùc thuaät ngöõ cho
caùc xung clock thoâng duïng. Theo quy öôùc, moät xung clock tích cöïc möùc cao neáu
caùc thay ñoåi traïng thaùi trong maïch xuaát hieän taïi caïnh leân cuûa xung clock hay taïi
möùc cao cuûa xung clock, vaø tích cöïc möùc thaáp cho tröôøng hôïp coøn laïi. Chu kyø
boån phaän laø phaàn traêm thôøi gian xung clock tích cöïc treân moät chu kyø. Thoâng
thöôøng trong moät heä thoáng soá ngöôøi ta söû duïng dao ñoäng thaïnh anh ñeå taïo caùc
xung clock. Taàn soá xung clock khoaûng 32768 khz (cho ñoàng hoà) ñeán 400 Mhz
(cho supercomputer). Caùc heä thoáng thoâng thöôøng söû duïng caùc phaàn töû CMOS vaø
TTL coù taàn soá xung clock vaøo khaûng töø 1 ñeán 25Mhz.
CLK
CLK
tH
tL
tH
tL
Tper
Tper
Chu kyø boån phaän=tH/Tper
Chu kyø boån phaän=tL/Tper
Hai loaïi maïch tuaàn töï thöôøng aùp duïng chính trong caùc thieát keá thöïc teá:
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 74
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Maïch tuaàn töï coù hoài tieáp: söû duïng caùc coång thoâng thöôøng vaø caùc voøng hoài tieáp
ñeå taïo khaû naêng nhôù trong maïch logic, baèng caùch ñoù taïo ra caùc khoái maïch tuaàn
töï nhö flip-flop vaø maïch choát ñeå thieát keá caùc maïch ôû möùc cao hôn
Maùy traïng thaùi vôùi xung clock ñöôïc ñoàng boä: söû duïng caùc phaàn töû nhôù, ñaëc bieät
laø D flipflop, ñeå taïo ra nhöõng maïch maø ngoõ ra seõ thay ñoåi ñoàng thôøi vôùi xung
Clock
Caùc daïng maïch tuaàn töï khaùc nhö daïng ña xung, ña phase thöôøng öùng duïng trong
caùc heä thoáng coù tính naêng cao vaø VLSI
4.2.
CAÙC PHAÀN TÖÛ HAI TRAÏNG THAÙI BEÀN
4.2.1. Maïch Ñaûo
Moät transistor coù theå laøm chöùc naêng maïch ñaûo nhö sô ñoà hình sau
+12V
4K
2.2K
2.2K
-12V
Khi VI ôû möùc ñieän aùp cao thì BJT chaïy baõo hoøa vaø doøng IC qua RC taïo suït aùp
neân V0 ≈ 0.2V (VCESAT) öùng vôùi möùc ñieän aùp thaáp
Khi VI ôû möùc ñieän aùp thaáp thì BJT phaân cöïc ngöôïc ôû ngoõ vaøo neân ngöng daãn,
doøng IC =0 neân khoâng giaûm aùp qua RC neân V0 ≈ VCC öùng vôùi möùc ñieän aùp cao
4.2.2. Maïch Hai Traïng Thaùi Beàn
Moät maïch tuaàn töï ñôn giaûn nhaát bao goàm hai coång ñaûo vôùi voøng hoài tieáp. Noù
khoâng coù ngoõ vaøo vaø coù 2 ngoõ ra nhö sau:
Vcc
Vin1
Vout1
Q
Vcc
Rc2
Rc1
R2
R1
Rb1
Vin2
Vout2
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Q
-VBB
Trang 75
https://fb.com/tailieudientucntt
Rb2
-VBB
Bài Giảng Kỹ Thuật Số
Chương 4
Maïch ñöôïc veõ laïi nhö sau
RC1
+VCC
R2
R1
T1
RC2
T2
RB2
RB1
-VBB
Giaû thieát coù maïch ñoái xöùng (T1 vaø T2 cuøng teân, caùc ñieän trô phaân cöïc cho 2
transistor cuøng trò soá) nhöng do 2 transistor khoâng theå caân baèng moät caùch tuyeät
ñoái neân seõ coù moät transistor chaïy maïnh hôn vaø moät transistor chaïy yeáu hôn
Giaû thieát T1 chaïy maïnh hôn T2 neân IC1 lôùn hôn neân VRC1 lôùn laøm ñieän aùp VC1
giaûm. VC1 qua ñieän trôû R2 phaân cöïc cho T2 giaûm laøm T2 chaïy caøng yeáu hôn laøm
IC2 nhoû hôn daãn ñeán VC2 taêng, ñieän aùp VC2 taêng qua R1 laøm taêng phaân cöïc cho
T1 daãn ñeán T1 chaïy maïnh hôn nöõa, cuoái cuøng T1 seõ tieán ñeán traïng thaùi baõo hoøa,
T2 tieán ñeán traïng thaùi ngöng daãn. Neáu khoâng coù moät taùc ñoäng naøo khaùc thì
maïch ñieän seõ ôû maõi traïng thaùi naøy. Ñaây laø moät traïng thaùi cuûa maïch Flip Flop
Ngöôïc laïi, neáu giaû thieát T2 chaïy maïnh hôn T1 lyù luaän töông töï cuoái cuøng T2 seõ
tieán ñeán traïng thaùi baõo hoøa, T1 tieán ñeán traïng thaùi ngöng daãn. Neáu khoâng coù
moät taùc ñoäng naøo khaùc thì maïch ñieän seõ ôû maõi traïng thaùi naøy. Ñaây laø traïng thaùi
thöù hai cuûa maïch Flip Flop
Maïch FF seõ ôû moät trong hai traïng thaùi treân neân ñöôïc goïi laø maïch löôõng oån
4.3.
FLIPFLOP
Phaàn töû nhôù quan troïng nhaát laø FlipFlop, noù ñöôïc taïo töø caùc coång Logic. Caùc
coång logic thì töï noù khoâng coù tính naêng nhôù, nhöng ta coù theå keát noái chuùng vôùi
nhau ñeå taïo neân khaû naêng nhôù
Sô ñoà khoái cho moät FF nhö sau:
Q
Các
ngõ
vào
Ngõ ra nhớ
FlipFlop
Q
Ngõ ra đảo
Thaáy raèng FF coù 2 ngoõ ra vaø 1 hay nhieàu ngoõ vaøo. Caùc ngoõ vaøo thöôøng ñöôïc söû
duïng ñeå chuyeån ñoåi giöõa caùc khaû naêng ngoõ ra, ta seõ thaáy raèng khi moät ngoõ vaøo
nhaän xung laøm thay ñoåi traïng thaùi ngoõ ra vaø traïng thaùi ngoõ ra naøy seõ vaãn giöõ
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 76
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
nguyeân khoâng thay ñoåi khi ngoõ vaøo naøy khoâng coøn xung nöõa, vì vaäy ta goïi FF coù
ñaëc tính nhôù
FlipFlop coøn coù caùc teân goïi khaùc laø choát (latch) vaø maïch hai traïng thaùi beàn
(bistable multivibrator)
4.3.1. RS-FF duøng Coång NOR
RESET
Q
Q
S
FF
R
Q
SET
Q
Baûng söï thaät
SET
RESET
Output
0
0
Khoâng thay ñoåi
1
0
Q=1
0
1
Q=0
1
1
Khoâng söû duïng
Khi SET = RESET= 0. Ñaây laø traïng thaùi nhôù vaø khoâng laøm thay ñoåi caùc traïng
thaùi ngoõ ra. Vì ñaây laø maïch hai traïng thaùi beàn neân seõ coù hai tröông hôïp ban ñaàu
xaûy ra, tröông hôïp Q =0, Q =1 vaø tröôøng hôïp Q =1, Q =0.
Tröôøng hôïp Q=0, Q =1
Q=0 daãn ñeán ngoõ ra coång NOR1 =1, Q =1 naøy ñöa veà ngoõ vaøo coång NOR2, ngoõ
ra coång NOR2=0, nhö vaäy maïch vaãn giöõ nguyeân traïng thaùi Q=0, Q =1
Tröôøng hôïp Q=1, Q =0
Q=1 daãn ñeán ngoõ ra coång NOR1 =0, Q =0 naøy ñöa veà ngoõ vaøo coång NOR2, ngoõ
ra coång NOR2=1, nhö vaäy maïch vaãn giöõ nguyeân traïng thaùi Q=1, Q =0
Nhö vaäy vôùi hai tröôøng hôïp, ngoõ ra seõ phuï thuoäc vaøo traïng thaùi tröôùc cuûa maïch
khi SET = RESET =0
¾ Thieát laäp caùc thay ñoåi cho FF
•
RESET
Q
Khi SET = 1, RESET = 0.
Ngoõ ra Q luoân = 0, Q luoân baèng 1 vaø
vaãn giöõ nguyeân traïng thaùi Q=1 khi
SET ñöôïc ñaët trôû laïi 0 (LATCH)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Q
SET
Trang 77
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
•
Khi SET = 0, RESET = 1. Ngoõ ra Q luoân = 0 vaø vaãn giöõ nguyeân traïng thaùi
Q=0 khi CLEAR ñöôïc ñaët trôû laïi 0 (LATCH)
•
Khi SET = CLEAR = 1: ñieàu kieän naøy laøm cho ngoõ ra Q = Q = 0, roõ raøng
ñaây laø ñieàu kieän khoâng mong muoán hôn nöõa neáu caùc ngoõ vaøo trôû laïi möùc 0
ñoàng thôøi, keát quaû ngoõ ra seõ khoâng theå ñoaùn ñöôùc ñöôïc. Traïng thaùi naøy
khoâng ñöôïc duøng vaø goïi laø traïng thaùi caám.
IC 4044 - 4 NOR RS-FF
S
X
0
0
1
1
R
X
0
1
0
1
E
0
1
1
1
1
Q
HiZ
Khoâng thay ñoåi
0
1
Caám
4.3.2. RS FlipFlop duøng coång NAND
RS – FF duøng coång NAND (töông töï, chæ löu yù söï hoaùn chuyeån ngoõ ra Q vaø Q
vaø caùc ñieàu kieän ngoõ vaøo)
SET
RESET
Output
1
1
Khoâng thay ñoåi
0
1
Q=1
1
0
Q=0
0
0
Caám
Q
Q
RESET
•
SET
Bieán ñoåi caùch bieåu thò khaùc cuûa coång NAND
Ta ñöôïc maïch nhö sau
SET
Q
Q
S
FF
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
R
Q
RESET
Trang 78
https://fb.com/tailieudientucntt
Q
Bài Giảng Kỹ Thuật Số
Chương 4
Ví dụ. Caáp daïng soùng sau vaøo ngoõ SR cuûa maïch choát duøng NAND, veõ daïng
soùng ngoõ ra Q, giaû söû ban ñaàu Q=0
SET
RESET
Q
Vì duï treân chæ ra raèng ngoõ ra maïch choát “nhôù traïng thaùi ngoõ vaøo tích cöïc tröôùc
ñoù” vaø seõ khoâng thay ñoåi traïng thaùi cho ñeán khi ngoõ vaøo coøn laïi tích cöïc. Noù
ñöôïc öùng duïng vaøo caùc coâng taéc choáng doäi (debounce switch).
So saùnh tröôøng hôïp söû duïng coâng taéc bình thöôøng vaø tröôøng hôïp söû duïng coâng
taéc choáng doäi nhö sau
Vcc
R
Vcc
1
S
Q
R
Q
Vout
Vout
0
R
Vcc
IC 74279 4 RS-FF
4.4.
FLIPFLOP DUØNG XUNG CK
Caùc heä thoáng soá coù theå hoaït ñoäng ñoàng boä hay khoâng ñoàng boä.
Moät heä thoáng khoâng ñoàng boä, ngoõ ra cuûa maïch logic coù theå thay ñoåi traïng thaùi
baát cöù luùc naøo khi moät hay nhieàu ngoõ vaøo thay ñoåi
Moät heä thoáng ñoàng boä, söï thay ñoåi ôû ngoõ ra ñöôïc ñoàng thôøi vôùi tín hieäu goïi laø
xung clock
Haàu heát caùc heä thoáng soá ñeàu döïa vaøo nguyeân lyù ñoàng boä vì maïch ñoàng boä deã
thieát keá
Q
input
FF
FF
CK
Q
CK tích cöïc caïnh leân
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Q
input
CK
Q
CK tích cöïc caïnh xuoáng
Trang 79
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
4.4.1. Clock RS – FlipFlop
S
Q
S
0
1
0
1
CLK
R
•
Q
R
0
0
1
1
CK
↑
↑
↑
↑
Q
Q0 (khoâng ñoåi)
1
0
Caám
Sô ñoà beân trong cuûa clock SR- FlipFlop
SET
Q
CK
Phát
hiện
cạnh
1
Q
RESET
Maïch phaùt hieän söôøn xung leân hay xuoáng seõ taïo moät xung heïp ôû ngoõ ra (CK*).
Xung naøy seõ xuaát hieän taïi caïnh leân hay caïnh xuoáng cuûa CK vaø taùc ñoäng môû
coång cho 2 coång NAND, maïch phaùt hieän söôøn xung nhö sau
CK
CK
CK
CK* CK
CK*
CK
CK
CK
CK*
CK
CK*
4.4.2. Caùc bieán theå cuûa RS – FF
Ñeå söû duïng ñöôïc caû toå hôïp R=S=1, thöôøng söû duïng caùc bieán theå cuûa RS-FF. Bao
goàm: R-FF, S-FF, E-FF.
R-FF öùng vôùi toå hôïp caám S=R=1 thì Q=0 vaø Q=1 , sô ñoà cuûa R-FF nhö sau
SET
Q
CK
Phát
hiện
cạnh
1
Q
RESET
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 80
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
S-FF öùng vôùi toå hôïp caám S=R=1 thì Q=1 vaø Q=0 , sô ñoà cuûa S-FF nhö sau
SET
Q
Phát
hiện
cạnh
CK
1
Q
RESET
E-FF öùng vôùi toå hôïp caám S=R=1 thì Q vaø Q giöõ nguyeân traïng thaùi (gioáng toå hôïp
R=S=0), sô ñoà cuûa E-FF nhö sau
SET
Q
Phát
hiện
cạnh
CK
1
Q
RESET
4.4.3. Clock JK – FlipFlop
J
J
0
1
0
1
Q
CK
K
•
Q
K
0
0
1
1
CK
↑
↑
↑
↑
Q
Q0 (khoâng ñoåi)
1
0
Q0
Sô ñoà beân trong cuûa clock JK – FF
J
CK
Q
Phát
hiện
cạnh
Q
K
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 81
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
4.4.4. D FlipFlop
D
D
Q
Q
CK Q
D
0
1
CK
↑
↑
Phát
hiện
cạnh
CK
Q
0
1
1
Q
Ví dụ, taïo D-FF töø RS-FF
4.4.5. Bieán theå cuûa D – FF
Trong thực tế coøn söû duïng moät bieán theå cuûa D-FF laø DV-FF, kyù hieäu vaø baûng söï
thaät nhö sau
D
V
0
0
1
1
Q
CK
V
Q
D
0
1
0
1
CK
↑
↑
↑
↑
Q
Q0 (khoâng ñoåi)
Q0 (khoâng ñoåi)
0
1
Vaäy V gioáng nhö chaân ñieàu khieån: khi V=1, FF hoaït ñoäng gioáng D-FF, khi V=0
FF seõ khoâng ñoåi traïng thaùi
4.4.6. T FlipFlop
T
CK
Khoâng coù CK
↓
↓
Q
CK
Q
T
x
0
1
Q
Q0
Q0
Q0
4.4.7. Caùc ngoõ vaøo khoâng ñoàng boä
Vôùi caùc FF ôû treân, caùc ngoõ vaøo S-R, J-K, D xem nhö caùc ngoõ ñieàu khieån, vaø
ñöôïc goïi laø caùc ngoõ vaøo ñoàng boä (synchronous input) vì taùc ñoäng cuûa chuùng ñoái
vôùi ngoõ ra thì ñoàng boä vôùi CK
Ngoaøi ra haàu heát caùc FF cuõng coù 1 hay nhieàu ngoõ vaøo khoâng ñoàng boä
(asynchronous input) hoaït ñoäng ñoäc laäp vôùi ngoõ vaøo ñoàng boä vaø xung clock. Caùc
ngoõ vaøo khoâng ñoàng boä naøy ñöôïc söû duïng ñeå ñaët ngoõ ra cuûa FF leân 1 (PRESET)
hay xoùa ngoõ ra cuûa FF veà 0 (CLR) baát chaáp caùc ñieàu kieän cuûa ngoõ vaøo
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 82
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
D
PR
Chương 4
PR
J
Q
CK
CK
K
CLR Q
CLR Q
7476
7474
D-FF
4.5.
PR
1
0
1
0
Q
CLR
1
1
0
0
Ngoõ ra
hoaït ñoäng theo CK
Q=1
Q=0
khoâng söû duïng
JK-FF
CAÙC ÖÙNG DUÏNG CUÛA FLIPFLOP
4.5.1. Ñoàng boä hoùa duøng FF
Haàu heát caùc heä thoáng soá ñeàu döïa treân nguyeân lyù ñoàng boä trong hoaït ñoäng cuûa
chuùng (traïng thaùi tín hieäu thay ñoåi ñoàng boä vôùi xung clock). Trong moät soá tröôøng
hôïp seõ coù moät soá tín hieäu khoâng ñöôïc ñoàng boä vôù xung clock, noùi caùch khaùc laø
baát ñoàng boä. Caùc tín hieäu naøy thöôøng xuaát hieän ôû tröôøng hôïp nhaán moät phím taïi
moät thôøi ñieåm ngaãu nhieân so vôùi xung clock, söï ngaãu nhieân naøy coù theå ñöa ñeán
moät keát quaû khoâng mong muoán. Ñeå khaéc phuïc ñieàu naøy ta seõ xeùt ví duï sau:
Ví dụ,
Khóa chống
dội
Clock
A
X
A
X
Clock
Xung khoâng mong muoán
Clock
Khóa chống
dội
D
PR
Q
X
CLK
CLR
Clock
Q
A
Q
X
Xung ñoàng boä
4.5.2. Maïch phaùt hieän moät chuoãi ngoõ vaøo tuaàn töï
Trong moät soá öùng duïng, caàn nhaän bieát chuoãi xung naøo ñeán tröôùc trong hai chuoãi
xung, giaû söõ ngoõ ra seõ ôû möùc cao neáu ngoõ vaøo A ôû möùc cao tröôùc ngoõ vaøo B
A
A
B
B
X
X
A
B
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 83
https://fb.com/tailieudientucntt
X
Q
CLK
K
Ta choïn B laøm xung CK kích caïnh leân cho maïch FF
PR
J
CLR Q
Bài Giảng Kỹ Thuật Số
Chương 4
4.5.3. Thanh ghi dòch
Caùc daïng cuûa thanh ghi dòch goàm
•
Vaøo song song/ ra song song
•
Vaøo noái tieáp/ra noái tieáp
•
Vaøo song song/ra noái tieáp
•
Vaøo noái tieáp/ ra song song
1D
2D
3D
4D
5D
6D
a. Vaøo song song/ ra song song (74174, 74374)
•
MR
CK
D4
PR Q
D
CL
CLK
CL
Q
CL
Q
Q4
Q5
PR Q
D
CLK
CL
Q
PR Q
D
CLK
CLK
•
D0
D1
PR Q
D
74LS174
CLK CLR
74174. Sô ñoà beân trong cuûa 74174 (6bit ghi dòch,
ngoõ vaøo töø D0 ñeán D5 ngoõ ra töø Q0 ñeán Q5)
D5
1Q
2Q
3Q
4Q
5Q
6Q
Q
Q1
Q0
74374. thanh ghi dòch 8 bit vaøo song song/ 8 bit ra song song
D0
D1
D2
D3
D4
D5
D6
D7
Q0
Q1
Q2
Q3
Q4
Q5
Q6
Q7
OC
CLK
OC
CLK
D
Output
0
↑
1
1
0
↑
0
0
0
0
X
QO
1
X
X
HiZ
74LS374
b. Vaøo noái tieáp/ ra noái tieáp
Ñeå caát n döõ lieäu vaøo thanh ghi ta caàn n xung CK, thôøi gian ghi chaäm. Töông töï,
ñeå xuaát döõ lieäu caàn n-1 xung, thôøi gian xuaát chaäm. Lôïi ñieåm: ít sai
Ds
CK
D
PR Q
PR Q
D
CLK
CLK
CL
Q
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
D
PR Q
CLK
CL
Q
D
PR Q
CLK
CL
Q
Trang 84
https://fb.com/tailieudientucntt
CL
Q
Os
Bài Giảng Kỹ Thuật Số
Chương 4
4731. CMOS thanh ghi dòch 256bit (4 boä ghi dòch 64bit noái tieáp)
DS
DS
Q
64bit
DS
Q
64bit
64bit
CP
CP
CP
DS
Q
Q
64bit
CP
c. Vaøo song song/ ra noái tieáp
•
74LS166 laø loaïi IC naïp döõ lieäu vaøo song song (8bit),
xuaát döõ lieäu ra noái tieáp (Döõ lieäu ñöôïc naïp vaøo töø chaân
A,…,H vaø xuaát ra tuaàn töï ôû chaân SER OUT. Ngoaøi ra
74166 coøn coù 1 ngoõ vaøo data noái tieáp SER
74LS166
CLR
SH/LD
INH
CLK
H
G
F
E
D
C
B
A
SER
CKI laø chaân cho pheùp xung CK, CKI=[0]: cho pheùp
xung CK, CKI=[1] : caám xung CK.
SH/LD=[0]: naïp döõ lieäu, SH/LD=[1]: dòch döõ lieäu.
Sau khi dòch 1 bit ra khoûi haøng döõ lieäu (veà höôùng bit
H), bit A seõ troáng vaø bit SR (Serial in) seõ dòch vaøo
thanh choát cuûa bit A.
QH
d. Vaøo noái tieáp / ra song song 74164
74164. thanh ghi dòch 8bit, A vaø B laø ngoõ vaøo data cho D-FF
QA
QB
A
QC
QD
QE
B
QF
CLK QG
QH
CLR
74LS164
A
D
B
PR Q
CLK
CL
Q
Ví dụ. Giaû söû raèng ban ñaàu traïng thaùi thanh ghi 74164 laø 00000000, xaùc ñònh
chuoãi traïng thaùi keá tieáp cuûa maïch sau
CK
1
1
CLK B A
CLR
H GFE D CB A
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
74LS164
Trang 85
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
4.5.4. Öùng duïng Trong microcomputer
D
A15
A14
A13
A12
X3
Q
X2
Q
X1
Q
X0
CLK
D
A11
A10
A9
A8
MPU
Q
CLK
D
CP
CLK
D3
D2
D1
D0
D
CLK
Hình treân laø moät ñôn vò vi xöû lyù (MPU) vôùi caùc ngoõ ra duøng ñeå truyeàn data nhò
phaân ñeán thanh ghi X (4 D-FF). Haàu heát caùc MPU coù ít nhaát 16 ñöôøng ñòa chæ,
nhöng thöôøng seõ khoâng söû duïng heát. ÖÙng duïng MPU ñeå truyeàn soá nhò phaân töø
thanh ghi trong MPU ñeán thanh ghi ngoaøi X. Ñeå thöïc hieän ñieàu naøy, MPU thöïc
hieän caùc böôùc sau:
•
Ñaët soá nhò phaân ra ngoõ ra D3D2D1D0
•
Ñaët maõ ñòa chæ ñuùng töø A15 ñeán A8 ñeå choïn thanh ghi X
•
Khi data vaø ñòa chæ ngoõ ra ñaõ oån ñònh, MPU seõ taïo xung clock caáp cho thanh
ghi X ñeå hoaøn taát quaù trình truyeàn song song töø MPU ñeán thanh ghi X
Caùc FF trong thanh ghi X coù theå söû duïng cho nhieàu nuïc ñích khaùc nhau. Ví duï,
sau khi MPU thöïc hieän caùc pheùp tính vaø hieån thò keát quaû, moãi FF seõ ñöôïc noái
vôùi 1 LED vaø data keát quaû naøy coù theå thaáy ñöôïc. Ví duï khaùc, moãi FF thaønh phaàn
coù theå ñieàu khieån taét/môû caùc thieát bò khaùc nhö motor hay role döïa treân cô sôû maõ
nhò phaân truyeàn töø MPU ra
4.5.5. Boä Chia Taàn Soá
Số MOD: laø soá traïng thaùi ngoõ ra cuûa moät maïch ñeám
Ví dụ: moät maïch ñeám coù chuoãi traïng thaùi ngoõ ra sau laø maïch ñeám MOD 4
000
010
101
111
MOD 4
Ví dụ: xeùt maïch sau
A LSB
1
B
1
C MSB
1
2
1
J
PR Q
1
CLK
1
K
CuuDuongThanCong.com
PR Q
1
CLK
CL
Q
1
1
GV: Nguyễn Trọng Hải
J
K
J
PR Q
CLK
CL
Q
1
K
CL
1
1
Trang 86
https://fb.com/tailieudientucntt
Q
Bài Giảng Kỹ Thuật Số
Chương 4
1
2
3
4
5
6
7
8
9
0
1
2
3
4
5
6
7
0
10
11
1
2
Clock
A
B
C
QA seõ thay ñoåi traïng thaùi baèng Q tröôùc ñoù taïi caïng xuoáng cuûa xung CK
1
=> TQA=2TCK
=> f QA = f CK
2
QB seõ thay ñoåi traïng thaùi baèng Q tröôùc ñoù taïi caïng xuoáng cuûa QA
1
=> TQB=2TQA
=> f QB = f QA
2
QC seõ thay ñoåi traïng thaùi baèng Q tröôùc ñoù taïi caïng xuoáng cuûa QB
1
=> TQC=2TQB
=> f QC = f QB
2
Nhö vaäy moãi FF chia taàn soá ngoõ vaøo CK cuûa noù 2 laàn.
Toång quaùt vôùi n FF thì
1
f Qout = n f CK
2
ÖÙùng duïng boä chia taàn laøm boä ñeám nhò phaân. Döïa vaøo giaûn ñoà xung treân, ñöa ra
ñöôïc baûng söï thaät sau. Giaû söû ban ñaàu CBA =000
C
0
0
0
0
1
1
1
1
0
0
B
0
0
1
1
0
0
1
1
0
0
A
0
1
0
1
0
1
0
1
0
1
CK
Ban ñaàu
Sau xung CK1
Sau xung CK2
Sau xung CK3
Sau xung CK4
Sau xung CK5
Sau xung CK6
Sau xung CK7
Sau xung CK8
Sau xung CK9
000
001
111
010
110
011
101
100
•
Boä ñeám ôû treân coù 23 traïng thaùi khaùc nhau töø 000 ñeán 111, noù ñöôïc goïi laø boä
ñeám MOD 8
•
Vôùi n FF coù 2n traïng thaùi khaùc nhau, soá MOD toái ña laø MOD 2n
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 87
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
4.5.6. MAÏCH ÑEÁM
a. Ñeám khoâng ñoàng boä vôùi MOD 2n
•
Moâ hình ñeám leân
Q0 LSB
Q
Q
CK
Q
CK
CK
Q
Q
Q
Q0 LSB
Q
CK
Q
CK
CK
Q
Q
Q
Moâ hình ñeám xuoáng
Q0 LSB
Qn MSB
Q1
Q
Q
CK
Q
CK
CK
Q
Q
Q
Q0 LSB
Qn MSB
Q1
Q
Q
CK
Q
CK
CK
Q
•
Qn MSB
Q1
Q
•
Qn MSB
Q1
Q
Q
Ñieàu kieän Q+ = Q0
1
J
1
Q
PR
T
CK
1
K
PR
Q
D
CK
CL
Q
CL
Q
CK
CL
Q
PR
Q
Ví dụ, boä ñeám leân nhò phaân 4 bit duøng JK-FF vôùi CK kích caïnh xuoáng nhö sau
A
1
1
J
PR
Q
1
K
CL
Q
1
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
J
PR
Q
1
K
C
1
1
CK
CK
1
B
1
J
PR
Q
1
Q
1
1
K
J
PR
Q
CL
Q
CK
CK
CL
D
1
CL
Q
1
Trang 88
https://fb.com/tailieudientucntt
1
K
1
Bài Giảng Kỹ Thuật Số
Chương 4
•
Xung clock ñöôïc ñöa vaøo ngoõ CK cuûa FF -A, vì vaäy FF-A seõ thay ñoåi traïng
thaùi sau moãi xung clock (löu yù laø taát caû caùc ngoõ vaøo J=K=1)
•
Ngoõ ra cuûa FF-A ñöôïc ñöa vaøo ngoõ vaøo CLK cuûa FF-B, vì vaäy FF-B thay ñoåi
traïng thaùi khi ngoõ ra QA thay ñoåi töø 1 xuoáng 0. Töông töï cho FF-C vaø FF-D
•
Baûng sau moâ taû caùc ngoõ ra cuûa caùc FF sau moãi xung CK, sau xung clock thöù
16 caùc ngoõ ra seõ trôû veà 0000 vaø laëp laïi trang thaùi ban ñaàu
D
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
0
C
0
0
0
0
1
1
1
1
0
0
0
0
1
1
1
1
0
B
0
0
1
1
0
0
1
1
0
0
1
1
0
0
1
1
0
A
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
Xung CK
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 (laëp laïi)
Daïng maïch ñeám maø ngoõ ra FF ñöôïc söû duïng nhö CK cho taàng sau ñöôïc goïi laø
maïch ñeám khoâng ñoàng boä, vì taát caû caùc FF khoâng thay ñoåi traïng thaùi ñoàng boä vôùi
xung clock, chæ coù FF-A thay ñoåi töông öùng vôùi xung clock
CK
QA
QB
QC
QD
0
1
2
3
4
5
6
7
8
9
10
11 12 13
Ví dụ, thiết kế boä ñeám leân nhò phaân 4 bit duøng FF nhö sau
(a)
(b)
D
PR Q
T
CLK
CLK
CL
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
PR Q
CL
Q
Q
Trang 89
https://fb.com/tailieudientucntt
14 15
0
Bài Giảng Kỹ Thuật Số
Chương 4
Ví dụ, thiết kế boä ñeám xuoáng nhò phaân 4 bit duøng FF nhö sau
(a)
(c)
(b)
D
PR Q
T
PR Q
J
CL
K
CLK
CLK
CLK
CL
Q
PR Q
Q
CL
Q
Ví dụ, xaây döïng maïch taïo xung 1Hz töø ñieän löôùi 50Hz nhö sau:
50Hz
50Hz
1Hz
MOD 50
counter
Schmitt
Trigger
Ñieän aùp löôùi ac coù taàn soá 50hz qua boä bieán ñoåi sin sang soùng vuoâng, sau ñoù cho
qua boä chia 50 (MOD 50 counter) ñöôïc xung 1hz
Vaán ñeà ñaët ra laø caàn bao nhieâu FF cho boä chia 50. Vôùi 6 FF ta ñöôïc maïch chia
26=64. Nhö vaäy söû duïng giaûi phaùp ñeám MOD 2n laø khoâng thích hôïp.
b. Ñeám khoâng ñoàng boä vôùi MOD < 2n
Các bước thiết kế
Bước 1. Thöïc hieän choïn daïng maïch
Bước 2. Xaùc ñònh soá FF caàn toái thieåu
Goïi
n laø soá FF caàn
Choïn n sao cho 2n-1 < MOD < 2n
Bước 3. Aùp duïng tính chaát cuûa caùc ngoõ vaøo baát ñoàng boä (Pr, Cl) ñeå xaùc ñònh
traïng thaùi xoùa theo trình töï sau:
Laäp baûng traïng thaùi cho caùc ngoõ ra vaø caùc ngoõ vaøo baát ñoàng boä
Vieát haøm cho caùc ngoõ Pr vaø Cl
Ruùt goïn haøm Pr vaø Cl (duøng bìa K, ñaïi soá Boolean)
Veõ maïch hoaøn chænh
Ví dụ, Thieát keá maïch ñeám leân nhò phaân MOD6 duøng JK-FF nhö sau
J
PR Q
CLK
K
Xaùc ñònh soá FF toái thieåu:
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
CL
Q
22 < 6 < 23 ⇒ soá FF caàn laø 3
Trang 90
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Baûng traïng thaùi ñeám
QC
0
0
0
0
1
1
0
QB
0
0
1
1
0
0
0
QA
0
1
0
1
0
1
0
Cl
1
1
1
1
1
1
0
Pr
1
1
1
1
1
1
1
Cl
QA
0
1
00
1
1
01
1
1
11
0
X
10
1
1
QCQB
Vaäy
Cl = Q B + Q C = Q B Q C , Pr = 1
Daïng maïch ñeám leân MOD 6
A
1
PR
1
J
1
CLK
CL
K
B
1
Q
Q
PR
1
J
1
CLK
CL
K
Q
Q
C
1
1
J
PR
Q
1
CLK
CL
K
Q
Sinh viên vẽ dạng sóng ABC để kiểm chứng
Ví dụ, Thieát keá maïch ñeám xuoáng MOD 12 duøng FF sau
(a)
(c)
(b)
D
PR Q
PR Q
T
J
CLK
CLK
CLK
CL
Q
PR Q
CL
K
Q
CL
Q
c. Treã trong maïch ñeám khoâng ñoàng boä
Maïch ñeám khoâng ñoàng boä laø daïng ñôn giaûn nhaát cuûa caùc boä ñeám nhò phaân vì
caùc thaønh phaàn ñeå taïo ra maïch ñeám laø ít nhaát. Tuy nhieân cuõng coù moät soá vaán ñeà
lieân quan ñeán maïch. FF sau seõ thay ñoåi traïng thaùi öùng vôùi söï thay ñoåi traïng thaùi
ngoõ ra cuûa FF tröôùc. Do moãi FF coù thôøi gian treã truyeàn ñaït (tpd), nghóa laø FF thöù
2 seõ khoâng ñaùp öùng trong khoaûng thôøi gian tpd khi FF ñaàu tieân nhaän ñöôïc xung
clock, töông töï FF thöù 3 seõ khoâng ñaùp öùng trong khoaûng thôøi gian 2tpd khi FF ñaàu
tieân nhaän ñöôïc xung clock, cuoái cuøng FF thöù N seõ khoâng ñaùp öùng trong khoaûng
thôøi gian Ntpd khi FF ñaàu tieân nhaän ñöôïc xung clock
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 91
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
CK
QA
QB
2tpd
tpd
3tpd
QC
Xeùt tröôøng hôïp sau
T
0
1
0
0
1
0
0
1
0
0
0
1
1
1
0
0
0
0
0
0
0
0
0
1
tpd
tpd
tpd
Neáu chu kyø xung clock T= 2tpd. Nhö ñaõ thaáy treân hình veõ, traïng thaùi ñeám seõ töø
000, 001 roài xuoáng 000, 010, 011, 010, 000, 101, …
Thaáy raèng caùc traïng thaùi ñeám khoâng coøn tuaân thuû ñeám leân, vaø khoâng bao giôø coù
traïng thaùi 100
Ñeå khaéc phuïc, chu kyø xung clock phaûi lôùn hôn thôøi gian treã lôùn nhaát cuûa maïch
ñeám nghóa laø
Tclock ≥ Ntpd
hoaëc fmax =
1
(taàn soá cöïc ñaïi cho pheùp)
Ntpd
Vôùi maïch ñeám khoâng ñoàng boä 4 bit
cho thôøi gian treã cuûa JK-FF (tpd = 24ns) => fmax =
1
=10.4Mhz
4.24ns
Khi soá FF taêng thì taàn soá cöïc ñaïi cuûa maïch giaûm xuoáng
d. Caùc vi maïch ñeám khoâng ñoàng boä
•
7493, 74293
74LS93 coù 2 boä ñeám beân trong: moät boä ñeám 2 vôùi ngoõ
vaøo xung CKA, moät boä ñeám 8 vôùi ngoõ vaøo xung CKB
Sinh vieân tra baûng söï thaät cuûa 7493 vaø lieät keâ chuoãi
ñeám khi noái QA veà CKB vaø chuoãi ñeám khi noái QD veà
CKA
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 92
https://fb.com/tailieudientucntt
CKA
QA
CKB
QB
R01
QC
R02
QD
74LS93
Bài Giảng Kỹ Thuật Số
•
Chương 4
74LS90
R91
R92 QA
74LS90 coù 2 boä ñeám beân trong: moät boä ñeám 2 vôùi ngoõ
vaøo CKA, moät boä ñeám 5 vôùi ngoõ vaøo CKB
CKA QB
CKB QC
Sinh vieân tra baûng söï thaät cuûa 7493 vaø lieät keâ chuoãi ñeám
khi noái QA veà CKB vaø chuoãi ñeám khi noái QD veà CKA
•
R01 QD
R02
74LS90
CD4024, CD4040
4024 laø boä ñeám nhò phaân 7bit (MOD128), 4040 laø boä ñeám nhò phaân 12bit
(MOD4096)
e. Ñeám ñoàng boä vaø maïng tuaàn töï
Ñeå khaéc phuï nhöôïc ñieåm thôøi gian treã cuûa xung CK, ôû maïng ñoàng boä, taát caû caùc
FF ñeàu söû duïng chung xung CK. Vì vaäy, caùc ngoõ ra seõ thay ñoåi ñoàng thôøi theo
xung CK
Phương pháp thiết kế
Bước 1, thieát laäp baûng moâ taû moái quan heä giöõa ngoõ ra hieän taïi (Q) vaø ngoõ ra keá
tieáp (Q+)
Bước 2, Thieát laäp caùc traïng thaùi ngoõ vaøo cho FF ñeå thoûa maõn caùc thay ñoåi ngoõ
ra töø baûng treân
Bước 3, Ruùt goïn caùc phöông trình ngoõ vaøo cho FF
Bước 4, Thöïc hieän maïch
ÔÛ böôùc 2, ñeå thieát laäp traïng thaùi ngoõ vaøo theo ngoõ ra, caùc baûng söï thaät tröôùc cuûa
FF phaûi thay ñoåi.
Ví dụ, baûng söï thaät cho SR-FF
S
0
0
0
0
1
1
1
1
R
0
0
1
1
0
0
1
1
Q
0
1
0
1
0
1
0
1
Q+
0
1
0
0
1
1
-
Q
0
0
0
1
1
1
Q+
0
0
1
0
0
1
S
0
0
1
0
0
1
R
0
1
0
1
0
0
Q
0
0
1
1
Q+
0
1
0
1
S
0
1
0
x
Ví dụ, Töông töï, baûng söï thaät cho JK-FF, D-FF, T-FF
Q
0
0
1
1
Q+
0
1
0
1
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
T
0
1
1
0
Q
0
0
1
1
Q+
0
1
0
1
J
0
1
x
x
K
x
x
1
0
Q
0
0
1
1
Trang 93
https://fb.com/tailieudientucntt
Q+
0
1
0
1
D
0
1
0
1
R
x
0
1
0
Bài Giảng Kỹ Thuật Số
Chương 4
Ví dụ, Thieát keá maïch ñeám coù chuoãi ñeám sau duøng T-FF
Bước 1,2,
Ngoõ ra hieän taïi
C
B
A
0
0
0
0
0
1
0
1
0
0
1
1
1
0
0
1
0
1
1
1
0
Ngoõ ra keá tieáp
C+
B+
A+
1
0
0
0
1
1
0
0
0
1
1
1
-
Ngoõ vaøo
TC
TB
1
0
0
0
0
1
0
1
-
000
TA
0
1
1
1
-
011
100
111
010
Bước 3,
TC
TB
C
0
1
00
1
0
01
x
11
10
BA
TA
C
0
1
00
0
1
x
01
x
x
1
0
11
1
1
0
x
10
1
x
0
1
00
0
1
x
01
x
0
1
11
0
x
10
BA
TC = CB+CB
C
BA
TB = CA+CB
TA = C+B
Maïch cuoái cuøng vaø giaûn ñoà traïng thaùi cho maïch nhö sau
C
B
Q
CK
TC
A
CK
TB
CK
Q
Q
CK
TA
CK
C
0
1
1
0
0
0
B
0
0
1
1
1
0
A
0
0
1
0
1
0
Tc
C
B
TB
TA
B C
C B
C B
C A
Maëc duø baûng traïng thaùi cho maïch hình treân khoâng chæ ra heát caùc tröôøng hôïp, caùc
traïng thaùi keá cuûa traïng thaùi 001, 101, 110 cuõng ñöôïc chæ roõ trong quaù trình thieát
keá maïch.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 94
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Ví dụ, neáu caùc FF ñöôïc ñaët giaù trò ban ñaàu C=0, B=0, A=1 vaø coù xung Clock, töû
phöông trình T-FF suy ra TA = TB =1 vaø traïng thaùi seõ chuyeån thaønh 111, vaø khi
nhaän xung ck keá tieáp, maïch seõ hoaït ñoäng nhö boä ñeám ñaõ thieát keá
000
011
100
100
111
010
ÔÛ traïng thaùi ban ñaàu khi caáp nguoàn cho maïch, traïng thaùi ñaàu tieân cuûa FF laø
khoâng ñoaùn ñöôïc. Vì lyù do naøy, taát caû caùc traïng thaùi don’t care trong boä ñeám
phaûi ñöôïc kieåm tra ñeå chaéc chaén raèng noù seõ ñöa ñeán chuoãi ñeám chính neáu
khoâng coù moät taùc ñoäng reset naøo cho maïch
Ví dụ, thieát keá laïi ví duï treân duøng SR-FF
Keát quaû:
RC = A, SC = B
RB = CA , SB = C
RA = A, SA = CA+BA
Ví dụ, thieát keá laïi ví duï treân duøng D-FF
Ñoái vôùi D-FF, Q+ =D, vì vaäy bìa ngoõ vaøo D töông öùng vôùi bìa traïng thaùi keá. Vì
vaäy, bieåu thöùc cho D coù theå ñoïc tröïc tieáp töø bìa Q+.
Keát quaû:
DC = C+ = B
DB = B+ = C+ BA
DA = A+ = CA+BA
Ví dụ, thieát keá laïi ví duï treân duøng JK-FF
Keát quaû:
JC = B , KC = A
JB = C, KB = CA
JA = C+B, KA = 1
•
Phương pháp nhanh để xác định biểu thực ngõ vào cho JK-FF
Q
0
0
1
1
Q+
0
1
0
1
J
0
1
x
x
K
x
x
1
0
Töø ví duï treân thaáy raèng JA vaø KA khoâng chöùa bieán A, töông töï JB vaø KB ñoäc laäp
vôùi B, JC vaø KC ñoäc laäp vôùi C. Toång quaùt, haøm cöïc tieåu cho J vaø K cuûa FF Q
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 95
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
khoâng phuï thuoäc vaøo Q, ñieàu naøy laø bôûi vì Q=1 trong bìa J laø don’t care, vì vaäy
baát cöù 1 ôû phía Q=0 cuûa bìa J coù theå ñöôïc keát hôïp vôùi 1 don’t care laøm trieät tieâu
bieán Q, bìa K thì cuõng töông töï vì taát caû Q=0 trong bìa K ñeàu laø don’t care.
Töø baûng traïng thaùi keá cho JK, khi Q=0 thì J=Q+, vì J ñoäc laäp vôùi Q, neân coù theå
ñoïc J tröïc tieáp töø Q=0 treân bìa Q+, töông töï khi Q=1 thì K =Q+ neân coù theå ñoïc
tröïc tieáp K töø Q=1 treân bìa Q+
Xeùt ví duï treân
C+
B+
C
0
1
00
1
1
01
x
11
10
BA
A+
C
0
1
00
0
1
x
01
x
x
0
0
11
0
1
0
x
10
1
x
JC
Keát quaû:
BA
C
0
1
00
0
1
01
x
x
11
0
0
10
1
x
BA
JB
KB
KC
JC = B , KC = A
JB = C, KB = CA
JA = C+B, KA = 1
Phöông phaùp treân coù 2 thuaän lôïi:
(1) Vieäc taùch thaønh 2 bìa J, K laø khoâng caàn thieát.
(2) Soá bieán trong haøm giaûm ñi 1 do JQ vaø KQ ñoäc laäp vôùi Q).
Ví dụ, thieát keá maïch chuyeån maõ 8-4-2-1 BCD sang maõ quaù 3 duøng JK-FF
Baûng traïng thaùi chuyeån ñoåi cho nhö sau
A
0
0
0
0
0
0
0
0
1
1
BCD 8-4-2-1
B
C
0
0
0
0
0
1
0
1
1
0
1
0
1
1
1
1
0
0
0
0
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
D
0
1
0
1
0
1
0
1
0
1
+
A
0
0
0
0
0
1
1
1
1
1
Quaù 3
B+ C+
0
1
1
0
1
0
1
1
1
1
0
0
0
0
0
1
0
1
1
0
D+
1
0
1
0
1
0
1
0
1
0
Trang 96
https://fb.com/tailieudientucntt
JA
KA
JA
Bài Giảng Kỹ Thuật Số
Keát quaû:
Chương 4
JA = BC+BD
KA=0
JB = C+D
KB=C+D
JC = D
KC= D
JD= 1
KD =1
Ví dụ, Thieát keá maïch ñeám leân/ xuoáng ñoàng boä MOD8 duøng JK-FF
Maïch ñeám leân MOD8
1
Q
1
PR
J
PR
Q
CLK
Q
CL
1
J
Q
PR
K
CL
Q
1
K
1
J
CLK
CLK
Q
CL
1
1
1
1
K
1
74LS76
clock
Maïch ñeám xuoáng MOD8
1
Q
PR
Q
CLK
CL
K
J
Q
PR
Q
CLK
CL
K
1
J
Q
PR
Q
CLK
CL
K
1
1
J
1
1
74LS76
clock
Maïch ñeám leân/xuoáng MOD8
Keát hôïp 2 maïch treân ñeå taïo thaønh maïch ñeám leân/ xuoáng nhö sau:
Count-up
1
1
Q
PR
Q
CLK
CL
K
J
1
1
Q
PR
Q
CLK
CL
K
J
1
Q
PR
Q
CLK
CL
K
1
J
74LS76
Count-down
clock
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 97
https://fb.com/tailieudientucntt
1
1
Bài Giảng Kỹ Thuật Số
Chương 4
Ví dụ, Thieát keá maïch ñeám coù khaû naêng ñaët traïng thaùi (presetable counter)
Nhieàu maïch ñeám ñoàng boä ñöôïc thieát keá coù khaû naêng ñaët traïng thaùi baét ñaàu cho
boä ñeám. Khaû naêng naøy coù theå ñoàng boä hoaëc khoâng ñoàng boä vôùi xung CK.
Minh hoaï maïch ñeám leân 3 bit coù khaû naêng ñaët traïng thaùi khoâng ñoàng boä
P1
P0
P2
Q
PR
J
Q
PR
J
Q
PR
J
1
Q
CLK
CL
K
Q
CLK
CL
K
Q
CLK
CL
K
1
74LS76
clock
LOAD
Nhieàu IC söû duïng ñaët traïng thaùi ñoàng boä vôùi xung clock.
f. Moät soá IC ñeám ñoàng boä thoâng duïng
•
74163, boä ñeám leân 4bit, Pr vaø CLR ñoàng boä, coù khaû naêng ñaët tröôùc traïng thaùi
•
74192, boä ñeám leân/xuoáng ñoàng boä MOD10, Pr vaø CLR baát ñoàng boä
•
74193, boä ñeám leân/xuoáng ñoàng boä 4bit, Pr vaø CLR baát ñoàng boä
74LS163
A
B
C
D
QA
QB
QC
QD
RCO
CLK
ENT
ENP
LOAD
CLR
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
74LS192
74LS193
UP
DOWN QA
CLR QB
LOAD QC
QD
A
BO
B
CO
C
D
A
B
C
D
QA
QB
QC
QD
UP
CO
DN
BO
LOAD
CLR
Trang 98
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
g. Maïch ñeám voøng
Ñöôïc xeùt treân cô sôû cuûa maïch ñeám ñoàng boä, boä ñeám voøng coù caáu truùc cuûa thanh
ghi dòch nhöng coù theâm hoài tieáp. Thoâng thöôøng söû duïng D-FF hay JK-FF
A
B
C
PR Q
D
PR Q
D
CLK
CLK
CL
PR Q
D
CLK
CL
Q
CL
Q
Q
CK
A
PR Q
J
B
PR Q
J
CLK
K
K
Q
PR Q
J
CLK
CL
C
CLK
CL
K
Q
CL
Q
CK
Traïng thaùi ban ñaàu ñaët cho maïch laø A=0, B=0, C=1
CK
A
B
C
Maïch coù chu trình ñeám MOD3 baèng vôùi soá FF coù trong maïch. Caùc traïng thaùi cuûa
FF ñöôïc chuyeån daàn töø C -> A -> B.
•
Boä ñeám voøng Johnson
A
B
1
1
1
PR
D
C
Q
CLK
PR
D
Q
CL
Q
1
CL
Q
1
1
CK
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Q
CLK
CLK
CL
PR
D
Trang 99
https://fb.com/tailieudientucntt
Q
Bài Giảng Kỹ Thuật Số
Chương 4
ck
A
B
C
Baûng traïng thaùi
CK
0
1
2
3
4
5
6
A
0
1
1
1
0
0
0
B
0
0
1
1
1
0
0
C
0
0
0
1
1
1
0
Maïch söû duïng 3-FF neân soá MOD = 6
Toång quaùt, vôùi maïch söû duïng n-FF thì soá MOD laø 2n
•
Vi maïch ñeám voøng Johnson laø 4017 MOD10
CD4017
O0
O1
CLK
O2
O3
CKI
O4
O5
O6
O7
O8
O9
COUT
RESET
4.5.7. Öùng duïng boä ñeám:
a. Ñeám taàn soá
Clear
Unknow freq
Counter
Unknow freq.
SAMPLE
pulses
SAMPLE pulses
Clear
Z
Counter
Display
t0
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
t1 T.gian lấy mẫu t2
Trang 100
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Maïch ñeám taàn soá laø maïch ño vaø hieån thò taàn soá cuûa tín hieäu.
Ngoõ vaøo coång AND bao goàm caùc xung vôùi taàn soá chua bieát fx vaø 1 xung laáy maãu
ñieàu khieån thôøi gian cho pheùp xung qua coång AND vaøo boä ñeám.
Maïch ñeám seõ ñeám soá xung xuaát hieän trong thôøi gian laáy maãu. Gía trò hieån thò
cuûa boä ñeám laø taàn soá cuûa tín hieäu caàn ño (neáu thôøi gian laáy maãu t2 – t1 =1s thì
ñôn vò cuûa taàn soá laø Hz)
Söï chính xaùc cuûa phuông phaùp naøy tuøy thuoäc vaøo khoaûng thôøi gian laáy maãu.
Phöông phaùp thöôøng söû duïng ñeå nhaän ñöôïc 1 xung laáy maãu chính xaùc laø söû duïng
boä dao ñoäng thaïch anh ñeå taïo ra taàn soá chính xaùc (ví duï 100khz) sau ñoù ngöôøi ta
chia xuoáng theo caùc thang ño nhö sau
100kh
Dao động
thạch anh
100kh
Biến đổi
sinvuông
10khz
Bộ
đếm10
Chia 10
100hz
1khz
Bộ
đếm10
Chia 10
Bộ
đếm10
Chia 10
Bộ
đếm10
Chia 10
SAMPLE pulse
Q
PR
Q
CLK
CL
K
J
1
1
Cuoái cuøng boä ñeám taàn soá hoaøn taát nhö sau
Unknow
freq
CLEAR
Counter
SAMPLE
pulse
Decoder/
Display
Q
Tp
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
PR
Q
CLK
CL
K
T
=100ns
RT
Q
J
1
1
CT
Trang 101
https://fb.com/tailieudientucntt
10hz
1hz
Bộ
đếm10
Chia 10
Bài Giảng Kỹ Thuật Số
Chương 4
Input pulse
SAMPLE
pulse
T
Q
output
counter counter
clear
is
counter count counter
stop
clear
display
show freq
is
b. Ñoàng hoà soá
Moät trong nhöõng öùng duïng thoâng duïng nhaát cuûa boä ñeám laø ñoàng hoà soá, hieån thò
thôøi gian trong ngaøy nhö giôø, phuùt, giaây.
Ñeå taïo moät ñoàng hoà soá chính xaùc yeâu caàu taàn soá xung clock caáp cho ñoàng hoà
phaûi chính xaùc. Ñoái vôùi nhöõng ñoàng hoà soá söû duïng pin, thöôøng söû duïng thaïch
anh ñeå taïo taàn soá cô baûn. Ñoái vôùi ñoàng hoà soá söû duïng ñieän löôùi ac, duøng taàn soá
cuûa ñieän löôùi ñeå taïo taàn soá cô baûn. Trong caùc tröôøng hôïp treân taàn soá cuûa thaïch
anh hay ñieän löôùi ñöôïc chia xuoáng thaønh taàn soá 1hz caáp cho ñoàng hoà
50hz
1hz
50hz
Pulse
shaper
Chia
50
MOD2
1-FF
BCD
counter
MOD6
counter
BCD
counter
MOD6
counter
BCD
counter
Decoder
display
0-1
ten
Decoder
display
0-9
Unit
Decoder
display
0-5
ten
Decoder
display
0-9
Unit
Decoder
display
0-5
ten
Decoder
display
0-9
Unit
Hours
section
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Minute
section
Second
section
Trang 102
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Ñoái vôùi maïch ñeám giôø
coù moät soá tình huoáng
sau:
0001
Khi soá haøng chuïc ôû giaù
trò 0, thì boä ñeám haøng
ñôn vò laø boä ñeám BCD
Khi soá haøng chuïc ôû giaù
trò 1, thì boä ñeám haøng
ñôn vò chæ ñeám MOD3
(hieån thò giaù trò giôø töø
10 ñeán 12 roài trôû laïi 1
(cho neân maïch naøy phaûi
coù khaû naêng ñaët tröôùc
soá ñeám)
Q
PR
Q
CLK
CL
K
J
1
CLR
CK-D CK-UP
PL COBO D C B A
1
74LS192
Decoder
Display
Unit of
hours
Display
Tens of
hours
Maïch cho boä ñeám giôø
nhö hình beân
DCB A
4.5.8. Boä nhôù truy caäp ngaãu nhieân
Di
Nhập data
R/W
Ai
D PR
Q
CLK
CL
Q
DO
Xuất data
Địa chỉ ô nhớ
Baûng chöùc naêng
Ngoõ vaøo
Ai
0
1
1
1
R/W
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
X
0
0
1
Di
X
0
1
X
Cheá ñoä
Nhôù, D0 = 0
Nhôù 0 vaøo oâ nhôù, D0 = 0
Nhôù 0 vaøo oâ nhôù, D0 = 0
Ñoïc oâ nhôù, D0 = bit nhôù
Trang 103
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
4.6.
Chương 4
MÁY TRẠNG THÁI
Heä tuaàn töï coøn coù teân goïi khaùc laø maùy traïng thaùi (State Machine), teân naøy
thöôøng söû duïng khi duøng moät heä tuaàn töï ñeå ñieàu khieån 1 heä thoáng soá thöïc hieän
moät thuû tuïc hoaëc moät thuaät toaùn töøng böôùc moät. Coù theå ñònh nghóa caùc maùy
traïng thaùi baèng caùc giaûn ñoà traïng thaùi, hoaëc moät kieåu löu ñoà ñaëc bieät ñöôïc goïi laø
löu ñoà maùy traïng thaùi hay löu ñoà SM (State Machine) duøng ñeå moâ taû ñaëc tính
laøm vieäc cuûa moät maùy traïng thaùi
Trong thieát keá soá, thöôøng söû duïng töø maùy traïng thaùi ñeå chæ caùc maïch ñoàng boä
nhö mạch đếm… ở ñoù caùc giaù trò ra thay ñoåi töø moät traïng thaùi nhò phaân naøy sang
moät traïng thaùi nhò phaân khaùc khi maïch ñöôïc cung caáp xung clock.
SM coù hai loaïi: Moore vaø Mealy.
4.6.1. Máy trạng thái kiểu MOORE
Sô ñoà khoái maùy traïng thaùi kieåu Moore vaø moät maïch counter nhò phaân 2bit laø moät
ví duï cho maùy traïng thaùi kieåu Moore
Caùc t/hieäu
ngoaøi
Giaûi maõ
t.thaùi keá
Löu tröõ t.thaùi
hieän taïi
Giaûi maõ
ngoõ ra
Caùc FF
Clock
X1
X2
Xm
Maïng toå
hôïp
Q1
Q2
Qk
Q1+
Q +2
Q +k
D1
CK
D2
CK
Dk
CK
Q1
Q2
Qk
Clock
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 104
https://fb.com/tailieudientucntt
Heä toå
hôïp
(cho
caùc
ngoõ
ra)
Z1
Z2
Zn
Bài Giảng Kỹ Thuật Số
Chương 4
4.6.2. Máy trạng thái kiểu MEALY
Sô ñoà khoái maùy traïng thaùi Mealy
Kích
Logic
thích
traïng thaùi
keá
Giaù trò
vaøo
Boä nhôù
traïng thaùi
Traïng thaùi
hieän haønh
Logic ra
G
Caùc giaù trò
ra (Output)
Ngoõ CK
Clock
X1
X2
Z1
Z2
Zn
HEÄ
TOÅ
HÔÏP Q+
1
Xm
D1
CK
Q+
2
Q1
Q2
D2
CK
Qk+
Qk
Dk
CK
Q1
Q2
Qk
Clock
4.7.
LƯU ĐỒ MÁY TRẠNG THÁI
Caùc löu ñoà SM coøn ñöôïc goïi laø löu ñoà ASM (Algorithmic State Machine). Löu
ñoà SM cho nhieàu thuaän lôïi trong vieäc deã hieåu hôn hoaït ñoäng cuûa moät heä thoáng
soá baèng caùch quan saùt thay vì laø giaûn ñoà traïng thaùi töông ñöông. Coù theå chuyeån
moät löu ñoà SM cho tröôùc thaønh nhieàu daïng töông ñöông, vaø moãi daïng daãn tröïc
tieáp ñeán moät caøi ñaët phaàn cöùng.
Ba thaønh phaàn chính cuûa moät löu ñoà SM
tên trạng
thái
Mã trạng
thái
(a) Hoäp traïng thaùi
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
nhánh
đúng
nhánh
sai
1
0
điều kiện
(b) Hoäp quyeát ñònh
danh
sách xuất
theo điều
kiện
(c) Hoäp xuaát theo ñk
Trang 105
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
•
Traïng thaùi cuûa moät heä thoáng ñöôïc bieåu dieån baèng hoäp traïng thaùi (state box),
hoäp traïng thaùi coù theå chöùa moät danh saùch giaù trò ra. Maõ traïng thaùi coù theå ñaët
beân caïnh hoäp ôû phaàn treân. Teân traïng thaùi ñöôïc ñaët trong hình troøn beân traùi
hoäp traïng thaùi.
•
Hoäp quyeát ñònh (decision box) ñöôïc bieåu dieãn baèng moät kyù hieäu hình thoi
vôùi caùc nhaùnh ñuùng vaø sai. Ñieàu kieän ñaët trong hoäp laø moät bieåu thöùc
Boolean ñöôïc xaùc ñònh ñeå laáy nhaùnh naøo.
•
Hoäp xuaát theo ñieàu kieän (conditional output box) chöùa danh saùch vaø caùc giaù
trò ra theo ñieàu kieän phuï thuoäc vaøo caû traïng thaùi cuûa heä thoáng vaø caùc giaù trò
vaøo
Moät löu ñoà SM ñöôïc xaây döïng töø caùc khoái SM (SM block) moãi khoái SM chöùa
chính xaùc moät hoäp traïng thaùi cuøng vôùi caùc hoäp quyeát ñònh vaø caùc hoäp xuaát theo
ñieàu kieän lieân heä vôùi traïng thaùi ñoù.
Moät khoái SM coù chính xaùc moät ñöôøng vaøo vaø moät hoaëc nhieàu ñöôøng ra vaø moâ taû
hoaït ñoäng cuûa maùy trong thôøi gian maø maùy ñang trong traïng thaùi.
Khi moät heä thoáng soá ñi vaøo traïng thaùi lieân heä vôùi moät khoái SM cho tröôùc, caùc
giaù trò ra ôû danh saùch xuaát trong hoäp traïng thaùi seõ trôû thaønh ñuùng. Caùc ñieàu kieän
trong caùc hoäp quyeát ñònh seõ ñöôïc ñònh trò ñeå xaùc ñònh xem ñöôøng naøo ñi theo
qua khoái SM. Khi treân ñöôøng ñi coù gaëp moät hoäp xuaát theo ñieàu kieän thì caùc giaù
trò ra töông öùng seõ trôû thaønh ñuùng. Moät ñöôøng daãn qua khoái SM töø ngoõ vaøo ñeán
ngoõ ra ñöôïc goïi laø ñöôøng daãn noái gheùp (link path)
Ví dụ, moät khoái SM
Z1, Z2
S1
nhaùnh a
0
1
X1
0
Z3, Z4
0
1
X3
1
nhaùnh b
X3
1
Z5
2
3
n
n ñöôøng ra
khi vaøo traïng thaùi S1, caùc giaù trò ra Z1 vaø Z2 = 1. Neáu giaù trò vaøo X1 vaø X2 ñeàu
baèng 0 thì Z3 vaø Z4 baèng 1 vaø ôû cuoái thôøi gian traïng thaùi, maùy ñi vaøo traïng thaùi
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 106
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
keá qua ñöôøng ra 1, ngöôïc laïi neáu X1 =1 vaø X3 = 0, giaù trò ra Z5 = 1 vaø ñi vaøo
traïng thaùi keá qua ñöôøng ra 3
Toång quaùt thì moät khoái SM coù theå ñöôïc veõ baèng nhieàu daïng khaùc nhau. Hai khoái
SM sau laø töông ñöông.
Z1
S1
0
X1
Z1
S1
0
1
Z2
S2
X3
X1
0
1
1
0
Z2
Z2
S2
S3
1
1
X1
0
X2
S3
Ví dụ, Veõ moät khoái SM töông ñöông vôùi khoái SM sau.
`
0
C
0
1
A
1
1
B
0
Z1
Phaûi tuaân theo moät soá quy taéc nhaát ñònh khi xaây döïng moät khoái SM:
Thöù nhaát, vôùi moïi keát hôïp caùc bieán vaøo hôïp leä phaûi coù chính xaùc moät ñöôøng ra
ñöôïc ñònh nghóa. Ñieàu naøy laø caàn thieát vì moãi toå hôïp vaøo ñöôïc cho pheùp phaûi
daãn ñeán 1 traïng thaùi keá duy nhaát.
Thöù hai, khoâng cho pheùp coù ñöôøng hoài tieáp noäi trong moät khoái SM.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 107
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Ví dụ, 1 caùch veõ sai vaø 1 caùch veõ ñuùng ñoái vôùi 1 khoái SM coù ñöôøng hoài tieáp
(b) Ñuùng
(a) Sai
Moät khoái SM coù theå coù nhieàu ñöôøng song song maø daãn ñeán cuøng moät ñöôøng ra,
vaø hôn moät ñöôøng trong caùc ñöôøng naøy coù theå tích cöïc ñoàng thôøi. Ngoaøi ra cuõng
coù theå bieåu dieãn baèng moät khoái SM noái tieáp töông ñöông. Trong khoái noái tieáp
naøy coù theå coù moät ñöôøng daãn noái gheùp tích cöïc duy nhaát giöõa ngoû vaøo vaø ra. Vôùi
baát cöù toå hôïp naøo cuûa caùc giaù trò vaøo, caùc giaù trò ra seõ gioáng nhö trong daïng song
song töông ñöông.
Ví dụ,
Z1
Z1
1
1
X1
Z2
0
Z3
1
X2
0
Z4
X1
X3
0
Z2
X2
(a) daïng song song
Z3
X3
Z3
(b) daïng noái tieáp
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 108
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Coù theå chuyeån moät giaûn ñoà traïng thaùi cuûa maùy tuaàn töï sang löu ñoà SM töông
ñöông moät caùch deã daøng.
Ví dụ, Giaûn ñoà traïng thaùi
1/0
1/0
S0
0/0
Za
0/0
S1
S2
Zb
Zc
1/Z2
0/Z1
Vaø löu ñoà SM töông ñöông
00
S0
Za
link 1
0
X
1
01
Zb
S1
link 2
X
0
1
11
link 3
Zc
S1
0
X
Z1
1
Z2
Giaûn ñoà ñònh thì cho löu ñoà SM
clock
traïng thaùi
X
S0
S1
S2
S2
S0
Za
Zb
Zc
Z1
Z2
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 109
https://fb.com/tailieudientucntt
S0
Bài Giảng Kỹ Thuật Số
Chương 4
ÔÛ giaûn ñoà traïng thaùi, coù caû 2 giaù trò ra Moore vaø Mealy, löu ñoà SM töông ñöông
coù 3 khoái, moät khoái öùng vôùi moät traïng thaùi. Caùc giaù trò ra Moore (Za, Zb, Zc)
ñöôïc ñaët trong caùc hoäp traïng thaùi, töø ñoù chuùng khoâng phuï thuoäc vaøo giaù trò vaøo.
Caùc giaù trò ra Mealy (Z1, Z2) xuaát hieän trong caùc hoäp xuaát theo ñieàu kieän, chuùng
phuï thuoäc vaøo caû traïng thaùi vaø giaù trò vaøo. Trong ví duï naøy, moãi khoái SM chæ coù
moät hoäp quyeát ñònh, do ñoù chæ phaûi kieåm tra 1 bieán vaøo. Ñoái vôùi caû hai giaûn ñoà
traïng thaùi vaø löu ñoà SM, Zc luoân baèng 1 trong traïng thaùi S2. Neáu X=0 trong traïng
thaùi S2, Z=1 vaø traïng thaùi keá laø S0. Neáu X=1, Z2 =1 vaø traïng thaùi keá laø S2
ÔÛ giaûn ñoà ñònh thì cho löu ñoà SM, vôùi chuoãi vaøo X=1,1,1,0,0,0. Taát caû caùc thay
ñoåi traïng thaùi xaûy ra ngay sau caïnh leân cuûa xung nhòp. Vì caùc giaù trò Moore phuï
thuoäc vaøo traïng thaùi vaø chæ coù theå thay ñoåi töùc thôøi sau 1 thay ñoåi traïng thaùi hoaëc
moät thay ñoåi giaù trò vaøo. Noùi chung, taát caû caùc giaù trò ra seõ coù giaù trò ñuùng cuûa
chuùng ôû caïnh tích cöïc cuûa xung nhòp
Ví dụ, Laäp löu ñoà SM cho boä chia nhò phaân song song cho caùc soá nhò phaân
döông, soá bò chia (dividend) 6 bit cho soá chia (divisor) 3 bit ñeå coù ñöôïc thöông 3
bit.
Minh hoïa quaù trình chia
100010
110
101
000
1010
110
100
110
101
Pheùp chia coù theå thöïc hieän baèng pheùp toaùn tröø vaø dòch. ñeå xaây döïng boä chia seõ
söû duïng thanh ghi soá bò chia 7 bit vaø thanh ghi soá chia 3 bit nhö sau
Thanh ghi số bị chia
x7
x6
x5
x4
x3
x2
start
x1
Sh
Su
Bộ trừ và so
sánh
y3
C (so sánh)
y2 y1
V
Điều
khiển
Chỉ báo tràn trên
clock
Số chia
Trong quaù trình chia thay vì dòch soá chia sang phaûi tröôùc moãi laàn tröø, ôû ñaây seõ
dòch soá bò chia sang traùi. Chuù yù laø caàn theâm 1 bit ôû ñaàu beân traùi thanh ghi soá bò
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 110
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
chia ñeå cho khoâng maát 1 bit khi dòch traùi soá bò chia. Thay vì duøng 1 thanh ghi ñeå
chöùa thöông soá, coù theå ñöa thöông soá töøng bit moät vaøo ñaàu beân phaûi cuûa thanh
ghi soá bò chia khi dòch traùi soá bò chia
Neáu ban ñaàu x7x6x5x4 ≥ y3y2y1 (nghóa laø neáu 4 bit traùi cuûa thanh ghi soá bò chia
vöôït quaù hoaëc baèng soá chia) thöông soá seõ lôùn hôn 8 vaø traøn treân xaûy ra. Chuù yù laø
neáu
x 7 x 6 x 5 x 4 x 3 x 2 x 1 x 7 x 6 x 5 x 4 0000 x 7 x 6 x 5 x 4 8
≥
=
≥8
y 3 y 2 y1
y 3 y 2 y1
y 3 y 2 y1
baùo traøn vì thöông soá chæ coù 3 bit (toái ña baèng 7)
Tín hieäu dòch (Sh = shift) seõ dòch soá bò chia sang traùi moät vò trí. Tín hieäu tröø (Su
= Subtract) seõ tröø soá chia cho 4 bit taän cuøng beân traùi cuûa thanh ghi soá bò chia vaø
ñaët bit thöông soá (bit taän cuøng beân phaûi thanh ghi soá bò chia) leân 1. Neáu soá chia
lôùn hôn 4 bit taän cuøng beân traùi cuûa soá bò chia, ngoõ ra cuûa boä so saùnh laø C=0,
ngöôïc laïi C=1. Maïch ñieàu khieån taïo ra chuoåi caùc tín hieäu dòch vaø tröø mong
muoán. Baát cöù luùc naøo C=1, tín hieäu tröø ñöôïc taïo ra vaø bit thöông soá ñöôïc ñaët leân
Giaûn ñoà traïng thaùi cuûa maïch ñieàu khieån
Start’/0
C/Su
C.Start/V
S0
Stop
C’.Start/Sh
C’/0
S1
S3
C’/Sh
C/Su
C’/Sh
S2
C/Su
Ban ñaàu soá bit chia 6 bit vaø soá chia 3 bit ñöôïc ñöa vaøo caùc thanh ghi thích hôïp.
Maïch vaãn ôû traïng thaùi döøng Stop (S0) cho ñeán khi coù tín hieäu Start. Neáu giaù trò
ban ñaàu cuûa C=1, thöông soá seõ caàn 4 bit trôû leân. Vì khoâng gian chæ cung caáp cho
thöông soá 3 bit, ñieàu kieän naøy laøm traøn treân do ñoù boä chia döøng vaø boä chæ traøn seõ
ñaët leân 1 baèng ngoõ ra traøn treân.
Bình thöôøng giaù trò ban ñaàu cuûa C=0, vì vaäy dòch seõ xaûy ra ñaàu tieân vaø maïch seõ
ñi vaøo traïng thaùi S1. Roài neáu C=1 thì xaûy ra tröø. Sau khi hoaøn taát tröø C seõ luoân
luoân baèng 0 vì vaäy xung nhòp keá seõ taïo ra dòch. Quaù trình naøy tieáp tuïc cho ñeán
khi xaûy ra 3 laàn dòch vaø ñieàu khieån oå trong traïng thaùi S3. Roài pheùp tröù cuoái cuøng
xaûy ra neáu caàn, vaø ñieàu khieån quay veà traïng thaùi döøng. Vôùi vd naøy seõ giaû söø laø
khi tín hieäu baét ñaàu (start) xaûy ra noù seõ laø 1 trong thôøi gian 1 clock vaø roài giöõ laø
0 cho ñeán khi heä ñieàu khieån quay veà traïng thaùi S0. Do ñoù Start seõ luoân laø 0 trong
caùc traïng thaùi S1, S2, S3
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 111
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Töø ñoù suy ra löu ñoà SM nhö sau
00
S0
0
Sh
Start
1
C
01
S1
0
0
Sh
1
V
S2
Sh
S3
1
Su
10
0
C
C
1
Su
11
0
C
1
Su
S0 laø traïng thaùi baét ñaàu, neáu Start=1, tín hieäu so saùnh C ñöôïc kieåm tra, neáu C=1,
thöông soá lôùn hôn 3 bit, vì vaäy baùo traøn V=1 ñöôïc taïo ra vaø khoâng coù söï thay ñoåi
xaûy ra. Neáu C=0, Sh=1, ôû xung nhòp keá soá bò chia ñöôïc dòch sang traùi vaø traïng
thaùi chuyeån sang S1. C ñöôïc kieåm tra trong traïng thaùi S1. Neáu C=1 coù theå coù
pheùp tröø, Su=1 vaø khoâng coù söï thay ñoåi traïng thaùi. Neáu C=0, Sh=1 vaø soá bò chia
ñöôïc dòch khi traïng thaùi chuyeån sang S2. Hoaït ñoäng ôû S2 thì gioáng S1. Trong
traïng thaùi S3 traïng thaùi keá luoân laø S0, vaø C=1 laøm cho pheùp tröø xaûy ra
Ví dụ, Laäp löu ñoà Sm cho ñieàu khieån boä nhaân song song cho caùc soá nhò phaân
döông.
Nhaân nhò phaân chæ caàn pheùp toaùn dòch vaø coäng. Thay vì ban ñaàu taïo ra taát caû caùc
tích boä phaän roài coäng laïi, thì moãi tích boä phaän (partial product) ñöôïc coäng moãi
khi ñöôïc taïo ra vaø do ñoù khoâng caàn coäng moät laàn hôn 2 soá nhò phaân
Nhaân 2 soá 4 bit caàn 1 thanh ghi soá bò nhaân (multiplicant register) 4bit, moät thanh
ghi soá nhaân 4 bit vaø thanh ghi 8bit cho soá haïng tích. Thanh ghi tích soá laøm vieäc
nhö thanh ghi tích luõy laø tích luõy toång caùc tích boä phaän. Thay vì dòch soá bò nhaân
sang traùi tröôùc khi coäng, ôû ñaây seõ dòch thanh ghi tích sang phaûi
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 112
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Soá bò nhaân
Soá nhaân
Caùc tích boä phaän
Chương 4
→
→
1101
1011
1101
1101
10111
0000
100111
1101
10001111
Tích soá
Sô ñoà khoái cuûa boä nhaân song song
Thanh ghi tích soá
Thanh ghi tích luõy
PC
C
Boä coäng
M=1: coäng &dòch
M=0: dòch
Soá nhaân
N
Ñieàu
khieån
Ad
PC
Sh
Ad: tín hieäu coäng
Sh: tín hieäu dòch
PC: xung clock
M: bit boä nhaân
N: tín hieäu start
C: soá nhôù
Soá bò nhaân
Ví duï, nhaân 13 x 11 ñöôïc laøm laïi sau ñaây chæ vò trí caùc bit trong caùc thanh ghi ôû
moãi thôøi ñieåm xung nhòp
Noäi dung ban ñaàu cuûa t.ghi tích
luõy (coäng soá bò nhaân vì M=1)
Sau khi coäng
Sau khi dòch phaûi
Coäng soá bò nhaân vì M=1
Sau khi coäng
Sau khi dòch phaûi
Boû qua coäng vì M=0
Sau khi dòch
coäng soá bò nhaân vì M=1
Sau khi coäng
Sau khi dòch (ñaùp soá)
000001011
1101
011011011
001101101
1101
100111101
010011110
M(11)
(13)
001001111
1101
100011111
010001111
M=1
M=1
M=0
Ñöôøng chaám chaám laø ñöôøng chia giöõa boä nhaân vaø tích soá
Maïch ñieàu khieån phaûi ñöôïc thieát keá ñeå cho ra chuoãi caùc tín hieäu coäng vaø dòch
ñuùng.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 113
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Giaûn ñoà traïng thaùi cho ñieàu khieån boä nhaân, SV giaûi thích töông töï nhö maïch chia
N’/0
S0
- /Sh
MN/Ad
S1
S7
M/Ad
- /Sh
M’N/Sh
M’N/Sh
S2
S6
M’N/Sh
M/Ad
M’N/Sh
- /Sh
S3
S5
S4
M/Ad
- /Sh
N’/0
Ad
N
Ñieàu khieån
Coäng - dòch
Sh
PC
K=1 neáu n-1 laàn dòch
Boä ñeám
K/Sh
M’N/Sh
M’K/Sh
K’/Sh
S0
M/Ad
- /Sh
M’/Sh
S0
(b) Giaûn ñoà traïng thaùi cuûa
ñieàu khieån coäng dòch
N’/0
MN/Ad
M’N/Sh
M/Ad
S0
(a) Ñieàu khieån boä nhaân
S0
MN/Ad
S0
(c) Giaûn ñoà traïng thaùi cuoái
cuûa ñieàu khieån coäng dòch
M’K’/Sh
S0
Laäp löu ñoà SM cho ñieàu khieån boä nhaân, ñieàu khieån naøy taïo ra chuoãi caùc xung
coäng vaø dòch mong muoán cuûa boä nhaân nhò phaân. Boä ñeám seõ ñeám soá laàn dòch vaø
xuaát K=1 tröôùc khi laàn dòch cuoái cuøng xaûy ra. Löu ñoà SM cho ñieàu khieån boä
nhaân töông öùng vôùi giaûn ñoà traïng thaùi hình (c)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 114
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
S0
0
1
N
1
M
0
Ad
Sh
S2
Sh
S1
1
K
1
0
0
M
Sh
Ad
1
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
M
Trang 115
https://fb.com/tailieudientucntt
0
Bài Giảng Kỹ Thuật Số
4.8.
Chương 4
BỘ NHỚ BÁN DẪN
Boä nhôù baùn daãn chia laøm hai loaïi chính
•
Boä nhôù baûng (table memory)
•
Boä nhôù haøm (function memory)
Boä nhôù baùn daãn
Boä nhôù haøm
Boä nhôù baûng
RAM
Tónh
Ñoäng
PLD
ROM
MROM
PROM
EPROM
EPROM
PLA
PAL
LCA
PPAL
EPPAL
EEPPAL
EPLD
Vôùi
PEEL
(Pro.
elec.
erasable
logic
GAL
(generic
array
logic)
RAM = Random Access Memory
ROM = Read Only Memory
PLD = Programmable Logic Device
PLA = Programmable Logic Array
PAL = Programmable Array Logic
LCA = Logic Cell Array
M = Mask programed
P = Programmable
EP = Erasable and Programmable
EEP = Electrically Erasable and Programmable
Bộ nhớ bảng,
•
Đòa chæ A ñöôïc ñònh nghóa trong daõy 0≤ A ≤ 2N –1
Vôùi ñoä roäng töø cuûa ñòa chæ laø N, giaù trò cuûa N phuï thuoäc vaøo kích thöôùc cuûa
boä nhôù. Coù theå caát döõ lieäu ôû moät ñòa chæ trong 2N ñòa chæ. Ñoä roäng töø döõ lieäu
laø m = 1…16 bit
•
Dung löôïng boä nhôù K ñöôïc xaùc ñònh bôûi: K=mxn (bit)
Vôùi m laø ñoä roäng töø döõ lieäu, n laø soá ñòa chæ
Tính theo byte (K/8) cho caùc ñoä roäng töø döõ lieäu laø 8 hay 16 bit
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 116
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Ví dụ, Baûng cho ROM coù N=3bit ñòa chæ, m=2 bit döõ lieäu
Giaù trò
thaäp phaân
0
1
2
3
4
5
6
7
Ñòa chæ
a2 a1 a0
0
0
0
1
0
0
0
1
0
1
1
0
0
0
1
1
0
1
0
1
1
1
1
1
Döõ lieäu
d1
d0
d01
d00
d11
d10
d21
d20
d31
d30
d41
d40
d51
d50
d61
d60
d71
d70
D0
D1
D2
D3
D4
D5
D6
D7
Bộ nhớ hàm
•
Chöùa caùc haøm logic (Boolean) thay vì laø caùc baûng. Moãi bieán cuûa baûng chaân
trò coù theå ñöôïc bieåu dieãn baèng haøm logic.
Vieát döôùi daïng tích chuaån thì haøm logic cuûa bieán d0 ôû ví duï treân laø
d0 = a2 .a1.a0 d00 +a2 .a1.d10 +...+a2a1a0 d70
= m0d00 + m1d10+…+m7d70 (vôùi mi: minterm thöù i)
neáu trong baûng coù ít dio = 1 thì vieäc söû duïng boä nhôù haøm tieän lôïi hôn boä nhôù
baûng
Các thiết bị logic lập trình được PLD (Programmable Logic device)
•
PLD laø teân goïi toång quaùt cuûa moät IC soá maø ngöôøi ta coù theå laäp trình ñöôïc noù
ñeå thöïc hieän caùc haøm logic khaùc nhau.
Vì haøm logic ñöôïc bieåu dieãn döôùi daïng toång caùc tích hay tích caùc toång neân
caáu truùc maïch trong PLD thoâng thöôøng laø moät daõy AND vaø OR ñoàng daïng
(identical cell) maø coù theå laäp trình töøng coång ñöôïc.
•
Caùc thieát keá duøng PLD coù caùc öu ñieåm sau:
¾ Taêng khaû naêng tích hôïp. coù theå giaûm khoái löôïng veà maïch thieát keá trong
khi vaãn coù theå taêng chöùc naêng cho maïch
¾ Coâng suaát thaáp. CMOS vaø moät soá ít hôn caùc maïch keát hôïp seõ laøm giaûm
ñaùng keå coâng suaát nguoàn cung caáp
¾ Taêng ñoä tin caäy. Nguoàn cung caáp thaáp vaø vieäc giaûm toái ña caùc maïch lieân
keát ôû ngoaøi laøm cho vieäc truyeàn giöõa caùc khoái ñaùng tin caäy hôn
¾ Giaù thaønh thaáp.
¾ Deã söû duïng.
¾ Deã daøng thay ñoåi. Khi caàn coù söï thay ñoåi trong thieát keá, khoâng caàn phaûi
theâm thaét caùc “daây noái”, taát caû laø thay ñoåi beân trong cuûa PLD vaø coù theå
thöïc hieän caùc thay ñoåi ñoù moät caùch nhanh choùng.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 117
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
4.9.
Chương 4
ROM - THIẾT KẾ HỆ THỐNG SỐ DÙNG ROM
4.9.1. ROM
ROM laø moät maïch toå hôïp coù n ngoõ vaøo vaø m ngoõ ra. Caùc ngoõ vaøo ñöôïc goïi laø
ñòa chæ (address input) vaø thöôøng ñöôïc ñaët laø A0A1…An-1. Caùc ngoõ ra ñöôïc goïi laø
caùc ngoõ ra döõ lieäu (data output) vaø thöôøng ñöôïpc ñaët teân laø D0D1D2…Dm-1
2n x m ROM
address
input
(n đường)
A0
A1
A2
D0
D1
D2
An-1
Dm-1
address
output
(m đường)
Hình 1-2. Caáu truùc cô baûn cuûa moät ROM 2n x m
ROM chöùa baûng chaân trò cuûa moät haøm logic toå hôïp n ngoõ vaøo, m ngoõ ra.
Ví dụ, baûng chaân trò cuûa haøm toå
hôïp 3 ngoõ vaøo 4 ngoõ ra vaø ta coù
theå chöùa noù trong 1 ROM 23 x 4
(8x 4). Boû qua caùc trì hoaõn veà thôøi
gian, caùc ngoõ ra döõ lieäu cuûa moät
ROM ôû moïi luùc laø caùc bit ra cuûa
haøng trong baûng chaân trò ñöôïc
choïn bôûi caùc ngoõ vaøo ñòa chæ
A2
0
0
0
0
1
1
1
1
Input
A1
0
0
1
1
0
0
1
1
A0
0
1
0
1
0
1
0
1
D3
1
1
1
0
0
0
0
1
Output
D2 D1
1
1
1
0
0
1
1
1
0
0
0
1
1
0
0
0
D0
0
1
1
1
1
0
0
0
Chú ý
•
Coù theå duøng ROM nhö baát cöù phaàn töû logic toå hôïp naøo
•
ROM laø boä nhôù khoâng boác hôi (nonvolatile memory) vì noäi dung cuûa noù vaãn
giöõ ñöôïc ngay caû khi khoâng caáp ñieän
•
Vaán ñeà hoaùn vò caùc coät bit trong baûng chaân trò cuûa haøm caàn ghi ROM
•
Khi duøng ROM ñeå chöùa moät baûng chaân trò cho tröôùc, caùc tín hieäu input vaø
output ñoïc töø phaûi sang traùi trong baûng chaân trò thöôøng ñöôïc gaùn vaøo caùc ngoõ
vaøo ñòa chæ vaø ngoõ ra data cuûa ROM vôùi vôùi caùc nhaõn theo thöù töï taêng daàn
Ví dụ, Duøng ROM ñeà thöïc hieän haøm nhaân nhò phaân khoâng daáu cho 2 soá nhò
phaân 4 bit. Neáu duøng maïch rôøi ta duøng caùc IC 74284 vaø 74285, coøn duøng ROM
thì söû duïng ROM 28 x 8 (256 x 8) vôùi keát noái nhö hình 1-5
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 118
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
256 x 8 ROM
A0
A1
A2
A3
A4
A5
A6
A7
Y
(Số bị nhân)
X
(Số nhân)
D0
D1
D2
D3
D4
D5
D6
D7
Tích số
Noäi dung ghi ROM ôû treân nhö sau (daïng file vaên baûn hex)
Ñòa chæ
00:
10:
20:
30:
40:
50:
60:
70:
80:
90:
A0:
B0:
C0:
D0:
E0:
F0:
00
00
00
00
00
00
00
00
00
00
00
00
00
00
00
00
00
01
02
03
04
05
06
07
08
09
0A
0B
0C
0D
0E
0F
00
02
04
06
08
0A
0C
0E
10
12
14
16
18
1A
1C
1E
00
03
06
09
0C
0F
12
15
18
1B
1E
21
24
27
2A
2D
00
04
08
0C
10
14
18
1C
20
24
28
2C
30
34
38
3C
00
05
0A
0F
14
19
1E
23
28
2D
32
37
3C
41
46
4B
…
…
…
…
…
…
…
…
…
…
…
…
…
…
…
…
Tích soá
cuûa 1 x 5
4.9.2. Cấu trúc nội của ROM
Cô cheá söû duïng ROM ñeå löu tröõ thì thay ñoåi öùng vôùi caùc coâng ngheä cuûa ROM
khaùc nhau. Trong phaàn lôùn caùc ROM, söï xuaát hieän hoaëc vaéng maët cuûa moät
diode hay transistor seõ phaân bieät giöõa 0 vaø 1
Cấu trúc với giải mã 1 chiều
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 119
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Sô ñoà ROM 8x 4 vôùi caáu truùc giaûi maõ 1 chieàu (duøng 1 boä giaûi maõ TTL vaø caùc
diode).
HI
A0
A1
A2
A
B
C
HI
G1
G2A
G2B
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
0
D0
D1
D2
D3
Moãi ñöôøng ra boä giaûi maõ ñöôïc goïi laø ñöôøng töø (word line) bôûi vì noù choïn moät
haøng hoaëc moät töø cuûa baûng chöùa trong ROM
Moãi ñöôøng thaúng ñöùng trong hình ñöôïc goïi laø ñöôøng bit (bit line) bôûi vì noù töông
öùng vôùi moät bit ra cuûa ROM
Nhận xét: coù diode töông öùng möùc 0, khoâng coù diode töông öùng möùc 1
Caùc MOS ROM thöôøng duøng transistor thay vì laø diode ôû moãi vò trí maø bit seõ
ñöôïc löu tröõ.
Cấu trúc với giải mã 2 chiều
Neáu xaây döïng moät ROM 128x1 duøng caáu truùc ôû phaàn tröôùc phaûi söû duïng moät boä
giaûi maõ 7 sang 128, nghóa laø phaûi söû duïng ñeán moät löôïng lôùn 128 caùc coång
NAND 7 ngoõ vaøo, neáu thieát keá cho ROM vôùi haøng trieäu bits hoaëc nhieàu hôn seõ
khoâng coù boä giaûi maõ 20 sang 1048576. Thay vaøo ñoù ngöôøi ta seõ söû duïng caáu truùc
khaùc ñöôïc goïi laø giaûi maõ hai chieàu (two-dimentional decoding)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 120
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Ví dụ, ROM 128 x 1
HI
A4
A5
A6
A
B
C
HI
G1
G2A
G2B
Y0
Y1
Y2
Y3
Y4
Y5
Y6
Y7
0
0 1 2 3 4 5 6 7 8 9 101112131415
G2
S0 S1 S2 S3
D0
0
A0
A1
A2
A3
D0
3 bit ñòa chæ cao A6A5A4 seõ choïn haøng, moãi haøng chöùa 16 bit baét ñaàu taïi ñòa chæ
A6A5A40000. Khi ñaët ñòa chæ cho ROM, 16bit ôû haøng ñöôïc choïn ñöa vaøo boä MUX vaø
4 bit ñòa chæ thaáp seõ choïn bit data mong muoán.
Ngoaøi vieäc giaûm tính phöùc taïp vieäc giaûi maõ, giaûi maõ 2 chieàu coù moät thuaän lôïi khaùc
laø ROM coù moät kích thöôùc vaät lyù gaàn vuoâng, ñieàu naøy quan troïng cho vieäc cheá taïo
vaø ñoùng goùi IC
Với ROM coù nhieàu ngoõ ra döõ lieäu, caùc daõy löu tröõ töông öùng vôùi moãi ngoõ ra döõ lieäu
coù theå ñöôïc laøm heïp hôn ñeå ñaït ñöôïc boá trí chip gaàn vôùi hình vuoâng hôn.
Ví dụ, Moät boá trí cuûa ROM 32K x 8
A6
A7
A8
A9
A10
A11
A12
A13
A14
9 to 512
decoder
A0
A1
A2
A3
A4
A5
512 x 64 512 x 64 512 x 64 512 x 64 512 x 64 512 x 64 512 x 64 512 x 64
array
array
array
array
array
array
array
array
64 to 1 64 to 1 64 to 1 64 to 1 64 to 1 64 to 1 64 to 1 64 to 1
MUX
MUX
MUX
MUX
MUX
MUX
MUX
MUX
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 121
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
4.9.3. Các kiểu ROM thương mại
Baûng caùc kieåu ROM thöông maïi
Kieåu
Coâng ngheä
Chu kyø ñoïc
Mask ROM NMOS, CMOS 25 – 500ns
Mask ROM Bipolar
<100ns
Chu kyø ghi
4 tuaàn
4 tuaàn
PROM
Bipolar
<100ns
5 phuùt
EPROM
EEPROM
NMOS, CMOS
NMOS
25-500ns
50-500ns
5 phuùt
10ms/bytes
Chuù thích
Ghi 1 laàn, coâng suaát thaáp
Ghi 1 laàn, coâng suaát cao, maät
ñoä thaáp
Ghi 1 laàn coâng suaát cao,
khoâng coù maët naï
Duøng laïi ñöôïc, coâng suaát thaáp
Giôùi haïn 10000 laàn ghi/vò trí
Caùc ROM thoâng duïng nhaát laø caùc EPROM: 2764, 27128, 27256, vaø 27512
8K x 8
10
9
8
7
6
5
4
3
25
24
21
23
2
20
22
27
1
A0
A1
A2
A3
A4
A5
A6
A7
A8
A9
A10
A11
A12
16K x 8
O0
O1
O2
O3
O4
O5
O6
O7
CE
OE
PGM
VPP
10
9
8
7
6
5
4
3
25
24
21
23
2
26
20
22
27
1
2764
Chuù yù:
11
12
13
15
16
17
18
19
A0
A1
A2
A3
A4
A5
A6
A7
A8
A9
A10
A11
A12
A13
O0
O1
O2
O3
O4
O5
O6
O7
CE
OE
PGM
VPP
32K x 8
11
12
13
15
16
17
18
19
10
9
8
7
6
5
4
3
25
24
21
23
2
26
27
20
22
1
27128
A0
A1
A2
A3
A4
A5
A6
A7
A8
A9
A10
A11
A12
A13
A14
O0
O1
O2
O3
O4
O5
O6
O7
11
12
13
15
16
17
18
19
CE
OE
VPP
27256
chaân VCC phaûi noái vôùi +5V
chaân VIH phaûi noái vôùi tín hieäu logic HIGH hôïp leä
chaân VPP duøng ñeå ñöa vaøo ñieän aùp laäp trình
4.9.4. Các ngõ vào điều khiển và định thì ROM
Caùc ngoõ ra cuûa ROM thöôøng phaûi ñöôïc noái vaøo moät BUS 3 traïng thaùi, ôû ñoù caùc
thieát bò khaùc coù theå laùi BUS ôû caùc thôøi ñieåm khaùc nhau. Do ñoù, phaàn lôùn caùc
chip ROM thöông maïi coù ngoõ ra döõ lieäu 3 traïng thaùi vaø moät ngoõ vaøo Output
Enable (OE: cho pheùp xuaát) ñeå cho pheùp caùc ngoõ ra
Nhieàu öùng duïng ROM ñaëc bieät laø öùng duïng löu tröõ chöông trình seõ coù nhieàu
ROM ñöôïc noái chung vaøo 1 BUS, moãi laàn chæ coù 1 ROM laùi BUS. Phaàn lôùn caùc
ROM coù ngoõ vaøo chip select (CS: choïn chip) ñeå laøm ñôn giaûn vieäc thieát keá caùc
heä thoáng. Ngoaøi OE coøn caàn phaûi coù CS ñeå cho pheùp ngoõ ra 3 traïng thaùi
Tuy nhieân trong nhieàu ROM, CS cuõng laøm vieäc nhö ngoõ vaøo caét nguoàn caáp ñieän
(power down input), CS ôû möùc khoâng tích cöïc thì khoâng caáp nguoàn cho caùc
decoder noäi, caùc driver vaø caùc MUX cuûa ROM. ÔÛ cheá ñoä chôø naøy (standby
mode) 1 ROM tieâu thuï ít hôn 10% coâng suaát so vôùi cheá ñoä hoaït ñoäng (active
mode).
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 122
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Hình sau chæ caùc ngoõ vaøo CS vaø OE ñöôïc söû duïng nhö theá naøo ôû beân trong moät
ROM tieâu bieåu
A0
A1
row
decoder
Storage Array
Power on
Power on
Am-1
Power on
Am
Am+1
colum MUX
An-1
CS
OE
4.9.5. Thiết kế hệ tuần tự dùng ROM
Coù theå thieát keá deã daøng moät heä tuaàn töï duøng ROM keát hôïp vôùi caùc FF.
Moâ hình toång quaùt cuûa heä tuaàn töï duøng ROM vaø caùc D-FF coù xung nhòp
X1
X2
Z1
Z2
Zn
ROM
Q1+
Xm
Q1
Q2
Qk
Q+
2
Qk+
D1
CK
D2
CK
Dk
CK
Q1
Q2
Qk
Clock
Phaàn toå hôïp cuûa heä tuaàn töï coù theå duøng ROM ñeå thöïc hieän caùc haøm ra (Z1, Z2, …,
Zn) vaø caùc haøm traïng thaùi keá (Q1+, Q2+, …, Qk+).
Traïng thaùi cuûa heä ñöôïc chöùa trong moät thanh ghi (taïo baèng caùc D-FF) vaø ñöa
hoài tieáp veà ngoõ vaøo cuûa ROM.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 123
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Nhö vaäy heä tuaàn töï vôùi m input, n output vaø k bieán traïng thaùi coù theå ñöôïc caøi
ñaët baèng k D-FF vaø ROM vôùi (m+k) ngoõ vaøo (nghóa laø 2m+k töø word) vaø (n+k)
output
Thöông duøng D FF hôn JK FF vì söû duïng caùc FF vôùi 2 ngoõ vaøo seõ caàn phaûi taêng
soá ngoõ ra ôû ROM.
Ví dụ, Thieát keá maïch chuyeån ñoåi maõ BCD sang maõ quaù 3, ngoõ vaøo vaø ra laø noái
tieáp vôùi LSB ñi tröôùc
input (BCD) X
t2
t1
t0
t3
0
0
0
0
0
0
0
1
0
0
1
0
0
0
1
1
0
1
0
0
0
1
0
1
0
1
1
0
0
1
1
1
1
0
0
0
1
0
0
1
Output (excess – 3) Y
t3
t2
t1
t0
0
0
1
1
0
1
0
0
0
1
0
1
0
1
1
0
0
1
1
1
1
0
0
0
1
0
0
1
1
0
1
0
1
0
1
1
1
1
0
0
Baûng treân lieät keâ caùc input vaø output mong muoán taïi caùc thôøi ñieåm t0, t1, t2 vaø t3
Tröôùc heát thaønh laäp baûng traïng thaùi, sau ñoù ruùt goïn baûng baèng caùch so caùc haøng
gioáng nhau thì gom laïi. Khi so caùc haøng coù chöùa daáu gaïch ngang (ñaây laø tröôøng
hôïp “don’t care” thì daáu gaïch ngang seõ khôùp vôùi baát cöù traïng thaùi naøo hoaëc baát
cöù giaù trò ra naøo. Baèng caùch so khôùp caùc haøng theo caùch naøy, ta coù H ≡ I ≡ J ≡ K
≡ L vaø M≡ N ≡ P, sau khi khöû I, J, K, L N vaø P thaáy raèng E ≡ F ≡ G vaø baûng ñöôïc
thu goïn thaønh 7 haøng sau
Thời gian
Chuỗi vào
nhận được
t0
t1
reset
0
1
00
01
10
11
000
001
010
011
100
101
110
111
t2
t3
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trạng
thái hiện
tại
A
B
C
D
E
F
G
H
I
J
K
L
M
N
P
Trạng thái
kế
X = 0 X=1
B
C
D
F
E
G
H
L
I
M
J
N
K
P
A
A
A
A
A
A
A
A
A
A
-
Trang 124
https://fb.com/tailieudientucntt
Giá trị ra hiện
tại (Z)
X=0 X=1
1
0
1
0
0
1
0
1
1
0
1
0
1
0
0
1
0
1
0
0
0
1
1
1
-
Bài Giảng Kỹ Thuật Số
Chương 4
Baûng traïng thaùi ñöôïc ruùt goïn cuûa boä chuyeån ñoåi maõ
Thời gian
Trạng
thái hiện
tại
A
B
C
D
E
H
M
t0
t1
t2
t3
Trạng thái
kế
X = 0 X=1
B
C
D
F
E
G
H
H
H
M
A
A
A
-
Giá trị ra hiện
tại (Z)
X=0 X=1
1
0
1
0
0
1
0
1
1
0
0
1
1
-
Coù theå duøng moät caùch khaùc ñeå suy ra baûng treân baèng caùch baét ñaàu baèng giaûn ñoà
traïng thaùi.
Giaûn ñoà traïng thaùi coù daïng hình caây. Moãi ñöôøng baét ñaàu ôû traïng thaùi reset bieåu
dieãn moät trong 10 chuoãi vaøo coù theå coù
t0
A
0/1
1/0
Reset
B
t1
C
1/0
0/1
D
t2
F
1/1
0/0
H
t3
0/0
L
1/1
0/0
E
0/1
1/0
0/1
J
N
I
0/0
1/1
0/0
0/1
0/0
G
1/0
M
1/1
0/1
0/1
1/0
P
K
0/0
0/1
Baûng gaùn traïng thaùi vaø baûng chuyeån traïng thaùi
Thôøi
gian
t0
t1
t2
t3
Traïng thaùi
hieän taïi
A
B
C
D
E
H
M
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Q 1Q 2Q 3
000
010
011
101
100
111
110
Q1+Q2+Q3+
X=0
X=1
010
011
101
100
100
100
111
111
111
110
000
000
000
---
Z
0
1
1
0
0
1
0
1
Trang 125
https://fb.com/tailieudientucntt
1
0
0
1
1
0
1
---
Bài Giảng Kỹ Thuật Số
Chương 4
Caøi ñaët boä chuyeån ñoåi maõ naøy duøng ROM vaø caùc D-FF. Vì coù 7 traïng thaùi neân
caàn 3 DFF. Nhö vaäy caàn ROM coù 4 input (24 word) vaø 4 output . Duøng gaùn nhò
phaân tröïc tieáp, xaây döïng baûng chuyeån traïng thaùi cho traïng thaùi keá cuûa caùc D-FF
nhö laø haøm cuûa traïng thaùi hieän taïi vaø input.
Vì ñang söû duïng caùc D FF, D1 = Q1+, D2=Q2+, D3=Q3+. baûng chaân trò cho ROM
xaây döïng ñöôïc deã daøng töø baûng chuyeån traïng thaùi. Nhö vaäy caùc output cuûa ROM
(Z, D1, D2, D3) laø caùc haøm cuûa caùc input cuûa ROM (X, Q1, Q2, Q3)
(a) Baûng traïng thaùi
T. thaùi
h.taïi
A
B
C
D
E
H
M
T. thaùi keá
X=0
B
D
E
H
H
A
A
X=1
C
E
E
H
M
A
---
(b) baûng chuyeån traïng thaùi
G.trò ra h.taïi Z
X=0
1
1
0
0
1
0
1
X=1
0
0
1
1
0
1
---
Q1+Q2+Q3+
Q 1Q 2Q 3
A
B
C
D
E
H
M
000
001
010
011
100
101
110
X=0
001
011
100
101
101
000
000
X=1
010
100
100
101
110
000
---
Baûng chaân trò cho ROM
X
Q1
Q2
Q3
Z
D1 (Q1+)
D2 (Q2+)
D3 (Q3+)
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
0
0
0
0
1
1
1
1
0
0
0
0
1
1
1
1
0
0
1
1
0
0
1
1
0
0
1
1
0
0
1
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
1
1
0
0
1
0
1
x
0
0
1
1
0
1
x
x
0
0
1
1
1
0
0
x
0
1
1
1
1
0
x
x
0
1
0
0
0
0
0
x
1
0
0
0
1
0
x
x
1
1
0
1
1
0
0
x
0
0
0
1
0
0
x
x
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 126
https://fb.com/tailieudientucntt
Z
X=0
1
1
0
0
1
0
1
X=1
0
0
1
1
0
1
---
Bài Giảng Kỹ Thuật Số
Chương 4
Caøi ñaët maïng tuaàn töï duøng ROM
X1
Z
ROM
16 words
x 4 bit
Q1+
D1
CK
Q+
2
Q1
Q2
D2
CK
Q+
3
Q3
Dk
CK
Q1
Q2
Q3
Clock
4.10. PLD tổ hợp (Combinational PLD)
5.3.1. Dãy logic lập trình được (PLA)
PLA thöïc hieän cuøng chöùc naêng cô baûn nhö ROM. Moät PLA vôùi n input vaø m
output coù theå caøi ñaët m haøm cuûa n bieán. Toå chöùc noäi cuûa PLA thì khaùc vôùi toå
chöùc noät cuûa ROM
Caáu truùc PLA (PLA nxm vôùi p soá haïng tích)
n
input
Dãy
OR
Dãy
AND
p đường word
(số hạng tích)
Ví dụ, Toå chöùc noäi cuûa PLA 4x3 vôùi 6 soá haïng tích
a
b
c
m đường ra
d
Dãy OR
a'bd
abd
ab'c'
b'c
c
bc
Dãy AND
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Các
đường
Word
F1 F2 F3
Output
Trang 127
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Vôùi kyù hieäu
a' b d
a'
b
d
a'bd
a'bd
c bc
a'bd
ab'c'
c
a'bd
ab'c'
bc
F3
F3
Baûng PLA cho PLA ôû treân
a
0
1
1
-
b
1
1
0
0
1
c
0
1
1
1
d
1
1
-
F1
1
1
1
1
0
0
F2
1
0
0
0
1
0
F3
0
1
1
0
0
1
Moãi haøng trong baûng bieåu dieån moät soá haïng tích toång quaùt.
Có hai loại PLA:
•
PLA laäp trình maët naï (Mask programmable): ñöôïc laäp trình luùc cheá taïo
(töông töï PROM)
•
PLA laäp trình tröôøng (field programmable) coù caùc noái keát caàu chì (fusible
link) coù theå laøm ñöùt ñeå löu tröõ caùc maãu trong caùc daõy AND vaø OR.
Chú ý. Khi soá bieán vaøo nhoû, thì toång quaùt laø ROM kinh teá hôn duøng PLA. Tuy
nhieân khi soá bieán vaøo lôùn, PLA thöôøng cho giaûi phaùp kinh teá hôn ROM
5.3.2. Logic dãy lập trình được PAL (Programmable Array Logic)
PAL laø tröôøng hôïp ñaëc bieät cuûa PLA, trong ñoù caùc daõy AND laäp trình ñöôïc vaø
daõy OR laø coá ñònh. Caáu truùc cô baûn cuûa PAL thì gioáng nhö PLA
Moät ñoaïn PAL
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 128
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Vì chæ coù daõy AND laø laäp trình ñöôïc, do ñoù PAL kinh teá hôn PLA. Caùc nhaø thieát
keá logic thöôøng söû duïng caùc PAL ñeå thay theá caùc coång logic khi phaûi caøi ñaët
nhieàu haøm
Phaàn lôùn caùc nhaø saûn xuaát PAL chæ ra thieát keá noäi cuûa PAL ôû kyù hieäu cuûa noù
Ví dụ
PAL
16 L 8 B – 4
`soá input
tieâu taùn coâng suaát 1/4w
Caáu truùc ra
toác ñoä
Soá output
Vôùi caáu truùc ra
H = High ngoõ ra taùc ñoäng möùc cao
L = Low ngoõ ra taùc ñoäng möùc thaáp
C = Complement ngoõ ra coù caû hai ñöôøng taùc ñoäng möùc cao vaø thaáp
Toác ñoä:
khoaûng traéng – toác ñoä chuaån
A= toác ñoä cao
B=toác ñoä raát cao
D=toác ñoä cöïc cao
Tieâu taùn coâng suaát
blank = full
-2 = ½
-4 = ¼
Ví dụ, kyù hieäu logic truyeàn thoáng cho PAL 16L8
PAL16L8
1
2
3
4
5
6
7
8
9
11
I1
I2
I3
I4
I5
I6
I7
I8
I9
I10
O1
O2
O3
O4
O5
O6
O7
O8
19
18
17
16
15
14
13
12
chaân 10, 20 cho nguoàn vaø ñaát
Xem theâm sô ñoà logic cuûa PAL 14L4 vaø PAL 1246 ôû caùc trang 240, 241 trong
Fundamentals of logic design cuûa Roth
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 129
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Khi thiết kế với PAL phaûi ñôn giaûn hoùa caùc phöông trình logic vaø coá ñöa
chuùng khôùp vaøo moät (hoaëc nhieàu) caùc PAL. Khoâng gioáng nhö caùc PLA (toång
quaùt hôn) caùc soá haïng AND khoâng theå chia seû cho 2 hay nhieàu coång OR, vôùi
moät kieåu PAL cho tröôùc, soá soá haïng AND ñöa vaøo moãi coång OR laø coá ñònh vaø bò
giôùi haïn. Neáu soá soá haïng AND trong haøm ñöôïc ñôn giaûn laø quaù lôùn thì ta coù theå
choïn PAL coù nhieàu ngoõ vaøo vaø ít output hôn
Ví dụ, duøng PAL thieát keá maïch ñoåi moät soá nhò phaân 4 bit sang soá HEX vaø xuaát
maõ ASCII 7 bit cho soá hex
W
0
0
.
.
1
1
.
.
1
Input
X
Y
0
0
0
0
Z
0
1
số
hex
0
1
A6
0
0
mã ASCII cho số mã hex
A5 A4 A3 A2 A1 A0
1
1
0
0
0
0
1
1
0
0
0
1
0
0
0
1
1
0
9
A
0
1
1
0
1
0
1
0
0
0
0
0
1
1
1
1
1
F
1
0
0
0
1
1
0
W
X
Y
Z
A6
PAL
B
A5
A4
A3
A2
A1
A0
Chú ý:
Vì A5 = A4 vaø A6 = A 4 neân chæ caàn duøng PAL taïo ra 5 haøm cuûa 4 bieán
Ñeå vieát ñöôïc baûng PAL phaûi ruùt goïn caùc haøm ra vaø keát quaû nhö sau
A 4 =W+X.Y
A 4 =WX+WY
A 3 =W X.Y
A 3 =W+X+Y
A 2 =WX+XZ+XY
A 2 =X+W Y.Z
A1=WX.Y.Z+YZ+ WY
A 0 =WZ+X.YZ+WXZ+WYZ
Sau ñoù tìm caùc PAL thích hôïp ñeå caøi ñaët caùc haøm treân. Choïn ñöôïc PAL12H6, coù
moät output khoâng duøng. Coù theå vieát laïi chöông trình cho A2 nhö sau
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 130
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
A 2 =WX+(XZ+XY)=WX+B vôùi B=XZ+XY
roài coù theå söû duïng ngoõ ra theâm ñeå taïo ra B vaø noái B vaøo moät trong caùc ngoõ vaøo
PAL nhö ôû hình treân. Vôùi caùch naøy ta theå taïo ra 5 haøm vôùi moät PAL
Xem theâm caùc ví duï trong chöông 8 cuûa Digital desgn principle and practices
cuûa John F. Wakerly
5.3.3. Thiết kế hệ tuần tự dùng PLA
Coù theå caøi ñaët caùc heä tuaàn töï duøng PLA vaø caùc FF theo caùch töông töï nhö duøng
ROM vaø caùc FF. Tuy nhieân trong tröôøng hôïp caùc PLA, söï gaùn traïng thaùi laø quan
troïng vì vieäc söû duïng caùc pheùp gaùn toát coù theå giaûm ñöôïc soá caùc soá haïng tích caàn
coù vaø töø ñoù giaûm ñöôïc kích thöôc cuûa PLA
Ví dụ, caøi ñaët baûng traïng thaùi cuûa VD thieát keá duøng ROM nhöng baây giôø duøng 1
PLA 3 DFF.
T. thaùi h.taïi
T. thaùi keá
G.trò ra h.taïi Z
X=0 X=1
X=0
X=1
A
B
C
1
0
B
D
E
1
0
C
E
E
0
1
D
H
H
0
1
E
H
M
1
0
H
A
A
0
1
M
A
--1
--Caáu hình maïch thì gioáng nhö duøng ROM ngoaïi tröø thay theá ROM baèng moät PLA
vôùi kích thöôùng thích hôïp.
Söû duïng pheùp gaùn nhò phaân tröïc tieáp daãn ñeán baûng chaân trò sau
X
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
Q1
0
0
0
0
1
1
1
1
0
0
0
0
1
1
1
1
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Q2
0
0
1
1
0
0
1
1
0
0
1
1
0
0
1
1
Q3
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
Z
1
1
0
0
1
0
1
x
0
0
1
1
0
1
x
x
D1 (Q1+)
0
0
1
1
1
0
0
x
0
1
1
1
1
0
x
x
D2 (Q2+)
0
1
0
0
0
0
0
x
1
0
0
0
1
0
x
x
D3 (Q3+)
1
1
0
1
1
0
0
x
0
0
0
1
0
0
x
x
Trang 131
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Coù theå chöùa baûng naøy trong moät PLA 4 input, 13 soá haïng tích vaø 4 output nhöng
thaáy raèng noù seõ khoâng thuaän lôïi hôn vieäc duøng ROM ñaõ laøm ôû phaàn tröôùc.
Neáu söû duïng pheùp gaùn traïng thaùi, phöông trình ra vaø phöông trình vaøo caùc D-FF
D1 = Q1 Q 2 + Q1Q 2
D2 = Q2
D 3 = Q 2 .Q 3 + XQ 1 Q 2 + XQ 1 .Q 2 + X.Q 1 .Q 2 Q 3
Z = XQ 3 + XQ 3
Baûng PLA töông öùng vôùi caùc phöông trình naøy nhö sau.
X
0
1
0
0
1
Q1
1
0
1
0
0
-
Q2
0
1
0
0
0
0
1
-
Q3
1
0
0
1
Z
0
0
0
0
0
0
0
1
1
D1 (Q1+)
1
1
0
0
0
0
0
0
0
D2 (Q2+)
0
0
1
0
0
0
0
0
0
D3 (Q3+)
0
0
0
1
1
1
1
0
0
Ñeå caøi ñaët baûng naøy caàn 1 PLA coù 4 input, 9 soá haïng tích vaø 4 output.
5.3.4. Thiết kế hệ tuần tự dùng PAL
Duøng caùc PAL toå hôïp, caùch thieát keá töông töï nhö vôùi PLA nhöng phaûi chuù yù ruùt
goïn haøm ra
4.11. PLD tuần tự (sequential PLD = PLA(PAL)+các FF)
Phaàn lôùn caùc thieát keá soá caàn caùc FF, caùc PLD coù chöùa caùc FF nhö vaäy thöôøng
ñöôïc goïi laø PLD coù thanh ghi (registered PLD) hay PLD tuaàn töï.
Moät ñoaïn cuûa PAL tuaàn töï.
A A
B
B Q
Q
clock
EN
D Q
Q
Q
Bộ đệm
ra đảo 3
t.thái
A
B
D-FF ñöôïc laùi töø moät coång OR. Ngoõ ra FF ñöôïc ñöa hoài tieáp veà daõy AND laäp
trình ñöôïc qua moät boä ñeäm. Nhö vaäy caùc ngoõ vaøo coång AND coù theå ñöôïc noái
vaøo A, A ,…,Q hay Q . Caùc phöông trình traïng thaùi keá
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 132
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Q + = D = ABQ + A BQ
Ngoõ ra FF ñöôïc noái vaøo boä ñeäm ñaûo 3 traïng thaùi, cho pheùp khi EN=1
Ñaëc tính cuûa moät soá PAL tuaàn töï thoâng duïng. Moãi PAL chöùa 1 thanh ghi coù töø 4
ñeán 10 D-FF. 6 PAL ñaàu trong baûng töông töï vôùi 16R4 (coù 1 daõy coång AND vôùi
16 input vaø 4 D-FF)
Kieåu
16R4
16R6
16R8
20R4
20R6
20R8
20X4
20X8
20X10
Soá ngoõ vaøo
(tröïc tieáp+hoài tieáp + caùc IO)
8+4+4
8+6+2
8+8+0
12+4+4
12+6+2
12+8+0
10+4+6
10+8+2
10+10+0
Soá ngoõ ra
(FF + IO)
4+4
6+2
8+0
4+4
6+2
8+0
4+6
8+2
10+0
Soá caùc coång AND
treân coång OR
8
8
8
8
8
8
3/2*
3/2*
-/2
Ghi chuù: * 3 vôùi caùc ngoõ ra toå hôïp, 2 cho caùc ngoõ vaøo D FF
3 PAL cuoái trong baûng chæ caùc “XOR PAL”. XOR PAL coù moät coång XOR laùi
moãi ngoõ vaøo D FF nhö sau
clock
EN
D Q
Q
Q
Trong PAL naøy, moãi coång XOR ñöôïc laùi baèng hai coång OR, vaø moãi coång OR
ñöôïc laùi baèng 2 coång AND, caùc ngoõ ra FF coù theå ñöôïc hoài tieáp veà caùc coång AND
nhö trong caùc PAL coù thanh ghi khaùc.
Daïng toång quaùt cuûa phöông trình traïng thaùi keá cho moãi FF trong XOR PAL laø
Q + = D = (P1 + P2 ) ⊕ (P3 + P4 )
Vôùi P1 P2 P3 P4 laø caùc soá haïng tích
Ñeå minh hoïa vieäc söû duïng caùc XOR PAL, thieát keá moät boä ñeám nhò phaân 4 bit
(ñeám leân, ñeám xuoáng) vôùi 3 ngoõ vaøo ñieàu khieån U(up), D(down) vaø L (load).
Khi U=1 boä ñeám taêng theâm 1, khi D = 1 boä ñeám giaûm 1, vaø khi L =1, boä ñeám
naïp döõ lieäu song song töø caùc ngoõ vaøo döõ lieäu cuûa noù (DI)
Baûng caùc traïng thaùi keá cuûa boä ñeám cho U=1 vaø cho D=1, giaû söû raèng U=D=1
khoâng xaûy ra
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 133
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Q3
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
Q2
0
0
0
0
1
1
1
1
0
0
0
0
1
1
1
1
Q1
0
0
1
1
0
0
1
1
0
0
1
1
0
0
1
1
Chương 4
Q0
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
Q3
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
0
U=1
Q2
Q 1+
0
0
1
0
1
0
0
1
0
1
1
1
1
1
0
0
0
0
1
0
1
0
0
1
0
1
1
1
1
1
0
0
+
+
Q0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
+
Q3
1
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
+
D=1
Q2
Q 1+
1
1
0
0
0
0
1
0
1
0
0
1
0
1
1
1
1
1
0
0
0
0
1
0
1
0
0
1
0
1
1
1
+
Q 0+
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
Tröôùc heát, suy ra caùc phöông trình traïng thaùi keá cho boä ñeám leân.
Trong moïi haøng Q0 khaùc Q0+ vì vaäy FF Q0 phaûi thay ñoåi traïng thaùi ôû moïi xung
nhòp khi U=1 vì leõ ñoù
Q 0+ = Q 0 ⊕ U
Nhaän thaáy Q1 thay ñoåi (Q1 ≠ Q1+) chæ neáu Q0 =1. vì theá
Q1+ = Q1 ⊕ UQ0
Q2 thay ñoåi trong caùc haøng 3, 7, 11 vaø 15 chæ khi Q1 = Q0 = 1 vì theá
Q2+ = Q2 ⊕ UQ1Q0
Q3 thay ñoåi traïng thaùi chæ trong nhöõng haøng maø Q2 =Q1=Q0=1, vì theá
Q3+= Q3 ⊕ UQ2Q1Q0
Töông töï, baèng caùch quan saùt baûng, coù theå suy ra caùc phöông trình cho boä ñeám
xuoáng khi D=1
Q 0+ = Q 0 ⊕ D
Q 1+ = Q 1 ⊕ D Q 0
Q2+ = Q2 ⊕ D Q 0 .Q 1
Q3+ = Q3 ⊕ D Q 0 .Q 1 .Q 2
Toång quaùt ñeå söû duïng XOR PAL, phaûi bieåu dieãn traïng thaùi keá cuûa Qi ôû daïng
Qi+ = Qi ⊕ Fi
Caùc Fi ñöôïc tìm baèng phöông phaùp quan saùt hoaëc ruùt goïn baèng baûng Karnaugh
Tieáp tuïc thieát keá boä ñeám leân xuoáng vôùi ngoõ vaøo ñieàu khieån U, D, L.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 134
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Tröôùc heát xeùt tröôøng hôïp khi U=D=0. Khi L=1, boä ñeám ñöôïc naïp song song töø
caùc ngoõ vaøo döõ lieäu cuûa noù (DI), vaø khi L=0 traïng thaùi boä ñeám giöõ khoâng ñoåi.
Döïa vaøo tính chaát haøm Boolean
f(x1, x2,…, xn) = x1f(1, x2, …,xn) + x 1 f(0,x2,…,xn)
Nhö vaäy phöông trình traïng thaùi keá cho moãi FF laø
Qi+ = LDi +L’DI
Keát hôïp caùc phöông trình khi xeùt caû U, D, L. Giaû söû L=1 aûnh höôûng leân caû U=1
hay D=1 vaø U=D=1 khoâng bao giôø xaûy ra.
Neáu baét ñaàu baèng phöông trình
Q 0+ = Q 0 ⊕ U
thay Q0+ baèng LD0+L’Q0 vaø thay U baèng U+D, ñöôïc
Q0+ = (LD0+L’Q0)⊕ (U+D).
Phöông trình naøy cho keát quaû ñuùng khi L=0 vaø U hoaëc D laø 1. Ñeå ñaûm baûo L=1
aûnh höôûng öu tieân hôn ñeám leân ñeám xuoáng, ta phaûi nhaân U vaø D cho L’, caùc
phöông trình sau coøn laïi cuõng laøm töông töï, ta coù
Q0+ = (LD0+L’Q0) ⊕ (UL’+DL’)
Q1+ = (LD1+L’Q1) ⊕ (UL’Q0 + DL’Q’0)
Q2+ = (LD2+L’Q2) ⊕ (UL’Q0Q1 + DL’Q’0Q’1 )
Q3+ = (LD3+L’Q3) ⊕ (UL’Q0Q1Q2 + DL’Q’0Q’1Q’2)
Khi L=D=0, caùc phöông trình naøy ruùt goïn tröôøng hôïp chæ ñeám leân, vaø khi L=U=0
caùc phöông trình naøy ruùt goïn veà tröôøng hôïp ñeám xuoáng
Caùc daïng phöông trình toång hôïp ôû treân thích hôïp ñeå caøi ñaët baèng XOR PAL
4.12. Các PLD tuần tự khác
Khi coâng ngheä IC ñaõ ñöôïc caûi tieán, nhieàu loaïi PLD khaùc ra ñôøi, caùc PLD môùi
döïa treân nhöõng môû roäng cuûa khaùi nieäm PAL hoaëc döïa treân caùc daõy coång
22V10 laø 1 PLD raát linh hoaït maø coù theå duøng noù ñeå caøi ñaët caùc maïng toå hôïp vaø
tuaàn töï. 22V10 coù 12 chaân daønh rieâng cho ngoõ vaøo vaø 10 chaân coù theå laäp trình
hoaëc laøm ngoõ vaøo hoaëc ngoõ ra. Chöùa 10 D-FF, 10 coång OR, soá coång AND ñöa
vaøo moãi coång OR töø 8 ñeán 16. Moãi coång OR laùi moät logic macrocell, moãi
macrocell chöùa 1 D-FF, caùc FF coù cuøng clock, moät ngoõ vaøo reset baát ñoàng boä
chung (AR= Asynchronuos Reset) vaø moät ngoõ vaøo ñaët tröôùc ñoàng boä chung (SP=
synchronuos Preset)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 135
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Sô ñoà khoái cuûa 22V10
Chi tieát cuûa moät macrocell xuaát cuûa 22V10.
S1 S0
F0
VCC
VCC
S
F1
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 136
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Caùc keát noái ñeán caùc chaân ra coù theå ñieàu khieån ñöôïc baèng caùch laäp trình
macrocell naøy. Caùc ngoõ vaø ñieàu khieån MUX xuaát S1 S0 choïn moät trong caùc ngoõ
vaøo döõ lieäu.
Ví dụ,
S1S0 =10 choïn ngoõ vaøo döõ lieäu 2. Khi caàu chì F1 hôû (S1 =1), FF bò boû qua vaø ngoõ
ra töø coång OR. Ngoõ ra coång OR cuõng ñöôïc hoài tieáp veà ñeå coù theå duøng nhö moät
ngoõ vaøo cuûa daõy coång AND
Neáu F1 coøn nguyeân (S1=0), thì ngoõ ra FF ñöôïc noái vaøo chaân ngoõ ra vaø noù cuõng
ñöôïc hoài tieáp veà ñeå coù theå duøng noù laøm ngoõ vaøo coång AND. Khi caàu chì Fo hôû
(S0=1), ngoõ ra khoâng bò ñaûo ñeå noù taùc ñoäng möùc cao.
Khi F0 coøn nguyeân (S0=0), ngoõ ra bò ñaûo neân noù taùc ñoäng möùc thaáp. Chaân ngoõ ra
ñöôïc laùi baèng boä ñeäm ñaûo 3 traïng thaùi. Khi ngoõ ra boä ñeäm ôû traïng thaùi toång trôû
cao, coång OR vaø FF khoâng noái vôùi chaân ngoõ ra (xuaát) vaø chaân naøy coù theå duøng
laøm ngoõ vaøo
Ví dụ, Duøng 22V10 thieát keá boä ñieàu khieån ñeøn giao thoâng cho giao loä cuûa
ñöôøng A vaø ñöôøng B. Moãi ñöôøng coù caùc caûm bieán ñeå phaùt hieän söï xuaát hieän xe
coä ñeán gaàn hoaëc döøng ôû giao loä.
Sa = 1 nghóa laø xe ñang tieán ñeán ñöôøng A
Sb = 1 nghóa laø xe ñang tieán ñeán ñöôøng B
A laø ñöôøng chính vaø seõ coù ñeøn xanh cho ñeán khi coù moät xe chaïy ñeán B, roài ñeøn
thay ñoåi vaø B coù ñeøn xanh. Vöøa heát 50giaây caùc ñeøn seõ thay ñoåi veà nhö cuõ tröø khi
coù moät xe treân ñöôøng B vaø khoâng coù xe ôû A, tröôøng hôïp naøy chu kyø B ñöôïc môû
roäng theâm 10s. Khi A xanh noù giöõ xanh toái thieåu 60 giaây vaø roài caùc ñeøn thay ñoåi
chæ khi xe tieán ñeán B. Caùc noái keát beân ngoaøi cuûa boä ñieàu khieån
Clock
Sa Sb
PAL 22V10
Ga Ya Ra
Gb Yb Rb
Giaûn ñoà traïng thaùi cho boä ñieàu khieån. Cho muïc ñích ñònh thì, maïng tuaàn töï ñöôïc
laùi baèng 1 clock coù chu kyø 10giaây. Nhö vaäy söï thay ñoåi traïng thaùi coù theå xaûy ra
haàu nhö ôû 10giaây. Ñeå ñôn giaûn hoùa giaûn ñoà. Ta duøng kyù hieäu sau: GaRb trong
moät traïng thaùi coù nghóa laø Ga=Rb=1 vaø taát caû caùc bieán ra khaùc laø 0, Sa’Sb ôû
cuøng moät cung nghóa laø Sa=0 vaø Sb=1 seõ gaây ra chuyeån traïng thaùi theo cung ñoù.
Moät cung khoâng coù nhaõn haøm yù raèng chuyeån traïng thaùi seõ xaûy ra khi coù clock
xaûy ra, ñoäc laäp vôùi caùc bieán vaøo. Nhö vaäy ñeøn A xanh seõ saùng trong 6 chu kyø
clock vaø ñoåi traïng thaùi sang vaøng neáu coù 1 xe ñang ñôïi ôû ñöôøng B
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 137
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
S0
Chương 4
GaRb
10s
S2
10s
S1
10s
GaRb
GaRb
GaRb
10s
S3
S4
10s
GaRb
S5
Sb’
GaRb
Sb
S6
YaRb
S6
YaRb
(Sa+Sb’)
S11
S10
S9
S8
S7
RaGb
RaGb
RaGb
RaGb
RaGb
Ga
1
1
1
1
1
1
0
0
0
0
0
0
0
Bieán ra
Ra Gb
0
0
0
0
0
0
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
1
1
1
0
Sa’Sb
Baûng traïng thaùi cuûa boä ñieàu khieån.
SaSb
00
S1
S2
S3
S4
S5
S5
S7
S8
S9
S10
S11
S12
S0
S0
S1
S2
S3
S4
S5
S6
S7
S8
S9
S10
S11
S12
01
S1
S2
S3
S4
S5
S6
S7
S8
S9
S10
S11
S11
S0
10
S1
S2
S3
S4
S5
S5
S7
S8
S9
S10
S11
S12
S0
11
S1
S2
S3
S4
S5
S6
S7
S8
S9
S10
S11
S12
S0
Ya
0
0
0
0
0
0
1
0
0
0
0
0
0
Yb
0
0
0
0
0
0
0
0
0
0
0
0
1
Rb
1
1
1
1
1
1
1
0
0
0
0
0
0
Caøi ñaët baûng treân duøng 4 D-FF vôùi caùc ngoõ vaøo D1, D2, D3 , D4 vaø caùc ngoõ ra Q1,
Q2, Q3, Q4. Baèng pheùp gaùn traïng thaùi nhò phaân tröïc tieáp, suy ra caùc phöông trình
D1=Q1Q2’+Q2Q3Q4
D2=Q1’ Q2’Q3Q4 + SaQ1Q3Q4 + Sb’Q1Q3Q4’ + Q1’Q2Q4 + Q1’Q2Q3’
D3= Q3Q4’ + SbQ3’ Q4 + Sa’Q3’ Q4 + Q2’Q3’ Q4 + Sa’SbQ1Q4
D4= Sa’SbQ1Q3 + Q2’ Q4’ + Q1’ Q4’ + SaSb’Q2Q3’ Q4
13 traïng thaùi coù 4 bit maõ hoùa traïng thaùi Q3Q2Q1Q0
Ga = Q1’Q3’ + Q1’Q2’
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Ya = Q2Q3Q4’
Ra= Q1 + Q2Q3Q4
Trang 138
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Gb = Q1Q2’ + Q2Q3Q4
Yb = Q1Q2
Rb=Q1’Q2’+Q1’Q4’+Q1'Q3’
Vì taát caû phöông trình naøy coù ít hôn 8 soá haïng AND, 22V10 laø phuø hôïp. Neáu 1
soá phöông trình coù quaù nhieàu soá haïng khoâng khôùp cho 22V10 thì seõ caàn thöû caùc
pheùp gaùn traïng thaùi khaùc
Neáu caøi ñaët boä ñieàu khieån duøng JK FF vaø caùc coång, 4FF vaø 34 coång seõ caàn
cho gaùn traïng thaùi nhò phaân tröïc tieáp.
Q3Q2Q1Q0 = traïng thaùi
6 bieán vaøo SaSb Q3Q2Q1Q0
Theo tính chaát haøm Boolean:
f(x1, x2, x3, …, xn) = x 1 .x 2 f(0,0, x3, …,xn) + x 1 x2f(0,1,x3,…,xn) +
x1 x 2 f(1,0,x3,…,xn)+ x1x2 f(1,1,x3,…,xn)
=> Ga = Sa’Sb’F00 + Sa’SbF01 + SaSb’F10 + SaSbF11
Caùc FF vaø caùc coång naøy caàn khoaûng 11 IC loaïi SSI, so vôùi giaûi phaùp 22V10 thì
tieát kieäm naêng löôïng vaø tin caäy hôn
4.13. Dãy cổng lập trình được (PGA)
Caùc PLD coù khaû naêng duøng ñeå caøi ñaët moät heä tuaàn töï nhöng khoâng phaûi laø moät
heä thoáng soá ñaày ñuû. Caùc PGA (programmable gate Array) linh ñoäng hôn vaø coù
theå ñöôïc söû duïng ñeå caøi ñaët moät heä thoáng soá nhoû treân moät chip IC.
Moät PGA tieâu bieåu laø moät IC chöùa moät daõy caùc logic cell ñoàng daïng vôùi caùc lieân
keát noái laäp trình ñöôïc. Ngöôøi söû duïng coù theå laäp tình caùc haøm ñöôïc caøi ñaët baèng
moãi logic cell vaø caùc keát noái giöõa caùc cell
Configurable logic block
khoái IO
Vuøng lieân keát noái
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 139
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Ví duï, Hình treân laø moät phaàn cuûa caáu truùc Xilinx XC2064 LCA (logic cell array)
goàm moät daõy noäi 64 khoái logic coù theå ñaët caáu hình ñöôïc CLB (configurable logic
block), xung quanh laø moät voøng 58 khoái giaoo tieáp nhaäp xuaát. Caùc lieân keát giöõa
caùc khoái naøy coù theå laäp trình ñöôïc baèng caùch chöùa döû lieäu trong caùc oâ nhôù RAM
noäi. Moãi CLB chöùa moät logic toå hôïp vaø 1 D-FF vaø coù theå laäp trình ñöôïc ñeå thöïc
hieän nhieàu haøm logic
Caáu truùc cuûa moät CLB
*
*
preset A
J B
G
Khối
logic tổ
hợp
KC
clear D
*
F
D
*
*
Y(Q)
S
CK
Q
R
*
clock
A
B
C
F
A
Hàm 4
biến bất
kỳ
B
C
D
Hàm 3
biến bất
kỳ
F
Hàm 3
biến bất
kỳ
G
D
Q
G
A
B
Q
C
Lựa chọn một hàm 4 biến
D
Q
Lựa chọn hai hàm 3 biến
Caùc khoái hình thang trong sô ñoà bieåu dieãn caùc boä doàn keânh (MUX) coù theå laäp
trình ñöôïc ñeå choïn moät trong caùc ngoõ vaøo. Ví duï: ngoõ vaøo thaáp nhaát ôû khoái logic
toå hôïp coù theå ñeán töø D hay Q vaø ngoõ ra Q coù theå ñeán töø F, G hay Q. Khoái logic
toå hôïp chöùa caùc teá baøo nhôù RAM vaø coù theå ñöôïc laäp trình ñeå caøi ñaët moät haøm 4
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 140
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
bieán baát kyø hoaëc 2 haøm 3 bieán baát kyø (hình 1-29. Ví duï coù theå ñaët F=G=f1(A, B,
C, Q) hay F=f2 (A, B,…) vaø G =f3(B, C, Q). Caùc ñöôøng ñöùt neùt chæ caùc keát noái caàn
ñeå ñaët caáu hình logic cell laø moät JK-FF vôùi caùc ngoõ vaøo “preset” vaø “ clear”.
Logic toå hôïp coù caùc ngoõ vaøo J,K vaø Q vaø caøi ñaët traïng thaùi keá cho FF, F=Q+ =
JQ’ + K’Q. Ngoaøi ra caøi ñaët G=Q’ ñeå cung caáp moät ngoõ ra buø cho FF. Caùc tín
hieäu Preset vaø Clear ñöôïc daãn tröïc tieáp tôùi S (asynchronuos set) vaø R
(asynchronuos reset) cuûa D-FF
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 141
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
Bài tập chương 4
4.1. Giả sử ban đầu Q = 0, đưa X, Y đến ngõ vào SET, RESET của 1 RS-FF dùng
NAND, xác định dạng sóng Q và Q
X
Y
Z
4.2. Giả sử ban đầu Q= 0, đảo dạng sóng ngõ vào X, Y ở bài 4.1, sử dụng RS-FF
dùng cổng NOR, xác định dạng sóng Q và Q .
4.3. Dạng sóng bài 4.1 được kết nối với mạch hình sau. Giả sử rằng ban đầu
Q=0, xác định dạng sóng Q.
X
Z
S
Q
R
Q
Y
4.4. Một clocked FF cụ thể có tS = 20ns và tH = 5ns. Mất bao lâu để các ngõ vào
điều khiển ổn định trước khi xảy ra sự chuyển đổi xung CK. .
4.5. Một Toggle FF là 1 FF có 1 ngõ vào đơn và hoạt động sao cho trạng thái ngõ
ra thay đổi mỗi khi có xung đưa đến ngõ vào. clocked SR-FF có thể được nối
để hoạt động trong chế độ này (hình) . Dạng sóng đưa đến ngõ vào CLK là
sóng vuông 1KH. Xác định dạng sóng ngõ ra Q, giả sử ban đầu Q = 0
1 KHz
S
Q
CLK
R
Q
4.6.a. Hãy trình bày làm thế nào để J-K FF có thể hoạt động như 1 toggle FF.
Đưa sóng vuông 10kHz đến ngõ vào và xác định dạng sóng ngõ ra.
b.Nối ngõ ra Q của FF phần a đến ngõ vào J-K FF thứ 2 (J2=K2=1). Xác định
tần số dạng sóng tại ngõ ra Q của FF thứ 2.
4.7. Xung CK được đưa đến 2 FF khác nhau: (a) J-K FF kích bằng cạnh lên; (b) JK FF kích bằng cạnh xuống. Hãy vẽ dạng sóng ngõ ra Q cho mỗi FF trên, giả
sử ban đầu Q = 0.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 142
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
1
2
Chương 4
3
4
5
6
7
8
9
10
11
Clock
J input
K input
4.8. Một D-FF được dùng để làm mạch tạo trễ sao cho thông tin xuất hiện ở ngõ
ra trễ một thời gian sau khi nó xuất hiện tại ngõ vào D.
a/ Xác định dạng sóng Q ở hình sau và so sánh với dạng sóng ngõ vào.
Data
Input
D
CK
Q
Q
Data
Input
1
0
Ck
1
0
b/ Làm thế nào để có thể delay thời gian 2 clock?
4.9. Một D-FF được nối như hình sau. Giả sử ban đầu Q = 0 , xác định dạng sóng
Q.
1KHz
D
CK
Q
Q
4.10. Xác định dạng sóng Q cho FF ở hình sau. Giả sử ban đầu Q = 0
1
CK 0
1
J
CK
CLR 1
0
1
Pr 1
0
K
Pr
Q
Q
CLR
4.11. Ban đầu ngõ vào A, B, C trong mạch điện đều ở mức LOW. Giả sử ngõ ra Y
ở mức HIGH chỉ khi A, B, C ở mức HIGH trong 1 trình tự nhất định.
a/ Xác định trình tự làm Y ở mức HIGH
b/ Giải thích tại sao xung START là cần thiết.
c/ biến đổi mạch này để dùng D-FF.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 143
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
A
J
J
X
B
CLK
C
K Clear
CLK
Y
K Clear
Start
4.12. Hãy vẽ mạch logic để truyền song song dữ liệu đồng bộ từ 1 thanh ghi 3 bit
sang thanh ghi khác dùng FF J- K.
4.13. làm lại bài 4.12 khi truyền song song bất đồng bộ.
4.14. Thiết kế mạch đếm lên MOD 6 dùng T-FF có xung tác động cạnh lên, Pr va`
CLR tích cực mức cao
4.15. Thiết kế mạch đếm lên MOD 10 dùng D-FF có xung tác động cạnh lên, Pr
va` CLR tích cực mức cao
4.16. Thực hiện mạch đếm MOD 60 từ bài 4.14 và 4.15
4.17. Hãy vẽ lưu đồ chuyển đổi trạng thái của mạch đếm xuống MOD 6 dùng xung
CK tác động cạnh lên và so sánh với sơ đồ đếm xuống dùng xung CK tác động
cạnh xuống. Chúng khác nhau như thế nào?
4.18. a/ Để xây dựng 1 mạch đếm nhị phân đếm từ 0 đến 1023 thì phải sử dụng
bao nhiêu FF?
b/ xác định tần số tại ngõ ra của FF cuối cùng của mạch đếm này khi tần số
xung clock ngõ vào là 2 Mhz.
c/ Số MOD của mạch đếm là bao nhiêu?.
d/ Nếu ban đầu mạch đếm đếm là 0 thì sau 2060 xung số đếm được là bao
nhiêu?.
4.19. Một mạch đếm có tín hiệu clock là 256 KHz , tần số ngõ ra FF cuối cùng là
2KHz
a/ Hãy xác định số MOD.
b/ Hãy xác định phạm vi đếm.
4.20. 1 mạch tách sóng quang được sử dụng để tạo 1 xung mỗi khi có 1 khách
hàng đi vào. Các xung này được đưa đến bộ đếm 8 bit. Bộ đếm này dùng để đếm
số lượng khách hàng đi vào trong cửa hàng. Sau khi cửa hàng đóng cửa, người
chủ cửa hàng kiểm tra mạch đếm và thấy rằng nó chỉ một số đếm là 000010012 =
910. Anh ta biết rằng điều này không đúng vì có nhiều hơn 9 người trong cửa
hàng của ông ta. Giả sử mạch đếm dang làm việc đúng. Lý do nào cho sự trái
ngược này?.
4.21. Hãy vẽ lưu đồ chuyển đổi trạng thái của mạch đếm MOD 16.
4.22. Hãy xác định dạng sóng tại Q1, Q2, Q3 .
1
Q1
0
T
tp=10ms
OS
T
Q1
tp=5ms
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Q2
OS
Q3
T
OS
Q3
Q2
tp=20ms
tp=10ms
Trang 144
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 4
4.23. Xét mạch sau
`
1
J
C
1
C
1
J
CLK
1
K
B
J
CLK
K
A
CLK
B
A
K
1Hz
X
Y
Z
D
B
X
CLK
W
C
D
CLK
X
PRE
PRE
Y
Y
Start pule
1
0
Ban đầu tất cả các FF trong trạng thái 1. Hoạt động của mạch bắt đầu với
xung Start tức thì được đưa đến các ngõ vào PRE của FF X và Y. Hãy xác
định dạng sóng tại A,B,C,X,Y,Z và W trong 20 chu kỳ xung đồng hồ.
4.24. Mạch điện sau có thể sử dụng để phát 2 tín hiệu clock không trùng khớp tại
cùng 1 tần số. Các tín hiệu clock này được sử dụng trong vài hệ thống vi
xử lý đòi hỏi 4 sự chuyển đổi clock khác nhau để đồng bộ các hoạt động
của chúng. Vẽ dạng sóng tại CP1 và CP2 khi tần số clock ngõ vào là 1Mhz.
+5V
J
Clock
Q
CP1
CLK
K
Q
CP2
4.25. Moät maïch ñoàng boä coù voøng ñeám sau:
000
111
010
101
011
a). Thieát keá boä ñeám treân duøng JK FF coù xung taùc ñoäng caïnh xuoáng.
b). Giaû söû traïng thaùi hieän taïi cuûa maïch laø 001 tìm traïng thaùi keá cuûa maïch caâu a.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 145
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 5
CHƯƠNG 5
CÁC HỌ VI MẠCH SỐ
5.1. TỔNG QUAN
Xét về cơ bản có 2 lọai thiết bị bán dẫn là lưỡng cực và đơn cực. Dựa trên các thiết bị
này, các mạch tích hợp được hình thành.
Các họ mạch logic lưỡng cực
Các yếu tố chính của IC lưỡng cực là điện trở, diode và BJT, hai họat động trong IC
lưỡng cực là: tắt và bão hòa, các họ logic lưỡng cực:
•
Mạch logic RTL
•
Mạch logic DCTL
•
Mạch logic HTL
•
Mạch logic TTL
•
Mạch logic Schottky TTL
•
Mạch logic ECL
Các họ mạch logic đơn cực
Các thiết bị MOS là các thiết bị đơn cực và chỉ có các MOSFET được vận hành trong
các mạch logic MOS, các mạch logic MOS là
•
PMOS
•
NMOS
•
CMOS
5.2. CÁC ĐẶC TRƯNG CỦA CÁC VI MẠCH SỐ
Phân lọai các IC số
Lọai IC
Các cổng căn bản
Số các linh kiện
Tổ hợp quy mô nhỏ SSI
Nhỏ hơn 12
Lên đến 99
Tổ hợp quy mô trung bình MSI
12-99
100-999
Tổ hợp quy mô lớn LSI
100-999
1000-9999
Tổ hợp quy mô rất lớn VLSI
Lớn hơn 1000
Lớn hơn 10000
Các đặc trưng
•
Tốc độ họat động, lệ thuộc vào thời gian trễ truyền đạt
tpHL
tpLH
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 146
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 5
•
Tổn hao công suất, xác định bởi tích số nguồn cung cấp Vcc và dòng Icc (giá trị
trung bình của dòng Icc mức 0 và mức 1), đơn vị mW
•
Chỉ số giá trị, xác định bởi tích số tốc độ và công suất
•
Chỉ số giá trị (pJ)= thời gian trì hõan truyền đạt (ns)x công suất (mW)
•
Chỉ số giá trị càng nhỏ càng tốt
•
Hệ số tải, là số cổng có thể được vận hành bởi một cổng, hệ số tải càng cao
càng thuận lợi
•
Các tham số dòng và áp
o Điện áp đầu vào ở mức cao VIH (điện áp tối thiểu mà cổng có thể nhận biết
mức 1)
o Điện áp đầu vào ở mức thấp VIL (điện áp tối đa mà cổng có thể nhận biết
mức 0)
o Điện áp đầu ra ở mức cao VOH(điện áp tối thiểu tại đầu ra tương ứng mức 1)
o Điện áp đầu ra ở mức thấp VOL (điện áp tối đa tại đầu ra tương ứng mức 0)
o Cường độ dòng điện đầu vào mức cao IIH (dòng tối thiểu được cung cấp
tương ứng với mức 1)
o Cường độ dòng điện đầu vào mức thấp IIL (dòng tối đa được cung cấp tương
ứng với mức 0)
o Cường độ dòng điện đầu ra mức cao IOH (dòng cực đại mà ngõ ra cung cấp
tương ứng với mức 1)
o Cường độ dòng điện đầu ra mức thấp IOH (dòng cực tiểu mà ngõ ra cung cấp
tương ứng với mức 0)
•
Nhiễu
Điện áp
VOH
VIH
Lề nhiễu ở trạng thái 1
VIL
VOH
Lề nhiễu ở trạng thái 0
0
•
Miền nhiệt độ họat động, từ 0-700C cho các ứng dụng tiêu dùng và công
nghiệp, từ 550C – 1250C cho các mục đích quân sự
•
Yêu cầu về nguồn
•
Tính đa dạng, khả năng tích hợp, giá thành, chế tạo, dễ phối hợp với vi mạch
công nghệ khác
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 147
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 5
5.3. HỌ RTL (RESISTOR-TRANSISTOR LOGIC)
Bao gồm các điện trở và transistor, đây là họ logic được tích hợp sớm nhất
Ví dụ, một cổng NOR RTL
Vcc
Rc
Y
Rb1
Q1
Q2
A
Rb2
B
Các mạch RTL có đặc tính chung là cần dòng IB cho các BJT nên còn được gọi là
mạch thu dòng (current sinking), vì vậy khi kết nối với các mạch khác cần phải lưu ý
để thỏa mãn điều kiện này, nếu không mạch sẽ không làm việc
Lề nhiễu ở trạng thái 0 là 0.5-0.2=0.3V
Lề nhiễu ở trạng thái 1 phụ thuộc vào tải
5.4. HỌ DTL (DIODE-TRANSISTOR LOGIC)
Bao gồm diode ở ngõ vào và transistor ở ngõ ra
Ví dụ, cổng NAND DTL
Vcc
R1
DA
A
Rc
D1
Y
D2
Q
B
DB
AND
Rb
NOT
Ngõ ra Y kéo lên nguồn Vcc được gọi là ngõ ra kéo lên thụ động (Passive pull up)
5.5. HỌ TTL (TRANSISTOR-TRANSISTOR LOGIC)
Loại DTL sớm được thay thế bởi mạch TTL tức Transistor ở ngõ vào và Transistor ở
ngõ ra
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 148
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 5
Ví dụ, cổng NAND TTL
Vcc
R1
R2
Rc
R1
Q1
Q3
Q2
A
A
B
Q2
DA
B
Y
Q1
Q4
R3
Lưu ý: khi các ngõ vào A,B để hở (thả nổi ngõ vào) thì không có dòng chảy ra ở A, B
nên ngõ vào để hở giống như nối lên cao (logic 1)
Đầu ra TTL hoạt động như bộ thu nhận dòng ở trạng thái thấp (Q4) và cung cấp dòng
ở trạng thái cao (Q3)
Ngõ ra Y kéo lên Transistor nên được gọi là ngõ ra kéo lên tích cực (Active pull up)
hay còn gọi là ngõ ra cột chạm (Totel pole). Với Q3 sẽ không có dòng nào truyền qua
Rc khi ngõ ra ở mức thấp nên sẽ giảm bớt dòng tiêu hao trong mạch. Trong khi kiểu
kéo lên thụ động sẽ làm cho Q4 dẫn một dòng khá lớn khi ngõ ra ở mức thấp
Ưu điểm thứ hai của cấu hình Totem pole là khi Y ở trạng thái cao, Q3 có trở kháng
đầu ra thấp nên rất thuận tiện nếu tải có tính dung C
Nhược điểm của cấu hình totem pole thể hiện trong giải đoạn chuyển tiếp từ thấp lên
cao. Vì Q4 tắt chậm nên khi Q4 chưa tắt mà Q3 đã dẫn, thời gian này (vài ns) cả 2
transostor đều dẫn điện nên hút một dòng tương đối lớn.
5.6. CÁC ĐẶC ĐIỂM CỦA HỌ TTL CHUẨN
Loạt IC TTL chuẩn đầu tiên gọi là seri 54/74, tùy theo hãng chế tạo sẽ có thêm các
tiền tố. VD, Texas Instruments có tiền tố SN, National Semiconductor dùng DM,
Signetic là S
Ví dụ, cổng NOR sẽ có các mã số khác nhau DM7402, SN7402…
Khoảng nhiệt độ và điện thế nguồn
Seri 74 vận hành trong khoảng điện thế 4.75 đến 5.25 và nhiệt độ 00C đến 700C
Seri 54 chấp nhận điện thế nguồn trong khoảng 4.5 đến 5.5 và nhiệt độ -550C đến
1250C
Mức điện thế của seri 74
Tối đa
VOL
VOH
2.4
VIL
2.0
VIH
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Chuẩn
0.2
3.4
Tối thiểu
0.4
0.8
Trang 149
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 5
Công suất tiêu hao bình quân một cổng khoảng 10mW
Thời gian trễ tiêu biểu tpLH=11ns và tpHL=7ns, trung bình 9ns
Đầu ra TTL chuẩn có thể kích thích 10 đầu vào TTL chuẩn
5.7. HỌ TTL CẢI TIẾN
Định mức hiệu suất
Trễ do truyền (ns)
Công suất (Mw)
Chỉ số giá trị (pJ)
Hệ số tải
Các thông số điện thế
VOH(min)
VOL(min)
VIH(min)
VIL(min)
Các định mức dòng ngõ ra
IOH (mA)
IOL (mA)
Các định mức dòng ngõ vào
IIH ( μA )
IIL (mA)
74
74S
74LS 74AS 74ALS
74F
9
10
90
10
3
20
60
20
9.5
2
19
20
1.7
8
13.6
40
4
1.2
4.8
20
3
6
18
33
2.4
0.4
2.0
0.8
2.7
0.5
2.0
0.8
2.7
0.5
2.0
0.8
2.5
0.5
2.0
0.8
2.5
0.4
2.0
0.8
2.5
0.5
2.0
0.8
-0.4
16
-1
20
-0.4
8
-2
20
-0.4
8
-1
20
40
-1.6
50
-2
20
-0.4
20
-0.5
20
-0.1
20
-0.6
Ví dụ, Xác định giới hạn nhiễu DC cho một IC 74LS so sánh với IC 74
Ví dụ, Một đầu ra 74ALS kích thích 3 đầu vào 74S và một đầu vào 74 được không
5.8. TTL VỚI NGÕ RA CỰC THU HỞ (OPEN COLLECTOR OUTPUT)
Sơ đồ điển hình của NAND cực thu hở
VCC
R1
R2
Y
A
B
A
B
R3
Lưu ý: Mạch có cực thu để hở có thể được sử dụng như mạch Logic thông thường
bằng cách mắc thêm R thích hợp với tình trạng của tải.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 150
https://fb.com/tailieudientucntt
X
Bài Giảng Kỹ Thuật Số
Chương 5
5.9. HỌ TTL BA TRẠNG THÁI (TRISTATE)
Ngoài 2 trạng thái cơ bản 1 và 0, các mạch logic còn có thêm trạng thái tổng trở cao
Hi-Z
Ví dụ xét cổng NOT 3 trạng thái sau
A
X
A
Cho phép (E)
X= A
X
A
E=1
E=0
5.10. MẠCH LOGIC MOS
Chuyển mạch MOSFET cơ bản
+5V
D
G
VGS=0
G
S
D
VGS=5V
G
D
S
S
Mạch số dùng MOSFET được phân thành 3 nhóm: P-MOS, N-MOS và CMOS
Đặc điểm của logic MOS
o So với họ lưỡng cực thì N-MOS và P-MOS có tốc độ hoạt động chậm hơn, tiêu
hao năng lượng ít hơn, giới hạn nhiễu hẹp hơn, khoảng điện thế nguồn nuôi lớn
hơn, hệ số tải lớn hơn và đòi hỏi ít chỗ trên chip hơn
o Mức logic dành cho mạch MOS là
V(0) ≈ 0V
V(1) ≈ VDD
5.11. HỌ CMOS
Công nghệ CMOS tung ra các sản phẩm có đặc điểm hiệu suất ngày càng tốt hơn,
cung cấp không chỉ tất cả chức năng logic có ở TTL, mà còn nhiều chức năng đặc biệt
không có ở TTL
CMOS
Thông số 4000B 74HC 74HCT 74AC 74ACT 74AHC 74AHCT
VIH(min)
3.5
3.5
2.0
3.5
2.0
3.85
2.0
VIL(max)
1.5
1.0
0.8
1.5
0.8
1.65
0.8
VOH(min)
4.95
4.9
4.9
4.9
4.9
4.4
3.15
VOL(max)
0.05
0.1
0.1
0.1
0.1
0.44
0.1
VNH
1.45
1.4
2.9
1.4
2.9
0.55
1.15
VNL
1.45
0.9
0.7
1.4
0.7
1.21
0.7
Lưu ý: không bao giờ được phép thả nổi các đầu vào CMOS không dùng đến, tất cả
đầu vào CMOS phải được nối hoặc với mức điện thế cố định (0 hoặc VDD) hoặc với
đầu vào khác (Lý do đầu vào CMOS thả nổi rất nhạy với tạp âm nhiễu và tĩnh điện
vốn có thể dễ dàng phân cực MOSFET ở trạng thái dẫn điện)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 151
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 5
5.12. MỘT SỐ CỔNG
Tất cả các cổng đều thuộc loại tích hợp SSI
Cổng
NOT
NOT
NOT
NAND 2 ngõ vào
NAND 2 ngõ vào
NAND 2 ngõ vào
NAND 3 ngõ vào
NAND 3 ngõ vào
NAND 4 ngõ vào
NAND 4 ngõ vào
NAND 8 ngõ vào
NAND 13 ngõ vào
OR 2 ngõ vào
NOR 2 ngõ vào
NOR 3 ngõ vào
NOR 4 ngõ vào
AND 2 ngõ vào
AND 2 ngõ vào
AND 3 ngõ vào
AND 3 ngõ vào
XOR
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Ký hiệu
7404
7405
7414
7400
7401
74132
7410
7412
7420
7422
7430
74133
7432
7402
7427
7425
7408
7409
7411
7415
7486
Loại ngõ ra
Active Pull up
Open collector
Schmitt trigger
Active Pull up
Open collector
Schmitt trigger
Active Pull up
Open collector
Active Pull up
Open collector
Active Pull up
Active Pull up
Active Pull up
Active Pull up
Active Pull up
Active Pull up
Active Pull up
Open collector
Active Pull up
Open collector
Trang 152
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
CHƯƠNG 6.
GIAO TIẾP TƯƠNG TỰ - SỐ
6.1.
BIẾN ĐỔI ADC
6.2.1. Khái niệm
Boä bieán ñoåi töông töï sang soá (ADC) ñoùng vai troø quan troïng trong heä thoáng xöû lí
thoâng tin khi maø caùc luoàng tín hieäu ñöa vaøo heä vi xöû lí laø tín hieäu daïng töông töï .
Caùc boä chuyeån ñoåi thöïc hieän hai chöùc naêng cô baûn laø löôïng töû hoùa vaø maõ hoùa.
Löôïng töû hoùa laø gaùn nhöõng giaù trò cuûa moät tín hieäu töông töï vaøo vuøng caùc giaù trò
rôøi raïc sinh ra trong quaù trình maõ hoùa. Ñoái vôùi ADC ta cuõng duøng caùc loaïi maõ soá
nhö nhò phaân, BCD, buø moät, buø hai.
Quaù trình laáy maãu (Sampling).
Böôùc ñaàu tieân trong chuyeån ñoåi töông töï – soá laø rôøi raïc hoaù theo thôøi gian tín
hieäu ñaàu vaøo ban ñaàu. Vieäc laáy maãu nhö vaäy ñöôïc boä phaän laáy maãu vaø giöõ –
Sample & Hold Circuit (S&H) thöïc hieän.
Böôùc tieáp theo, boä chuyeån ñoåi töông töï – soá A/D chuyeån ñoåi caùc maãu nghieäm
lieân tuïc theo giaù trò vaø ñaõ ñöôc rôøi raïc hoaù theo thôøi gian ñoù thaønh tín hieäu löôïng
töû hoaù theo giaù trò vaø bieåu dieãn döôùi daïng soá nhò phaân.
Phaûi choïn taàn soá laáy maãu sao cho caùc trò lấy maãu coù theå ñaëc tröng cho tín hieäu
ban ñaàu maø khoâng bò toån thaát thoâng tin (fsample ≥ 2 fmax).
Maïch laáy maãu vaø döøng S&H.
Trong kyõ thuaät chuyeån ñoåi töông töï – soá, tín hieäu töông töï bieán thieân lieân tuïc
theo thôøi gian u(t) ñöôïc laáy maãu ôû nhöõng thôøi ñieåm nhaát ñònh, vaø giaù trò tín hieäu
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 153
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
nhaän ñöôïc seõ ñöôïc löu giöõ trong moät khoaûng thôøi gian ñònh tröôùc. Trong nhieàu boä
chuyeån ñoåi A/D, tín hieäu phaûi ñöôïc giöõ khoâng ñoåi trong suoát thôøi gian chuyeån
ñoåi. Ñeå thöïc hieän vieäc ñoù, duøng maïch Track-and-Hold – T&H.
Caáu truùc cô baûn cuûa maïch T&H
Sau moãi laàn môû chuyeån maïch, tuï ñieän naïp ñeán giaù trò ñieän aùp ñaàu vaøo u vao (t) vaø
löu giöõ giaù trò töùc thôøi cuûa ñieän aùp ñaàu vaøo tröôùc thôøi ñieåm môû chuyeån maïch. Caû
hai boä khuyeách ñaïi thuaät toaùn laøm boä ñeäm buffer cho ñaàu vaøo cuõng nhö ñaàu ra.
Moät khaû naêng khaùc thöïc hieän maïch T&H.
Moät transistor tröôøng FET (Isolated – Gate – FET) ñöôïc maéc giöõa KÑTT ñaûo pha
vaø KÑTT tích phaân. Khi usamp = 0, transistor FET seõ daãn vaø ñieän aùp ñaàu ra u ra
töông öùng ñieän aùp ñaàu vaøo aâm u vao , giaû thieát haèng soá thôøi gian tích phaân cuûa
KÑTT tích phaân (ñöôïc xaùc ñònh bôûi doøng ñieän ñaàu ra cöïc ñaïi cuûa KÑTT) laø ñuû
nhoû. Vaøo thôøi ñieåm t = t0 , transistor tröôøng khoaù, nhö vaäy vieäc naïp tuï (ñieän aùp tuï
ñieän) khoâng ñoåi vaø ñieän aùp ñaàu ra u ra ñöôïc giöõ laïi ôû möùc giaù trò u ra (t) = u ra
( t0 ), cho ñeán khi transistor tröôøng laïi ñöôïc ñieàu khieån môû maïch. Khi FET ñoùng,
caùc diode seõ daãn vaø nhôø ñoù maø traùnh ñöôïc hieän töôïng KÑTT bò quaù ñieàu khieån.
Chuyeån ñoåi song song (Flash Converter, giaûi ñieàu nhieàu laàn). Ñeå coù theå tieán
haønh chuyeån ñoåi cöïc nhanh, ngöôøi ta söû duïng caùc chuyeån ñoåi song song, coøn
ñöôïc goïi laø Flash Converter hay boä giaûi ñieàu nhieàu laàn. Trong kieåu chuyeån ñoåi
naøy, ñieän aùp caàn chuyeån ñoåi seõ ñöôïc ñoàng thôøi so saùnh caân baèng vôùi 2 N − 1
ñieän aùp quy chieáu
(
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 154
https://fb.com/tailieudientucntt
)
Bài Giảng Kỹ Thuật Số
Chương 6
Boä chuyeån ñoåi A/D 3 bit vôùi caùc boä so song song U LSB = U ref 2 N = U ref 8
Hình N3.4.15 – .
(
)
Phaàn chuû yeáu cuûa chuyeån ñoåi song song laø 2 N − 1 boä so saùnh, hoaït ñoäng chöùc
naêng maïch so saùnh vôùi ñieän aùp ra u ra = +U B töông öùng tín hieäu logic K=1, nhöng
neáu u ra = −U B thì töông öùng K=0 nhö sau.
.
Vieäc chuyeån ñoåi ñöôïc tieán haønh chæ moät böôùc, cho pheùp toác ñoä chuyeån ñoåi ñaït
möùc cao nhaát coù theå, nhöng giaù thaønh cao töông öùng, vì ñoàng thôøi phaûi duøng soá
löôïng lôùn caùc boä so saùnh 2 N − 1 . Tín hieäu cuûa moät trong baûy boä so cuûa chuyeån
ñoåi song song 3 bit ñöôïc giôùi thieäu trong baûng N3.4-3.
(
)
Xaáp xæ hoaù luõy tieán lieân tuïc (phöông phaùp caân, chuyeån ñoåi theo baäc). Phöông
phaùp naøy döïa treân cô sôû nguyeân lyù caân baèng. Trong sô ñoà boä chuyeån ñoåi, hoaït
ñoäng theo nguyeân lyù xaáp xæ hoaù luõy tieán, coøn goïi laø chuyeån ñoåi theo baäc, ngoaøi
modul ñieàu khieån quaù trình vaø thanh ghi coøn coù boä so saùnh vaø moät chuyeån ñoåi soá
– töông töï D/A
Trong caùc böôùc luõy tieán, boä so seõ thöû xem ñieän aùp caàn chuyeån ñoåi lôùn hôn hay
nhoû hôn ñieän aùp u(Z) do boä chuyeån ñoåi ngöôïc D/A taïo ra. Tieáp theo, bit baäc cao
nhaát (MSB) seõ ñöôïc ñaët ñònh, ñöôïc chuyeån ñoåi D/A bieán ñoåi ngöôïc trôû laïi thaønh
ñieän aùp töông töï u(Z) vaø so saùnh vôùi ñieän aùp ñaàu vaøo u vao . Tuøy theo giaù trò u(Z)
lôùn hay nhoû hôn u vao maø ñieän aùp quy chieáu seõ ñöôïc coäng vaøo hay tröø ñi töø giaù trò
ñoù, vaø theo ñoù maø soá nhò nguyeân töông öùng cuûa tín hieäu soá nhò phaân ñaàu ra seõ laø
0 hay 1. Trong moãi chu trình tieáp theo, seõ laøm tieáp chöõ soá nhò nguyeân cho baäc
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 155
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
döôùi vaø quaù trình so saùnh seõ ñöôïc laëp laïi. Ñoái vôùi moät chuyeån ñoåi N bit thì caàn N
böôùc so saùnh vaø chu trình laëp laïi tuaàn hoaøn.
Chuyeån ñoåi A/D 4 bit theo nguyeân lyù xaáp xæ hoaù luõy tieán.
Tín hieäu cuûa boä chuyeån ñoåi song song 3 bit.
Ñieän aùp vaøo
Tín hieäu so saùnh
K 7 K 6 K 5 K 4 K 3 K 2 K1
Maõ nhò phaân
Z 2 Z1Z 0
Ñieän aùp töông töï
u vao
0 ≤ u vao < 12 U LSB
0 0 0 0 0 0 0
0 0 0
0
1
2
U LSB ≤ u vao < 32 U LSB
0 0 0 0 0 0 1
0 0 1
U ref / 8
3
2
U LSB ≤ u vao < 52 U LSB
0 0 0 0 0 1 1
0 1 0
2 U ref / 8
5
2
U LSB ≤ u vao < 72 U LSB
0 0 0 0 1 1 1
0 1 1
3 U ref / 8
7
2
U LSB ≤ u vao < 92 U LSB
0 0 0 1 1 1 1
1 0 0
4 U ref / 8
9
2
U LSB ≤ u vao < 112 U LSB
0 0 1 1 1 1 1
1 0 1
5 U ref / 8
0 1 1 1 1 1 1
1 1 0
1 1 1
6 U ref / 8
11
2
U LSB ≤ u vao < 132 U LSB
13
2
U LSB ≤ u vao
1 1 1 1 1 1 1
7 U ref / 8
Boä rôøi raïc hoaù nhieàu taàng theo baäc (phöông phaùp phoái hôïp song song vaø caân
baèng).
Boä rôøi raïc hoaù nhieàu taàng giaûi quyeát thoaû hieäp giöõa toác ñoä chuyeån ñoåi vaø giaù
thaønh. Vì ñoái vôùi caùc chuyeån ñoåi thuaàn tuyù theo phöông phaùp song song (rôøi raïc
hoaù nhieàu taàng) thì caàn raát nhieàu boä so saùnh, ví duï: moät chuyeån ñoåi A/D 8 bit thì
caàn tôùi 255 boä so, ngöôøi ta phaân baäc boä rôøi raïc hoaù thaønh taàng. Vieäc ñoù cho pheùp
giaûm soá löôïng boä so saùnh, nhöng ñoàng thôøi toác ñoä chuyeån ñoåi chaäm hôn.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 156
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
Sô ñoà khoái chuyeån ñoåi 8 bit baèng hai chuyeån ñoåi song song 4 bit maéc theo baäc.
Chuyeån ñoåi A/D thöù nhaát nhaän vieäc löôïng töû hoaù thoâ, löôïng töû hoaù 4 bit baäc cao.
Keát quaû chuyeån ñoåi naøy seõ ñöôïc boä chuyeån ñoåi D/A bieán ñoåi ngöôïc thaønh ñieän
aùp töông töï vaø tröø ñi töø ñieän aùp ñaàu vaøo. Tín hieäu sai leäch (vi sai) seõ ñöôïc boä
chuyeån ñoåi A/D thöù hai löôïng töû hoaù (heä soá 16 laàn tinh hôn). Keát quaû chuyeån ñoåi
naøy cho 4 bit baäc thaáp hôn. Vieäc haïn cheá ñöôïc soá löôïng boä so saùnh(trong ví duï
tröôùc thì giaûm ñöôïc töø 255 xuoáng 30), laøm haï giaù thaønh chuyeån ñoåi noùi chung.
Chuyeån ñoåi theo phöông phaùp phaân taàng cascade. Theo phöông phaùp phaân taàng,
ngöôøi ta duøng moät boä chuyeån ñoåi song song N bit (Flash Converter) ñeå chuyeån
ñoåi 2N bit. ÔÛ ñaây caàn hai chu trình chuyeån ñoåi. So vôùi boä chuyeån ñoåi ôû treân thì ôû
ñaây tieát kieäm ñöôïc moät boä chuyeån ñoåi. Tín hieäu töông töï ôû ñaàu vaøo u vao trong
chu trình nhòp ñoàng boä ñaàu tieân ( S1 ñoùng, S 2 môû) ñöôïc bieán ñoåi bôûi boä chuyeån
ñoåi N bit. Keát quaû, cho N bit baäc cao nhaát, ñöôïc boä chuyeån ñoåi ngöôïc D/A bieán
ñoåi thaùnh giaù trò töông töï töông öùng, ñem tröø ñi ñieän aùp ñaàu vaøo u vao ban ñaàu.
Ñieän aùp vi sai ñöôïc khuyeách ñaïi leân 2 N laàn, vaø ñöôïc ñöa trôû laïi boä chuyeån ñoåi
song song N bit ( S1 môû, S 2 ñoùng). Ñem coäng keát quaû cuûa chuyeån ñoåi 1 vaø 2, roát
cuoäc ta coù keát quaû cuûa chuyeån ñoåi 2N bit “giaû laäp – pseudo”.
Chuyeån ñoåi A/D theo phöông phaùp phaân taàng cascade.
Chuyeån ñoåi theo phöông phaùp phaân taàng laëp laïi.
Trong chuyeån ñoåi phaân taàng laëp laïi (Recursive – Subranging – Analog – Digital –
Converter RSR-A/DC), seõ tieán haønh bieán ñoåi töông töï – soá moät töø maõ (n.N) bit
baèng chuyeån ñoåi song song N bit vôùi n böôùc tuaàn töï. Veà nguyeân lyù hoaït ñoäng, caùc
chuyeån ñoåi naøy döïa treân nguyeân lyù tieäm caän töøng böôùc, vôi khaùc bieät laø thay vì
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 157
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
söû duïng caùc boä so saùnh töông töï laøm chuyeån ñoåi 1 bit, ôû ñaây söû duïng boä chuyeån
ñoåi song song N bit. Noùi chung, cuõng caàn phaûi ñaûm baûo ñoä chính xaùc khueách ñaïi
ñoái vôùi toaøn thang ño (n.N) bit. Cuõng nhö trong phöông phaùp phaân taàng ñôn giaûn,
söû duïng moät boä chuyeån ñoåi soá – töông töï D/A ñeå bieán ñoåi ngöôïc giaù trò keát quaû
thaønh giaù trò töông töï töông öùng ñeå tröø ñi töø giaù trò ñaàu vaøo u vao . Nhö vaäy, caàn
duøng moät chuyeån ñoåi D/A (n.N) bit. So vôùi phöông phaùp tieäm caän töøng böôùc ñôn
thuaàn, coù söï caûi thieän do chuyeån ñoåi (n.N) bit maø chæ caàn n thay vì (n.N) chu trình
xaáp xæ hoaù. Gioáng nhö trong caùc phöông phaùp phaân taàng ñaõ neâu, cuõng duøng bit
thöù N ñeå hieäu chính sai soá, ñieàu ñoù caàn theâm moät chu trình nhòp phuï.
Boä chuyeån ñoåi A/DC 12 bit theo PP phaân taàng laëp laïi
a)- Sô ñoà nguyeân lyù; b)- Xaùc ñònh giaù trò soá baèng haïn cheá luõy tieán (k vaø i - soá töï nhieân).
Chuyeån ñoåi baäc Incremental (phöông phaùp ñeám). Trong chuyeån ñoåi A/D döïa
treân cô sôû phöông phaùp ñeám, ñieän aùp so caân baèng u(Z) ñöôïc moät boä chuyeån ñoåi
D/A taïo ra. Boä chuyeån ñoåi D/A ñoù ñöôïc moät boä ñeám thoâng thöôøng maéc phía ñaàu
vaøo ñieàu khieån.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 158
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
Chuyeån ñoåi A/D theo nguyeân lyù chuyeån ñoåi baäc Incremental.
Ngay khi u(Z) vöôït quaù ñieän aùp u vao caàn chuyeån ñoåi, thì vieäc chuyeån ñoåi bò
ngöng laïi. Töø traïng thaùi boä ñeám coù theå tröïc tieáp tính ra ñöôïc giaù trò soá cuûa ñieän
aùp ñöôïc chuyeån ñoåi. Öu ñieåm cuûa phöông phaùp naøy laø giaûm ñöôïc chi phí caáu taïo
thieát bò (chæ caàn moät boä so), trong khi coù nhöôïc ñieåm laø giaûm toác ñoä chuyeån ñoåi.
Soá chu trình caàn thieát trong chuyeån ñoåi phuï thuoäc vaøo ñoä lôùn cuûa ñieän aùp vaøo
u vao . Ñeå coù ñöôïc keát quaû giaù trò côõ N bit seõ caàn toái ña 2 N böôùc.
Chuyeån ñoåi baùm saùt (phöông phaùp ñeám). Ngöôïc vôùi chuyeån ñoåi baäc Incremental
neâu treân, chuyeån ñoåi baùm saùt ñeám tôùi – lui. Caáu taïo nguyeân lyù cuûa chuyeån ñoåi
baùm saùt (hình N3.4-22) veà cô baûn khaùc vôùi chuyeån ñoåi baäc Incremental laø thay vì
boä ñeám tôùi thuaàn tuùy, ôû ñaây söû duïng boä ñeám thuaän - nghòch phoái hôïp. Nhö vaäy,
tín hieäu ra cuûa D/AC luoân baùm saùt theo tín hieäu vaøo. Trong ñoù, söï bieán ñoäng tín
hieäu vaøo trong thôøi gian moät chu kyø nhòp ñoàng boä khoâng ñöôïc lôùn hôn giaù trò
U LSB . Khi bieán ñoäng tín hieäu nhanh thì thôøi gian ñeå ñaït tôùi söï caân baèng tieáp theo
coù theå laø raát laâu, tröôøng hôïp xaáu coù theå laâu tôùi côõ 2 N chu kyø nhòp ñoàng boä.
6.2.2. Một số loại IC ADC
•
ADC 0801/ ADC0802/ ADC0803/ ADC0804/ ADC0805 (IC CMOS 20 chaân),
ñaây laø caùc boä bieán ñoåi A/D 8 bit vôùi 1 keânh töông töï, söû duïng phöông phaùp lieân
tieáp xaáp xæ. Caùc boä bieán ñoåi naøy ñöôïc thieát keá ñeå coù theå giao tieáp vôùi caùc BUS
nhôø vaøo vieäc ñieàu khieån bus 3 traïng thaùi. Khi giao tieáp vôùi boä vi xöû lyù, chuùng seõ
ñoùng vai troø nhö nhöõng boä nhôù ñöôïc ñònh vò hay noùi caùch khaùc chuùng laø caùc port
I/O. Ñieän aùp tham chieáu chuaån ôû ñaàu vaøo coù theå ñöôïc ñieàu chænh cho pheùp maõ
hoùa caùc giaù trò ñieän aùp analog nhoû hôn traûi ñeàu ñoä phaân giaûi cuûa 8 bit.
•
Ñaëc ñieåm chung:
9
9
9
9
9
Deã daøng giao tieáp vôùi boä vi xöû lyù hoaëc hoaït ñoäng ñoäc laäp
Möùc logic ñaàu vaøo / ra töông thích vôùi caû 2 loaïi MOS vaø TTL
Boä phaùt xung nhòp cuøng naèm treân chip
Daûi tín hieäu analog loái vaøo 0 … 5V khi ñieän aùp nguoàn nuoâi laø 5V
Khoâng caàn hieäu chænh zero
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 159
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
9 Hoaït ñoäng toaøn vuøng 5V hay 2.5V tuøy theo giaù trò ñieän aùp tham chieáu
9 Doøng tieâu thuï : 1.9mA
ADC0804
+IN
-IN
VREF/2
CLKIN
CLKR
DB0
DB1
DB2
DB3
DB4
DB5
DB6
DB7
RD
WR
INTR
CS
VCC/VREF
GND AGND
9 Thôøi gian bieán ñoåi: 100μs
9 Coù taàng khueách ñaïi thuaät toaùn ôû chaân 9 ñeå coù phoái hôïp trôû khaùng
9 Ñieän trôû vaøo ôû chaân 9: 1.1kΩ
•
Ngoaøi ra coøn coù caùc IC: ADC 0808/ ADC0809, ñaây laø caùc boä bieán ñoåi A/D 8 bit
vôùi 8 keânh töông töï
Sinh vieân tra sô ñoà chaân vaø sô ñoà keát noái cho maïch thöïc teá
6.2.
BIẾN ĐỔI DAC
6.2.1. Khái niệm
Chuyeån ñoåi soá – töông töï Digital – Analog Converter (DAC) laø bieán ñoåi tín hieäu
ñaõ ñöôïc maõ hoaù daïng soá trôû laïi thaønh giaù trò ñieän aùp töông töï.
Nguyeân lyù chuyeån ñoåi soá – töông töï.
Giaû thieát raèng giaù trò soá Z ñöôïc xöû lyù nhö moät soá nhò phaân N bit theo maõ nhò phaân
vaø xöû lyù song song (1 bit moãi ñöôøng döõ lieäu). Tieáp theo, giaû thieát raèng chæ xeùt
ñeán caùc chuyeån ñoåi D/A maø chæ chuyeån ñoåi, xöû lyù nhöõng soá döông trong phaïm vi
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 160
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
,
0 ≤ Z ≤ Z max = 2 N − 1
ôû ñaây: soá nhò phaân Z bin = z N −1...z1 z0 bieåu thò bôûi N chöõ soá nhò nguyeân zi :
Z = z N −1 2 N −1 + ... + z2 22 + z1 21 + z0 20 .
Soá nhò phaân N bit ôû ñaàu vaøo cuûa boä chuyeån ñoåi D/A ñöôïc moät thanh ghi ñaàu vaøo
tieáp nhaän, vaø khi coù taùc ñoäng söôøn xung nhòp tieáp theo, noù ñöôïc chuyeån ñoåi thaønh
giaù trò töông töï töông öùng. Ñoä lôùn böôùc löôïng töû hoaù U LSB do quaù trình rôøi raïc
hoaù, töông öùng vôùi vi sai tín hieäu töông töï ôû ñaàu ra giöõa hai giaù trò soá keá tieáp:
,
U LSB = U ref 2 N
ôû ñaây U ref - ñieän aùp quy chieáu (reference) cuûa boä chuyeån ñoåi D/A. Ñoä lôùn böôùc
löôïng töû töông öùng giaù trò töông töï cuûa bit baäc thaáp nhaát Least Significant Bit
LSB. Ñaëc tuyeán truyeàn ñaït cuûa boä chuyeån ñoåi D/A ñôn cöïc lyù töôûng 3 bit ( U LSB
= U ref / 8) nhö sau.
Trong ñoù, K laø soá ñieåm rôøi raïc hoaù treân ñaëc tuyeán truyeàn ñaït, quy ñònh soá bit N
cuûa boä chuyeån ñoåi:
K = 2N
Ñieän aùp töông töï ôû ñaàu ra u ra cuûa chuyeån ñoåi D/A naèm trong khoaûng:
.
2n − 1
= U ref (1 − 2 − N )
.
2N
Moät trong nhöõng ñaïi löôïng ñaëc tröng quan troïng cuûa boä chuyeån ñoåi D/A laø tyû soá
chuyeån ñoåi vaø thôøi gian chuyeån ñoåi.
• Tyû soá chuyeån ñoåi: bao nhieâu giaù trò soá ñöôïc chuyeån ñoåi thaønh giaù trò töông töï
trong moät ñôn vò thôøi gian.
• Thôøi gian chuyeån ñoåi, noùi chung, töông öùng trò nghòch ñaûo cuûa tyû soá chuyeån
ñoåi.
0 ≤ u ra ≤ U LSB (2 N − 1) = U ref
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 161
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
Sô ñoà thöïc hieän chuyeån ñoåi soá – töông töï D/A baèng Pheùp coäng doøng hay aùp troïng
soá. ï.
a)- Phöông aùn khuyeách ñaïi u / i ; b)- Phöông aùn coù khuyeách ñaïi i / u .
Boä chuyeån ñoåi treân coù boä khuyeách ñaïi u / i cung caáp doøng ra khoâng ñoåi I ref = U ref
/ Rref . Neáu song song vôùi ñieän trôû Ri maéc moät chuyeån maïch Si ñöôïc ñieàu khieån
bôûi töø maõ Z,, sao cho noù môû khi coù chöõ soá nhò nguyeân 1 (Si ( zi = 1) = 1) , vaø khi coù
soá 0 noù vaãn giöõ traïng thaùi ñoùng (S i ( z i = 0 ) = 0) , thì ñieän aùp ñaàu ra baèng:
N −1
U ref
i =0
Rref
u ra = I ref ∑ S i Ri =
N −1
∑S R
i =0
i
,
i
ôû ñaây ñieän trôû troïng soá nhò phaân Ri laø:
Ri = 2i R , - i = 0,1,…,N – 1.
Hình b giôùi thieäu phöông aùn sô ñoà coù boä khuyeách ñaïi i / u, hoaït ñoäng nhö moät boä
coäng ñaûo. Khaùc vôùi phöông aùn tröôùc, trong sô ñoà naøy chuyeån maïch Si seõ ñoùng
(S (z
i
i
)
= 1) = 1 khi coù soá nhò nguyeân 1. Vaø ñieän aùp ñaàu ra u ra baèng:
N −1
u ra = − Rref U ref ∑ S i
i =0
1
Ri
,
ôû ñaây ñieän trôû Ri coù troïng soá nhò phaân nghòch ñaûo so vôùi trong bieåu thöùc treân
R
i = 0,1, …, N – 1,
Ri = i ,
2
vaø S i = 1 khi soá nhò nguyeân thöù i laø 1, coøn ngoaøi ra thì S i = 0.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 162
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
Phöông aùn thöïc hieän sô ñoà Boä chuyeån ñoåi D/A 4 bit coù khuyeách ñaïi i / u treân cô
sôû chuyeån maïch baùn daãn.
Sô ñoà ñöôïc phaân baäc thöù nguyeân sao cho khi soá nhò nguyeân thöù i ñöôïc ñaët ñònh ôû
möùc 1 (töông öùng ñieän aùp döông trong phaïm vi U B , töùc laø U ( zi = 1) ≈ U B ), thì
transistor töông öùng ñöôïc môû vaø doøng collector cuûa noù, voán do ñoä lôùn ñieän trôû
R 2i quy ñònh, seõ chaïy qua “ñieän trôû toång” Rref . Nhö vaâïy, pheùp coäng theo bieåu
thöùc (N3.4-8) ñöôïc thöïc hieän. Ñieän aùp rôi treân ñieän trôû R 2i coù giaù trò baèng U ref
vì ñieän aùp dao ñoäng treân diode U D gaàn töông xöùng ñieän aùp BE aâm cuûa transistor
( U D ≈ −U BE ). Diode zener oån aùp giöõ cho ñieän aùp U ref khoâng ñoåi.
Ñoái vôùi nhöõng chuyeån ñoåi D/A thieát keá treân cô sôû caùc maïng trôû khaùng nhö treân,
thoâng thöôøng phaûi ñaùp öùng yeâu caàu raát cao veà ñoä chính xaùc cuûa caùc ñieän trôû maéc
trong maïch. Boä chuyeån ñoài soá – töông töï N bit coù lieân heä töông quan giöõa ñieän
aùp ñaàu ra cöïc ñaïi u ra. max vaø böôùc löôïng töû U LSB laø:
(
)
.
u ra. max = 2 N − 1 U LSB
Neáu phaûi ñaûm baûo sai soá tuyeät ñoái lôùn nhaát Δu ra cuûa ñieän aùp ñaàu ra u ra nhoû
hôn U LSB 2 , töùc laø Δu ra ≤ U LSB 2 , thì phaûi aùp duïng luaät phaân boá sai soá ñoái vôùi
sai soá heä thoáng cho bieåu thöùc (N3.4-6):
U ref N −1 ∂Ri
U ref
Δu ra =
Si
ΔRi =
∑
Rref i =0 ∂Ri
Rref
N −1
∑S
i =0
i
1
ΔRi < U LSB
2
.
Trò soá analog töông töï cuûa baäc löôïng töû hoaù ñaàu tieân coù theå xaùc ñònh töø caùc bieåu
thöùc (N3.4-6) vaø (N3.4-7), laø haøm cuûa ñieän aùp quy chieáu vaø giaù trò ñieän trôû R vaø
Rref :
U LSB =
U ref
ruùt ra: Δu ra =
Rref
U ref
Rref
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
R
N −1
∑S
i =0
i
ΔRi <
1 U ref
R
2 Rref
Trang 163
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
Tröôøng hôïp xaáu nhaát laø söï coá moïi chuyeån maïch Si ñeàu môû ( Si = 1), cho neân
phaûi ñaûm baûo ñieàu kieän sau:
N −1
1
ΔRi < R
∑
2
i =0
Neáu ta coi sai soá töông ñoái cuûa moïi ñieän trôû chæ trò nhò phaân laø nhö nhau, thì:
.
ΔRi = ΔR 2i
Sai soá töông ñoái lôùn nhaát coù theå chaáp nhaän theo ñieàu kieän Δu ra ≤ U LSB 2 maø sô
ñoà chuyeån ñoåi duøng maïng ñieän trôû treân coù theå ñaùp öùng:
N −1
1
R
2
i =0
ΔR
1
.
<
N
R
2 2 −1
ΔR ∑ 2i <
vaø
(
,
)
Phaûi ñaëc bieät ñaûm baûo thoaû maõn ñieàu kieän naøy ñoái vôùi ñieän trôû RN −1 - ñònh trò bit
baäc cao nhaát MSB. Veà maët sai soá toaøn phaàn, thì ñieän trôû naøy coù aûnh höôûng lôùn
nhaát, ñieàu ñoù coù nghóa laø ñoái vôùi caùc chuyeån ñoåi 12 bit thì ñieän trôû R11 ít nhaát
phaûi ñaûm baûo yeâu caàu ñoä chính xaùc sau:
ΔR11
R11
=
(
) = 0,00024 = 0,024% .
2 2 −1
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
1
11
Trang 164
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Chương 6
Maïng chuoãi ñieän trôû. Nhöôïc ñieåm neâu treân, thoâng thöôøng laø do söû duïng ñieän trôû
ñöôïc cheá xuaát haøng loaït, theo trò soá chuaån hoaù vôùi ít trò soá ñònh möùc khaùc nhau.
Coù theå khaéc phuïc nhöôïc ñieåm ñoù baèng caùch söû duïng maïng chuoãi ñieän trôû R-2R.
Phaàn lôùn caùc chuyeån ñoåi D/A söû duïng chuoãi ñieän trôû ñoù laøm nhöõng boä phaân aùp
vaø phaân doøng maëc ñònh. Sô ñoà maïch töông öùng chæ duøng caùc ñieän trôû R vaø 2R nhö
sau
.
Hình a laø sô ñoà coù nguoàn doøng; hình b laø sô ñoà töông ñöông giöõa nuùt i vaø (i+1)
khi zi =1 caùc maïch khaùc môû; hình c laøsô ñoà nguyeân lyù coù nguoàn aùp.
Sô ñoà töông ñöông hình b bieåu thò töông quan giöõa hai nuùt i vaø (i+1), coù theå theo
nguyeân taéc phaân doøng, quy ñònh tyû leä doøng I i +1 vaø I i luoân baèng 1/2:
.
I i +1 I i = 1 2
Trong ñoù, giaû ñònh raèng maïch thuoäc bit nhò nguyeân thöù i laø ñoùng, trong khi taát caû
caùc bit nhò nguyeân khaùc ñeàu ñang môû. Maët khaùc, tyû leä 1/2 ñuùng baèng chæ trò
troïng soá nhò phaân cuûa chuyeån maïch Si . Vôùi I ref = I i +1 + I i thì ñieän aùp u i baèng:
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 165
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
ui = I i R =
Chương 6
2
I ref R .
3
Do phaân aùp giöõa caùc nuùt i vaø (i+1) ta coù:
u i +1 1
=
ui
2
.
Xaùc ñònh ñieän aùp ñaàu ra u ra baèng caùch aùp duïng nguyeân lyù sieâu vò:
u ra =
N −1
2
I ref R ∑ S i 2 i − N +1 ,
3
i =0
vaø ñaùnh giaù troïng soá nhò phaân cuûa ñieän aùp thaønh phaàn u i . Trong phöông aùn sô ñoà
hình c, thay vì nguoàn doøng N caàn coù nguoàn aùp quy chieáu. Töø thaønh phaàn ñieän aùp
ñaët tröôùc, xaùc ñònh ñöôïc ñieän aùp ñaàu ra u ra :
N −1
2
u ra = U ref ∑ S i 2 i − N +1 .
3
i =0
6.2.2. MỘT SỐ IC DAC CHUYÊN DỤNG
•
DAC 0808 laø boä chuyeån ñoåi DAC 8bit
Caùc thoâng soá vaø ñaëc tính kyõ thuaät SV töï tra taøi lieäu
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 166
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
PHỤ LỤC B
I.
NGOÂN NGÖÕ LAÄP TRÌNH CHO PLD
Cuõng gioáng nhö ROM hay PROM, moät PLD cuõng ñöôïc laäp trình ñeå taïo ra file ñoát
caùc caàu chì hay diode.
Ngoân ngöõ söû duïng ñeå laäp trình cho PLD trong chöông trình naøy laø ABEL
(Advanced Boolean Equation Language) laø moät trong nhöõng ngoân ngöõ laäp trình raát
maïnh cho PLD, hoã trôï cho nhieàu ngoõ vaøo, bao goàm caû sô ñoà traïng thaùi vaø baûng söï
thaät. Trình bieân dòch cuûa ABEL coù khaû naêng moâ phoûng vaø taïo file fuse map (caàu
chì) cho PLD. Trong phuï luïc naøy chæ toùm taét höôùng daãn söû duïng caùc phaàn caáu truùc
vaø cuù phaùp veà caùc phaùt bieåu, khai baùo, chæ daãn…chuû yeáu nhaát ñeå phuïc vuï cho caùc
baøi thí nghieäm sau ñoù. Ñeå hieåu saâu hôn veà ngoân ngöõ naøy, sinh vieân neân tham khaûo
theâm caùc taøi lieäu khaùc hoaëc phaàn help trong ngoân ngöõ.
Ngoaøi ABEL coøn coù caùc ngoân ngöõ khaùc nhö VHDL, AHDL…
CAÁU TRUÙC CUÛA MOÄT CHÖÔNG TRÌNH ABEL
module module name
title string
deviceID device deviceType;
pin declarations
other declarations
equations
equations
test_vectors
end module name
Module. Teân chöông trình vaø caùc thoâng soá hình thöùc
Title. Duøng ñeå moâ taû module
Declaration. Moâ taû caùc module caáp thaáp hôn, ñònh nghóa caùc khoái chöùc naêng
nhö devive, pin, node, constant, macro, caùc taäp hôïp,…
Equations. Söû duïng caùc haøm, caùc löu ñoà traïng thaùi hay baûng söï thaät ñeå moâ taû
caùc thieát keá logic
Test_vectors. Test_vectors sö duïng trong caùc file moâ phoûng JEDEC
End. Keát thuùc moät module
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 251
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
Löu yù: caáu truùc ôû treân bao goàm caùc thaønh phaàn cô baûn cuûa moät chöông trình
ABEL, tuøy vaøo nhöõng öùng duïng cuï theå coù theå seõ coù theâm caùc phaùt bieåu khaùc
nhö maùy traïng thaùi, v.v…
1. CAÙC PHAÙT BIEÅU (STATEMENTS)
1.1.
Phaùt bieåu Module
Cuù phaùp
module modname [( dummy_arg[,….])]
Muïc ñích:
Phaùt bieåu module xaùc ñònh ñieåm baét ñaàu cuûa moät chöông trình vaø phaûi coù
phaùt bieåu END ñeå xaùc ñònh ñieåm keát thuùc cuûa module
Söû duïng
Modname laø moät danh hieäu hôïp leä ñöôïc ñaët laøm teân goïi cho module
chöông trình
Danh hieäu hôïp leä laø moät chuoãi daøi toái ña 31 kyù töï (chöõ caùi, chöõ soá, daáu
gaïch döôùi’_’), ñöôïc baét ñaàu baèng chöõ caùi hay daáu gaïch döôùi ’_’. Danh
hieäu phaân bieät chöõ hoa hay chöõ thöôøng.
Dummy_arg (coù theå coù) : laø moät thoâng soá hình thöùc (töông töï nhö trong
ngoân ngöõ hôïp dòch)
Ví duï
MODULE My_Example
…
END My_Example
Module coù teân My_Example vaø phaùt bieåu END My_Example keát thuùc
module naøy.Trong module naøy khoâng söû duïng thoâng soá hình thöùc.
MODULE My_Example (A,B)
…
C=A+B
END My_Example
Trong module naøy coù söû duïng hai thoâng soá hình thöùc A vaø B, bieåu thöùc
C=A+B, vôi A,B ñöôïc traû veà gía trò thöïc (töø module khaùc) khi bieân dòch
1.2.
Phaùt bieåu Title
Cuù phaùp
title ‘string’
Muïc ñích:
Phaùt bieåu title ñaët cho module moät töïa ñeà (header) ñeå minh hoïa ñaëc ñieåm
chöùc naêng do ngöôøi laäp trình taïo ra.Chuoãi kyù töï seõ xuaát hieän trong caû file
döõ lieäu vaø file fusemap sau khi bieân dòch
Söû duïng
string: laø chuoãi kyù töï naèm trong hai daáu nhaùy ñôn (‘) vaø giôùi haïn 324 kyù
töï
Söû duïng phaùt bieåu tilte laø tuøy choïn
Ví duï
module m6809a
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 252
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
title ’6809 memory decode
Jean Designer
Data I/O Corp Redmond WA’
1.3.
Phaùt bieåu equations
Cuù phaùp
equations
element [?] = condition;
when-then-else_statement;
Muïc ñích:
Phaùt bieåu equations ñònh choã baét daàu cuûa moät hay moät nhoùm bieåu thöùc
Boole bieãu dieãn haøm logic ngoõ ra theo ngoõ vaøo
Söû duïng
condition. Moät moâ taû
element. teân danh ñònh cuûa moät tín hieäu, taäp caùc tín hieäu hay tín hieäu
thöïc maø moâ taû giaù trò cuûa noù ñöôïc gaùn
when-then-else_statement: phaùt bieåu when-then-else
Sau moãi bieåu thöùc phaûi coù daáu chaám phaåy (;)
Ví duï
Equations
A = B&C#A;
[W,Y] = 3;
!F = (B = =C);
1.4.
Phaùt bieåu Truth_table
Cuù phaùp
hay
Muïc ñích:
Söû duïng
Ví duï
truth_table (inputs -> outputs)
truth_table (inputs : > reg_outs)
Truth_table trình baøy baûng söï thaät minh hoïa ngoõ ra nhö moät haøm toå hôïp cuûa caùc
ngoõ vaøo
Caùc baûng söï thaät coù theå thay theá hoaëc boå sung theâm cho caùc bieåu thöùc
(trong equations) hay sô ñoà traïng thaùi (trong state_diagram)
inputs : laø caùc ngoõ vaøo cuûa haøm logic
outputs : laø caùc ngoõ ra cuûa haøm logic
reg_outs : laø caùc ngoõ ra cuûa caùc thanh ghi (FF)
Daáu -> bieãu dieãn heä toå hôïp
Daáu : > bieãu dieãn heä tuaàn töï
Truth_table ([A,B] -> C)
[0,1] -> 1;
[1,0] -> 1;
[1,1] -> 0;
[0,0] -> 0;
Roõ raøng truth_table ôû treân bieãu dieãn bieåu thöùc C=A+B
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 253
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
1.5.
Phụ lục B
Phaùt bieåu state_diagram
Cuù phaùp
State_diagram state variables
State state_exp:[equations];
.
.
[trans-stmt…];
Muïc ñích:
Phaùt bieåu state_diagram ñònh nghóa caùc bieán traïng thaùi baét ñaàu söï moâ taû
hoaït ñoäng cuûa maùy traïng thaùi (töông töï nhö ñoà thò traïng thaùi hay löu ñoà
maùy traïng thaùi)
Söû duïng
state_variables: laø taäp hôïp caùc bieán traïng thaùi trong maùy traïng thaùi
state: laø töø khoùa ñeå bieãu dieãn söï chuyeån bieán töø traïng thaùi hieän taïi sang
traïng thaùi keá tieáp vaø ngoõ ra hieän taïi
state_exp : laø bieåu thöùc hay haèng soá ñòng nghóa traïng thaùi hieän taïi
equations: laø caùc bieåu thöùc logic ngoõ ra hieän taïi cuûa maùy traïng thaùi
trans_stmt : laø moät phaùt bieåu daïng IF – THEN – ELSE , GOTO, CASE
(tuøy choïn) ñeå moâ taû söï chuyeån bieán töø traïng thaùi hieän btaïi sang traïng thaùi
keá tieáp theo ñieàu kieän taùc ñoäng cuûa ngoõ vaøo
Ví duï
1.6.
Giaû söû ta coù 2 ngoõ vaøo x1 vaø x2, ngoõ ra laø z, maùy traïng thaùi coù 3 traïng thaùi
kyù hieäu S0,S1,S2, 2 bieán traïng thaùi Q = [Q0,Q1] (2 ngoõ ra cuûa FF)
State_diagram Q
State S0: if (x1&x2 = =0) then S2
S0
Else S1
State S1: z=1;
1
0
x1x2
Go to S2;
State S2: z=0;
z=1
S1
S2 z=0
Go to S0;
Phaùt bieåu goto
Cuù phaùp
Goto state_exp
Muïc ñích:
Phaùt bieåu goto bieãu dieãn söï chuyeån bieán khoâng ñieàu kieän töø traïng thaí
hieän taïi sang traïng thaùi keá tieáp laø state_exp.
Söû duïng
State_exp: laø bieåu thöùc bieãu dieãn traïng thaí keá tieáp
Ví duï
Si: goto Sj; nhaûy ñeán traïng thaùi Sj
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 254
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
1.7.
Phụ lục B
If – then – else
Cuù phaùp
hay
If exps then state_exp1
[else state_exp2];
if exp1 then state_exp1
else if exp2 then state_exp2
[else if….]
else state_expn;
Muïc ñích: Phaùt bieåu if – then – else : moâ taû söï chuyeån hoùa traïng thaùi theo ñieàu kieän
ngoõ vaøo.
Neáu bieåu thöùc ngay sau töø khoùa if laø ñuùng , chuyeån bieán höôùng ñeán traïng
thaùi ngay sau töø khoùa then; neáu sai chuyeån bieán höôùng ñeán trang thaùi
ngay sau töø khoùa else.
Söû duïng
exps: laø bieåu thöùc baát kyø hôïp leä naøo
state_exp1, state_exp2…..: laø bieåu thöùc bieãu dieãn traïng thaùi keá tieáp.
Caùc phaùt bieåu if – then – else coù theå ñöôïc noái vôùi nhau lieân tieáp nhöng
keát thuùc phaûi laø daáu chaám phaåy.
Ví duï
State 1 : if (A = = B) then 2; “neáu A = b chuyeån ñeán traïng thaùi 2
State 2 : if A then 3 else 4; “ neáu A ñuùng (≠0) chuyeån ñeán traïng thaùi 3
“ neáu A sai (=0) chuyeån ñeán traïng thaùi 4
state 0 : if a then 1
else if b then 2
else if c then 3
else 0;
1.8.
Phaùt bieåu case
Cuù phaùp
Case [exps1 : state+exp1;]
[expsi : state_expi;]
end case;
Muïc ñích:
Phaùt bieåu case moâ taû söï chuyeån bieán traïng thaùi trong tröôøng hôïp coù nhieàu
ñieàu kieän taùc ñoäng.
Söû duïng
Traùnh khoâng ñeå 2 ñieàu kieän xaûy ra cuøng luùc vaø traùnh tröôøng hôïp keát quaû
traïng thaùi keá khoâng ñoaùn tröôùc ñöôïc
Ví duï
STATE S0:
CASE (sel == 0): S0 ;
(sel == 1): S1 ;
ENDCASE
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 255
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
1.9.
Phụ lục B
Phaùt bieåu test_vectors:
Cuù phaùp
Text vectors[‘note’] (inputs → outputs)
[invalues → out values]
Muïc ñích: Caùc test_vectors duøng ñeå moâ phoûng hoaït ñoäng cuûa heä vaø kieåm tra caùc
chöùc naêng hoaït ñoäng cuûa heä khi chaïy chöông trình moâ phoûng
Söû duïng
note: laø moät chuoãi kyù töï ñeå moâ taû caùc text_vectors
inputs : laø 1 danh ñònh hay taäp hôïp caùc danh ñònh teân caùc tín hieäu vaøo hay
hoài tieáp veà ngoõ vaøo cuûa heä.
Outputs : laø 1 danh ñònh hay taäp hôïp caùc danh ñònh teân caùc tín hieäu ra cuûa
heä.
Invalues : laø 1 hay taäp hôïp caùc giaù trò vaøo
Outvalues : laø 1 hay taäp hôïp caùc giaù trò ra laø haøm logic cuûa caùc giaù trò vaøo
vaø gía trò traïng thaùi (heä tuaàn töï)
Ví duï
equations
C = A&B;
“C = A.B
D = A#B;
“D = A+B
Text_vectors ([A,B]→[C,D])
[0,0]→[0,0]
[0,1]→[0,1]
[1,0]→[0,1]
[1,1]→[1,1]
1.10. Phaùt bieåu istype
Cuù phaùp
Signal [ , signal] … istype ’attr[ , attr]…’;
Hay signal [ , signal] … pin istype ‘attr[ , attr]… ‘;
Muïc ñích: Phaùt bieåu istype ñònh nghóa caùc thuoäc tính cuûa pin hay node laäp trình ñöôïc
cuûa caùc duïng cuï (PLD).
Caùc thuoäc tính cuûa pin hay node coù theå khai baùo cuøng moät doøng
Söû duïng
signal: laø moät danh hieäu pin hay node
attr: laø moät chuoãi kyù töï xaùc ñònh caùc thuoäc tính cuûa caùc signal
Caùc thuoäc tính hôïp leä laø:
‘buffer’ : ñeäm
‘com’ : heä toå hôïp
‘invert’ : ñaûo
‘neg’ : tính cöïc möùc thaáp
‘pos’ : tính cöïc möùc cao
‘reg’ : thanh ghi (heä tuaàn töï)
‘reg_D’,’reg_T’,’reg_JK’,’reg_SR’ : caùcFF, D, T, JK, SR
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 256
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Ví duï
Phụ lục B
F0, A istype ‘neg , reg’;
istype ñònh nghóa F0 , A laø tín hieäu cuûa thanh ghi , taùc ñoäng möùc thaáp
outputs pin 15 istype ‘reg , invert’
tín hieäu output chaân 15 cuûa thanh ghi ngoõ ñaûo (ngoõ ra Q )
1.11. Phaùt bieåu end
End
Cuù phaùp
Hay
end modname
Muïc ñích: Duøng keát hôïp vôùi caùc phaùt bieåi module ñeå môû ñaàu vaø keát thuùc module
chöông trình
Söû duïng
signal: laø moät danh hieäu pin hay node
attr: laø moät chuoãi kyù töï xaùc ñònh caùc thuoäc tính cuûa caùc signal
Caùc thuoäc tính hôïp leä laø:
‘buffer’ : ñeäm
‘com’ : heä toå hôïp
‘invert’ : ñaûo
‘neg’ : tính cöïc möùc thaáp
‘pos’ : tính cöïc möùc cao
‘reg’ : thanh ghi (heä tuaàn töï)
‘reg_D’,’reg_T’,’reg_JK’,’reg_SR’ : caùcFF, D, T, JK, SR
Ví duï
F0, A istype ‘neg , reg’;
istype ñònh nghóa F0 , A laø tín hieäu cuûa thanh ghi , taùc ñoäng möùc thaáp
outputs pin 15 istype ‘reg , invert’
tín hieäu output chaân 15 cuûa thanh ghi ngoõ ñaûo (ngoõ ra Q )
2. CAÙC KHAI BAÙO (DECLARATIONS)
2.1.
Pin
Cuù phaùp
[!]pin_id[,[l]pin_id…]pin[pin#[,pin#]] istype ’attr’];
Muïc ñích: Töø khoùa pin duøng ñeå khai baùo nhöõng tín hieäu input vaø output, laø nhöõng tín
hieäu in/out quy ñònh saün treân duïng cu ï(theo soå tra cöùu). Khai baùo cuõng coù
theå ñònh nghóa thuoäc tính chaân
Khi 1 danh saùc danh ñònh chaân vaø soá chaân coù trong cuøng moät khai baùo
chaân , seõ coù söï töông öùng 1-1 giöõa danh ñònh chaân vaø soá chaân
Söû duïng
pin_id: laø moät danh hieäu duøng ñeå ñaët teân cho 1 chaân
pin #: laø soá thöù töï chaân treân duïng cuï (PLD)thaät
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 257
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
attr: laø moät chuoãi xaùc ñònh caùc thuoäc tính cuûa chaân
!: kyù hieäu NOT,tích cöïc möùc thaáp
Ví duï
!clock,reset,S1 pin 12,15,3;
khai baùo naøy gaùn teân chaân: clock chaân 12, reset chaân 15, S1 chaân 3
!clock: tích cöïc möùc 0
2.2.
Node
Cuù phaùp
[!]node_id[,[!]node_id … ]node[node#[,node# …][istype ’attr’];
Muïc ñích: Töø khoùa node duøng ñeå khai baùo nhöõng tín hieäu gaùn cho nhöõng nuùt aån
trong duïng cuï
Söû duïng
node_id: laø moät danh hieäu duøng ñeå ñaët teân moät nuùt
node#: laø soá thöù töï nuùt treân duïng cuï thaät (nuùt töông ñöông nhö chaân aån
trong duïng cuï vaø soá nuùt ñöôïc cho trong soå tay tra cöuù)
Ví duï
B node istype’reg’ : xaùc ñònh nuùt B laø 1 ngoõ cuûa FF trong duïng cuï
A,B node 25,26 : gaùn teân A laø nuùt 25, gaùn teân B laø nuùt 26. Soá nuùt naøy do
nhaø saûn xuaát quy ñònh trong soå tay tra cöùu
2.3.
Duïng cuï (Device)
Cuù phaùp
Device-id device real_device;
Muïc ñích: Khai baùo device cho moät PLD thaät. Trong quaù trình bieân dòch, caùc haøm
logic seõ ñöôïc ñöa veà daïng theo caáu truùc coång ñuùng nhö cuûa duïng cuï thaät.
Söû duïng
device-id: laø moät danh hieäu, chính laø teân file fusemap
real-device: moâ taû maõ soá duïng cuï (PLD) ñaët giöõa 2 daáu nhaùy ñôn (‘)
Phaûi ñaët daáu ; sau khai baùo
Ví duï
D1 device ‘P16R4’: khai baùo naøy cho bieát D1 laø loaïi PLD PAL 16R4
3. CAÙC KHAI BAÙO KHAÙC (OTHER DECLARATIONS)
3.1.
Haèng (constant)
Cuù phaùp
id[,id]… = expr[,expr] …;
Muïc ñích: Khai baùo haèng ñònh nghóa nhöõng haèng soá ñöôïc duøng trong 1 module
Söû duïng
id: laø moät danh hieäu ñaët teân cho 1 haèng
expr: xaùc ñònh gía trò haèng
Ví duï
X = .X.;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
“X mang yù nghóa khoâng xaùc ñònh
Trang 258
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
3.2.
Phụ lục B
Z = .Z.;
“Z mang yù nghóa toång trôû cao
C = .C.
“C mang yù nghóa taùc ñoäng caïnh leân
A = ^b01 ;
“soá nhò phaân
B = ^h16;
“soá hex
C = 10;
“soá thaäp phaân
Taäp hôïp (set)
Ñònh nghóa
Taäp hôïp laø taäp hôïp nhöõng tính hieäu vaø haèng soá maø taùc vuï thöïc hieän nhö laø
1 ñôn vò
Baát cöù taùc vuï naøo aùp duïng cho 1 taäp hôïp seõ ñöôïc aùp duïng cho moãi phaàn töû
trong taäp hôïp
Taäp hôïp seõ laøm ñôn giaûn vieäc moâ taû logic vaø caùc test-vectors baèng caùch
chæ caàn duøng teân goïi taäp hôïp
Söû duïng
Moät taäp hôïp ñöôïc ñaïi dieän bôûi 1 danh saùch caùc haèng soá vaø tín hieäu ngaên
caùch baèng caùc daáu chaám phaåy hay daáu khoaûng (..), ñaët trong daáu ngoaëc
vuoâng ([ ]). Sau moãi khai baùo taäp hôïp phaûi coù daáu ;
Ví duï
MULOUT = [B0,B1,B2,B3,B4,B5,B6,B7];
hay
MULOUT = [B0…B7];
MULOUT laø khai baùo laø teân moät taäp hôïp goàm 8 tín hieäu töø B0 ñeán B7
BCD = [D,C,B,A]
LED = [g,f,e,d,c,b,a]
Test-vectors (BCD → LED)
[0,0,0,0] →[1,0,0,0,0,0,0]
BCD laø 1 taäp hôïp goàm caùc tín hieäu D,C,B,A
LED laø 1 taäp hôïp goàm caùc tín hieäu g,f,e,d,c,b,a
3.3.
Macro
Cuù phaùp
Macro_id macro [(dummy_arg [, dummy_arg]…)]{block};
Muïc ñích: Khai baùo macro ñònh nghóa 1 macro thöïc hieän caùc chöùc naêng, caùc pheùp
toaùn,bieåu thöùc logic trong moät khoái
Chæ ñònh nghóa macro 1 laàn trong phaàn khai baùo macro trong module vaø seõ
ñöôïc duøng baát cöù nôi naøo trong module
Khai baùo macro töông töï nhö trong trình hôïp ngöõ
Macro chæ coù theå ñöôïc duøng trong module maø noù ñöôïc khai baùo
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 259
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
macro_id: laø moät danh hieäu ñaët teân cho macro
dummy_arg: laø moät thoâng soá hình thöùc
block: laø caùc bieåu thöùc logic
Söû duïng
Ví duï
NAND3 macro (A,B,C) {!(A&B&C)}
NAND3 laø macro thöïc hieän chöùc naêng haøm logic A.B.C vôùi A,B,C laø caùc
thoâng soá hình thöùc
Sau ñoù trong module khai baùo macro naøy ta coù khai baùo:
D = NAND 3 (Clock, Hello, busy);
Keát quûa laø: D = !(Clock&Hello&Busy) khi bieân dòch
3.4.
Enable
Enable output_id = [!]expr;
Cuù phaùp
Muïc ñích: Khai baùo enable cho pheùp caùc ngoõ ra 3 traïng thaùi hoaït ñoäng theo tín hieäu
ñieàu khieån bôûi gía trò cuûa expr
Söû duïng khai baùo naøy theo sau phaùt bieåu equations
output_id: laø danh hieäu ñaët teân cho 1 ngoõ ra hoaëc 1 taäp hôïp ngoõ ra
expr: laø 1 bieåu thöùc logic
Söû duïng
Ví duï
OE pin11;
F0,F1,F2,F3 pin 19,18,17,16;
Count = [F0,F1,F2,F3];
Equations
Enable count = !OE
Caùc ngoõ ra töø F0 ñeán F3 trong taäp hôïp count laø caùc ngoõ ra 3 traïng thaùi , seõ
hoaït ñoäng khi OE = 0 vaø seõ ôû traïng thaùi high-Z khi OE = 1
Coù theå söû duïng tieáp vó ngöõ .OE thay cho khai baùo enable (xem phaàn tieáp
vó ngöõ)
4. CAÙC TOAÙN TÖÛ (OPERATORS)
4.1.
Toaùn töû chuaån (standard)
!
NOT
=
toaùn töû gaén cho bieåu thöùc toå hôïp
#
OR
:=
toaùn töû gaùn cho bieåu thöùc thanh ghi (tuaàn töï)
&
AND
$
XOR
!$
XNOR
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 260
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
Ngoaøi ra töø khoaù @ALTERNATE baùo cho trình bieân dòch bieát boä toaùn töû töông ñöông
(alternate) thay theá cho boä toaùn töû chuaån (caùc kyù hieäu deã nhôù hôn)
Boä toaùn töû thay theá (phaûi coù töø khoaù @ALTERNATE ôû ñaàu module chöông trình)
/
*
+
:+:
:*:
4.2.
NOT
AND
OR
XOR
XNOR
Toaùn töû so saùnh
==
baèng
!=
khoâng baèng
<
nhoû hôn
>
lôùn hôn
<=
nhoû hôn hoaëc baèng
>=
lôùn hôn hoaëc baèng
Ngoaøi ra coøn cho pheùp vieát caùc bieåu thöùc ñieàu kieän , bieåu thöùc naøy seõ traû veà 1 neáu
thoaû ñieàu kieän vaø traû veà 0 neáu khoâng thoûa ñieàu kieän
Ví duï Q = (P = =1);
“Q seõ baèng 1 neáu P =1 vaø Q seõ baèng 0 neáu P khaùc 1
5. CAÙC TIEÁP ÑAÀU NGÖÕ (Prefix), tieáp vó ngöõ (suffix)
5.1.
Tieáp ñaàu ngöõ
Toùan töû Not (! hay /) ñöôïc duøng nhö tieàp ñaàu ngöõ ñeå baùo trình bieân dòch bieát tín
hieäu hoaït ñoäng (tích cöïc) ôû möùc logic
Ví duï:
5.2.
!Q0 pin 15; töông ñöông vôùi Q0 pin 15 istype ‘neg’;
Tieáp vó ngöõ
Caùc tieáp vó ngöõ thöôøng ñöôïc duøng trong cheá ñoä thanh ghi ñeå truy xuaát ñeán töøng
chaân noäi trong thanh ghi
Ví duï Q0.CK truy xuaát ñeán chaân clock cuûa tín hieäu ra Q0 ôû cheá ñoä thanh ghi
Töông töï nhö ñoái vôùi .RE,.PR,.D,.T….. laàn löôït truy xuaát ñeán caùc chaân
reset,preset,D,T cuaû thanh ghi
Tieáp vó ngöõ .OE cho pheùp xuaát ôû ngoõ ra 3 traïng thaùi
Ví duï out.oe = !ena;
ena =0 → ngoõ ra out ñöôïc pheùp xuaát
ena = 1 → ngoõ ra out ôû traïng thaùi high-Z
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 261
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
6. GHI CHUÙ (Comments)
Caùc ghi chuù minh hoaï , giaûi thích cuûa chöông trình baét ñaàu baèng daáu nhaùy keùp
(“)vaø keát thuùc baèng daáu nhaùy keùp (“) hoaëc xuoáng doøng.
Ví duï
Q1,Q2,Q3, pin 14,15,16 “outputs
“declarations
QSTATE = [Q1,Q2,Q3]; “sets
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 262
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
BAØI THÍ NGHIEÄM
BIEÂN DÒCH VAØ MOÂ PHOÛNG ABEL
A. MUÏC ÑÍCH – YEÂU CAÀU BAØI THÍ NGHIEÄM:
•
Giuùp sinh vieân naém ñöôïc kyõ thuaät laäp trình vaø bieân dòch ngoân ngöõ ABEL trong
thieát keá PLD (caùc daïng hoài tieáp, khoâng hoài tieáp, thanh ghi…)
•
SV phaûi ñoïc kyõ tröôùc baøi cô sôû lyù thuyeát vaø oân laïi kieán thöùc veà kyõ thuaät soá
•
SV phaûi nhaäp saün caùc baøi thí nghieäm vaøo ñóa meàm
B. THIEÁT BÒ SÖÛ DUÏNG:
Maùy vi tính + chöông trình
•
C. NOÄI DUNG THÍ NGHIEÄM:
1. Thí nghieäm 1
Muïc ñích: Duøng caùc bieåu thöùc trong equations ñeå thöïc hieän maïch (mode ñôn).
Thieát keá boä MUX 12 → 4 duøng GAL16V8 nhö hình sau
1
2
3
4
5
6
7
8
9
11
A0
A1
A2
A3
B0
B1
B2
B3
C0
C1
U2
I0
I1
I2
I3
I4
I5
I6
I7
I8
I9
F0
F1
F2
F3
F4
F5
F6
F7
12
13
14
15
16
17
18
19
C2
C3
Y0
Y1
Y2
Y3
S1
S0
16V8
Caùc ngoõ vaøo: [a3,a2,a1,a0], [b3,b2,b1,b0], [c3,c2,c1,c0]
Ngoõ ra : [y0, y1, y2, y3]
•
Ñieàu khieån choïn keânh : [S1, S0]
Chöông trình
1
2
3
4
5
Module mux12t4
title '12 to 4 multiplexer
Thi nghiem 1'
“Cac khai bao
mux12t4 device 'P16V8S';
6
7
8
9
10
a0,a1,a2,a3
b0,b1,b2,b3
c0,c1,c2,c3
s1,s0
y0,y1,y2,y3
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
pin
pin
pin
pin
pin
1,2,3,4;
5,6,7,8;
9,11,12,13;
18,19;
14,15,16,17;
Trang 263
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
11
12
13
14
15
16
17
18
•
Phụ lục B
H = [1,1,1,1];
L = [0,0,0,0];
X = [.x.,.x.,.x.,.x.];
select = [s1, s0];
y = [y3,y2,y1,y0];
a = [a3,a2,a1,a0];
b = [b3,b2,b1,b0];
c = [c3,c2,c1,c0];
19
20
21
22
23
equations
y = (select
(select
(select
(select
24
25
26
27
28
29
30
31
32
33
34
35
36
37
test_vectors ([select, a, b, c] -> y)
[0 , 1, X, X] -> 1;
[0 ,10, H, L] -> 10;
[0 , 5, H, L] -> 5;
[1 , H, 3, H] -> 3;
[1 ,10, 7, H] -> 7;
[1 , L,15, L] -> 15;
[2 , L, L, 8] -> 8;
[2 , H, H, 9] -> 9;
[2 , L, L, 1] -> 1;
[3 , H, H, 0] -> 0;
[3 , L, L, 9] -> 9;
[3 , H, L, 0] -> 0;
end
==
==
==
==
0)
1)
2)
3)
&
&
&
&
a
b
c
c
#
#
#
;
Giaûi thích chöông trình
-
-
-
Doøng 1 khai baùo teân module laø mux12t4
Doøng 2,3 khai baùo teân title vaø ñaët teân
Doøng 4 laø chuù thích
Doøng 5 khai baùo duïng cuï (device) teân U1 vaø duøng vi maïch 16V8S (simple
mode)
Doøng 6,7,8,9,10 laø khai baùo gaùn teân caùc chaân töông öùng nhö hình
Doøng 11, 12, 13 laø khai baùo haèng : L = 0, H = 1, X=tuøy ñònh
Doøng 14,15,16,17,18 laø khai baùo taäp hôïp : select = [S1,S0] laø taäp goàm 3 bieán
ñieàu khieån choïn keânh, töông töï cho taäp a, b, c, y. Vieäc khai baùo taäp hôïp naøy seõ
raát tieän khi ta caàn tham chieáu tôùi caùc ngoõ ñieàu khieån hoaëc ngoõ ra ôû phaàn sau ñoù
Doøng 19 baét ñaàu phaùt bieåu equations.
Giaù trò gaùn cho toaùn töû ‘baèng’ duøng heä thaäp phaân. Neáu duøng heä nhò phaân ta ghi :
(select = = ^b00)
Doøng 24 baét ñaàu phaùt bieåu test_vectors ñeå kieåm tra chöùc naêng cuûa heä, khai baùo
caùc tín hieäu ngoõ vaøo vaø ngoõ ra caàn kieåm tra
Ngoõ vaøo laø taäp hôïp caùc bieán select, a, b, c. Ngoõ ra laø taäp hôïp caùc bieán y
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 264
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
•
Phụ lục B
Doøng 25 ñeán 27 laø caùc vector kieåm tra doàn keânh khi cho ngoõ vaøo select=0
Doøng 28 ñeán 30 laø caùc vector kieåm tra doàn keânh khi cho ngoõ vaøo select=1
Doøng 31 ñeán 33 laø caùc vector kieåm tra doàn keânh khi cho ngoõ vaøo select=2
Doøng 34 ñeán 36 laø caùc vector kieåm tra doàn keânh khi cho ngoõ vaøo select=3
Doøng 37 laø phaùt bieåu END keát thuùc chöông trình
Bieân dòch chöông trình
Böôùc 1: Nhaäp file nguoàn trong thí nghieäm treân
Böôùc 2:
Bieân dòch chöông trình duøng phaàn meàm ABEL
Töø thö muïc ABEL ñaùnh leänh abe filename
Böôùc 3: Xem laïi caùc file môùi hình thaønh (file.doc, file.list)
Böôùc 4: Theâm töø khoùa flag ‘-t1’ vaøo sau phaùt bieåu module
Module mod-id flag ‘-t1’
Böôùc 5: Bieân dòch laïi chöông trình vaø xem keát quaû ôû file.sim. Nhaän xeùt.
2. Thí nghieäm 2
Muïc ñích: Thieát laäp ñieàu khieån caùc ngoõ ôû cheá ñoä I/O vaø Hi Z (mode phöùc)
Thieát keá boä ñeäm 2 chieàu 3 traïng thaùi duøng GAL 16V8
S1 S0
S1
S0
GAL16V8
B2 B1 B0
1
2
3
4
5
6
7
8
9
11
U2
I0
I1
I2
I3
I4
I5
I6
I7
I8
I9
F0
F1
F2
F3
F4
F5
F6
F7
12
13
14
15
16
17
18
19
16V8
A2 A1 A0
Caùc ngoõ vaøo/ra: [a2,a1,a0], [b2,b1,b0]
Ñieàu khieån choïn chieàu data: [S1, S0]
Neáu [S1,S0] = [0,1]: höôùng töø B sang A
Neáu [S1,S0] = [1,0]: höôùng töø A sang B
•
Chöông trình
1
2
3
module tsbuffer
title 'bi-directional three state buffer
Thi nghiem 2'
4
TSB1 device 'P16V8c';
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 265
https://fb.com/tailieudientucntt
A2
A1
A0
B2
B1
B0
Bài Giảng Kỹ Thuật Số
5
6
7
S1,S0
A2,A1,A0
B2,B1,B0
8
9
10
11
Select
A
=
B
=
X,Z =
12
13
14
Equations
A = B;
B = A;
15
16
17
18
19
20
21
22
23
24
25
26
27
•
Pin 1,2;
Pin 13,14,15;
Pin 16,17,18;
= [S1,S0];
[A2,A1,A0];
[B2,B1,B0];
.X., .Z.;
Enable A = (Select==1);
Enable B = (Select==2);
test_vectors
([Select,
[ 0
,
[ 0
,
[ 1
,
[ 1
,
[ 2
,
[ 2
,
[ 3
,
[ 3
,
A,
0,
7,
X,
X,
3,
5,
0,
7,
B]->
0]->
7]->
3]->
5]->
X]->
X]->
0]->
7]->
[
[
[
[
[
[
[
[
[
A,
Z,
Z,
3,
5,
X,
X,
Z,
Z,
B])
Z];
Z];
X];
X];
3];
5];
Z];
Z];
end
Giaûi thích chöông trình
-
•
Phụ lục B
Doøng 4 khai baùo device ôû mode phöùc (modeI/O)
Doøng 11 khai baùo .z. laø toång trôû cao
Doøng 15 cho pheùp A xuaát khi [S1S0] = [01], luùc naøy höôøng truyeàn töø B->A
Doøng 16 cho pheùp B xuaát khi [S1S0] = [10], luùc naøy höôøng truyeàn töø A->B
Bieân dòch chöông trình
Böôùc 1: Nhaäp file nguoàn trong thí nghieäm treân
Böôùc 2:
Bieân dòch chöông trình duøng phaàn meàm ABEL
Töø thö muïc ABEL ñaùnh leänh abe filename
Böôùc 3: Xem laïi caùc file môùi hình thaønh (file.doc, file.list)
Böôùc 4: Theâm töø khoùa flag ‘-t1’ vaøo sau phaùt bieåu module
Module mod-id flag ‘-t1’
Böôùc 5: Bieân dòch laïi chöông trình vaø xem keát quaû ôû file.sim. Nhaän xeùt.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 266
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
3. Thí nghieäm 3
Muïc ñích: Söû duïng baûng söï thaät trong truth_table ñeå thöïc hieän maïch
Thieát keá 2 boä giaûi maõ 2→ 4 söû duïng GAL16V8 hoaït ñoäng theo baûng söï thaät sau:
Input
G
B
1
0
1
0
1
1
1
1
0
x
•
A
0
1
0
1
x
Y3
1
1
1
0
1
Output
Y2 Y1
1
1
1
0
0
1
1
1
1
1
Y0
0
1
1
1
1
1
2
3
4
5
6
7
8
9
11
G1
A1
B1
G2
A2
B2
U2
I0
I1
I2
I3
I4
I5
I6
I7
I8
I9
F0
F1
F2
F3
F4
F5
F6
F7
16V8
Chöông trình
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Module decod2t4
Title 'giai ma 2 sang 4
Thi nghiem 3'
23
24
25
26
27
28
truth_table (inputs2-> outputs2)
[1,0,0] ->
[H,H,H,L];
[1,0,1] ->
[H,H,L,H];
[1,1,0] ->
[H,L,H,H];
[1,1,1] ->
[L,H,H,H];
[0,X,X] ->
[H,H,H,H];
Decod2t4 device 'P16V8S';
G1,G2
pin 2,5;
A1,B1,A2,B2
pin 3,4,6,7;
Y01,Y11,Y21,Y31
pin 19,18,17,16;
Y02,Y12,Y22,Y32
pin 15,14,13,12;
H,L,X = 1,0,.x.;
inputs1 = [G1,B1,A1];
outputs1 = [Y31,Y21,Y11,Y01] ;
inputs2 = [G2,B2,A2];
outputs2 = [Y32,Y22,Y12,Y02];
Truth_table (inputs1->outputs1)
[1,0,0] ->
[H,H,H,L];
[1,0,1] ->
[H,H,L,H];
[1,1,0] ->
[H,L,H,H];
[1,1,1] ->
[L,H,H,H];
[0,X,X] ->
[H,H,H,H];
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 267
https://fb.com/tailieudientucntt
12
13
14
15
16
17
18
19
Y32
Y22
Y12
Y02
Y31
Y21
Y11
Y01
Bài Giảng Kỹ Thuật Số
•
Phụ lục B
29
30
31
32
33
34
test_vectors (inputs1-> outputs1)
[1,0,0] ->
[H,H,H,L];
[1,0,1] ->
[H,H,L,H];
[1,1,0] ->
[H,L,H,H];
[1,1,1] ->
[L,H,H,H];
[0,1,0] ->
[H,H,H,H];
35
36
37
38
39
40
41
test_vectors (inputs2-> outputs2)
[1,0,0] ->
[H,H,H,L];
[1,0,1] ->
[H,H,L,H];
[1,1,0] ->
[H,L,H,H];
[1,1,1] ->
[L,H,H,H];
[0,0,1] ->
[H,H,H,H];
end
Giaûi thích chöông trình
Chöông trình treân duøng phaùt bieåu truth_table ñeå khai baùo baûng söï thaät hoaït ñoäng
cuûa heä thay cho bieåu thöùc. Trong tröôøng hôïp naøy caùch vieát truth_table seõ goïn hôn
caùch vieát theo bieåu thöùc (equations).
•
Bieân dòch chöông trình
Böôùc 1: Nhaäp file nguoàn trong thí nghieäm treân
Böôùc 2:
Bieân dòch chöông trình duøng phaàn meàm ABEL
Töø thö muïc ABEL ñaùnh leänh abe filename
Böôùc 3: Xem laïi caùc file môùi hình thaønh (file.doc, file.list)
Böôùc 4: Theâm töø khoùa flag ‘-t1’ vaøo sau phaùt bieåu module
Module mod-id flag ‘-t1’
Böôùc 5: Bieân dòch laïi chöông trình vaø xem keát quaû ôû file.sim. Nhaän xeùt.
4. Thí nghieäm 4
Muïc ñích: Thieát keá vôùi mode thanh ghi cho maïch tuaàn töï
Thieát keá boä ñeám leân (ñoàng boä) 16 duøng GAL16V8. Boä ñeám coù ngoõ Cl ñoàng
boä, tính cöïc möùc 0 nhö hình sau
CK
CL
1
2
3
4
5
6
7
8
9
11
U2
I0
I1
I2
I3
I4
I5
I6
I7
I8
I9
F0
F1
F2
F3
F4
F5
F6
F7
12
13
14
15
16
17
18
19
Q0
Q1
Q2
Q3
16V8
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 268
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
Phụ lục B
Ta thieát laäp baûng traïng thaùi hieän taïi vaø keá tieáp cho caùc ngoõ ra Q3Q2Q1Q0
Traïng thaùi hieän taïi
Q3
Q2
Q1
Q0
0
0
0
0
1
0
0
0
0
0
1
0
1
0
0
1
0
1
0
0
1
0
1
0
1
1
0
0
1
1
0
1
0
0
0
1
0
0
1
1
0
1
0
1
1
1
1
0
0
0
1
1
1
0
1
1
0
1
1
1
1
1
1
1
+
Q3
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
0
Traïng thaùi keá
Q2+ Q1+ Q0+
1
0
0
0
1
0
1
1
0
1
0
0
0
1
1
1
0
1
1
1
1
0
0
0
1
0
0
0
0
1
1
1
0
1
0
0
0
1
1
1
1
0
1
1
1
0
0
0
Töø ñoù ruùt ra ñöôïc
Q0 + = Q0 .Cl
(vôùi Cl tích cöïc möùc thaáp)
Q1+ = Q1 ⊕ Q0.Cl
Q 2 + = Q 2 ⊕ (Q1.Q0).Cl
Q3 + = Q3 ⊕ (Q 2.Q1.Q0).Cl
Theo caáu truùc GAL16V8, chaân 1 laø chaân CK ñoàng boä caùc thanh ghi beân trong
•
Chöông trình
1
2
3
4
5
6
module count4
title 'COUNTER
Bai so 1'
Counter device
CK,CL
Q3,Q2,Q1,Q0
7
8
Count = [Q3,Q2,Q1,Q0];
C,H,L = .C.,1,0 ;
"Xung CK tac dong canh len
9
10
11
12
13
Equations
Q0 :=
Q1 :=
Q2 :=
Q3 :=
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
MOD16
'P16V8R';
pin 1,2 ;
pin 19,18,17,16;
!Q0 & CL;
(Q1$Q0) & CL;
(Q2$(Q1&Q0))&CL;
(Q3$(Q2&Q1&Q0))&CL;
Trang 269
https://fb.com/tailieudientucntt
Bài Giảng Kỹ Thuật Số
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
•
Phụ lục B
Test_vectors([CK,CL] -> Count)
[C,L]
->
0 ;
[C,H]
->
1 ;
[C,H]
->
2 ;
[C,H]
->
3 ;
[C,H]
->
4 ;
[C,H]
->
5 ;
[C,H]
->
6 ;
[C,H]
->
7 ;
[C,H]
->
8 ;
[C,H]
->
9 ;
[C,H]
->
10 ;
[C,H]
->
11 ;
[C,H]
->
12 ;
[C,H]
->
13 ;
[C,H]
->
14 ;
[C,H]
->
15 ;
[C,H]
->
0 ;
END
Giaûi thích
Trong mode thanh ghi caùc bieåu thöùc söû duïng toaùn töû gaùn ‘:=’ ñeå bieãu dieãn ngoõ ra laø
heä tuaàn töï (thanh ghi).
•
Bieân dòch chöông trình
Böôùc 1: Nhaäp file nguoàn trong thí nghieäm treân
Böôùc 2:
Bieân dòch chöông trình duøng phaàn meàm ABEL
Töø thö muïc ABEL ñaùnh leänh abe filename
Böôùc 3: Xem laïi caùc file môùi hình thaønh (file.doc, file.list)
Böôùc 4: Theâm töø khoùa flag ‘-t1’ vaøo sau phaùt bieåu module
Module mod-id flag ‘-t1’
Böôùc 5: Bieân dòch laïi chöông trình vaø xem keát quaû ôû file.sim. Nhaän xeùt.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 270
https://fb.com/tailieudientucntt
BOÄ GIAÙO DUÏC & ÑAØO TAÏO
TRÖÔØNG ÑAÏI HOÏC KYÕ THUAÄT COÂNG NGHEÄ
THAØNH PHOÁ HOÀ CHÍ MINH
Ths. NGUYEÃN TROÏNG HAÛI
TOÙM TAÉT BAØI GIAÛNG
VERILOG
LÖU HAØNH NOÄI BOÄ
07/2005
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
CHÖÔNG I
TOÅNG QUAN
Verilog HDL laø moät trong hai ngoân ngöõ moâ phoûng phaàn cöùng thoâng duïng nhaát,
ñöôïc duøng trong thieát keá IC, ngoân ngöõ kia laø VHDL.
HDL cho pheùp moâ phoûng caùc thieát keá deã daøng, söûa chöõa loãi, hoaëc thöïc nghieäm
baèng nhöõng caáu truùc khaùc nhau. Caùc thieát keá ñöôïc moâ taû trong HDL laø nhöõng kyõ
thuaät ñoäc laäp, deã thieát keá, deã thaùo gôõ, vaø thöôøng deå ñoïc hôn ôû daïng bieåu ñoà, ñaëc
bieät laø ôû caùc maïch ñieän lôùn.
Verilog thöôøng ñöôïc duøng ñeå moâ taû thieát keá ôû boán daïng:
Thuaät toaùn (moät soá leänh gioáng ngoân ngöõ C nhö: if, case, for,while…).
Chuyeån ñoåi thanh ghi (keát noái baèng caùc bieåu thöùc Boolean).
Caùc coång keát noái( coång: OR, AND, NOT…).
Chuyeån maïch (BJT, MOSFET).
Ngoân ngöõ naøy cuõng chæ roõ caùch thöùc keát noái, ñieàu khieån vaøo/ra trong moâ phoûng.
Caáu truùc chöông trình duøng ngoân ngöõ Verilog
// Khai baùo module
Module teân chöông trình (teân bieán I/O); // teân chöông trình truøng teân file.v.
Input [msb:lsb] bieán;
Output [msb:lsb] bieán;
Reg [msb:lsb] bieán reg;
Wire [msb: lsb] bieán wire;
// Khai baùo khoái always, hoaëc khoái initial.
… caùc leänh …
Endmodule
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 1
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông II
CHÖÙC NAÊNG CAÙC TÖØ VÖÏNG
TRONG VERILOG
Nhöõng taäp tin vaên baûn nguoàn Verilog bao goàm nhöõng bieåu hieän thuoäc tính töø vöïng
sau ñaây:
I.
Khoaûng traéng
Khoaûng traéng ngaên nhöõng töø vaø coù theå chöùa khoaûng caùch, khoaûng daøi, doøng
môùivaø daïng ñöôøng daãn. Do ñoù, moät leänh coù theå ñöa ra nhieàu doøng phöùc taïp
hôn maø khoâng coù nhöõng ñaëc tính ñaëc bieät.
II.
Chuù giaûi
Nhöõng chuù giaûi coù theå chæ ñònh baèng hai caùch: ( gioáng trong C/C++)
Chuù giaûi ñöôïc vieát sau hai daáu gaïch xieân (//). Ñöôïc vieát treân cuøng moät doøng.
Ñöôïc vieát giöõa /* */, khi vieát nhieàu doøng chuù giaûi.
III. Chöõ soá:
Löu tröõ soá ñöôïc ñònh nghóa nhö laø moät con soá cuûa caùc bit, giaù trò coù theå laø: soá
nhò phaân, baùt phaân, thaäp phaân, hoaëc thaäp luïc phaân.
Ví duï: 3’b001, 5’d30 = 5’b11110,
16’h5ED4 = 16’d24276 = 16’b0101111011010100
IV. Töø ñònh danh:
Töø ñònh danh do ngöôøi duøng quy ñònh cho bieán soá, teân haøm, teân moâñun, teân
khoái vaø teân tröôøng hôïp. Töø ñònh danh baét ñaàu baèng moät maãu töï hoaëc ñöôøng
gaïch döôùi ’_’ ( khoâng baét ñaàu baèng moät con soá hoaëc $ ) vaø keå caû moïi chöõ soá
cuûa maåu töï, nhöõng con soá vaø ñöôøng gaïch döôùi, töø ñònh danh trong Verilog thì
phaân bieät daïng chöõ.
V.
Cuù phaùp:
Kí hieäu cho pheùp:
ABDCE…abcdef…1234567890_$
Khoâng cho pheùp: caùc kí hieäu khaùc -, &, #, @
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 2
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
VI. Toaùn töû:
Toaùn töû laø moät, hai, hoaëc ba kí töï duøng ñeå thöïc hieän caùc toaùn haïng treân bieán.
Caùc toaùn töû bao goàm >, +, &, !=.
VII. Töø khoùaVerilog:
Coù nhöõng töø maø phaûi coù yù nghóa ñaëc bieät trong Verilog. Ví duï: assign, case,
while, wire, reg, and, or, nand, vaø module. Chuùng khoâng ñöôïc duøng nhö töø
ñònh danh. Töø khoùa Verilog cuõng bao goàm caû chæ daãn chöông trình bieân dòch
vaø System Task (heä thoáng soaïn thaûo) vaø caùc haøm.
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 3
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông III
CAÙC COÅNG CÔ BAÛN
TRONG VERILOG
Caùc coång logic cô sôû laø moät boä phaän cuûa ngoân ngöõ Verilog. Coù hai ñaëc tính ñöôïc
chæ roõ laø: drive_strenght vaø delay.
Drive_strenght chæ söùc beàn cuûa coång. Ñoä beàn ngoõ ra laø söï keát noái moät chieàu
ñeán nguoàn, keá ñoù taïo neân söï keát noái trong suoát trans daãn, keát thuùc laø toång trôû
keùo leân hoaëc xuoáng. Drive_strenght thöôøng khoâng ñöôïc chæ roõ, trong tröôøng
hôïp naøy ñoä beàn maëc ñònh laø strong1 vaø strong0 .
Delay: neáu delay khoâng ñöôïc chæ roõ, thì khi ñoù coång khoâng coù trì hoaõn truyeàn
taûi; neáu coù hai delay ñöôïc chæ ñònh, thì tröôùc tieân laø mieâu taû trì hoaõn leân, thöù
hai laø trì hoaõn xuoáng. Neáu chæ coù moät delay ñöôïc chæ ñònh, thì khi ñoù trì hoaõn
leân xuoáng laø nhö nhau. Delay ñöôïc boû qua trong toång hôïp. Phöông phaùp cuûa
söï trì hoaõn chæ ñònh naøy laø moät tröôøng hôïp ñaëc bieät cuûa “Parameterized
Modules”. Caùc tham soá cho caùc coång cô sôû phaûi ñöôïc ñònh nghóa tröôùc nhö
delay.
I.
Caùc coång cô baûn:
Caùc coång cô baûn coù moät ngoõ ra, vaø coù moät hoaëc nhieàu ngoõ vaøo. Trong caùc
coång, cuù phaùp cuï theå bieåu dieãn beân döôùi, caùc töø khoaù cuûa caùc coång: and, or,
nand, nor.
1.
Cuù phaùp:
GATE (drive_strength)#(delays)
Teân töø khoùa coång _teân (output, input_1, input_2, …, input_N);
Delay: #( leân, xuoáng) hoaëc #leân_vaø_xuoáng hoaëc #( leân_vaø_xuoáng)
2.
Ví duï:
And c1 (o, a, b, c. d); // coù 4 ngoõ vaøo coång And goïi laø c1
c2 (p, f, g); // vaø 2 ngoõ vaøo coång and goïi laø c2
Or #(4,3) ig ( o, b, c); // coång Or ñöôïc goïi laø ig, rise time = 4, fall time = 3
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 4
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Xor #(5) xor1 (a, b, c); // sau 5 ñôn vò thôøi gian thì a = b xor c
II.
Coång buf, not:
Caùc coång naøy thöïc thi ñeäm vaø ñaûo theo theo thöù töï ñòmh saún. Chuùng coù moät
ngoõ vaøo, hai hay nhieàu ngoõ ra. Cuù phaùp cuï theå bieåu dieãn ôû beân döôùi, töø khoaù
buf, not.
1.
Cuù phaùp:
Teân töø khoùa coång _teân (output_1, output_2, …, output_N, input);
2.
Ví duï:
Not #(5) not_1( a,c); // sau 5 ñôn vò thôøi gian thì a = ñaûo c
Buf c1 (o, p, q, r, in); // boä ñeäm 5 ngoõ ra vaø 2 ngoõ ra
c2 (p, f, g);
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 5
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông IV
CAÙC DAÏNG DÖÕ LIEÄU
I.
Ñaët giaù trò:
Verilog bao goàm 4 giaù trò cô baûn. Haàu heát caùc daïng döõ lieäu Verilog chöùa caùc
giaù trò sau:
0: möùc logic 0, hoaëc ñieàu kieän sai.
1: möùc logic 1, hoaëc ñieàu kieän ñuùng.
X: möùc logic tuyø ñònh
Z: traïng thaùi toång trôû cao.
X vaø Z duøng coù giôùi haïn trong toång hôïp (synthesis)
II.
Wire:
Moâ taû vaät lieäu ñöôøng daây daãn trong moät maïch ñieän vaø ñöôïc duøng ñeå keát noái
caùc coång hay caùc module. Giaù trò cuûa Wire coù theå ñoïc, nhöng khoâng ñöôïc gaùn
trong haøm (function) hoaëc khoái (block). Wire khoâng löu tröõ giaù trò cuûa noù
nhöng vaãn phaûi ñöôïc thöïc thi bôûi 1 leänh gaùn keá tieáp hay bôûi söï keát noái Wire
vôùi ngoõ ra cuûa 1 coång hoaëc 1 module. Nhöõng daïng ñaëc bieät khaùc cuûa Wire:
Wand(wired_and): giaù trò phuï thuoäc vaøo möùc logic And toaøn boä boä ñieàu khieån
keát noái ñeán Wire.
Wor (wired_or): giaù trò phuï thuoäc vaøo möùc logic Or toaøn boä boä ñieàu khieån keát
noái ñeán Wire.
Tri(three_state): taát caû boä ñieàu khieån keát noái ñeán 1 tri phaûi ôû traïng thaùi toång
trôû cao.
1.
Cuù phaùp:
Wire [msb:lsb] teân bieán wire.
Wand [msb:lsb] teân bieán wand.
Wor [msb:lsb] teân bieán wor.
Tri [msb:lsb] teân bieán tri.
2.
Ví duï:
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 6
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Wire c;
Wand d;
Assign d= a;
Assign d= b;// giaù trò d laø möùc logic cuûa pheùp And a vaø b.
Wire [9:0] A; // vectô A coù 10 wire.
III. Reg:
Reg (register) laø moät ñoái töôïng döõ lieäu maø noù chöùa giaù trò töø moät thuû tuïc gaùn
keá tieáp. Chuùng chæ ñöôïc duøng trong haøm vaø khoái thuû tuïc. Reg laø moät loaïi bieán
Verilog vaø khoâng nhaát thieát laø thanh ghi töï nhieân. Trong thanh ghi nhieàu bit,
data ñöôïc löu tröõ baèng nhöõng chöõ soá khoâng daáu vaø khoâng coù kí hieäu ñuoâi môû
roäng, ñöôïc thöïc hieän maø ngöôøi söû duïng coù chuû y ùlaø soá buø hai.
1.
Cuù phaùp:
Reg [msb:lsb] teân bieán reg.
2.
Ví duï:
Reg a; // bieán thanh ghi ñôn giaûn 1 bit.
Reg [7:0] A; // moät vectô 8 bit; moät bank cuûa 8 thanh ghi.
Reg [5:0]b, c; // hai bieán thanh ghi 6 bit.
IV. Input, Output, Inout:
Nhöõng töø khoaù naøy bieåu thò ngoõ vaøo, ngoõ ra, vaø port hai chieàu cuûa moät module
hoaëc task. Moät port ngoõ ra coù theå ñöôïc caáu hình töø caùc daïng: wire, reg, wand,
wor, hoaëc tri. Maëc ñònh laø wire.
1.
Cuù phaùp:
Input [msb:lsb] port ngoõ vaøo.
Output [msb:lsb] port ngoõ ra.
Inout [msb:lsb] port ngoõ vaøo,ra hai chieàu.
2.
Ví duï:
Module sample (b, e, c, a);
Input a; // moät ngoõ vaøo maëc ñònh laø kieåu wire.
Output b, e; // hai ngoõ ra maëc ñònh laø kieåu wire.
Output [1:0] c; /* ngoõ ra hai bit, phaûi ñöôïc khai baùotrong moät leänh rieâng*/
Reg [1:0] c; // ngoõ c ñöôïc khai baùo nhö moät reg.
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 7
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
V.
Phaàn Verilog
Integer (Soá nguyeân):
Integer laø moät bieán ña naêng. Trong toång hôïp chuùng ñöôïc duøng chuû yeáu cho
voøng laëp, tham soá, vaø haèng soá. Chuùng hoaøn toaøn laø reg. Tuy nhieâu chuùng chöùa
döõ lieäu baèng nhöõng soá coù daáu, trong khi ñoù khai baùo daïng reg chöùa chung
baèng soá khoâng daáu. Neáu chuùng chöùa nhöõng soá maø khoâng ñònh nghóa thôøi gian
bieân dòch thì kích thöôùc maëc ñònh laø 32 bit. Neáu chuùng chöùa haèng, söï toång hôïp
ñieàu chænh caùc soá coù kích thöôùc nhoû nhaát caàn thieát cho söï bieân dòch.
1.
Cuù phaùp:
Integer teân bieán nguyeân;
…teân haèng nguyeân…;
2.
Ví duï:
Integer a; // soá nguyeân ñôn giaûn 32bit.
Assign b= 63; // maëc ñònh laø moät bieán 7 bit.
VI. Supply 0, Supply1:
Xaùc ñònh choå ñöôøng daãn leân möùc logic 0 ( ñaát), logic 1( nguoàn) theo thöù töï
ñònh saün.
VII. Time:
Time laø moät löôïng 64 bit maø ñöôïc söû duïng cuøng vôùi $time, heä thoáng thao taùc
chöùa löôïng thôøi gian moâ phoûng. Time khoâng ñöôïc hoã trôï toång hôïp vaø vì theá
chæ ñöôïc duøng trong muïc ñích moâ phoûng.
1.
Cuù phaùp:
Time bieán time;
2.
Ví duï:
Time c;
c = $time; // c = thôøi gian moâ phoûng doøng ñieän.
VIII. Parameter (Tham soá):
Moät Parameter xaùc ñònh 1 haèng soá maø ñöôïc ñaët khi baïn cho ví duï cuï theå laø
moät module. Caùc naøy cho pheùp ta coù theå söûa chöõa.
1.
Cuù phaùp:
Parameter par_1= gaùi trò, par_2= gaùi trò, …;
Parameter [giôùi haïn] par_3 = giaù trò;
2.
Ví duï:
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 8
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Parameter add = 2b’00, sub = 3b’111;
Parameter n = 4;
Parameter [3:0] par_2 = 4b’1010;
…
reg [n-1:0] harry;// moät thanh ghi 4 bít maø ñoä roäng ñöôïc ñaët bôûi tham soá n ôû
treân.
always @(x)
y = {{(add - sub) {x}}}
if (x) begin
state = par_2[1];
else
state =par_2[2];
end.
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 9
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
ChöôngV
TOAÙN TÖÛ
I.
Toaùn töû soá hoïc:
Nhöõng toaùn töû naøy thöïc hieän caùc pheùp tính soá hoïc. Daáu ’+’ vaø ’-’ coù theå ñöôïc
söû duïng moät trong hai toaùn töû ñôn (-z) hoaëc keùp (x - y).
1. Toaùn töû:
+, -, *, /, %.
2. Ví duï:
parameter n = 4;
Reg[3:0] a, c, f, g, count;
f= a +c;
g= c –n;
count = (count +1) % 16; // coù theå ñeám töø 0 ñeán 15.
II.
Toaùn töû quan heä:
Toaùn töû quan heä so saùnh hai toaùn haïng vaø traû veà moät ñôn bit laø 0 hoaëc 1.
Nhöõng toaùn töû naøy toång hôïp vaøo duïng cuï so saùnh. Bieán Wire vaø Reg laø nhöõng
bieán döông. Vì theá, (-3b001) = (3b111) vaø (-3b001) > ( 3b110) nhöng neáu laø
soá nguyeân thì -1< 6.
1. Caùc toaùn töû quan heä:
<, <=, >, >=, = =, !=.
2. Ví duï:
If (x= =y) e =1;
Else e= 0;
// so saùnh hai vector a, b
reg [3:0] a, b;
if (a[3] = =b [3]) a[2:0] >b[2:0];
else b[3];
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 10
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
III. Toaùn töû bit_wire:
So saùnh töøng bit hai toaùn toaùn haïng.
1. Caùc toaùn töû:
~ (bitwire NOT), & (bitwire AND),
^~ (bitwire XNOR).
| (bitwire OR), ^ (bitwire XOR), ~^ hoaëc
2. Ví duï:
Module and2(a, b, c);
Input [1:0] a, b;
Output [1:0] c;
Assign c = a & b;
Endmodule
IV. Toaùn töû logic:
Toaùn töû logic traû veà 1 bit ñôn 0 hoaëc 1. chuùng gioáng nhö toaùn töû bitwire chæ laø
nhöõng toaùn haïng ñôn bit. Chuùng coù theå laøm vieäc treân bieåu thöùc, soá nguyeân
hoaïc nhoùm bit, vaø coi nhu taát caû caùc giaù trò khoâng baèng 0 laø ’1’. Toaùn töû logic
ñöôïc duøng nhieàu trong leänh ñieàu kieän (if… else), khi chuùng laøm vieäc treân bieåu
thöùc.
1.
Toaùn töû:
!(NOT), && (AND), || (OR)
2.
Ví duï:
Wire [7:0] x, y, z;
Reg a;
…
if ((x= = y)&&(z)) a=1;
else a=! x;
V.
Toaùn töû bieán ñoåi:
Coù taùc duïng treân taát caû caùc bit cuûa moät vectô toaùn haïng vaø traû veà giaù trò ñôn
bit. Nhöõng toaùn töû naøy laø hình thöùc töï ñoåi soá cuûa caùc toaùn töû bitwire ôû treân.
1.
Caùc toaùn töû:
~ (bieán ñoåi NOT), & (bieán ñoåi AND), ~&( bieán ñoåi NAND), | (bieán ñoåi OR), ~|
(bieán ñoåi NOR), ^ (bieán ñoåi XOR), ~^ hoaëc ^~ (bieán ñoåi XNOR).
2.
Ví duï:
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 11
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Module chk_zero (a,z);
Input [2:0] a;
Output z;
Assign z = ~| a;
Endmodule
VI. Toaùn töû gheùp:
Dòch toaùn töû ñaàu baèng chöõ soá cuûa caùc bit ñöôïc ñònh nghóa bôûi toaùn töû thou hai.
Vò trí coøn troáng seõ ñöôïc ñieàn vaøo vôùi nhöõng soá 0 cho caû hai tröôøng hôïp dòch
traùi hoaëc phaûi.
1.
Toaùn töû:
<< ( dòch traùi), >> (dòch phaûi).
2.
Ví duï:
assign c = a<<2; c = a dòch traùi 2 bit caùc choã troáng ñöôïc ñieàn vôùi nhöõng soá 0.
VII. Toaùn töû dòch:
Gheùp hai hoaëc nhieàu toaùn haïng thaønh moät vectô lôùn.
1.
Toaùn töû:
{} (concatenation)
2.
Ví duï:
Wire [1:0] a, b;
Wire [2:0] x;
Wire [3:0] y, Z;
Assign x = {1’b0, a}; // x[2] = 0, x[1] = a[1], x[0] = a[0].
Assign y = {a, b}; // y[3]= a[1], y[2] = a[0], y[1] = b[1], y[0] = b[0].
VIII. Toaùn töû thöù baûn:
Taïo ra nhieàu baûn sao cuûa moät muïc choïn.
1.
Toaùn töû:
{n{ muïc choïn }} n nhoùm thöù baûn trong moät muïc choïn.
2.
Ví duï:
Wire [1:0] a, b;
Wire [3:0] x;
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 12
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Assign x = {2{1’b0},a}; // x= {0, 0, a}.
IX. Toaùn töû ñieàu kieän:
Gioáng nhö C/C++. Chuùng ñònh giaù moät trong hai bieåu thöùc cô baûn trong moät
ñieàu kieän. Noù seõ toång hôïp thaønh boä ña coäng (MUX).
1.
Toaùn töû :
(ñieàu kieän)? keát quaû khi ñieàu kieän ñuùng : keát quaû khi ñieàu kieän sai.
2.
Ví duï:
assign a = (g) ? x : y;
Assign a = ( inc = =2) ? a+1: a-1;
X.
Thöù töï toaùn töû:
Nhöõng toaùn töû trong möùc gioáng nhau ñònh giaù töø traùi sang phaûi
Toaùn töû
Teân
[]
Choïn bit, choïn phaàn
()
Phaàn trong ngoaëc ñôn
!, ~
Möùc logic vaø bit_wire NOT
&, |, ~&, ~|, ^, ~^ Bieán ñoåi: AND, OR, NAND, NOT, XOR, XNOR.
+, -
Daáu chæ soá aâm soá döông.
{}
Gheùp noái { 3’b101,3’b110} = 6’b101110
{{ } }
Thöù baûn {3{3’b101 } }=9’b101101101
*, /, %
Nhaân, chia, phaàn traêm.
+, -
Coäng tröø nhò phaân.
<<, >>
Dòch traùi, phaûi.
<, <=, >, >=
Daáu so saùnh. Bieán Reg vaø wire ñöôïc laáy baèng nhöõng soá
döông.
= =, !=
Baèng vaø khoâng baèng trong toaùn töû logic.
&
Bit_wire AND, and taát caû caùc bit vôùi nhau.
^, ~^
Bit_wire XOR, Bit_wire XNOR.
|
Bit_wire OR.
&&, ||
Toaùn töû logic AND, OR.
?:
x = ( ñieàu kieän ) T:F
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 13
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông VI
TOAÙN HAÏNG
I.
Literals (daïng kí töï):
Laø toaùn haïng coù giaù trò khoâng ñoåi maø ñöôïc duøng trong bieåu thöùc Verilog. Coù
hai daïng kí töï laø:
Chuoãi: laø moät maûng coù nhieàu kí töï ñöôïc ñaët trong daáu ””.
Chöõ soá: laø nhöõng soá khoâng ñoåi, nhò phaân, baùt phaân, thaäp phaân, hoaëc soá hex.
1.
Cuù phaùp caùc chöõ soá:
n’F dddd…
Trong ñoù:
n : soá nguyeân mieâu taû soá bit.
F: moät trong boán ñònh daïng sau: b( soá nhò phaân), o( soá baùt phaân), d( soá thaäp
phaân), h( soá hex).
2.
Ví duï:
“time is”// chuoãi kí töï.
267 // maëc ñònh 32 bit soá thaäp phaân.
2’b01 // 2 bit nhò phaân.
20’h B36E // 20 bit soá hex.
‘o62 // 32 bit baùt phaân.
II.
Choïn 1 phaàn töû bit vaø choïn 1 phaàn caùc bit.
Ñaây laø söï löïa choïn moät bít ñôn hoaëc moät nhoùm bit theo thöù töï, töø moät wire,
reg hoaëc töø tham soá ñaët trong ngoaïc [ ]. Choïn 1 phaàn töû bit vaø choïn 1 phaàn caùc
bit coù theå ñöôïc duøng nhö laø caùc toaùn haïng trong bieåu thöùc baèng nhieàu caùch
thöùc gioáng nhau maø caùc ñoái töôïng döõ lieäu goác ñöôïc duøng.
1.
Cuù phaùp:
Teân bieán [ thöù töï bit].
Teân bieán [ msb: lsb].
2.
Ví duï:
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 14
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Reg [7:0] a, b;
Reg [3:0] ls;
c = a[7] & b[7];
ls = a[7:4] + b[3:0];
III. Goïi haøm chöùc naêng:
Giaù trò traû veà cuûa moät haøm coù theå ñöôïc duøng tröïc tieáp trong bieåu thöùc maø
khoâng caàn gaùn tröôùc cho bieán reg hoaëc wire. Goïi haøm chöùc naêng nhö laø moät
trong nhöõng toaùn haïng. Chieàu roäng bít cuûa giaù trò traû veà chaéc chaén ñöôïc bieát
tröôùc.
1.
Cuù phaùp:
Teân haøm(danh saùch bieán).
2.
Ví duï:
Assign a = b & c & chk_bc(b, c);
Function chk_bc;
Input c, b;
Chk_bc = b^ c;
Endfunction
IV. Wire, reg, vaø tham soá:
Wire, reg, vaø tham soá coù theå ñuôïc duøng nhö laø caùc toaùn haïng trong bieåu thöùc
Verilog.
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 15
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông VII
MODULES
I.
Khai baùo modules:
Moät module laø baûn thieát keá chuû yeáu toàn taïi trong Verilog. Doøng ñaàu tieân cuûa
khai baùo module chæ roõ danh saùch teân vaø port (caùc ñoái soá). Nhöõng doøng keá tieáp
chæ roõ daïng I/O (input, output, hoaëc inout) vaø chieàu roäng cuûa moãi port. Maëc
ñònh chieàu roäng port laø 1 bit.
Sau ñoù, nhöõng bieán port phaûi ñöôïc khai baùo wire, wand, …, reg. Maëc ñònh laø
wire. Nhöõng ngoõ vaøo ñaëc tröng laø wire khi döõ lieäu ñöôïc choát bean ngoaøi
module. Caùc ngoõ ra laø daïng reg neáu nhöõng tín hieäu cuûa chuùng ñöôïc chöùa trong
khoái always hoaëc initial.
1.
Cuù phaùp:
Module teân module (danh saùch port);
Input [msb:lsb] danh saùch port ngoõ vaøo;
Output [msb:lsb] danh saùch port ngoõ ra;
Inout [ msb:lsb ] danh saùch port vaøo_ ra;
… caùc leänh…
endmodule
2.
Ví duï:
Module add_sub(add, in1, in2, out);
Wire, reg, vaø tham soá:
Input[7:0 ] in1, in2;
Wire in1, in2;
Output [7:0] out;
Reg out;
… caùc leänh khaùc…
Endmodule
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 16
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
II.
Phaàn Verilog
Chæ ñònh lieân tieáp:
Caùc chæ ñònh lieân tieáp ñöôïc duøng ñeå gaùn moät giaù trò leân treân moät wire trong
moät module. Ñoù laø caùc chæ ñònh thoâng thöôøng beân ngoaøi khoái always hoaëc khoái
initial. Caùc chæ ñònh lieân tieáp ñöôïc thöïc hieän vôùi moät leänh gaùn (assign) roõ raøng
hoaëc baèng söï chæ ñònh moät giaù trò ñeán moät wire trong luùc khai baùo. Chuù yù raèng,
caùc leänh chæ ñònh lieân tieáp thì toàn taïi vaø ñöôïc chaïy lieân tuïc trong suoát quaù
trình moâ phoûng. Thöù töï caùc leänh gaùn khoâng quan troïng. Moïi thay ñoåi beân phaûi
cuûa baát cöù ngoõ vaøo seõ laäp töùc thay ñoåi beân traùi cuûa caùc ngoõ ra.
1.
Cuù phaùp:
Wire bieán wire = giaù trò;
Assign bieán wire = bieåu thöùc;
2.
Ví duï:
Wire [ 1:0 ] a = 2’b 01;
Assign b = c &d;
Assign d = x | y;
III. Module instantiations:
Nhöõng khai baùo module laø nhöõng khuoân maãu maø noù ñöôïc taïo neân töø caùc ñoái
töôïng thöïc teá ( instantiation). Caùc module ñôn cöû beân trong caùc module khaùc,
vaø moãi daãn chöùng taïo moät ñoái töôïng ñoäc nhaát töø khuoân maãu. Ngoaïi tröø ñoù laø
module möùc treân laø nhöõng daãn chöùng töø chính chuùng.
Caùc port cuûa module ví duï phaûi thoûa nhöõng dònh nghóa trong khuoân maãu. Ñaây
laø maët lyù thuyeát: baèng teân, söû duïng daáu chaám(.) ”.teân port khuoân maãu ( teân
cuûa wire keát noái ñeán port)”. Baèng vò trí, ñaët nhöõng port ôû nhöõng vò trí gioáng
nhau trong danh saùch port cuûa caû khuoân maãu laãn instance.
1.
Cuù phaùp:
Teân instance1 (danh saùch keát noái port );
Teân instance2(danh saùch keát noái port);
…
2.
Ví duï:
// ñònh nghóa module
module and4(a,b,c);
input [3:0]a,b;
output [3:0]c;
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 17
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
assign c = a&b;
endmodule
// module instantiations
wire [3:0] in1, in2;
wire [3:0] o1, o2;
// ñaët vò trí
and4 C1(in1, in2,o1);
// teân
and4 C2(.c(o2), .a(in1), .b(in2));
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 18
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông VIII
KHUOÂN MAÃU HAØNH VI
(BEHAVIORAL)
Verilog coù 4 möùc khuoân maãu:
• Chuyeån maïch. Khoâng ñöôïc ñeà caäp ñeán ôû ñaây.
• Coång.
• Möùc traøn döõ lieäu.
• Haønh vi hoaëc thuû tuïc ñöôïc ñeà caäp ôû beân döôùi
Caùc leänh thuû tuïc Verilog ñöôïc duøng taïo moät maãu thieát keá ôû möùc cao hôn. Chuùng
chæ ra nhöõng caùch thöùc maïnh cuûa veäc laøm ra nhöõng thieát keá phöùc taïp. Tuy nhieân,
nhöõng thay ñoåi nhoû n phöông phaùp maõ hoùa coù theå gay ra bieán ñoåi lôùn trong phaàn
cöùng. Caùc leänh thuû tuïc chæ coù theå ñöôïc duøng trong nhöõng thuû tuïc.
I.
Nhöõng chæ ñònh theo thuû tuïc:
Laø nhöõng chæ ñònh duøng trong phaïm vi thuû tuïc Verilog (khoái always vaø initial).
Chæ bieán reg vaø integers (vaø choïn ñôn bit/ nhoùm bit cuûa chuùng, vaø keát noái
thoâng tin) coù theå ñöôïc ñaët beân traùi daáu ‘=’ trong thuû tuïc. Beân phaûi cuûa chæ ñònh
laø moät bieåu thöùc maø coù theå duøng baát cöù daïng toaùn töû naøo.
II.
Delay trong chæ ñònh:
Trong chæ ñònh treã ∆t laø khoaûng thôøi gian traûi qua tröôùc khi moät leänh ñöôïc thöïc
thi vaø beân traùi leänh gaùn ñöôïc taïo ra. Vôùi nhieàu chæ ñònh treã (intra-assignment
delay), beân phaûi ñöôïc ñònh giaù trò tröïc tieáp nhöng coù moät delay cuûa ∆t tröôùc
khi keát quaû ñöôïc ñaët beân traùi leänh gaùn. Neáu theâm moät quaù trình thay ñoåi nöõa
caïnh beân phaûi tín hieäu trong khoaûng thôi gian ∆t,thì khoâng cho keát quaû ôû ngoõ
ra. Delay khoâng ñöôïc hoã trôï bôûi caùc coâng cuï.
1.
Cuù phaùp chæ ñònh thuû tuïc:
Bieán = bieåu thöùc;
Chæ dònh treã:
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 19
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
#∆t bieán = bieåu thöùc;
intra_assignment delay:
bieán = #∆t bieåu thöùc.
2.
Ví duï:
Reg [6:0] sum; reg h, zilch;
Sum[7] = b[7]^c[7]; // thöïc thi töùc thôøi;
Ziltch = #15 ckz & h; // ckz & h ñònh giaù trò töùc thôøi; ziltch thay ñoåi sau 15 ñôn
vò thôøi gian.
#10 hat = b & c;/* 10 ñôn vò thôøi gian sau khi ziltch thay ñoåi, b & c ñöôïc ñònh
giaù vaø hat thay ñoåi*/
III. Chæ ñònh khoái:
Chæ ñònh khoái (=) thöïc hieän lieân tuïc trong thöù töï leänh ñaõ ñöôïc vieát. Chæ ñònh
thöù hai khoâng ñöôïc thöïc thi neáu nhö chæ ñònh ñaàu cho hoaøn thaønh.
1.
Cuù phaùp:
Bieán = bieåu thöùc;
Bieán = #∆t bieåu thöùc;
#∆t bieán = bieåu thöùc;
2.
Ví duï:
Initial
Begin
a = 1; b = 2; c = 3;
#5 a = b + c; // sau 5 ñôn vò thôøi gian thöïc hieän a = b + c = 5.
d = a; // d = a = 5.
Always @(posedge clk)
Begin
Z = Y; Y = X; // thanh ghi dòch.
y = x; z = y; // flip flop song song.
IV. Begin …end:
Leänh khoái begin … end ñöôïc duøng ñeå nhoùm moät vaøi leänh maø moät leänh cuù phaùp
ñöôïc cho pheùp. Bao goàm function, khoái always vaø khoái initial. Nhöõng khoái naøy
coù theå ñöôïc tuøy yù goïi teân. Vaø bao goàm khai baùo reg, integer, tham soá.
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 20
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
1.
Phaàn Verilog
Cuù phaùp:
Begin: teân khoái
Reg[msb:lsb] danh saùch bieán reg;
Integer [msb:lsb] danh saùch integer;
Parameter [msb:lsb] danh saùch tham soá;
…caùc leänh…
End
2.
Ví duï:
function trivial_one;// teân khoái laø: trivial_one
input a;
begin: adder_blk
integer i;
… leänh…
end
V.
Voøng laëp for:
Gioáng nhö c/c++ ñöôïc duøng ñeå thöïc hieän nhieàu laàn moät leänh hoaëc khoái leänh.
Neáu trong voøng laëp chæ chöùa moät leänh thì khoái begin … end coù theå boû qua.
1.
Cuù phaùp:
For (bieán ñeám = giaù trò 1; bieán ñeám </ <=/ >/ >= giaù trò 2;
bieán ñeám = bieán ñeám +/- giaù trò)
begin
… leänh …
end
2.
Ví duï:
For (j = 0; j<=7; j = j+1)
Begin
c[j] = a[j] & b[j];
d[j] = a[j] | b[j];
end
VI. Voøng laëp while:
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 21
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Voøng laëp while thöïc hieän nhieàu laàn moät leänh hoaëc khoái leänh cho ñeán khi bieåu
thöùc trong leänh while ñònh giaù laø sai.
1.
Cuù phaùp:
While (bieåu thöùc)
Begin
… caùc leänh…
end
2.
Ví duï:
While (!overflow)
@(posedge clk);
a = a +1;
end
VII. Khoái leänh if… else if… else:
Thöïc hieän moät leänh hoaëc moät khoái leänh phuï thuoäc vaøo keát quaû cuûa bieåu thöùc
theo sau meänh ñeà if.
Cuù phaùp
If (bieåu thöùc)
Begin
… caùc leänh…
end
else if (bieåu thöùc)
Begin
… caùc leänh…
end
else
Begin
… caùc leänh…
end
VIII. Case:
Leänh case cho pheùp löïa choïn tröôøng hôïp. Caùc leäng trong khoái default thöïc thi
khi khoâng coù tröôøng hôïp löïa choïn so saùnh gioáng nhau. Neáu khoâng coù söï so
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 22
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
saùnh, bao goàm caû default, laø ñuùng, söï toång hôïp seõ taïo ra choát khoâng mong
muoán.
1.
Cuù phaùp:
Case (bieåu thöùc)
Case 1:
Begin
… caùc leänh…
end
Case 2:
Begin
… caùc leänh…
end
Case 3:
Begin
… caùc leänh…
end
…
default:
begin
… caùc leänh…
end
endcase
2.
Ví duï:
Case (alu_clk)
2’b00: aluout = a + b;
2’b01: aluout = a - b;
2’b10: aluout = a & b;
default:
aluout = 1’bx;
endcase
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 23
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông IX
KHOÁI ALWAYS VAØ
KHOÁI INITIAL
I.
Khoái always:
Laø caáu truùc chín trong khuoân maãu RTL (Register Transfer Level). Gioáng chæ
ñònh lieân tuïc, ñaây laø traïng thaùi toàn taïi maø ñöôïc thöïc thi lieân tuïc trong khi moâ
phoûng. Caùi naøy cuõng coù nghóa laø taát caû caùc khoái always trong moät module thöïc
thi moät caùch lieân tuïc. Khoái always coù theå ñöôïc duøng trong choát, flip flop hay
caùc keát noái logic. Neáu caùc leänh cuûa khoái always naèm trong phaïm vi khoái
begin… end thì ñöôïc thöïc thi lieân tuïc, neáu naèm trong khoái fort… join, chuùng
ñöôïc thöïc thi ñoàng thôøi (chæ trong moâ phoûng).
Khoái always thöïc hieän baèng möùc, caïnh leân hoaëc caïnh xuoáng cuûa moät hay
nhieàu tín hieäu (caùc tín hieäu caùch nhau bôûi töø khoùa OR).
Cuù phaùp:
Always @(söï kieän 1 or söï kieän 2 or…)
Begin
… caùc leänh…
end
Always @(söï kieän 1 or söï kieän 2 or…)
Begin: teân khoái
… caùc leänh…
end
II.
Khoái initial
Gioáng nhö khoái always nhöng khoái initial chæ thöïc thi moät laàn töø luùc baét d8aàu
cuûa quaù trình moâ phoûng. Khoái naøy thì tieâu bieåu ñeå bieán khôûi chaïy vaø chæ ñònh
daïng soùng tín hieäu trong luùc moâ phoûng.
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 24
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
1.
Phaàn Verilog
Cuù phaùp:
Initial
Begin
… caùc leänh…
end
2.
Ví duï:
Initial
Begin
Clr = 0;
Clk = 1;
End
Initial
Begin
a = 2’b00;
#50 a = 2’b01;
#50 a = 2’b10;
end
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 25
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông X
HAØM
Haøm ñöôïc khai baùo trong phaïm vi moät module, vaø coù theå ñöôïc goïi töø nhöõng leänh
lieân tuïc, khoái always, hoaëc nhöõng haøm khaùc. Trong leänh chæ ñònh lieân tuïc, cuùng
ñöôïc chæ ñònh lieân tuïc khi baát kì caùc haøm khai baùo ngoõ vaøo thay ñoåi. Trong chöông
trinh chuùng ñöôïc chæ dòng tôùi khi caàn goïi.
Caùc haøm moâ taû söï keát noái logic, vaø khoâng taïo ra choát. Do ñoù moät leänh if maø khoâng
else se moâ phoûng , maëc duø noù coù choát döõ lieäu nhöng moâ phoûng thì khoâng coù. Ñaây laø
tröôøng hôïp dôû cuûa toång hôïp khoâng coù moâ phoûng theo sau. Ñaây laø khaùi nieäm toát ñeå
maõ hoùa haøm, vì vaäy chuùng seõ khoâng taïo ra choát neáu maõ haøm ñöôïc duøng trong moät
chöông trình.
I.
Khai baùo haøm:
Khai baùo haøm laø chæ ra teân haøm, chieàu roäng cuûa haøm giaù trò traû veà, ñoái soá haøm
döõ lieäu vaøo, caùc bieán (reg) duøng trong haøm, vaø tham soá cuïc boä cuûa haøm, soá
nguyeân cuûa haøm.
1.
Cuù phaùp:
Function [msb:lsb] teân haøm;
Input [msb:lsb]bieán vaøo;
Reg [msb:lsb]bieán reg;
Parameter [msb:lsb] tham soá;
Integer [msb:lsb] soá nguyeân;
… caùc leänh…
endfunction
2.
Ví duï
Function [7:0] my_func; // haøm traû veà giaù trò 8 bit
Input [7:0] i;
Reg [4:0] temp;
Integer n;
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 26
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
temp = i[7:4]| (i[3:0]);
my_func = {temp,i[1:0]};
endfunction
II.
Ví duï:
Moät haøm chæ coù chöùa moät döõ lieäu ra. Neáu coù nhieàu hôn moät giaù trò traû veà ñöôïc
yeâu caàu, ngoõ ra seõ phaûi keát noái taïo thaønh moät vector tröôùc khi ñaët giaù trò cho
haøm ñeå goïi teân haøm. Goïi teân chöông trình module coù theå trích ra sau ñoù, rieâng
ñoái vôùi ngoõ ra töø caùc bieåu maåu noái vaøo nhau. Ví duï döôùi ñaây minh hoïa toång
quaùt caùch duøng vaø cuù phaùp haøm trong verilog.
1. Cuù phaùp:
Teân haøm = bieåu thöùc.
2. Ví duï:
Module simple_processor (instruction, outp);
Input [31:0] instruction;
Output [7:0] outp;
Reg [7:0] outp;// coù theå ñöôïc gaùn trong khoái always.
Reg func;
Reg [7:0] opr1, opr2;
Function[16:0] decode add(instr)
Input [31:0] instr;
Reg add_func;
Reg [7:0] opcode, opr1, opr2;
Begin
Opcode = instr[31:24];
Opr1 = instr[7:0];
Case (opcode)
8’b 10001000:
begin
add_func = 1;
opr2 = instr[15:8];
end
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 27
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
8’b 10001001:
begin
add_func = 0;
opr2 = instr[15:8];
end
8’b 10001010: begin
add_func = 1;
opr2 = 8’b 00000001;
end
default: begin
add_func = 0;
opr2 = 8’b00000001;
end
endcase
decode_add = {add_func, opr2, opr1};
end
endfunction
always @(intruction) begin
{func, opr2, opr1}= decode_add (intruction);
if (func= =1)
outp = opr1+ opr2;
else
outp = opr1 – opr2;
end
endmodule
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 28
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông XI
CHÖÙC NAÊNG LINH KIEÄN
Choát döõ lieäu (latches): ñöôïc suy neáu moät bieán, moät trong caùc bit khoâng ñöôïc gaùn
trong caùc nhaùnh cuûa moät leänh if. Choát döõ lieäu cuõng ñöôïc suy ra töø leänh case neáu
moät bieán ñöôïc gaùn chæ trong moät vaøi nhaùnh.
Hoaøn thieän maõ coù theå ñoïc ñöôïc duøng leänh if ñeå toång hôïp choát vì thaät khoù ñeå chæ
ñònh roõ raøng. Theo lyù thuyeát, moät söï xaùc laäp hôïp lí neân ñöôïc suy ra töø maõ Verilog.
Cuù phaùp:
If… else if… else vaø case.
I.
Thanh ghi Edge_triggered, flip_flop, boä ñeám:
Moät thanh ghi (flip_flop) ñöôïc suy luaän baèng vieäc duøng xung kích caïnh leân
hoaëc xuoáng trong danh saùch söï kieän cuûa leänh khoái always.
Cuù phaùp:
Always @(posedge clk or posedge reset1 or nesedge reset2)
Begin
If (reset1) begin
Caùc chæ ñònh reset
end
else if (reset2) begin
Caùc chæ ñònh reset
End
Else begin
Caùc chæ ñònh reset
End
II.
Boä ña coäng:
Ñöôïc suy ra bôûi vieäc gaùn moät bieán maø giaù trò moãi bieán khaùc nhau trong moûi
nhaùnh cuûa leänh if hoaëc case. Coù theå traùnh caùc chæ ñònh vaø moïi nhaùnh coù theå
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 29
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
toàn taïi baèng vieäc söû duïng ngoaøi nhöõng nhaùnh maëc ñònh. Chuù yù raèng choát seõ
ñöôïc taïo ra neáu moät bieán khoâng ñöôïc gaùn cho caùc ñieàu kieän nhaùnh coù theå toàn
taïi.
Ñeå hoaøn thieän maõ coù theå ñoïc ñöôïc, duøng leänh case ñeå taïo maãu ña coäng lôùn.
III. Boä coäng, tröø:
Toaùn töû coäng tröø trong boä coäng tröø maø coù chieàu roäng phuï thuoäc vaøo chieàu roäg
cuûa toaùn töû lôùn hôn.
IV. Boä ñeäm 3 traïng thaùi:
Boä ñeäm ba traïng thaùi ñöôïc suy ra neáu bieán ñöôïc gaùn theo ñieàu kieän giaù trò
toång trôû cao Z duøng moät trong caùc toaùn töû: if, case,…
V.
Caùc linh kieän khaùc:
Haàu heát caùc coång logic ñöôïc suy ra töø vieäc duøng nhöõng toaùn haïng töông öùng
cuûa chuùng. Nhö moät söï löïa choïn moät coång hoaëc moät thaønh phaàn coù theå ñöôïc
giaûi thích roõ raøng baèng ví duï cuï theå vaø söû duïng caùc coång cô sôû (and, or, nor,
inv…) mieãn laø baèng ngoân ngöõ Verilog.
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 30
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
Chöông XII
MOÄT SOÁ VÍ DUÏ
I.
Caáu truùc moät chöông trình duøng ngoân ngöõ Verilog:
// Khai baùo module
Module teân chöông trình (teân bieán I/O); // teân chöông trình truøng teân file.v.
Input [msb:lsb] bieán;
Output [msb:lsb] bieán;
Reg [msb:lsb] bieán reg;
Wire [msb: lsb] bieán wire;
// Khai baùo khoái always, hoaëc khoái initial.
… caùc leänh …
Endmodule
II.
Moät soá ví duï:
Phaàn meàn hoã trôï: MAX+plusII 10.0 BASELINE
1.
Ví duï 1:
a.
Chöông trình tính NOR caùc bit cuûa bieán vaøo
module vdcong(in,out);
input[3:0] in;
output out;
assign out= ~|in;
endmodule
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 31
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
b.
Moâ phoûng
2.
Ví duï 2:
a.
Chöông trình coäng hai bieán boán bit
Phaàn Verilog
module adder (sum_out, carry_out, carry_in, ina, inb);
output [3:0]sum_out;
input [3:0]ina, inb;
output carry_out;
input carry_in;
wire carry_out, carry_in;
wire[3:0] sum_out, ina, inb;
assign
{ carry_out, sum_out } = ina + inb + carry_in;
Endmodule
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 32
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
b.
Moâ phoûng
3.
Ví duï 3:
a.
Chöông trình giaûi maõ 2 sang 4
Phaàn Verilog
module dec2to4 (w, en, y);
input [1:0] w;
input en;
output[3:0] y;
wire[1:0]w;
reg[3:0]y;
wire en;
always @(w or en)
begin
if(en==1'b1)
begin
case(w)
2'b00: y<=4'b1000;
2'b01: y<=4'b0100;
2'b10: y<=4'b0010;
default:y<=4'b0001;
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 33
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
endcase
end
else
end
y<= 4'b0000;
endmodule
b.
Moâ phoûng
4.
Ví duï 4:
a.
Boä doàn keânh 2 sang 1
module mux12(w0, w1, s, y);
input w0, w1;
input s;
output y;
wire w0, w1, s;
reg y;
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 34
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
always @(w0 or w1 or s)
begin
if(s==1)
y = w0;
else
y = w1;
end
endmodule
b.
Moâ phoûng
5.
Ví duï 5:
a.
Chöông trình doàn keânh 4 sang 1
module mux14(w0, w1, w2, w3, s, y);
input w0, w1, w2, w3;
input[1:0] s;
output y;
wire w0, w1,w2,w3;
reg y;
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 35
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
always @(w0 or w1 or s)
begin
case (s)
2'b00: y=w0;
2'b01: y=w1;
2'b10: y=w2;
default: y = w3;
endcase
end
endmodule
b.
Moâ phoûng
6.
Ví duï 6:
a.
Chöông trình ñoåi BCD sang baûy ñoaïn
Module mp_led(bcd,led);
input [3:0] bcd;
output [7:0] led;
wire [3:0] bcd;
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 36
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
reg [7:0] led;
always @(bcd)
begin
case(bcd)
4'b0000: led = 8'b00000011;
4'b0001: led = 8'b10011111;
4'b0010: led = 8'b00100101;
4'b0011: led = 8'b00001101;
4'b0100: led = 8'b10011001;
4'b0101: led = 8'b01001001;
4'b0110: led = 8'b01000001;
4'b0111: led = 8'b00011111;
4'b1000: led = 8'b00000001;
4'b1001: led = 8'b00001001;
default: led = 8'b00000000;
endcase
end
endmodule
b.
Moâ phoûng
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 37
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
7.
Ví duï 7:
a.
Chöông trình giaûm töø 9 xuoáng 0, hieån thò ra led 7 ñoaïn
module bcd (clock, rst, s1, led, digit1);
input clock, s1, rst;
output [7:0] led;
output digit1;
reg [7:0] led;
reg [3:0] bcd;
wire digit1;
assign digit1 = 1'b1;
always @(posedge clock )
begin
if (rst == 1'b1) bcd <= 4'b1001;
else if (s1 == 1'b1) bcd <= bcd - 1'b1;
if (bcd == 4'b0) bcd <= 4'b1001;
end
always @(posedge clock)
begin
case(bcd)
4'b0000: led = 8'b11111100;
4'b0001: led = 8'b01100000;
4'b0010: led = 8'b11011010;
4'b0011: led = 8'b11110010;
4'b0100: led = 8'b01100110;
4'b0101: led = 8'b10110110;
4'b0110: led = 8'b10111110;
4'b0111: led = 8'b11100000;
4'b1000: led = 8'b11111110;
4'b1001: led = 8'b11100110;
default: led = 8'b11111111;
endcase
end
endmodule
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 38
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
b.
Moâ phoûng
8.
Ví duï 8:
a.
Chöông trình taêng töø 0 ñeán 9, hieån thò ra led 7 ñoaïn
module bcdtang (clock, rst, s1, led, digit1);
input clock, s1, rst;
output [7:0] led;
output digit1;
reg [7:0] led;
reg [3:0] bcd;
wire digit1;
assign digit1 = 1'b1;
always @(posedge clock )
begin
if (rst == 1'b1) bcd <= 4'b0;
else if (s1 == 1'b1) bcd <= bcd + 1'b1;
if (bcd == 4'b1001) bcd <= 4'b0000;
end
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 39
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
always @(posedge clock)
begin
case(bcd)
4'b0000: led = 8'b11111100;
4'b0001: led = 8'b01100000;
4'b0010: led = 8'b11011010;
4'b0011: led = 8'b11110010;
4'b0100: led = 8'b01100110;
4'b0101: led = 8'b10110110;
4'b0110: led = 8'b10111110;
4'b0111: led = 8'b11100000;
4'b1000: led = 8'b11111110;
4'b1001: led = 8'b11100110;
default: led = 8'b11111111;
endcase
end
endmodule
b.
Moâ phoûng
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 40
https://fb.com/tailieudientucntt
Toùm taét baøi giaûng TK Heä Thoáng Soá
Phaàn Verilog
TAØI LIEÄU THAM KHAÛO
1.
“Verilog Digital System Design”
2.
“Introduction of Verilog”
Zainalabedin Navadi
Northeastern University
University of Tehran
Peter M. Nyasulu
3.
“Cadence Verilog – XL Reference Manual”
4.
“Synopsys HDL Compiler for Verilog Reference Manual”
5.
Diglab 10K10 Mannual
GV: Nguyeãn Troïng Haûi
CuuDuongThanCong.com
Trang 41
https://fb.com/tailieudientucntt
BOÄ GIAÙO DUÏC & ÑAØO TAÏO
TRÖÔØNG ÑAÏI HOÏC KYÕ THUAÄT COÂNG NGHEÄ
THAØNH PHOÁ HOÀ CHÍ MINH
Ths. NGUYEÃN TROÏNG HAÛI
TOÙM TAÉT BAØI GIAÛNG
VHDL
Very High speed integrated circuit Description Language
LÖU HAØNH NOÄI BOÄ
07/2005
CuuDuongThanCong.com
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
VHDL
Very High speed integrated circuit Description Language
I. CẤU TRÚC CỦA MỘT THIẾT KẾ DÙNG NGÔN NGỮ VHDL.
---------------------------------- Ghi chú
---------------------------------
PACKAGE
(Tùy chọn)
library
(Thư viện)
use
ENTITY
(Bắt buộc)
ARCHITECTURE
(Bắt buộc)
CONFIGURATIONS
(Tùy chọn)
1. PACKAGE (KHỐI).
Package là một vùng lưu trữ các dữ liệu để dùng chung cho các entity.
Mô tả dữ liệu bên trong một package cho phép được tham khảo bởi một entity khác, vì
vậy dữ liệu có thể được dùng chung.
Một package bao gồm 2 phần: phần mô tả định nghĩa giao diện cho package, phần
thân ấn định các hoạt động cụ thể của package.
Cú pháp khai báo khối được xác định là:
PACKAGE example_arithmetic IS
-- các khai báo khối có thể chứa các khai báo sau:
Subprogram declaration.
Type, subtype declaration.
Constant, deferred constant declaration.
Signal declaration creates a global signal.
File declaration.
Alias declaration.
Attribute declaration, a user-define attribute.
Attribute specification.
Use clause.
END example_arithmetic;
Tất cả các đối tượng khai báo trong package có thể được truy xuất bởi bất kỳ một thiết
kế nào đó bằng cách sử dụng mệnh đề use và khai báo library.
library my_lib;
use my_lib.example_arithmetic.all;
Một số thư viện chuẩn
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 1
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
library ieee;
use ieee.std_logic_1164.all;
std_logic_1164: là thư viện logic chuẩn của IEEE (đoạn 1164), mục đích cung cấp
các chuẩn cơ bản để có thể mô tả các kiểu dữ liệu kết nối trong VHDL.
std_logic_arith: là thư viện chứa tập các phép toán và hàm
Kiểu std_logic có thể có các giá trị
U
Uninitialized
X
Unknown
0
Zero
1
One
Z
Tristate (Must be upper case!)
W
Weak unknown
L
Weak Zero
H
Weak One
-
Don't care
Ngoài ra có thể tự tạo riêng các thư viện trong thiết kế.
2. ENTITY
Khai báo entity chỉ dùng để mô tả ngõ vào và ngõ ra của một thiết kế. Mức cao nhất
của bất kỳ một thiết kế VHDL là một khai báo entity đơn, khi thiết kế trong VHDL, tên
của file lưu trữ phải trùng với tên theo sau của từ khóa entity.
Ví dụ, mô tả bộ cộng bán phần sau
X1
A
SUM
A1
CARRY
B
library ieee;
use ieee.std_logic_1164.all;
ENTITY HALF_ADDER IS
PORT( A,B : IN BIT;
SUM,CARRY
: OUT BIT);
END HALF_ADDER;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 2
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Trong khai báo ENTITY, có 4 kiểu tín hiệu khác nhau:
•
IN: mô tả các ngõ vào entity. Kiểu IN thì được sử dụng cho các ngõ vào clock, các
ngõ vào điều khiển,…
•
OUT: mô tả dòng dữ liệu đi ra khỏi entity, entity sẽ không thể đọc các tín hiệu này,
kiểu OUT chỉ được sử dụng khi tín hiệu không được sử dụng bởi bất kỳ kiểu nào
trong entity.
•
BUFFER: Kiểu tín hiệu này mô tả dòng dữ liệu đi ra khỏi entity, nhưng entity có
thể đọc những tín hiệu này (mục đích đọc lại tín hiệu ngõ ra ở bên trong của cấu
trúc). Tuy nhiên , tín hiệu sẽ không thể điều khiển từ ngõ ra của entity, vì vậy nó
không thể được sử dụng cho các dữ liệu ngõ vào.
•
INOUT: Kiểu tín hiệu này cho phép tín hiệu có thể có cả hai kiểu: vào và ra, khi
khai báo tín hiệu theo kiểu INOUT thì tín hiệu có thể được điều khiển từ ngõ ra của
entity. Kiểu tín hiệu này chỉ nên sử dụng khi thật cần thiết(ví dụ như bus dữ kiệu 3
trạng thái), và khi sử dụng kiểu tín hiệu này thì mã của chương trình sẽ trở nên khó
hiểu hơn đối với người thiết kế.
Loại tín hiệu cũng phải được mô tả trong khai báo PORT, loại tín hiệu sẽ mô tả các giá
trị mà tín hiệu đó có thể được ấn định, ngoài ra có thể mô tả một vector những tín hiệu
có cùng loại.
Lưu ý: trong file report, nếu không gán chân linh kiện thì các biến ngõ vào và ra sẽ
được gán ngẫu nhiên. Để gán các chân, có thể thực hiện từ phần mềm hỗ trợ hoặc thực
hiện như sau:
Ví dụ,
ENTITY my_design is
Port (a, b
: in integer range 0 to 7;
c
: bit_vector (3 to 5);
d
: bit_vector (27 downto 25);
e
: out Boolean);
attribute pinnum: string;
attribute pinnum of c: signal is "1,2,3";
attribute pinnum of d: signal is "6,5,4";
attribute pinnum of e: signal is "2";
END my_design;
3. ARCHITECTURE.
Chức năng của architecture là mô tả mối liên hệ giữa các tín hiệu ngõ vào và tín hiệu
ngõ ra ( bao gồm cả những tín hiệu BUFFER), có thể viết nhiều kiến trúc khác nhau
trong một entity, nhưng chỉ một trong số đó có khả năng xuất hiện trong mã VHDL.
architechture có 3 dạng: mô tả cấu trúc (structure); mô tả dòng dữ liệu (data flow); mô
tả hành vi (behavioral)
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 3
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Mô tả architechture dưới dạng cấu trúc (structure)
Ví dụ, chương trình bộ cộng trên sẽ có dạng:
ENTITY HALF_ADDER IS
PORT( A,B : IN BIT;
SUM,CARRY
: OUT BIT);
END HALF_ADDER;
ARCHITECTURE HA_STRUCTURE OF HALF_ADDER IS
Component XOR2
Port(X,Y: in BIT; Z: out BIT);
End component
Component AND2
Port(L,M: in BIT; N: out BIT);
End component
BEGIN
X1: XOR2 port map (A,B,SUM);
A1: AND2 port map (A,B,CARRY);
END HA_STRUCTURE;
Chú ý, trong trường hợp này các tín hiệu trong Port Map(ánh xạ cổng) của đối tượng
trong thành phần này và các tín hiệu trong khai báo phải được liên kết theo vị trí
Mô tả architechture dưới dạng dòng dữ liệu (data flow)
Ví dụ, chương trình bộ cộng trên sẽ có dạng:
ENTITY HALF_ADDER IS
PORT( A,B : IN BIT;
SUM,CARRY
: OUT BIT);
END HALF_ADDER;
ARCHITECTURE HA_STRUCTURE OF HALF_ADDER IS
BEGIN
SUM<=A xor B;
CARRY<=A and B;
END HA_STRUCTURE;
Mô hình dòng dữ liệu sử dụng phát biểu gán tín hiệu đồng thời, ký hiệu <= chỉ giá trị
được gán cho tín hiệu. Phép gán được thực hiện khi có 1 sự kiện tín hiệu của biểu thức
bên phải.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 4
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Mô tả architechture dưới dạng hành vi (behavioral)
Kiểu mô tả hành vi bao gồm tập hợp thứ tự các phép gán tín hiệu tuần tự được khai báo
bên trong phát biểu process.
Biến được khai báo trong process là biến cục bộ. Tín hiệu không được khai báo trong
process
Ví dụ, chương trình bộ cộng trên sẽ có dạng:
ENTITY HALF_ADDER IS
PORT( A,B : IN BIT;
SUM,CARRY
: OUT BIT);
END HALF_ADDER;
ARCHITECTURE HA_STRUCTURE OF HALF_ADDER IS
BEGIN
Process(A,B);
Begin
SUM<=A xor B;
CARRY<=A and B;
End process;
END HA_STRUCTURE;
Ví dụ, mô tả một D-FF:
D
Q
CK Q
ENTITY DFF IS
PORT( D,CK
Q
: IN BIT;
: OUT BIT);
END DFF;
ARCHITECTURE DFF_BEHAVIOR OF DFF IS
BEGIN
Process(CK);
Begin
If rising_edge(ck) then
Q<=D;
End if;
End process;
END DFF_BEHAVIOR ;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 5
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Mô tả architechture dưới dạng hỗn hợp (mixed style)
Có thể trộn lẫn 3 kiểu trong một architechture
Ví dụ, mô tả mạch cộng toàn phần (FULL_ADDER) sau
structure
dataflow
X1
A
: B
SUM
Cin
CARRY
behavior
ENTITY FULL_ADDER IS
PORT( A,B,CIN
: IN BIT;
SUM, COUT : OUT BIT);
END DFF;
ARCHITECTURE FA_MIXED OF FULL_ADDER IS
Component XOR2
Port(X,Y: in BIT; Z: out BIT);
End component
Signal S1: BIT
--Khai báo tín hiệu cục bộ trong architechture
BEGIN
X1: XOR2 port map (A,B,S1);
Process(A,B,CIN);
--structure
--behavior
Variable T1,T2,T3: BIT;
Begin
T1:=A and B;
T2:=A and CIN;
T3:=B and CIN;
COUT<=T1 or T2 or T3;
End process;
SUM<=S1 xor CIN;
--dataflow
END FULL_ADDER;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 6
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
4. CONFIGURATION
Configuration dùng để liên kết các hợp phần tới entity
configuration ban đầu có thể được ấn định tới rất nhiều architecture trong một entity.
ENTITY component_i IS
ARCHITECHTURE
Behavioral
OF
component_i
IS
….
ARCHITECHTURE
dataflow
OF
component_i
IS
….
ARCHITECHTURE
Structural
OF
component_i
IS
….
Định cấu hình cho phép mô phỏng các thiết kế ở thành phần con, dễ dàng kiểm tra
được thiết kế hơn một chương trình lớn.
Một cấu hình được dùng để nối từng cặp như sau:
•
Một thân architecture tới khai báo entity của nó.
•
Một component với một entity.
Ví dụ, xây dựng một entity FULL_ADDER ở trên có thể tách ra làm ba architecture
body: FA_BEHAVIOR, FA_STRUCTURE, và FA_MIXED. Một architecture bất kỳ
có thể được chọn bằng cách đặc tả một configuration thích hợp.
Library HS_LIB, CMOS_LIB;
ENTITY FULL_ADDER IS
Port(A,B,Cin : IN BIT; SUM, Cout: OUT BIT);
END FULL_ADDER;
ARCHITECTURE FA_STR OF FULL_ADDER IS
Component XOR2
Port(D1,D2 : IN BIT; DZ : OUT BIT);
END componen;
Component AND2
Port ( Z: OUT BIT; B0,B1: IN BIT);
END Component;
-- Đặc tả cấu hình:
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 7
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
CONFIGURATION FA_BINDING OF FULL_ADDER IS
For FA_STR
For X1,X2 : XOR2
use entity WORK.XOR2(XOR2BEH);
End for;
-- liên kết thực thể với nhiều đối tượng của một thành phần.
For A3: AND2
Use entity HS_LIB.AND2HS(AND2STR);
PORT MAP (HS_B => A1, HS_Z=>Z, HS_A => A0 );
End for;
--liên kết thực thể với các đối tượng đơn của một thành phần.
For all : OR2
Use entity CMOS_LIB.OR2CMOS(OR2STR);
End for;
-- liên kết thực thể với tất cả các đối tượng của thành phần OR2.
For others: AND2
Use entity WORK.A_GATE(A_GATE_BODY);
PORT MAP(A0,A1,Z);
End for;
-- liên kết thực thể với tất cả các đối tượng không được liên kết của
thành phần AND2.
End for;
End for;
Signal S1, S2, S3, S4, S5: BIT;
BEGIN
X1: XOR2 port map(A, B, S1);
X1: XOR2 port map(S1, Cin, SUM);
A1: AND2 port map(S2, A, B);
A2: AND2 port map(S3, B, Cin);
A3: AND2 port map(S4, A, Cin);
O1: OR2 port map(S2, S3, S5);
O2: OR2 port map(S3, B, Cin);
NAND_GATE port map(S4,S5,Cout);
END FA_STR;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 8
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Có 4 đặc tả cấu hình trong phần khai báo của thân kiến trúc (architecture body):
•
Đặc tả thứ nhất chỉ rằng đối tượng có nhãn X1 và X2 của component XOR2 liên
kết với entity bởi cặp entity - architecture XOR2 và XOR2BEH có sẵn trong thư
viện WORK.
•
Đặc tả thứ hai liên kết đối tượng component AND2 có nhãn A3 đến entity bởi cặp
entity - architecture AND2HS và AND2STR đã có trong thư viện thiết kế
HS_LIB. Anh xạ của cổng thành phần (AND2 ) và các cổng thực thể(AND2HS)
được liên kết theo tên (name association).
•
Đặc tả thứ ba chỉ rằng tất cả các đối tượng của component OR2 được liên kết với
entity bởi cặp entity - architecture có sẵn trong thư viện thiết kế CMOS_LIB.
•
Đặc tả cuối cùng chỉ rằng tất cả các đối tượng không liên kết (unbound) của
component AND2, đối tượng A1 và A2 được liên kết tới entity khác là: A_GATE
có architecture A_GATE_BODY, kiến trúc này có sẵn trong thư viện WORK.
Trong ví dụ này đã chỉ ra các đối tượng của cung một thành phần (component) có thể
được liên kết(bound) với các thực thể khác nhau.
II. CÁC KHAI BÁO TRONG VHDL.
1. Khai báo kiểu hỗ trợ.
Kiểu liệt kê, số nguyên, dãy một chiều và kiểu bản ghi.
•
Kiểu liệt kê.
Ví dụ,
Type STD_ULOGIC is (‘U’, ‘X’, ‘0’, ‘1’, ‘Z’, ‘W’, ‘L’, ‘H’, ‘_’);
--std_ulogic là 1 kiểu liệt kê bao gồm 9 giá trị được khai báo là
U<X<0<1<Z<W<L<H< _.
Signal S: STD_ULOGIC;
Type STATE_TYPE is (HALT, READY, RUN, ERROR);
--HALT< READY< RUN< ERROR
Variable STATE: STATE_TYPE;
Type CODE_TYPE is (NUL, ‘0’, ‘1’);
Function CODE (C: in INTEGER) return CODE_TYPE;
Kiểu STD_ULOGIC và STATE_TYPE là 2 kiểu liệt kê; tuy nhiên mức độ trừu tượng
của STATE_TYPE cao hơn của STD_ULOGIC.
Trật tự các giá trị xuất hiện trong khai báo liệt kê định nghĩa thứ tự của chúng, giá trị
bên trái nhỏ hơn giá trị bên phải.
•
Kiểu nguyên.
Kiểu nguyên là 1 tập hợp những giá trị rơi vào vùng số nguyên được chỉ ra.
Ví dụ,
type LENGTH is range 0 to 1000;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 9
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
type BYTE_INT is range –128 to 127;
type MY_INTEGER is range -2147483647 to 2147483647;
•
Kiểu dãy nhiều chiều.
Kiểu dãy nhiều chiều được VHDL hỗ trợ để định nghĩa một tập chỉ số.
Tuy nhiên chỉ có dãy một chiều được công cụ tổng hợp cho phép. Vậy phải khai báo
hai dãy một chiều thay vì một dãy hai chiều.
Ví dụ,
Type WORD is array (31 downto 0) of BIT;
Type RAM is array (1023 downto 0) of WORD;
Thay vì:
Type OTHER_RAM is array (1023 downto 0, 31 downto 0) of BIT
•
Kiểu bản ghi
Kiểu bản ghi định nghĩa tập các kiểu khác nhau. Mỗi thành phần bản ghi được định vị
bằng tên của nó, và có thể dịch bởi công cụ tổng hợp như là giá trị độ dời không đổi
hoặc được biến đổi trong vài trường hợp (khái niệm bản ghi không còn tồn tại nữa, địa
chỉ thành phần được tính toán chỉ một lần và trở thành mã cố định).
Ví dụ,
Architecture A of E is
Type CODE_TYPE is (NONE, DATA, STATMT) ;
Type ITEM_TYPE is record;
CODE: CODE_TYPE;
INT: INTEGER;
End record;
Signal S1, S2 : ITEM_TYPE;
Begin
Process
Variable V: ITEM_TYPE;
Begin
S1 <= V;
V:= S2;
…
S2.INT <= 0;
V.CODE := S1.CODE;
•
Tiêu chuẩn IEEE
Khối STD_LOGIC_1164 định nghĩa các giá trị kiểu đa luận lý. Khối này được hỗ trợ
bởi tất cả công cụ tổng hợp.
Ví dụ,
Type STD_LOGIC is ( ‘U’, -- Uninitialized
‘X’, -- Forcing Unknown
‘0’, -- Forcing 0
‘1’, -- Forcing 1
‘Z’, -- High Impedance
‘W’, -- Weak Unknown
‘L’, -- Weak 0
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 10
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
‘H’, -- Weak 1
‘U’, -- Don’t care );
'X', '1', '0' là giá trị mạnh và trội hơn các giá trị yếu 'W', 'L', 'H' và chúng lại trội hơn 'Z'.
'1' và '0' có thể hiểu như là nối nguồn và nối đất.
Giá trị 'U'và 'W' được gọi là giá trị gần luận lý, chủ yếu có chức năng mô phỏng và
hiển nhiên không có ý nghĩa phần cứng. Giá trị 'U' là chữ tận cùng bên trái trong định
nghĩa STD_ULOGIC liệt kê, và là giá trị mặc định cho các biến số hoặc các tín hiệu
ban đầu trước khi được gán các giá trị 'X' và 'W' biểu diễn trạng thái mà bộ mô phỏng
không thể xác định được. 'W' có ảnh hưởng ít hơn có thể bị gán đến '0', '1' và 'X'.
Do các công cụ tổng hợp chưa thể phân biệt giữa các độ mạnh yếu, nên các giá trị 'L'
và 'H' không có ngữ nghĩa tổng hợp chuẩn.
'Z' có thể được dùng trong mô phỏng như là kết quả khi không có bộ điều khiển nào
đang hoạt động. Đối với tổng hợp, phần cứng đặc biệt được ám chỉ khi gán phép gán
giá trị vô hướng 'Z' được dùng, mục đích của phép gán là đặt đầu ra tới bộ đệm 3 trạng
thái.
2. Các kiểu không hỗ trợ.
Vài kiểu dữ liệu không được dùng cho mục đích tổng hợp (ví dụ, tất cả kiểu vật lý định
nghĩa bởi người thiết kế không được hỗ trợ), kiểu vật lý định nghĩa trước TIME không
được hỗ trợ. Ngay cả sự ràng buộc thời gian đối với tổng hợp không được biểu diễn
trong VHDL với các biểu thức thời gian. Do đó mệnh đề after và reject không được
dịch và không có công cụ tổng hợp nào có thể đảm bảo rằng tín hiệu sẽ thay đổi sau
một khoảng thời gian chính xác.
Nếu các mệnh đề này được sử dụng trong mô tả VHDL, công cụ tổng hợp sẽ bỏ qua và
kết quả phần cứng có thể mâu thuẫn với mô tả đầu vào. Điều này nói rằng kiểu mẫu
chính xác cho tổng hợp không dùng bất kỳ biểu thức thời gian nào, bao gồm lệnh biểu
thức thời gian wait for. Trong mô phỏng qúa trình bị tạm ngưng trong thời gian định
nghĩa bởi biểu thức for. Trong suốt giai đoạn này, tất cả tín hiệu giữ các giá trị mới của
chúng. Trong miền tổng hợp không thể phỏng đoán phần cứng với các kết quả như vậy
mà không cung cấp phần cứng vì nó quá phức tạp và quá đặc biệt (như bộ định thời
gian).
3. Các kiểu con.
Các kiểu con rất hữu dụng cho tổng hợp. Ở mỗi bước mô phỏng, các kiểu con cung cấp
khả năng mạnh mẽ cho việc kiểm tra sử dụng kiểu. Các kiểu con còn thừa hưởng tất cả
toán tử định nghĩa từ các kiểu cơ bản của chúng.
Ví dụ, chức năng thao tác trên kiểu BIT_VECTOR có thể được dùng với bất kỳ kiểu
con của BIT_VECTOR dài bằng giá trị còn lại trong khoảng thích hợp.
III. CÁC ĐỐI TƯỢNG VHDL.
Đối tượng trong VHDL là các thông tin về hằng số, biến số và tín hiệu.
1. Hằng số.
Các khai báo hằng số:
Constant constant_name : type_name [:=value]
Ví dụ,
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 11
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Constant rise_time : time :=10 ns;
Constant bus_width : integer :=8;
Ví dụ,
Type TAB2 is array (BIT, BIT) of BIT;
Constant AND_TAB: TAB2 := ((‘0’, ’0’), (‘0’, ‘1’));
Giá trị hằng số được tính toán chỉ một lần. Quá trình tổng hợp chấp nhận hằng số của
bất kỳ kiểu tổng hợp nào.
Trong trường hợp khai báo như vậy không tạo ra bất kỳ phần cứng nào:
Nếu hằng số được dùng trong phép gán tín hiệu như các lệnh dưới đây thì phần cứng
được suy ra:
Ví dụ,
Signal Z, A, B : BIT;
…
Z <= AND_TAB (A,B);
Sự khai báo hằng số không tạo ra phần cứng. Hằng số chỉ cung cấp điều kiện để xác
định phần cứng. Hằng số là một biểu thức vì vậy nó tồn tại trong cùng một nơi như các
biểu thức:
Ví dụ, Phía phải của phép gán tín hiệu
Constant COD1: BIT_VECTOR := X ”EA”;
Constant MASK: BIT_VECTOR:=”01111111”;
Signal V, R, A: BIT_VECTOR(7 downto 0);
…
begin
V <= COD1; R <= A and MASK;
Ví dụ, trong biểu thức lệnh if hoặc case
If S= CST1 then …
Case VALUE is
When CST_N =>…
Ví dụ, trong lệnh đồng thời có điều kiện:
Z <= CST1 when A=’1’ else S when B= CST2 else CST3;
2. Khai báo biến số và tín hiệu.
Các khai báo biến số
Variable variable_name : type_name [:=value];
Ví dụ,
Variable CTRL_STATUS : BIT_VECTOR (10 DOWNTO 0);
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 12
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Ở đây biến CTRL_STATUS là một dãy có 11 phần tử, mỗi phần tử trong dãy có kiểu
là BIT
Ví dụ, Thực hiện mạch sau
(DATA and “01”)(0)
D
Q
Z
(DATA and “10”)(1)
CK Q
Clock
Entity MEMO_ONE is
Port ( DATA: in BIT_VECTOR (1 downto 0);
CLOCK :in BIT;
Z: out BIT);
Constant K1: BIT_VECTOR : = “01”;
Constant K2: BIT_VECTOR := “10” ;
End MEMO_ONE;
Architecture A of MEMMO_ONE is
Begin
Process (CLOCK)
Variable A1, A2: BIT_VECTOR(DATA’range);
Variable A3: BIT;
Begin
If CLOCK = ‘1’ and CLOCK’event then
A1 := DATA and K1;
A2 := DATA and K2;
A3 := A1(0) or A2(1);
Z <= A3;
End if;
End process;
End A;
Các biến số sử dụng trong ví dụ trên không tạo ra bất kỳ phần cứng nào. Thật ra quá
trình tương đương có thể được cho mà không có bất kỳ biến nào, ở đó tất cả các biến
được thay thế bởi các phương trình của chúng. Chúng ta có thể viết lại như sau.
Begin
If CLOCK = ‘1’ and CLOCK’event then
Z <= (DATA and K2)(1) or (DATA and K1)(0);
End if;
Khai báo tín hiệu:
Cú pháp:
Signal signal_name : type_name [:=value]
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 13
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Ví dụ,
Signal clock: bit;
--khai báo tín hiệu clock của kiểu bit lấy giá trị 1,0
Signal data_bus : bit_vector( 0 to 7);
-- khai bo tín hiệu data_bus thuộcc kiểu bit_vector có độ rộng 8 bit
3. Các giá trị khởi động.
Trong VHDL, có 3 loại giá trị ban đầu:
•
Giá trị mặc định từ định nghĩa kiểu hay kiểu con
•
Giá trị ban đầu khi đối tượng được khai báo
•
Giá trị được gán khi sử dụng một phát biểu lúc bắt đầu quá trình.
Trường hợp thứ nhất và thứ hai sẽ bị bỏ qua bởi công cụ tổng hợp, nên có thể phát sinh
mâu thuẫn giữa hoạt động mô phỏng và kết quả tổng hợp. Do đó đề nghị phải khởi
động một cách rõ ràng và có hệ thống các biến và tín hiệu với các lệnh đặc biệt. Điều
này đạt được trong phần mã tổng hợp phục vụ cho việc xử lý thiết lập/thiết lập lại và sự
khởi động phải được trình bày trong phần này.
Nếu cổng out hoặc thông số out của chương trình con có giá trị mặc định, chúng hoạt
động giống như một giá trị khởi động cho tín hiệu hoặc biến và sẽ bị công cụ tổng hợp
bỏ qua.
4. Các toán tử số học.
Toán tử logic và toán tử bit là một phần của toán tử số học. VHDL định nghĩa bảy loại
toán tử. Chúng được chỉ ở bảng dưới đây với sự tăng dần mức ưu tiên.
Loại
Toán tử
Ưu tiên
Luận lý
Or and nor nand xor xnor
Quan hệ
= /= > <
Dịch
Sll Srl Sla SRA Rol Ror
Cộng
+ - &
Một ngôi
+ -
Nhân
*
Hỗn hợp
** abs not
/
>=
Thấp nhất
<=
mod rem
Cao nhất
Toán tử luận lý
Toán tử luận lý và toán tử not chấp nhận các toán hạng có các kiểu BIT, BOOLEAN,
và VECTOR với kích thước giống nhau. Một quy ước được chấp nhận rộng rãi cho giá
trị boolean: TRUE tương đương với giá trị BIT '1' và ngược lại.
Toán tử nand và nor không kết hợp với nhau trong 1 cú pháp liên tục, chúng phải được
ngăn cách bằng dấu () :
A and B nand C; -- trái luật
(A and B ) nand C;-- đúng luật;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 14
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Ví dụ,
Signal S, X, Y: BIT_VECTOR (1 downto 0);
Signal R, A, B, C : BIT;
Signal T, D, E, F, G: BOOLEAN;
-Begin
S <= X and Y;
R <= (A and B) and C;
T <= D xor E xor F xor G;
Sơ đồ kết quả của các hàm trên như sau:
X(1..0)
S(1..0)
D
Y(1..0)
E
T
A
B
F
G
C
Toán tử quan hệ.
Toán tử quan hệ luôn trả về giá trị Boolean '0' hoặc '1' và là kết quả của sự so sánh hai
toán hạng cùng một kiểu cơ bản.
Trong mô phỏng, toán tử bằng và khác được định nghĩa rõ ràng cho các kiểu. Kết quả
là TRUE nếu hai toán hạng có cùng giá trị.
Các toán tử quan hệ được định nghĩa cho tất cả các kiểu vô hướng và dãy một chiều.
Thứ tự của kiểu vô hướng được định nghĩa bởi khai báo của nó, kiểu 'LEFT' thấp hơn
kiểu 'RIGHT'.
Đối với dãy một chiều, thứ bậc quan hệ của chúng được định nghĩa bởi bậc ngữ nghĩa.
Ví dụ,
“0” < ”1”
“A” < “BC”
“10” < “101”
-- is true
-- is true
-- is also true
Toán tử quan hệ này không thể dùng để so sánh các vector bit mã hóa các giá trị liệt kê.
Toán tử này nếu thực hiện với khối số học thì kết quả của lệnh cuối cùng "10" < "101"
sẽ được thông dịch khác nhau đối với số không dấu hoặc số có dấu.
Các toán tử cộng.
Toán tử cộng và trừ được định nghĩa cho các toán hạng số nguyên. Tất cả các công cụ
tổng hợp đều cài đặt các toán tử này và thường sử dụng với một số ràng buộc.
Lưu ý, đôi khi dùng các dấu ngoặc đơn để nhóm một tập hợp các cổng lại. Nói cách
khác hai biểu thức khác nhau chạy như nhau nhưng tạo ra phần cứng khác nhau
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 15
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Ví dụ,
Architecture …
Signal A, B, C: BIT_VECTOR(2 downto 0);
Signal B, S, R: BIT_VECTOR (0 to 5);
Signal D: BIT;
Begin
A <= D &not D &D;
S <= S & B (0 to 2) ;
R <= C(1 downto 0) & “000” & D;
Các toán tử dịch chuyển.
Các toán tử dịch chuyển hỗ trợ cho BIT_VECTOR Các toán tử dịch chuyển và quay là
sll, srl, sla, sra, rol và ror.
Các toán tử nhân.
Phép chia "/", phép nhân "*", lấy modulo "mod", lấy số dư "rem" được xếp trong
nhóm nhân. Chỉ có toán tử nhân được hỗ trợ thêm ví dụ không hạn chế đối với tất cả
các kiểu số nguyên. Đối với vài công cụ tổng hợp, nhiều chiến lược nhân được đề nghị
để tạo ra phần cứng.
"/", mod, và rem được hỗ trợ có hạn chế đối với các giá trị của toán hạng vế phải, các
công cụ tổng hợp đòi hỏi các giá trị này là dương và là lũy thừa của 2. Hơn nữa chúng
thường là các hằng số toàn cục. Kết quả phần cứng của toán tử này dựa trên các toán tử
dịch bit.
Ví dụ, xây dựng một bộ đếm modulo 4.
Entity INCREMENTER is
Port (CLK : in BIT;
RST : in BIT;
R
: out NATURAL range 0 to 3) ;
End INCREMENTER;
Architecture A of INCREMENTER is
Signal MEM: NATURAL range 0 to 3;
Begin
Process
If CLK = ‘0’ then
If RST = ’1’ then
MEM <= 0;
Else
MEM <= (MEM +1) MOD 4;
End if;
End if;
End process;
R <= MEM;
End A;
Các toán tử hỗn hợp.
Abs, giá trị tuyệt đối được hỗ trợ cho tất cả các giá trị số nguyên,
Toán tử số mũ "**", được hỗ trợ với hạn chế toán hạng trái là hằng số toàn cục, giá trị
của nó phải là 2.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 16
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
5. Phép gán biến số.
Biến không dùng chung được khai báo trong quá trình hoặc trong phần khai báo
chương trình con.
Phép gán biến được thực hiện bởi toán tử :=, thao tác này xảy ra ngay lập tức khi tính
toán. Do đó, giá trị của biến chỉ thay đổi bởi lệnh gán tiếp theo nếu giá trị mới khác với
giá trị cũ.
Ví dụ, cách gán biến khác nhau:
A:= 0 ;
-- giá trị integer 0 được gán cho biến A
REC.FIELD := B;
--B được gán cho bản ghi FIELD của REC
VECTOR := X “AA”;
-- phép gán vector toàn cục
WBUS(1) := F(A);
-- phép gán phần tử của vector
WORD(3 to 4) := “10”;
-- phép gán một nhóm phần tử vector
REC := (‘A’, 3, “10”);
-- Phép gán giá trị theo vị trí của vetor
REC := (LETTER => ‘C’, FIELD => 3, BIT2 => “11”);
-- Phép gán với tên
Hơn nữa, ở phần bên trái của lệnh gán, nhiều biến số có thể gộp lại.
Ví dụ
Variable V: BIT_VECTOR(1 to 3);
Variable A, B, C: BIT;
…
--Hai trạng thái sau là tương đương
(A, B, C) := V;
(1 => A;2 => B; 3 => C):= V;
Lưu ý, biến khai báo trong chương trình con chỉ tồn tại trong chương trình con này và
biến mất ở ngoài chương trình con. Vì vậy, nếu biến số đã được gán, kết quả bị mất sau
khi chạy lệnh return ngoại trừ được trả về khi dùng thông số out bên trong thủ tục hoặc
lệnh return bên trong hàm. Tuy nhiên biến này có thể tạo ra một phần nhớ nếu thời
điểm đồng bộ xảy ra trước khi chương trình con kết thúc.
6. Phép gán tín hiệu.
Mục đích của gán tín hiệu giống như phép gán biến. Hiệu quả của phép gán tín hiệu chỉ
xảy ra sau lệnh đồng bộ (lệnh wait ).
Signal <= a_waveform_with_one_item_and_without_delay_expression
7. Lệnh đồng bộ.
Trong VHDL lệnh duy nhất để đồng bộ là lệnh wait. Một quá trình phải chứa ít nhất
một lệnh wait.
Có hai cách dùng lệnh wait khác nhau là:
•
Đợi một sự kiện trên một tín hiệu tùy thuộc vào danh sách. Danh sách của wait
phải bao gồm tất cả tín hiệu được đọc trong quá trình:
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 17
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Ví dụ,
Process
Begin
Wait on A, B, C, D;
S <= A or B;
If E then
R <= C + D;
Else
R <= C+1;
End if;
End process;
•
Đợi một sự kiện xảy ra trên tín hiệu đồng hồ (Clock). Tín hiệu này phải là duy nhất,
clock được xác định bởi các sự kiện và sườn xung.
Ví dụ,
Wait until CLK = ‘1’;
Nếu kiểu của tín hiệu đồng hồ không là BOOLEAN hoặc BIT, mà là kiểu đa giá trị, thì
để phù hợp với sự mô phỏng, điều kiện sau phải được thêm vào lệnh wait:
CLK'LAST_VALUE = '0'. Điều này xác định sườn lên hợp lệ cho tổng hợp. Điều kiện
cạnh xung đồng hồ trở thành:
Ví dụ,
Wait until CLK =’1’ and CLK’last_value = ‘0’;
Nếu lệnh wait là rõ ràng, lệnh đồng bộ được mô tả bởi một lệnh điều kiện if
Ví dụ,
If CLK = ‘0’ and CLK’event and CLK’last_value =’1’ then …
Hoặc sử dụng thuộc tính 'STABLE với giá trị thời gian mặc định 0ns,
('STABLE là một hàm chấp nhận kiểu thông số TIME có giá trị mặc định là zero).
Ví dụ,
If CLK = ‘0’ and not CLK’stable and CLK’last_value =’1’ then …
Lệnh điều kiện.
Có hai cách biểu diễn lệnh điều kiện : lệnh if và lệnh case
Lệnh if.
Lệnh if bao gồm cả rẽ nhánh elsif và else, chỉ mức ưu tiên thực hiện các rẽ nhánh
khác nhau.
Ví dụ, thiết kế các MUX sau
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 18
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Process (S1, S2, R3, R1, R2, R3, R4)
Begin
If S1 = ‘1’ then
RESULT <= R1;
Elsif S2 = ’0’ then
RESULT <= R2;
Elsif S3 = ’1’ then
RESULT <= R3;
Else
RESULT <= R4;
End if;
End process;
Lệnh case.
Trong lệnh case, mỗi nhánh có cùng cấp với nhau (lệnh if và lệnh elsif, mỗi nhánh
được kiểm tra một cách tuần tự).
Trong lệnh case, tất cả các giá trị có thể phải được đưa vào hết và chúng là duy nhất,
không có ưu tiên.
Để nhóm lại tất cả các gia trị "don't care", mệnh đề others có thể được sử dụng. Lưu
ý, others không bao giờ nên dùng nếu tất cả giá trị đã được liệt kê trước đó
Ví dụ, Thiết kế mạch sau
Type CODE_TYPE is (ADD, SUB, RST, INCX);
Subtype WORD is INTEGER range 0 to 3;
Signal CODE: CODE_TYPE;
Signal X, Y, R: WORD;
Process (CODE, X, Y)
Begin
Case X is
When 0 => R <= Y;
When 1 => R <= CODE_TYPE’pos (CODE);
When others => R <= 0;
End case;
End process;
Chú ý rằng nhánh others được dùng cho giá trị 2 và 3 của tín hiệu X.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 19
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Tạo ra bộ nhớ.
Đôi khi một vài giá trị điều kiện không đúng, vì thế các giá trị có kết quả từ các điều
kiện này ở trạng thái không đổi. Trong trường hợp này, phải có phần tử nhớ .
Ví dụ,
If CONDITION (l1, l2,l3) then RESULT <= DATA (l1, l2, l3);
End if;
Bởi vì chức năng CONDITION không luôn luôn trả về hằng số TRUE, nên đôi khi
RESULT sẽ không thay đổi và sẽ giữ nguyên giá trị.
Với các dòng lệnh trên thì loại phần tử nhớ được tạo ra sẽ phụ thuộc vào biểu diễn
đồng bộ. Phần tử nhớ cũng được ám chỉ nếu tín hiệu đầu ra không xuất hiện trong bất
kỳ rẽ nhánh có thể nào của chương trình.
RESULT là tín hiệu được đọc (phía bên phải của phép gán tín hiệu) và được viết (phía
bên trái của phép gán tín hiệu). Vì vậy, phần tử nhớ là cần thiết. Nếu tín hiệu này phụ
thuộc vào danh sách, thì chỉ có mạch cài đặt được tạo ra. Ngược lại, nếu chỉ phụ thuộc
vào các giá trị đầu vào (l1, l2, l3) thì một phần tử nhớ mạch lật được tạo ra.
Ví dụ,
Process (I1, l2, l3) – inferring a flip-flop
Begin
If CONDITION (l1, l2, l3)
Then RESULT <= DATA(l1, l2 , l3, RESULT);
End if;
End;
Process (l1, l2, l3, RESULT) – inferring a latch
Begin
If CONDITION (l1, l2, l3)
Then RESULT <= DATA (l1, l2, l3. RESULT);
End if;
End;
Để đảm bảo không tạo ra phần tử nhớ, một phép gán tín hiệu đầu ra mặc định phải
được viết trước lệnh điều kiện như sau:
…
RESULT <= DEFAULT_VALUE; -- default assignment
If CONDITION (l1, l2, l3) then RESULT <= DATA (l1, l2, l3, RESULT);
End if;
…
Phép gán tín hiệu đầu tiên này không được nhầm lẫn với giá trị ban đầu đã được giải
thích.
Ví dụ, một rẽ nhánh else được tạo ra rõ ràng :
If CONDITION (l1, l2, l3)
then RESULT <= DATA (l1, l2, l3, RESULT);
else RESULT <= DEFAULT_VALUE;
End if;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 20
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Lệnh lặp lại.
Trong VHDL có hai loại lệnh lặp lại, vòng lặp for và vòng lặp while. Vòng lặp vô hạn
loop … end loop có thể được xem xét như một vòng lặp while với điều kiện luôn
luôn là TRUE.
Lệnh lặp vòng for được trợ giúp bởi các công cụ tổng hợp khi các giá trị biên là tĩnh
(static) toàn cục.
8. Lệnh quá trình và lệnh đồng bộ.
Các lệnh quá trình cho kiểu hành vi mạnh nhất và là cơ sở của mọi lệnh đồng thời.
Một lệnh quá trình bao gồm 3 phần: danh sách tùy chọn, khai báo cục bộ và phần lệnh
tuần tự.
Danh sách độ nhạy.
Một quá trình với một danh sách rõ ràng tương đương với một quá trình với một lệnh
đồng bộ đơn, quá trình được hoạt động mỗi khi một biến cố xảy ra trên một tín hiệu
của danh sách này. Các quá trình như sau:
Process (A, B, C) – danh sách các biến được xem xét
…
begin
…
end process;
Quá trình trên cũng có thể tương đương với:
Process
…
begin
…
wait on A, B, C;
end process;
Khai báo cục bộ.
Trong tất cả các khai báo có thể có bên trong phần khai báo quá trình, khai báo biến là
cần thiết, có thể bao hàm phần tử nhớ. Thật ra, biến có thể sử dụng trong hai cách khác
nhau:
•
Giống như các biến cục bộ, không tạo ra phần cứng nào:
Process (A, B, C)
Variable VAR : BIT;
Begin
VAR : = B and C;
S <= A and VAR;
End process;
– no memorization for this … and gate
-- before being read
Có thể viết hành vi tương tự bằng cách thay thế biến với phần bên phải của lệnh gán:
Process (A, B, C)
Begin
S <= A and B and C;
End process;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 21
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Ưng dụng của biến được chấp nhận bởi các công cụ tổng hợp và không có phần cứng
tương ứng. Trong trường hợp tổng quát thì giữa 2 lệnh đồng bộ, nếu một biến luôn
được gán trước khi được đọc, thì biến này không tạo ra bất kỳ phần cứng nào.
•
Khi thiết kế dữ liệu dưới dạng máy trạng thái.
Process
– synchronous finite state machine with two states
Type T_STATE is (STOP, GO);
Variable STATE: T_STATE;
Begin
Wait until CLK=’1’;
Case STATE is
--variable STATE is read
-- before being target of assignment
when STOP => STATE:= GO;
when GO
=> STATE:= STOP;
end case;
End process;
Ví dụ này chỉ ra rằng việc đọc biến không có nghĩa là có nó trong phần bên phải của
phép gán. Biểu thức case, điều kiện if hoặc thông số in của thủ tục hoặc hàm là cách
khác để đọc nó. Vì thế, giữa hai lênh đồng bộ, nếu một biến được đọc ít nhất một lần
trước khi được gán thì biến này tạo ra phần tử nhớ.
9. Phép gán tín hiệu.
Phép gán tín hiệu đơn giản.
Dạng đơn giản nhất của một phép gán tín hiệu đồng thời là định nghĩa tín hiệu đích
nhận được các giá trị của tín hiệu nguồn mỗi lần một sự kiện xảy ra:
S <= A;
-- S được gán tới A bởi phần cứng
Z <= ‘1’;
-- Tín hiệu Z là một hằng số
Các phép gán tín hiệu chọn lựa và có điều kiện.
Hai phép gán tín hiệu đồng thời được định nghĩa cho mục đích có điều kiện của tín
hiệu; phép gán chọn lựa và có điều kiện.
Ví dụ,
S <= a when x = ‘1’ else B when Y = ‘1’ else C
Ví dụ, nếu A, B, C, X, Y được định nghĩa như là các tín hiệu, quá trình tương là:
Process (A, B, C, X, Y)
Begin
If X = ‘1’ then
S <= A;
Elsif Y = ‘1’ then
S <= B;
Else
S <= C;
End if;
End process;
Hai ví dụ trên chứng minh các phép gán tín hiệu, với công cụ này cho phép người thiết
kế có thể mô tả các thiết kế của mình rõ ràng hơn.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 22
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
10. Component.
Mục đích của lệnh hợp phần là sử dụng một mẫu đã mô tả trước. Đây là cách chính để
xây dựng sự phân thứ bậc thiết kế. Trước khi sao chép, hợp phần phải được khai báo
cục bộ trong phần khai báo kiến trúc, hoặc riêng biệt trong một khối.
Sự khai báo hợp phần (component) định nghĩa cách nối dây cục bộ, có thể ít tổng quát
hơn so sự khai báo thực thể. Trong suốt giai đoạn cấu hình, môt số tín hiệu có thể ở vế
trái nếu chúng ở chế độ out hoặc inout, hoặc bị bỏ qua nếu chúng ở chế độ in với giá trị
mặc định.
Khi sao một hợp phần, các thông số tương thích chung phải được ánh xạ đến các giá trị
và các cổng nối với tín hiệu.
Ví dụ,
Architecture
SYNTHESIZABLE of DRIVE is
Signal
ORDER: ORDER_TYPE;
Signal
CONTROL: BIT;
Signal
DATA_IN, DATA_OUT: BIT_VECTOR(1 to N);
Component CTRL
Port (C : in BIT;
O: out BIT_VECTOR);
End component;
Component OPRT
Port (O:
in BIT_VECTOR;
D1:
in BIT_VECTOR;
D0:
out BIT_VECTOR);
End component;
-- specification configuration
for CONTROLER : CTRL use entity WORD.CTRL(A);
for OPERATING_PART:OPRT use entity WORD OPRT(A) generic map (N);
begin
-- two component instantiation statements.
CONTROLER: CTRL port map(CONTROL, ORDER);
OPERATIVE_PART: OPRT port map (ORDER, DATA_IN,
DATA_OUT);
End SYNTHESIZABLE;
Cấu hình chỉ ra cặp thực thể/ kiến trúc được chọn cho bản sao hợp phần. Với ví dụ sau ,
hai lệnh cấu hình đặc biệt có thể được thay thế bởi một cấu hình độc lập.
Configuration C1 of DRIVER is
For SYNTHESIZABLE
For CONTROLER: CTRL use entity WORD.CTRL(A);
End for;
For OPERATIVE_PART: OPRT use entity WORK.OPRT(A);
Generic map (N);
End for;
End for;
End C1;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 23
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
11. BLOCK.
Các lệnh block được sử dụng cho cấu trúc lệnh đồng thời
Ví dụ,
Signal A, B, C, D, E, F, G: BIT;
Signal S; BIT_VECTOR(1 to 4);
BLOCK_NAME : block
Subtype TWO_BIT_TYPE is BIT_VECTOR(1 to 2);
Signal V1, V2: TWO_BIT_TYPE;
Begin
V1 <= (A or C) &B; V2 <= E &(F and G);
S <= V1 &V2;
End block BLOCK_NAME;
Dưới một số điều kiện, một vài công cụ tổng hợp có thể dịch lệnh block như một cấp
của tổng hợp. Trong trường hợp này nhãn của lệnh khối được dùng như một thông số
cho cấu trúc lệnh.
Ứng dụng khác của lệnh block là định nghĩa phần lệnh đồng thời được điều khiển bởi
clock. Trong trường hợp này phần bảo vệ (guarded) được yêu cầu để mô tả chính xác
tín hiệu clock và điều kiện liên quan tới nó (cạnh lên hoặc xuống).
Hơn nữa, phép gán tín hiệu đồng thời được bảo vệ và hoạt động bởi biểu thức bảo vệ.
Điều này được chỉ ra trong ví dụ sau, ở đó giả thiết rằng tín hiệu clock là đa giá trị.
Ví dụ,
B: block (not CLK’state and CLK = ‘0’ and CLK’last_value =’1’)
Signal R: BIT;
Begin
R <= guarded DATA(1);
S <= guarded R ;
-- Tín hiệu S là DATA(1) được lám trễ 1 chu kỳ
End block
Ứng dụng thứ 3 của lệnh block được dùng trong mạch 3 trạng thái.
Liên kết với lệnh không nối (disconnect) và tín hiệu resolved, phép gán bảo vệ có thể
định nghĩa hành vi ba trạng thái. Khi điều kiện bảo vệ không thoả, tín hiệu đích không
được nối. Đây là hành vi mặc định của mệnh đề disconnect và được cho phép nếu kiểu
tín hiệu đích được resolved.
Đối với tổng hợp, vấn đề được giải quyết là giá trị cuối cùng khi tất cả tín hiệu nguồn
không được nối. Giá trị này phụ thuộc vào hai yếu tố: kết quả của hàm resolved trả về
(khi độ dài của vector đầu vào là null) và loại tín hiệu resolved (bus hoặc register).
Tóm tắt hành vi của loại tín hiệu này như sau:
•
Kết quả cuối cùng là giá trị được trả về bởi hàm resolved với vector đầu vào null
nếu kiểu tín hiệu đích là bus.
•
Kết quả cuối cùng là giá trị trước nếu chỉ có một tín hiệu nguồn và kiểu của tín hiệu
nguồn là register.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 24
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Sơ đồ bộ đệm ba trạng thái được tạo ra bởi lệnh block:
Một số công cụ tổng hợp hỗ trợ tín hiệu không nối loại bus, thì kết quả của hàm
resolved trả về 'Z' để mã hóa mức 3 trạng thái.
12. Gọi thủ tục đồng thời.
Thủ tục đồng thời là thủ tục được gọi từ trong một block hoặc một architechture.
P (A, B, C); -- concurent procedure call;
Tương đương với:
Process
-- process equivalent to the previous concurent procedure call
Begin
-- C is assumed to be an actual parameter of module out.
P(A, B, C);
Wait on A, B;
End process;
Cho phép dùng lệnh wait trong các thủ tục đồng thời. Trong tổng hợp, điều này không
được hỗ trợ. Thật ra, lệnh wait có nhiều tín hiệu chỉ được cho phép nếu các điều kiện
đồng bộ là như nhau.
Thường sử dụng gọi thủ tục đồng thời khi muốn có sự linh động và khả năng thích
nghi. Thủ tục đồng thời dễ dàng sử dụng hơn là bản sao hợp phần (component), vì
không đòi hỏi sự khai báo và chỉ rõ.
13. Lệnh GENERATE.
Hai lệnh generate được định nghĩa là: lệnh generate có điều kiện và lệnh generete lặp.
Từ quan điểm tổng hợp, lệnh này không được hỗ trợ đầy đủ. Trong giai đoạn chế tạo,
một tập các lệnh đồng thời tương đương được phát sinh.
Lệnh generate lặp.
Lệnh này có thể lặp lại một tập các lệnh đồng thời (ví dụ, lặp lại nhiều lần hợp phần
hoặc gán các tín hiệu vector). Trong ví dụ sau, các hằng số k1, k2 có thể là các thông
số tương thích chung và phần cứng tương ứng sẽ không thay đổi.
Ví dụ,
Architecture A of E is
Constant k1: NATURAL := 0;
Constant k2: NATURAL := 3;
Signal A, S: BIT_VECTOR(k1 to k2 );
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 25
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Signal R:
BIT_VECTOR (k1 +1 to k2 +1);
Begin
L: for J in k1 to k2 generate
S(J) <= not A(J);
R(J+1) <= A(j);
End generate;
End;
Trong ví dụ sau, kiến trúc A và B là tương đương, kết quả tổng hợp cuối cùng giống
nhau. Trong kiến trúc đầu tiên A, kết quả là vector V được gán trong lệnh tuần tự loop
và trong kiến trúc thứ hai B, các phép gán tín hiệu đồng thời N được phát ra.
Architecture A of E is
Constant N: NATURAL := 3;
Signal B:
BIT_VECTOR(0 to N );
Signal R:
BIT_VECTOR (1 to N);
Begin
Process (A, B)
Begin
For l in 1 to N loop
V(l) <= F(l, A(l), B (N-1 + 1));
End loop;
End process;
End A;
Architecture B of E is
Constant N: NATURAL := 3;
Signal B:
BIT_VECTOR(0 to N );
Signal A,V: BIT_VECTOR (1 to N);
Begin
L:
for l in 1 to N generate
V(l) <= F(l, A(l), B (N-1 + 1));
End generate;
End B;
Lệnh generate có điều kiện.
Để hoàn tất một mẫu sử dụng các lệnh generate lặp, có thể có ích khi kiểm tra các giá
trị đầu tiên cuối cùng của chỉ số vòng lặp. Các lệnh generate điều kiện có thể được
dùng để giải quyết vấn đề này. Ví dụ sau đây minh hoạ tính chất này, ở đó sự xử lý các
bản sao hợp phần có thể khác nhau (không có, có một, hoặc nhiều bản sao).
Entity E is
Generic (N: NATURAL);
Port (INPUT: in BIT;
OUTPUT: out BIT; …);
End E;
Architecture A of E is
Signal LOCAL:
BIT_VECTOR (1 to N -1);
Component M1
Port (l: in BIT; O: out BIT);
End component;
Begin
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 26
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
L1: if N = 0 generate
OUTPUT <= INPUT;
-- no component instantiation
End generate ;
L2: if N = 1 generate
C1: M1 port map (INPUT, OUTPUT); -- only one instantiation
End generate;
L3: if N >= 2 generate
-- other cases using the intermediate --LOCAL signal
F: M1 port map (INPUT, LOCAL(1));
L4: for: in l to N-2 generate
C :M1 port map (LOCAL(l), LOCAL(l+1));
End generate;
End A;
Sử dụng tương thích chung (Generic).
Thông số tương thích chung là tổng quát của khái niêm hằng số, để nói rằng trong suốt
giai đoạn chế tạo các giá trị của chúng phải được xác định. Vì vậy trước bước này, đối
với giai đoạn dịch, giá trị của chúng chỉ xác định kiểu mà không biết giá trị. Một vài
công cụ tổng hợp hỗ trợ hạn chế một số kiểu thông số tương thích chung (chỉ hỗ trợ
kiểu nguyên hoặc kiểu liệt kê). Tuy nhiên, không có lý do thực sự cho các hạn chế như
vậy, ngoại trừ để không hỗ trợ cho cấu hình.
Ví dụ, viết một mẫu chấp nhận một vector với kích thước N, như là đầu vào. N là
thông số tương thích chung của mẫu này.
Entity AND_N is
Generic (N: POSITIVE);
Port (Din : in BIT_VECTOR (1 to N);
R:
out BIT);
End AND_N;
Architecture A1 of AND_N is
Signal INTER :
BIT_VECTOR (1 to N);
BEGIN
INTER (1) <= Din (1);
L: for l in 1 to N-1 generate
INTER (l+1) <= (Din(l+1) and INTER (l));
End generate;
R <= INTER(N);
End A1;
Architecture A2 of AND_N is
BEGIN
Process (Din)
Variable RES: BIT;
Begin
RES := Din(1);
for l in 2 to N loop
RES:= RES and Din(l);
End loop;
R <= RES;
End process;
End A2;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 27
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Ví dụ, nhận dạng mẫu đã cho trong chuỗi bit tuần tự. Các thông số tương thích chung
là vector phải tìm, và một số bit dùng để báo số lỗi (0: mẫu phải tìm chính xác như đã
mô tả, 1: chỉ sai khác 1 bit mới chấp nhận,…)
Entity SEARCH_PATTERN is
Generic(PATTERN:
BIT_VECTOR;
ERROR_NUMBER: NATURAL);
Port ( CLK:
in BIT;
DATA: in BIT;
RESET:
in BIT;
FOUND:
out BIT);
Begin
Assert (PATTERN ‘length >= ERROR_NUMBER)
Report “pattern length cannot be shorter than ”& “the authorized error
number”
Severity ERROR;
End SEARCH_PATTERN;
Architecture A of SEARCH_PATTERN is
Subtype REG_TYPE is BIT_VECTOR (PATTERN’ range);
Signal REG: REG_TYPE;
Begin
P_REG: process (DATA, CLK, RESET)
Begin
If RESET = ‘1’ then
REG <= REG_TYPE (others => ‘0’);
Elsif CLK =’1’ and CLK’event then
REG <= REG(REG’left-1 downto REG’right) & DATA;
End if;
End process;
P_FOUND: process (REG)
Variable CPT: NATURAL range 0 to ERROR_NUMBER +1;
Begin
CPT := 0;
FOUND <= ‘0’;
For l in REG’range loop
If PATTERN(l) /= REG(l) then
CPT := CPT + 1;
If CPT >= ERROR_NUMBER then
FOUND <= ‘1’;
Exit;
End if;
End if;
End loop;
End process;
End A;
Trong các ví dụ trên cần chú ý những điểm sau:
•
Sử dụng các lệnh assert trong entity không tạo ra phần cứng. Lệnh này kiểm tra
tính nhất quán giữa các giá trị thông số khó mô tả bởi các biểu thức tĩnh (như là các
khoảng trong các kiểu hoặc biểu thức kiểu con).
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 28
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
•
Kiến trúc bao gồm hai quá trình: Quá trình đầu tiên suy ra phần cứng tuần tự với
một tín hiệu reset bất đồng bộ, trong khi đó quá trình thứ hai biểu diễn mạch tổ hợp
thuần tuý.
•
Khai báo REG_TYPE đã được đưa ra để hạn chế tập hợp còn lại (others => '0')
trong nhánh RESET bất đồng bộ.
•
Các thực thể tương thích chung cần được ánh xạ đến các giá trị thông số để tạo ra
phần cứng thực sự. Điều này có thể được làm trong bản sao hợp phần hoặc trong
cấu hình, ở đó các thông số tương thích chung được ánh xạ đến các giá trị của
chúng.
14. Phép so sánh.
Có hai loại so sánh sau:
•
Kiểm tra 2 đối tượng giống nhau. Bao gồm các hàm (cũng được gọi các toán tử)
bằng ('=') và không bằng ('/='). Tất các kiểu tổng hợp được có thể được so sánh khi
sử dụng các toán tử này.
•
Kiểm tra thứ bậc của hai đối tượng khi sử dụng các toán tử quan hệ, các toán tử này
có thể được thực hiện trên kiểu bất kỳ với một lệnh quan hệ như là các kiểu số
nguyên, các kiểu liệt kê và kiểu biểu diễn mã ASCII là quá tải đối với các toán tử
so sánh.
15. Các toán tử số học.
Sau các toán tử Boolean và các phép so sánh, một họ quan trọng khác là toán tử số
học. Bốn phép toán cơ bản đó là: phép cộng, trừ, nhân và chia.
Kiểu dữ liệu thuận tiện nhất để thực hiện các phép toán như vậy là kiểu INTEGER và
các kiểu con quan hệ với nó: NATURAL và POSITIVE. Các toán tử VHDL '+', '-', '*',
và '/ 'được định nghĩa trước và vì vậy có thể được sử dụng mà không cần khai báo.
Điều này cần thiết cho người thiết kế để hạn chế kích thước các đối tượng của kiểu
INTEGER đến giá trị tối tưu. Nếu người thiết kế không làm công việc này, công cụ
tổng hợp sẽ xác định kích thước đã định nghĩa của kiểu INTEGER trong khối
(STD.STANDARD).
Ví dụ,
Signal l1, l2, SUM_l: INTEGER range –16 to 15;
Signal N1, N2, SUM_N: INTEGER range 0 to 47;
SUM_l <= l1 + l2;
SUM_N <= N1 + N2;
Trong ví dụ ngắn này có một vài chú thích về quy ước mã hoá các số. Tất cả quá trình
tổng hợp nhằm vào việc dịch mã nguồn HDL thành biểu diễn nhị phân. Ơ đây, các số
có dấu l1, l2 và SUM_l được mã hoá ở dạng bù hai với việc sử dụng 4 +1 bit. Mặt
khác, các số không dấu N1, N2 và SUM_N được mã hóa với 6 bit (47<2**6-1). Tuy
nhiên, không cần thiết cho khoảng của đối tượng của kiểu INTEGER là luỹ thừa của
hai.
Toán tử nhân và chia phải được xác định trước, cả hai toán hạng phải là cùng kiểu số
nguyên hoặc là kiểu floating point. Kết quả cũng phải cùng kiểu, toán tử nhân cũng
được xác định bởi trường hợp khi một trong những toán hạng là kiểu vật lý và toán
hạng thứ hai là kiểu integer hoặc real. Kết quả trả về là kiểu vật lý.
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 29
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Đối với toán tử chia, chia một giá trị vật lý bởi một giá trị integer hoặc real thì được
cho phép, và kết quả trả về là kiểu vật lý. Phép chia của một giá trị kiểu vật lý bởi một
đối tượng khác cùng kiểu vật lý và phần còn lại của nó, một giá trị nguyên coi như một
kết quả.
Toán tử REM và MOD tác dụng cho toán hạng kiểu integer và kết quả có cùng một
kiểu. Kết quả của REM có biểu hiện của toán hạng thứ nhất và nó được xác định như
sau:
A rem B = A - (A / B) *B
Kết quả của toán tử MOD là biểu hiện toán hạng thứ hai, và nó được xác định như sau:
A mod B = A - B * N
Sau đây là những ví dụ sử dụng toán tử mod và rem:
7 mod 4
-- kết quả = 3;
(-7) rem 4
-- kết quả = -3;
7 mod (-4)
-- kết quả = -1;
(-7) mod (-4) -- kết quả = 3;
16. Các phép dịch và quay.
Các phép tính này thường được thực hiện trên các đối tượng có biểu diễn bit_vector.
Hai loại phép tính dịch và quay có thể được phân biệt : luận lý và số học.
Phép dịch số học có thể được sử dụng cho phép nhân (dịch sang trái) hoặc chia (dịch
sang phải) nếu toán hạng vế phải của một phép toán là một luỹ thừa của 2. Mỗi một
toán tử giữ một dãy BIT hoặc BOOLEAN như một toán hạng trái và giá trị INTEGER
như toán hạng phải, đóng vai trò giải thích toán tử. Nếu giá trị INTEGER là âm, hành
vi ngược nhau sẽ xảy ra.
Toán tử SLL (xoay trái luận lý) và toán tử SRL (xoay phải luận lý) điền vào những bit
huỷ bỏ với left-operand-type'LEFT.
Toán tử SLA (xoay trái số học) điền vào những bit bị huỷ bỏ với bit cực phải của toán
hạng trái.
Toán tử SRA (xoay phải số học ), điền vào những phần tử bị huỷ bỏ với bit cực trái của
toán hạng trái.
Ví dụ,
-- giả sử tất cả những toán hạng trái đều là BIT_VECTOR
"1001010" sll2 is "0101000";
-filled with BIT'LEFT, which is '0'
"1001010" srl3 is "0001001";
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 30
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
III. MỘT SỐ VÍ DỤ THIẾT KẾ CÁC MẠCH TỔ HỢP VÀ TUẦN TỰ.
Đoạn mã chương trình tạo mạch dồn kênh 2 sang 1.
LIBRARY ieee;
USE ieee.std_logic_1164.all;
ENTITY mux2to1 IS
PORT (w0, w1, s :IN STD_LOGIC;
F:
:OUT STD_LOGIC);
END mux2to1;
ARCHITECTURE behavior OF mux2to1 IS
BEGIN
WITH s SELECT
F <= w0 WHEN ‘0’,
w1 WHEN OTHERS;
END behavior;
Mạch so sánh 4 bit.
Mạch so sánh 4 bit bao gồm 8 bit ngõ vào, chia thành 2 nhóm, mỗi nhóm 4 bit và được
đặt tên là A và B. Kết quả của phép so sánh có 3 trường hợp: A bằng B, A lớn hơn B và
A nhỏ hơn B. Trong mạch so sánh này kết quả của phép so sánh ở ngõ vào sẽ được
biểu thị bằng 3 bit ngõ ra cho 3 trường hợp so sánh giữa A và B, AeqB(A equal B),
AgtB(A greater B), AltB (A lighter B). Mã chương trình của mạch so sánh 4 bit có
dạng như sau:
LIBRARY ieee;
USE ieee.std_logic_1164.all;
USE ieee.std_logic_unsgned.all;
ENTITY compare IS
PORT (A, B :
IN STD_LOGIC_VECTOR(3 DOWNTO 0);
AeqB, AgtB, AltB :OUT STD_LOGIC);
END compare;
ARCHITECTURE behavior OF compare IS
BEGIN
AeqB <= ‘1’ WHEN A = B ELSE ‘0’;
AgtB <= ‘1’ WHEN A > B ELSE ‘0’;
AltB <= ‘1’ WHEN A = B ELSE ‘0’;
END behavior;
Mạch mã hóa ưu tiên.
LIBRARY ieee;
USE ieee.std_logic_1164.all;
ENTITY priority IS
PORT (w :IN STD_LOGIC_VECTOR(3 DOWNTO 0);
y :OUT STD_LOGIC_VECTOR(1 DOWNTO 0);
z :IN STD_LOGIC;
END priority;
ARCHITECTURE behavior OF priority IS
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 31
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
BEGIN
PROCESS (w)
IF w(3) = ‘1’ THEN y <= “11”;
ELSIF w(2) = ‘1’ THEN y <= “10”;
ELSIF w(1) = ‘1’ THEN y <= “01”;
ELSE y <= “00”;
END IF;
END PROCESS;
Z <=0 WHEN w = “0000” ELSE ‘1’;
w1 WHEN OTHERS;
END behavior;
Từ đoạn mã trên ta có mạch bao gồm 4 ngõ vào, 3 ngõ ra, tùy thuộc vào các giá trị ngõ
vào mà các ngõ ra sẽ có giá trị tương ứng, ở mạch mã hóa ưu tiên này, w(3) có mức ưu
tiên cao nhất và w(0) có mức ưu tiên thấp nhất, giá trị ngõ ra z chỉ bằng 0 khi tất cả các
ngõ vào bằng 0, ngược lại nó luôn bằng 1. Đoạn mạch ở trên sử dụng mệnh đề if-thenelse, tuy nhiên người thiết kế có thể linh hoạt các thiết kế bằng những mệnh đề khác,
nhưng phải đảm bảo hoạt động của mạch là đúng nguyên tắc.
Mạch giải mã từ 2 đường sang 4.
Mạch giải mã từ 2 đường sang 4 đường, bao gồm 3 ngõ vào, đó là: w1, w2, En. Hai
ngõ vào w1, w2 là hai ngõ vào sẽ quyết định giá trị các ngõ ra, ngõ vào En là ngõ vào
cho phép(có thể là mức '0' hoặc mức '1' tùy theo người thiết kế), khi ngõ vào En tích
cực thì các ngõ ra mới có được giá trị tương ứng với các ngõ vào. Trong đoạn mã
VHDL cho mạch giải mã này, các ngõ ra có ký hiệu từ y3 đến y0. Đoạn mã của
chương trình có dạng như sau, trong đoạn mã này, phát biểu case được sử dụng.
LIBRARY ieee;
USE ieee.std_logic_1164.all;
ENTITY dec2to4 IS
PORT (w
: IN STD_LOGIC_VECTOR(1 DOWNTO 0);
En
: IN STD_LOGIC;
y
:OUT STD_LOGIC_VECTOR(0 TO 3);
END dec2to4;
ARCHITECTURE behavior OF dec2to4 IS
BEGIN
PROCESS (w, En)
BEGIN
IF En = ‘1’ THEN
CASE w IS
WHEN “00” =>
y <= “1000”;
WHEN “01” =>
y <= “0100”;
WHEN “10” =>
y <= “0010”;
WHEN OTHERS => y <= “0001”;
END CASE;
ELSE
y <= “0000”;
END IF;
END PROCESS;
END Behavior;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 32
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
Mạch chốt dữ liệu.
Mạch chốt dữ liệu có nhiệm vụ chốt lại dữ liệu ngõ vào và đưa dữ liệu đó tới ngõ ra, dữ
liệu tại ngõ ra sẽ thay đổi tương ứng với dữ liệu ngõ vào khi có một xung tác động.
Ngõ ra sẽ duy trì dữ liệu mà nó nhận được ở ngõ vào trong suốt quá trình chờ xung tác
động, khi không có xung tác động, nếu ngõ vào có thay đổi thì giá trị ngõ ra vẫn không
thay đổi giá trị mà nó nhận được ở lần nhận cuối cùng. Đoạn mã VHDL cho mạch
chốt được viết như sau:
LIBRARY IEEE;
USE ieee.std_logic_1164.all;
ENTITY flipflop IS
Port
( D, clock
: IN std_logic;
Q
: OUT std_logic);
END flipflop;
ARCHITECTURE bahavior OF flipflop IS
BEGIN
PROCESS
BEGIN
WAIT UNTIL Clock’EVENT AND Clock = ‘1’;
Q <= D;
END PROCESS;
END bahavior;
Với đoạn mã VHDL trên, ngõ vào dữ liệu có tên là D, xung tác động cạnh , ngõ ra là
Q, khi có một xung cạnh lên, ngõ ra Q sẽ nhận giá trị từ ngõ vào D và duy trì giá trị đó
trong suốt quá trình chờ một xung kế tiếp. Đoạn mã trên được viết với một bit ngõ vào,
một bit ngõ ra, người thiết kế hoàn toàn có thể thay đổi số bit ngõ vào và số bit ngõ ra
cho phù hợp với thiết kế của mình. Đoạn mã trên được viết đầy đủ cho một mạch chốt,
với các công cụ tổng hợp và biên dịch, người thiết kế có thể ứng dụng nó vào trong
mạch thực tiễn sau khi đã nạp vào IC.
Mạch tạo thanh ghi 8 bit.
Thanh ghi trong mạch số đóng vai trò rất quan trọng, các thiết kế số hiện đại hầu như
đều phải sử dụng thanh ghi, VHDL cho phép người thiết kế có thể tạo ra thanh ghi với
số bit mong muốn. Ngoài ra còn có thể linh hoạt chúng trong các thiết kế của mình,
thanh ghi thực tế chính là một mạch chốt dữ liệu. Đoạn mã sau đây viết cho thanh ghi
16 bit, trong thiết kế có sử dụng thông số tương thích chung generic.
LIBRARY IEEE;
USE ieee.std_logic_1164.all;
ENTITY regn IS
GENERIC ( N : INTEGER := 16);
Port
( D, clock
: IN std_logic_vector (N-1 DOWNTO 0);
Reset, clock : IN std_logic;
Q
: OUT std_logic_vector (N-1 DOWNTO 0);
END regn;
ARCHITECTURE behavior OF regn IS
BEGIN
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 33
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
PROCESS (Reset, clock)
BEGIN
IF Reset = ‘0’ THEN
Q <= (OTHERS => ‘0’);
ELSIF Clock’EVENT AND Clock = ‘1’ THEN
Q <= D;
END IF;
END PROCESS;
END behavior;
Mạch đếm lên.
Mạch đếm lên hoạt động theo nguyên tắc: khi có một xung tác động ở ngõ vào, ngõ ra
sẽ thay đổi một bit theo chiều hướng đếm lên, mạch đếm lên ngoài ngõ vào xung clock,
người thiết kế còn có thể tạo thêm các ngõ vào khác như Reset, Enable… để tạo thêm
tính linh hoạt của mạch. Mã VHDL cho mạch đếm lên được viết như sau:
LIBRARY IEEE;
USE ieee.std_logic_1164.all;
USE ieee.std_logic_unsigned.all;
ENTITY upcount IS
Port
( Reset, Clock, En : IN std_logic;
Q
: OUT std_logic_vector (3 DOWNTO 0);
END upcount;
ARCHITECTURE behavior OF upcount IS
SIGNAL Count : STD_LOGIC_VECTOR (3 DOWNTO 0);
BEGIN
PROCESS (Clock, Reset)
BEGIN
IF Reset = ‘0’ THEN
Count <= “0000”;
ELSIF Clock’EVENT AND Clock = ‘1’ THEN
IF En = ‘1’ THEN
Count <= Count+ 1;
ELSE
Count <= Count;
END IF;
END IF;
END PROCESS;
Q <= Count;
END
behavior;
Mạch đệm 3 trạng thái.
Mạch đệm 3 trạng thái giúp mạch thực tế khi hoạt động có thể điều chỉnh ngõ ra ở trạng
thái thích hợp cho sự vận hành của mạch, với 3 trạng thái, người thiết kế các mạch số sẽ
điều chỉnh mạch sao cho hoạt động tốt hơn và tiết kiệm năng lượng hơn. Mã VHDL cho
mạch đệm 3 trạng thái được viết như sau:
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 34
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
LIBRARY IEEE;
USE ieee.std_logic_1164.all;
ENTITY trin IS
GENERIC ( N : INTEGER := 8);
Port( X
: IN std_logic_vector (N-1 DOWNTO 0);
E
: IN std_logic;
F
: OUT std_logic_vector (N-1 DOWNTO 0);
END trin;
ARCHITECTURE behavior OF trin IS
BEGIN
F <= (OTHERS => ‘Z’) WHEN E =’0’ ELSE X;
END behavior;
Xây dựng máy trạng thái trong VHDL
library ieee;
use ieee.std_logic_1164.all;
use work.std_arith.all;
entity divby5 is
port(x, clk : in std_logic;
y
: out std_logic);
end divby5;
architecture state_machine of divby5 is
type StateType is (state0, state1, state2, state3, state4);
signal p_s, n_s : StateType;
begin
fsm: process (p_s, x)
begin
case p_s is
when state0 => y <= '0';
if x = '1' then
n_s <= state1;
else
n_s <= state0;
end if;
when state1 => y <= '0'
if x = '1' then
n_s <= state3;
else
n_s <= state2
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 35
https://fb.com/tailieudientucntt
Bài giảng Thiết Kế Hệ Thống Số
Phần VHDL
end if;
when state2 =>
if x = '1' then
n_s <= state0;
y <= '1';
else
n_s <= state4;
y <= '0';
end if;
when state3 => y <= '1';
if x = '1' then
n_s <= state2;
else
n_s <= state1;
end if;
when state4 => y <= '1';
if x = '1' then
n_s <= state4;
else
n_s <= state3;
end if;
when others => n_s <= state0;
end case
end process fsm;
state-clocked : process (clk)
begin
if rising_edge(clk) then
p_s <= n_s;
end if;
end process state_clocked;
end architecture state_machine;
GV: Nguyễn Trọng Hải
CuuDuongThanCong.com
Trang 36
https://fb.com/tailieudientucntt
Download