Giáo trình Tin học - Chương 1: Hệ đếm – Mã hóa và lưu trữ thông tin
6. Bài tập
1. Cho biết biểu diễn nhị phân của các số ở hệ thập lục phân sau:
a. BC b. 67 c. 10 e. 3F
2. Cho biết bit cực trái trong biểu diễn nhị phân của các số trong hệ thập lục phân là gì?
a. FF b. 7F c. 8F e. 1F
3. Biểu diễn các dãy bit sau về hệ thập lục phân:
a. 101010101010 b. 110010110111 c. 000011101011
4. Cho một màn hình có thể hiển thị được 24 dòng, ứng với mỗi dòng có 80 ký tự. Nếu một điểm
trên màn hình được lưu trữ trong bộ nhớ bằng một byte cho mã ASCII của ký tự tại điểm đó,
thì có bao nhiêu byte để lưu trữ toàn bộ các điểm trên màn hình?
5. Biến đổi các dãy bit sau về hệ thập lục phân tương ứng:
a. 111 b. 0001 c. 11101 d. 10001 e. 10111 f. 00000
g. 100 h. 1000 i. 10000 j. 11001 k. 11010 l. 11011
16 trang |
Chia sẻ: vutrong32 | Lượt xem: 1187 | Lượt tải: 0
Bạn đang xem nội dung tài liệu Giáo trình Tin học - Chương 1: Hệ đếm – Mã hóa và lưu trữ thông tin, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
MỤC LỤC 1
MỤC LỤC
MỤC LỤC..........................................................................................................................................1
Chương 1 - HỆ ĐẾM – MÃ HÓA VÀ LƯU TRỮ THÔNG TIN ................................................2
1. MÃ HÓA VÀ LƯU TRỮ THÔNG TIN ......................................................................................... 2
1.1. Cách tổ chức dữ liệu trong bộ nhớ chính.................................................................................. 2
1.2. Cách tổ chức một Byte.............................................................................................................. 2
1.3. Các kiểu dữ liệu ........................................................................................................................ 3
1.4. Các ngôn ngữ lập trình.............................................................................................................. 3
2. CÁC HỆ ĐẾM ................................................................................................................................. 3
2.1. Hệ nhị phân (cơ số 2)................................................................................................................ 3
2.2. Hệ bát phân (cơ số 8) ................................................................................................................ 4
2.3. Hệ thập phân (cơ số 10) ............................................................................................................ 4
2.4. Hệ thập lục phân (cơ số 16) ...................................................................................................... 4
3. CÁC QUI TẮC CHUYỂN ĐỔI MỘT SỐ GIỮA CÁC HỆ ĐẾM.................................................. 5
3.1. Qui tắc chung ............................................................................................................................ 5
3.2. Qui tắc chuyển đổi một số từ hệ 10 sang hệ cơ số b (b ≠10).................................................... 5
3.3. Qui tắc chuyển đổi một số từ hệ 2 sang hệ 16 .......................................................................... 5
3.4. Qui tắc chuyển đổi một số từ hệ 16 sang hệ nhị phân .............................................................. 5
4. CÁC PHÉP TOÁN TRÊN SỐ NHỊ PHÂN..................................................................................... 5
4.1. Cộng nhị phân ........................................................................................................................... 5
4.2. Cách lưu trữ số âm.................................................................................................................... 6
4.3. Cách lưu trữ số thực.................................................................................................................. 8
4.4. Các phép toán số học (arithmatic)/luận lý (logic)................................................................... 13
5. Bảng mã ASCII.............................................................................................................................. 15
6. Bài tập ............................................................................................................................................ 15
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 1: Hệ đếm – Mã hóa và lưu trữ thông tin 2
Chương 1 - HỆ ĐẾM – MÃ HÓA VÀ LƯU
TRỮ THÔNG TIN
1. MÃ HÓA VÀ LƯU TRỮ THÔNG TIN
Lưu trữ thông tin trên bộ nhớ (chính và phụ) dựa trên khả năng biểu diễn thông tin qua các bit
(đơn vị lưu trữ dữ liệu nhỏ nhất trong bộ nhớ).
1.1. Cách tổ chức dữ liệu trong bộ nhớ chính
Đơn vị lưu trữ nhỏ nhất trong bộ nhớ là bit (Binary ditgit). Bit có hai trạng thái: 0/False và
1/True. Thông tin được biểu diễn thông qua một nhóm bit (0 và 1), các thông tin khác nhau sẽ có
dãy bit khác nhau. Thông tin có thể là ký tự, số, hoặc dấu câu,Tốc độ truyền dữ liệu được tính
dưới dạng số bit trên 1 giây.
1 Kbps = 103 bits per second (hay 103 bps).
1 Mbps = 106 bits per second.
Mỗi 8 bit gộp lại thành một nhóm nhỏ gọi là Byte (theo thứ tự từ phải qua trái).
Số lượng byte trong bộ nhớ ở mỗi máy tính là khác nhau. Kích thước bộ nhớ chính được đo
bằng đơn vị Mega Byte (MB). Ngoài ra, còn có các đơn vị đo lường khác như sau:
1 KB = 1024 Byte = 210 Byte.
1 MB = 1024 KB = 220 Byte.
1 GB = 1024 MB = 230 Byte.
Tóm lại, bộ nhớ máy tính là chuỗi các byte được tạo từ các bit. Các byte bộ nhớ có thể truy
cập (access) hoặc cho phép đặt lại giá trị. Dữ liệu ở một byte là xác định tại một thời điểm, nghĩa
là nếu có yêu cầu thay đổi thông tin thì thông tin cũ sẽ bị mất. Thao tác lấy thông tin từ bộ nhớ
gọi là thao tác đọc dữ liệu (Read) và thao tác ghi thông tin lên bộ nhớ gọi là thao tác ghi dữ liệu
(Write).
Đối với các byte cho phép cả hai thao tác đọc – ghi (Read – Write) dữ liệu thì các byte này
nằm trong bộ nhớ RAM (Random Access Memory), dữ liệu lưu trữ ở các byte này sẽ bị mất khi
có sự cố mất điện. Với các byte chỉ cho thao tác đọc (Read) thì các byte này nằm trong bộ nhớ
ROM (Read Only Memory), các byte này chứa các dữ liệu do nhà sản xuất đưa vào.
1.2. Cách tổ chức một Byte
Một Byte có 8 bit được đánh số từ phải sang trái với các số từ 0 đến 7.
Bit thứ: 7 6 5 4 3 2 1 0
1 0 1 0 1 1 1 0
Bit có ý
nghĩa nhất
Bit ít có ý
nghĩa nhất
Bit thứ 7 gọi là bit cao (cực trái) và bit thứ 0 gọi là bit thấp (cực phải). Một Byte có thể lưu
trữ một số nguyên có giá trị trong khoảng từ 0 đến 255 (00000000 đến 11111111).
Như vậy, với 2 Byte có thể lưu trữ một số nguyên có giá trị từ 0 đến 65535. Sử dụng phương
pháp nhị phân để lưu trữ làm tăng hiệu quả lưu trữ các sô nguyên so với cách dùng bảng mã
ASCII. Ngoài ra, còn sử dụng hệ nhị phân để biểu diễn các số âm (dùng phương pháp bù 2), hoặc
dùng phương pháp dấu chấm động để biểu diễn số thập phân (số thực).
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 1: Hệ đếm – Mã hóa và lưu trữ thông tin 3
1.3. Các kiểu dữ liệu
1.3.1.
1.3.2.
1.3.3.
Số nguyên (Integer)
Trong thế hệ máy 8086, số nguyên integer được lưu trữ trong 2 Byte (16-bit). Như vậy tối đa
có 216 = 65536 giá trị nguyên dương.
Để biểu diễn số nguyên âm, trong dãy 16-bit, chia thành hai vùng:
- 1 bit dùng làm bit dấu (cực trái).
- 15 bit còn lại là giá trị số (215=32 768 số).
Có nhiều phương pháp biểu diễn số âm trong máy tính. Thông thường người ta dùng
phương pháp bù 2. Trong phương pháp này, phạm vi giá trị nguyên từ -32 768 đến +32
767.
Số thực (Real)
Số thực được biểu diễn dưới dạng dấu chấm tĩnh hoặc dấu chấm động.
Trong biểu diễn số thực dấu chấm động 4 Byte (32-bit), phạm vi số thực từ 10-38 đến10+38 (số
âm và dương).
Ký tự
Trong bảng qui ước ASCII, kích thước một ký tự là 1 Byte. Như vậy, bảng mã này có 256 ký
tự.
Trong bảng Unicode, kích thước một ký tự là 2 Byte, do đó bảng mã này có đến 65536 ký tự,
gồm nhiều bộ ký tự của các quốc gia.
1.4. Các ngôn ngữ lập trình
1. Hợp ngữ (Assembly)
2. FORTRAN
3. C/C++
5. Java
6. Visual Basic
7. C#
8. PHP
9.
2. CÁC HỆ ĐẾM
2.1. Hệ nhị phân (cơ số 2)
Hệ nhị phân (hay còn gọi là Binary) biểu diễn giá trị dưới dạng dãy các bit 0 và 1. Ví dụ:
1011.
Các số biểu diễn ở hệ nhị phân là một dãy bit, ứng với mỗi vị trí bit được gán một trọng số đi
từ phải qua trái có giá trị từ 1,2,4,8,..Dựa theo qui luật: số sau bằng 2 lần số trước. Ví dụ dãy bit
100101 là biểu diễn nhị phân của 37.
100101 = 1x1 = 1
0x2 = 0
1x4 = 4
0x8 = 0
0x16 = 0
1x32 = 32
Giá trị tổng cộng = 37
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 1: Hệ đếm – Mã hóa và lưu trữ thông tin 4
2.2. Hệ bát phân (cơ số 8)
Tên gọi trên máy tính là Octor.
Nhóm 3 bit lại với nhau (từ phải qua trái), ta được các số biểu diễn ở hệ 8 (23=8). Bảng
chuyển đổi giữa hệ 2 và hệ 8:
Hệ 2 Hệ 8 Hệ 2 Hệ 8
000 0 100 4
001 1 101 5
010 2 110 6
011 3 111 7
2.3. Hệ thập phân (cơ số 10)
Tên gọi trên máy tính là Decimal.
Các số cơ bản biểu diễn trong hệ cơ số 10 từ 0 đế 9. Ví dụ số 37.
2.4. Hệ thập lục phân (cơ số 16)
Tên gọi trên máy tính là Hexa.
Nhóm 4 bit lại với nhau (từ phải qua trái), ta được các số biểu diễn ở hệ 16 (24=16).
Các số biểu diễn trong hệ 16:
- Giá trị số: Từ 0 đến 9
- Ký tự: Từ A đến F.
Bảng chuyển đổi giữa hệ 2, 10, và 16:
Hệ 2 Hệ 10 Hệ 16 Hệ 2 Hệ 10 Hệ 16
0000 0 0 1000 8 8
0001 1 1 1001 9 9
0010 2 2 1010 10 A
0011 3 3 1011 11 B
0100 4 4 1100 12 C
0101 5 5 1101 13 D
0110 6 6 1110 14 E
0111 7 7 1111 15 F
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 1: Hệ đếm – Mã hóa và lưu trữ thông tin 5
3. CÁC QUI TẮC CHUYỂN ĐỔI MỘT SỐ GIỮA CÁC HỆ ĐẾM
Các số cơ bản của một hệ đếm là các số tối thiểu để biểu diễn mọi số trong hệ đếm ấy.
3.1. Qui tắc chung
Nếu một số có giá trị lớn hơn các số cơ bản thì nó sẽ được biểu diễn bằng cách tổ hợp các
chữ số cơ bản theo công thức sau:
X= an an-1a1 ao = anbn + an-1bn-1a1b + ao (*)
Với b là cơ số của hệ đếm, an,an-1,a1,ao là các chữ số cơ bản. X là số ở hệ đếm cơ số b.
3.2. Qui tắc chuyển đổi một số từ hệ 10 sang hệ cơ số b (b ≠10)
Lấy số thập phân chia cho cơ số b cho đến khi phần dương của phép chia bằng 0, số đổi được
sẽ là các phần dư của phép chia theo thứ tự ngược lại.
Ví dụ: cho X=610 nghĩa là X=6 trong hệ 10 sẽ được đổi thành 1102 trong hệ 2. Cách đổi như
sau: 6 chia 2 = 3, dư 0
3 chia 2 = 1, dư 1
1 chia 2 = 0, dư 1
Vậy kết quả là: 110.
Ngược lại, nếu muốn đổi một số từ cơ số b sang cơ số 10, ta sử dụng công thức (*). Ví dụ:
X=1102 thì X=1x22 +1x21 +0=6.
3.3. Qui tắc chuyển đổi một số từ hệ 2 sang hệ 16
Nhóm lần lượt 4 bit từ phải qua trái, sau đó thay thế các nhóm 4 bit bằng các giá trị tương
ứng với hệ thập lục phân (tra bảng). Ví dụ: X=11’10112=3B16.
3.4. Qui tắc chuyển đổi một số từ hệ 16 sang hệ nhị phân
Ứng với mỗi chữ số sẽ được biểu diễn dưới dạng 4 bit nhị phân.
Ví dụ: X=3B16=0011’10112=11’10112.
4. CÁC PHÉP TOÁN TRÊN SỐ NHỊ PHÂN
4.1. Cộng nhị phân
+ 0 1
0 0 1
1 1 10
Khi cộng, thực hiện công từ phải qua trái, ứng với mỗi cột ta cộng 2 số theo qui tắc trên, nếu
có nhớ thì cộng nhớ sang cột kế bên.
Ví dụ: cộng hai dãy bit sau đây, dãy 1: 111010; dãy 2: 11011
0 0 1 1 1 0 1 0
0 0 0 1 1 0 1 1 +
1
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 1: Hệ đếm – Mã hóa và lưu trữ thông tin 6
0 0 1 1 1 0 1 0
0 0 0 1 1 0 1 1 Nhớ 1 +
0 1
0 0 1 1 1 0 1 0
0 0 0 1 1 0 1 1 +
1 0 1
0 0 1 1 1 0 1 0
0 0 0 1 1 0 1 1 Nhớ 1 +
0 1 0 1
0 0 1 1 1 0 1 0
0 0 0 1 1 0 1 1 Nhớ 1 +
1 0 1 0 1
0 0 1 1 1 0 1 0
0 0 0 1 1 0 1 1 Nhớ 1 +
0 1 0 1 0 1
0 0 1 1 1 0 1 0
0 0 0 1 1 0 1 1 +
1 0 1 0 1 0 1
0 0 1 1 1 0 1 0
0 0 0 1 1 0 1 1 +
0 1 0 1 0 1 0 1
4.2. Cách lưu trữ số âm
4.2.1. Phương pháp dấu lượng (sign – magnitude)
Bit cực trái dùng làm bit dấu. Bit 1 là dấu dương (+), và bit 0 là dấu âm (-).
Ví dụ: với mẫu là 4 bit thì các số biểu diễn như sau:
Mẫu bit Giá trị biểu diễn
1111 7
1110 6
1101 5
1100 4
1011 3
1010 2
1001 1
1000 0
Mẫu bit Giá trị biểu diễn
0111 -1
0110 -2
0101 -3
0100 -4
0011 -5
0010 -6
0001 -7
0000 -8
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 1: Hệ đếm – Mã hóa và lưu trữ thông tin 7
Để biểu diễn một số âm về dạng nhị phân có dấu với mẫu K bit thì lấy số cần biểu diễn cộng
thêm 2k-1, sau đó biểu diễn chúng về hệ nhị phân.
Ví dụ: Với số +5 trong mẫu 4 bit thì biểu diễn là 5 + 23 = 1310 sẽ là 1101.
Với số -5 trong mẫu 4 bit thì biểu diễn là -5 + 23 = 310 sẽ là 0011.
4.2.2.
4.2.3.
Biểu diễn số bù 1
Vẫn dùng bit cực trái làm bit dấu nhưng với qui định bit 0 cho số dương và bit 1 cho số âm.
Để biểu diễn số n theo dạng bù 1, ta áp dụng qui tắc biểu diễu dưới dạng nhị phân của trị
tuyệt đối n theo mẫu K bit cho trước. Nếu n<0, đổi 1 thành 0 và ngược lại.
Ví dụ:
Với n = 5 (mẫu 4 bit) biễu diễn theo phương pháp bù 1 là 0101.
n = -5 ______________________________________1010.
Với n = 6 _______________________________________0110.
n = -6_______________________________________1001.
Biểu diễn số bù 2
Vẫn sử dụng bit cực trái làm bit dấu giống như bù 1, nhưng có một số khác biệt khi đổi sang
hệ nhị phân có dấu.
Biểu diễn dưới dạng nhị phân của trị tuyệt đối n theo mẫu K bit cho trước. Nếu n<0, bắt đầu
từ phải qua trái giữ nguyên các bit cho đến khi gặp bit có giá trị 1 đầu tiên, sau đó các bit tiếp
theo bên trái bit 1 đầu tiên đó đổi 1 thành 0 và ngược lại.
Ví dụ: Với n = -6, biểu diễn nhị phân trị tuyệt đối của n (theo mẫu 4 bit) là 0110, khi đó biểu
diễn số bù 2 của n là 1010.
Biểu diễn số bù 2 theo mẫu 4 bit
Mẫu bit Giá trị biểu diễu
0111 7
0110 6
0101 5
0100 4
0011 3
0010 2
0001 1
0000 0
Mẫu bit Giá trị biểu diễu
1111 -1
1110 -2
1101 -3
1100 -4
1011 -5
1010 -6
1001 -7
1000 -8
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 7– EndNote 8
Thực chất, số biểu diễn dưới dạng bù 2 là số biểu diễn ở dạng bù 1, sau đó cộng thêm 1.
4.2.4. Phép cộng số bù 1 và bù 2
4.2.4.1 Cộng số bù 1
Khi thực hiện phép toán cộng đối với số bù 1, làm tương tự như cộng nhị phân. Nếu ở hai
bit cực trái khi thực hiện phép cộng có phát sinh nhớ thì cộng nhớ vào kết quả.
Ví dụ: thực hiện cộng m = - 6 biểu diễn bù 1 (mẫu 5 bit) là 11001, và
n = - 4 biểu diễn bù 1 (mẫu 5 bit) là 11011.
1 1 0 0 1 +
1 1 0 1 1 Nhớ 1
1 0 1 0 0 + 1 Cộng thêm Nhớ 1
1 0 1 0 1 -10 ở bù 1
4.2.4.2 Cộng số bù 2
Khi thực hiện phép toán cộng đối với số bù 2, làm tương tự như cộng nhị phân. Nếu ở hai
bit cực trái khi thực hiện phép cộng có phát sinh nhớ thì bỏ nhớ.
Ví dụ:
Thực hiện cộng m = - 6 biểu diễn bù 2 (mẫu 5 bit) là 11010, và
n = - 4 biểu diễn bù 1 (mẫu 5 bit) là 11100.
1 1 0 1 0
1 1 1 0 0 +
1 0 1 1 0 -10 ở bù 2 (bỏ nhớ 1)
4.2.5.
4.3.1.
Tràn số
Hiện tượng tràn số xảy ra khi số cần biểu diễn vượt quá số bit cho trước.
Ví dụ:
Thực hiện phép cộng m = -6 và n = -4 ( bù 1 theo mẫu 4 bit). Kết quả phép cộng ở dạng bù
1 là 0110 là biểu biễn của +6 Æ kết quả sai!!!.
Để tránh trường hợp lỗi tràn số, ta tăng số bit biểu diễn lên. Tổng quát, số ở dạng bù 1 và 2,
giá trị dương lớn nhất khi dùng mẫu n bit là: 2n-1-1 và giá trị âm nhỏ nhất là -2n-1.
4.3. Cách lưu trữ số thực
Khác với số nguyên, số thực không chỉ đơn thuần biểu diễn ở dạng nhị phân 0 và 1 và còn
dựa vào dấu chấm cơ số, thường gọi là biểu diễn dấu chấm động (floating point notation).
Biểu diễn số thực dùng dấu chấm tĩnh (Fixed-point)
Để biểu diễn hỗn số bằng hệ nhị phân ta dùng dấu chấm cơ số (radix point). Số bên trái dấu
chấm cơ số biểu diễn nhị phân của phần nguyên của số thực và bên phải là biểu diễn nhị phân
của phần dư (phân số), vị trí bit bên phải đầu tiên sau dấu chấm là biểu diễn cho số
1/2,1/4,1/8,Với qui luật số sau nhỏ hơn 2 lần số trước. Các giá trị này gọi là trọng số của bit
tương ứng với vị trí tính từ vị trí đầu tiên bên phải của dấu chấm cơ số.
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 7– EndNote 9
Để biến đổi số thực ở hệ 2 phân sang hệ 10, thực hiện đổi phần nguyên và phần dư (phân
số) sang hệ thập phân, nhưng chú ý số nhị phân bên phải dấu chấm sẽ có trọng số bắt đầu từ ½
và giảm một nữa từ trái sang phải.
Ví dụ:
Cho số thực 5.625, biểu diễn nhị phân là 101.101. Cách tính như sau:
Phần nguyên là 5, biểu diễn nhị phân là 101 (tra bảng).
Phần dư (phân số là 5/8):
0.625 chia ½ (nhân 2) = 1.25
0.25 chia ½ = 0.5
0.5 chia ½ = 1
Do đó, biểu diễn nhị phân của 0.625 là 101.
Trong trường hợp ngược lại, muốn chuyển phần dư từ hệ 10 sang hệ 2 thì nhân thêm ½.
4.3.2. Cộng nhị phân trên số thực
Cộng nhị phân trên số thực cũng giống như cộng nhị phân trên số nguyên, nhưng chú ý là
dấu chấm cơ số phải sắp thẳng hàng cho hai số.
Ví dụ:
1 0 . 0 1 1 Biểu diễn của 2.375
1 0 0 . 1 1 Biểu diễn của 4.75 +
1 1 1 . 0 0 1 Biểu diễn của 7.125
4.3.3. Phương pháp biểu diễn dấu chấm động (Floating-point)
Để biểu diễn số thực dưới dạng dấu chấm động, sử dụng các khái niệm:
- Bit dấu (Sign): 0 (dương); 1(âm).
- Phần mũ (Expnent).
- Phần định trị (Mantissa).
nb = be.m, trong đó: b: cơ số
e: phần mũ
m: phần định trị
Ví dụ: n=17
17 = 101x1.7
Phương pháp này sử dụng chuẩn IEEE tích hợp sẳn trong các thế hệ máy tính sử dụng chip
Intel (Pentium) hiện nay. Chuẩn IEEE (Institude of Electical and Electronics Engineers) dành
riêng cho biểu diễn và tính toán trên số thực.
Dựa vào số bit biểu diễn, chuẩn IEEE phân thành 4 mức cơ bản sau:
Presision Sign
(bits)
Exponent
(bits)
Mantissa
(bits)
Total
(bits)
2 byte (half) 1 5 10 16
4 bytes (single) 1 8 23 32
8 bytes (double) 1 11 52 64
4.3.3.1 Phương pháp chung
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 7– EndNote 10
Miền giá trị của e bits mũ: -2e-1 ≤ E ≤ 2e-1-1.
Một số trường hợp đặc biệt:
Type Exponent Mantissa
Zeroes 0 0
Denormal 0 Non zero
Normal 12e-2 Any
Infinities (không xác định) 2e-1 0
Not a Number 2e-1 Non zero
Mỗi miền giá trị bỏ đi 2 giá trị: Infinities và NaN. Do đó, ta có bảng tương ứng 4 mức biểu
diễn như sau:
Presision Emin Emax
2 byte (half) -14 15
4 bytes (single) -126 127
8 bytes (double) -1022 1023
16 bytes (quadruple) -16382 16383
4.3.3.2 Dùng 32-bits
Biểu diễn giá trị:
v = s x 2e x m, trong đó: s = +1 khi bit dấu (S) là 0.
s = -1 khi bit dấu (S) là 1.
e = Exp – 127 (Exp là giá trị thập phân của 8 bit mũ).
m =1. (1 ≤ m < 2).
Ví dụ: biểu diễn nhị phân n=-118.625 (dùng chuẩn IEEE 754).
1. Biểu diễn n sang nhị phân dùng dấu chấm tĩnh (Fixed-point): 1110110.101
2. Di chuyển dấu chấm cơ số đến sau bit đầu tiên: 1.110110101 x 26.
3. Điền bit 0 vào sau dãy sao cho đủ 23 bit (tính từ sau dấu chấm cơ số):
11011010100000000000000.
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 7– EndNote 11
4. Ta xác định được số mũ e = 6. Theo công thức: Exp = 127+6 = 133. Chuyển 133 sang hệ
nhị phân sẽ là: 10000101.
Một số giá trị đặc biệt
Sign
(S)
Exponent
(e)
Mantissa
(m)
Value
0 00000000 00000000000000000000000 +0
(positive zero)
1 00000000 00000000000000000000000 -0
(negative zero)
1 00000000 10000000000000000000000 -2
0-127
x0.(2
-1
)= -2
0-127
x 0.5
0 00000000 00000000000000000000001 +2
0-127
x0.(2
-23
)
(smallest value)
0 00000001 01000000000000000000000 +2
1-127
x1.(2
-2
)= +2
1-127
x1.25
0 10000001 00000000000000000000000 +2
129-127
x1.0= 4
0 11111111 00000000000000000000000 + infinity
1 11111111 00000000000000000000000 - infinity
0 11111111 10000000000000000000000 Not a Number(NaN)
1 11111111 10000100010000000001100 Not a Number(NaN)
Lưu ý, vấn đề khi biểu diễn số thực là làm tròn số. Do đó, ta dùng phương pháp làm tròn
giá trị gần số chẳn nhất. Ví dụ:
Unrounded Rounded
3.4 3
5.6 6
3.5 4
2.5 2
4.3.3.3 Cộng (trừ) hai số thực
Ví dụ: Cộng hai số thực dưới dạng dấu chấm động sau:
m = 24 x 1.1001
n = 22 x 1.0010
Bước 1: lấy hiệu của số mũ.
Em = 24 (em = 4); En = 22 (en = 2)
Î Em-n = 24-2 = 22 (em-n = 2)
Bước 2: Di chuyển dấu chấm cơ số sang phải em-n vị trí. Ta được:
1.1001 000
0.0100 100
Bước 3: Cộng hai số lại với nhau:
1.1001 000
0.0100 100
1.1101 100
Bước 4: Làm tròn kết quả cộng ở bước 3: 1.1101 Æ 1.1110
Bước 5: Kết quả 24 x 1.1110
+
+
+
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 7– EndNote 12
4.3.3.4 Nhân hai số thực
Ví dụ: Nhân hai số thực dưới dạng dấu chấm động sau:
m = 2100 x 1.1001
n = 2110 x 1.0010
Bước 1: Nhân phần định trị của hai số lại với nhau
1.1001
1.0010
1.11000010
Æ Phần định trị: Fracmxn = 1.11000010
Æ Phần số mũ: Emxn = 2100+110-Emax = 283
Bước 2: Làm tròn kết quả của bước1: Phần định trị là 1.1100
Bước 3: Kết quả là 283 x 1.1100
x
x
4.3.3.5 Chia hai số thực
Ví dụ: Chia hai số thực dưới dạng dấu chấm động sau:
m = 2110 x 1.0000
n = 2100 x 0.0011
Bước 1: Đếm số bit 0 đứng trước dãy
zm = 0
zn = 3
Bước 2:
÷
- Dịch chuyển phần định trị 2 dãy bit m,n sang trái (shift – left) zm, zn lần.
Fracm = 10000 00000
Fracn = 00000 11000
- Tính số mũ: Em+n = 2110-100+Emax-zm+zn = 2140
Bước 3: Chia phần định trị của m,n
100000,0000
000001,1000
1,0101
Bước 4: Kết quả là 1,0101 x 2140
÷
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 7– EndNote 13
4.4. Các phép toán số học (arithmatic)/luận lý (logic)
4.4.1. Các phép toán luận lý
Tập các lệnh số học/luận lý bao gồm các phép toán số học, luận lý hoặc phép toán dịch bit
(shift), quay (rotate). Trên thực tế, máy tính thao tác trên các chuỗi ký tự.
4.4.1.1 AND
Thực hiện phép toán AND trên từng bit từ phải qua trái.
AND 0 1
0 0 0
1 0 1
Một trong những tác dụng chính của phép toán AND là để kiểm tra bit 1 hay 0. Ta nhận
thấy đặc điểm của phép toán AND là thành phần 0 trong một dãy bit không bị ảnh hưởng bởi
các thành phần khác. Ví dụ:
0 0 0 0 1 1 1 1
0 0 0 0 1 0 0 1 AND
0 0 0 0 1 0 1 0
Ta thấy dãy bit 0 của toán hạng thứ 1 không thay đổi và dãy 4 bit phải nhất của toán hạng
thứ 2 không thay đổi. Cách sử dụng phép toán AND trong ví dụ trên gọi là cách sử dụng mặt
nạ (masking). Toán hạng đầu được gọi là mặt nạ, nó được sử dụng để xác định phần của toán
hạng còn lại sẽ ảnh hưởng đến kết quả. Trong trường hợp này, mặt nạ được sử dụng để cho ra
kết quả là mỗi phần 4 bit của toán hãng trong đó các số 0 với 4 bit đầu của toán hạng thứ nhất
và 4 bit sau của toán hạng thứ 2.
Ngoài ra, phép toán AND còn được dùng để chép lại một phần của dãy bit, và thêm vào 0 ở
phần không chép lại.
4.4.1.2 OR
OR 0 1
0 0 1
1 1 1
Tương tự như phép toán AND, phép toán OR được dùng để chép lại một phần của dãy bit,
và thêm vào 1 ở phần không chép lại. Phép toán OR cũng sử dụng mặt nạ để xác định vị trí bit
được chép lại 0 và sử dụng bit 1 để chỉ các vị trí không được chép lại.
Ví dụ: thực hiện phép toán OR với dãy bit 11110000 sao cho có được kết quả với các số 1
ở 4 bit cao và các bit còn lại là 4 bit thấp của toán hạng kia.
1 1 1 1 0 0 0 0
1 0 1 0 1 0 1 0 OR
0 0 0 0 1 0 1 0
4.4.1.3 XOR
XOR 0 1
0 0 1
1 1 0
Sử dụng phép toán này để lấy phần bù của một chuỗi bit.
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 7– EndNote 14
Ví dụ:
1 1 1 1 1 1 1 1 XOR 1 0 1 0 1 0 1 0
0 1 0 1 0 1 0 1
4.4.1.4 Dịch bit (shift) và quay (rotation)
Các phép toán dịch bit và quay để giải quyết các bài toán thực hiện trên bit. Ví dụ biến đổi
một byte theo một yêu cầu nào đó bằng cách sử dụng mặt nạ, hoặc thao tác trên phần định trị
của các số biểu diễn ở dạng dấu chấm động. Phép toán dịch bit và quay theo hai hướng trái
hoặc phải.
1. Dịch bit
Nếu một byte 8 bit khi thực hiện phép toán dịch bit sang trái hay phải thì bit đầu tiên của
byte (bit cao nhất nếu dịch phải, bit thấp nhất nếu dịch trái) sẽ bị dịch chuyển, và bit cuối (bit
thấp nhất nếu dịch phải, bit cao nhất nếu dịch trái) sẽ được đặt là 0.
Ví dụ: dãy bit giá trị của một byte là 10001110, khi dịch trái một lần sẽ là 00011100, và khi
dịch phải một lần thì kết quả là 01000111.
Phép toán dịch bit được sử dụng cho các phép nhân hay chia cho 2, dịch trái là nhân cho 2,
dịch phải là chia cho 2.
2. Quay
Đối với phép toán quay, cũng giống như dịch bit nhưng bit cuối sẽ được chuyển vào bit đầu
tiên.
Ví dụ: dãy bit giá trị là 10001110, khi quay trái một lần thì kết quả là 00011101, và khi
quay phải một lần thì kết quả là 01000111.
4.4.2. Các phép toán số học
Các phép toán số học (cộng, trừ, nhân, chia) được thực hiện dựa trên các phép toán cơ bản là
phép cộng và tạo ra số âm. Ví dụ, trường hợp cộng giá trị biểu diễn của số bù 2 thì đó là phép
cộng nhị phân. Phép cộng các số biểu diễn bằng dấu chấm động thì phép cộng thực hiện ở phần
định trị, sau đó dịch trái hay phải phần mũ và kiểm tra bit dấu để cuối cùng tạo ra kết quả ở dạng
dấu chấm động.
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 7– EndNote 15
5. Bảng mã ASCII
Là chuẩn mã hóa một byte ký tự sang dạng chuỗi và ngược lại. ASCII kết hợp số 7-bit hoặc
8-bit để biểu diễn chuỗi 128 hoặc 256 ký tự. Chuẩn ASCII sử dụng 7-bit để biểu diễn các ký tự
chữ hoa và chữ thường, các số từ 0 đến 9, các dấu câu, và các ký tự điều khiển đặc biệt. Hầu hết
các hệ thống máy tính x86 đều hỗ trợ sử dụng bảng mã ASCII mở rộng. Bảng mã ASCII mở
rộng cho phép biểu diễn các ký tự đặc biệt như biểu tượng, các ký tự 32-bit của ngôn ngữ khác,
các ký hiệu đồ họa.
6. Bài tập
1. Cho biết biểu diễn nhị phân của các số ở hệ thập lục phân sau:
a. BC b. 67 c. 10 e. 3F
2. Cho biết bit cực trái trong biểu diễn nhị phân của các số trong hệ thập lục phân là gì?
a. FF b. 7F c. 8F e. 1F
3. Biểu diễn các dãy bit sau về hệ thập lục phân:
a. 101010101010 b. 110010110111 c. 000011101011
4. Cho một màn hình có thể hiển thị được 24 dòng, ứng với mỗi dòng có 80 ký tự. Nếu một điểm
trên màn hình được lưu trữ trong bộ nhớ bằng một byte cho mã ASCII của ký tự tại điểm đó,
thì có bao nhiêu byte để lưu trữ toàn bộ các điểm trên màn hình?
5. Biến đổi các dãy bit sau về hệ thập lục phân tương ứng:
a. 111 b. 0001 c. 11101 d. 10001 e. 10111 f. 00000
g. 100 h. 1000 i. 10000 j. 11001 k. 11010 l. 11011
6. Biến đổi các số ở hệ thập phân sau về hệ nhị phân tương ứng:
a. 7 b. 12 c. 16 d. 15 e. 33
7. Biến đổi các số biểu diễn ở hệ thập phân sau về hệ bát phân tương ứng:
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Chương 7– EndNote 16
a. 24 b. 243 c. 57 d. 81 e. 94
8. Biến đổi các số biểu diễn ở hệ bát phân sau sang hệ thập phân tương ứng:
a. 120 b. 43 c. 55 d. 12 e. 76
9. Biến đổi các số biểu diễn ở hệ cơ số 10 sau sang hệ cơ số 3 tương ứng:
a. 31 b. 99 c. 56 d. 98 e. 4
10. Biến đổi các số biểu diễn ở hệ cơ số 3 sau sang hệ cơ số 10 tương ứng:
a. 1011 b. 10200 c. 1112 d. 1102 e. 11
11. Biến đổi các số biểu diễn ở hệ cơ số 8 sau sang hệ cơ số 3 tương ứng:
a. 120 b. 43 c. 55 e. 12 75
12. Biến đổi các số ở dạng dấu lượng về hệ thập phân tương ứng:
a. 100001 b. 10011 c. 01101 d. 01111 e. 10111
13. Biến đổi các số ở hệ thập phân sau về dạng bù 1 với mẩu 4 bit tương ứng:
a. 0 b. 3 c. -3 d. -1 e. 1
14. Biến đổi các số ở dạng bù 2 về hệ thập phân tương ứng:
a. 1000 b. 10011 c. 01101 d. 01111 e. 10111
15. Biến đổi các số ở hệ thập phân sau về dạng bù 2 với mẩu 7 bit tương ứng:
a. 12 b. -12 c. -1 d. 0 e. 8
16. Từ bảng mã ASCII, hãy cho biết biểu diễn ở hệ 8, 10, và 16 của các kí tự sau:
a. * b. ! c. % d. @ e. +
17. Dùng phương pháp biểu diễn dấu chấm tĩnh, biểu diễn nhị phân các số thực sau:
a. 21 b. – 21 c. 45 d. – 45 e. 68 f. – 68
18. Dùng dấu chấm động, biểu diễn nhị phân các số thực sau:
a. 21 b. – 21 c. 45 d. – 45 e. 68 f. – 68
19. Từ kết quả câu 18, thực hiện cộng (dưới dạng dấu chấm động) các phép toán sau:
a. a + c b. d + e c. e : c d. a x b e. d – b
20. Đối với phương pháp biểu diễn dấu chấm động, ngoài chuẩn IEEE 754 còn chuẩn nào khác
không? Hãy liệt kê nếu có. Các chuẩn IEEE x có phụ thuộc vào thế hệ máy tính không? Hãy
cho biết tên chuẩn tương ứng với thế hệ máy tính nếu có.
Đại học Y Dược Tp. HCM – Bộ môn Tin học Tháng 10/2008
Các file đính kèm theo tài liệu này:
- chuong1_4826.pdf