

بِسْمِ اللّٰهِ الرَّحْمٰنِ الرَّحِيمِ

## راهنمای جامع مسئله های معماری کامپیوتر

### موریس مانو

به پیوست مجموعه تست های برگزیده فصل بندی شده و پاسخ تشریحی

تألیف و تدوین :

محمد جواد مروتی

سعید کاظمی

## تقدیم به ...

تقدیم به ساحت مقدس حضرت ولی عصر (عج) و همه کسانی که به رسم ادب این  
اوراق را تورق می کنند.  
گرچه از آن مستغنى اند

مروقتى

تقدیم به خانواده ام  
و هر آنکه لبخند با لبس عقد بسته.

کاظمى

## فهرست مطالب

|     |                                                 |
|-----|-------------------------------------------------|
| ۵   | حمایت داوطلبانه (Donation)                      |
| ۶   | پیشگفتار نویسنده‌گان                            |
| ۸   | فصل اول : مدارهای منطقی دیجیتال                 |
| ۲۶  | فصل دوم: قطعات دیجیتال                          |
| ۴۱  | فصل سوم: نمایش داده‌ها                          |
| ۵۶  | فصل چهارم: انتقال ثبات‌ها و ریز عمل‌ها          |
| ۷۴  | فصل پنجم: سازمان و طراحی یک کامپیوتر پایه       |
| ۹۵  | فصل ششم: برنامه‌نویسی کامپیوتر پایه             |
| ۱۲۰ | فصل هفتم: کنترل ریز برنامه‌نویسی شده            |
| ۱۳۶ | فصل هشتم: واحد مرکزی پردازش                     |
| ۱۶۲ | فصل نهم: پردازش خط لوله‌ای و برداری             |
| ۱۷۳ | فصل دهم: معماری کامپیوتر و الگوریتم‌های حسابی   |
| ۲۱۵ | فصل یازدهم: سازمان ورودی - خروجی                |
| ۲۳۵ | فصل دوازدهم: سازمان حافظه                       |
| ۲۵۶ | تست‌های فصل ۴ «انتقال ثبات‌ها و ریز عمل‌ها»     |
| ۲۵۸ | حل تست‌های فصل ۴                                |
| ۲۵۹ | تست‌های فصل ۵ «سازمان و طراحی یک کامپیوتر پایه» |
| ۲۶۲ | حل تست‌های فصل ۵                                |
| ۲۶۴ | تست‌های فصل ۶ «برنامه‌نویس کامپیوتر پایه»       |
| ۲۶۶ | حل تست‌های فصل ۶                                |
| ۲۶۷ | تست‌های فصل ۷ «کنترل ریز برنامه‌نویسی شده»      |

|     |                                                       |
|-----|-------------------------------------------------------|
| ۲۶۹ | حل تست‌های فصل ۷                                      |
| ۲۷۰ | تست‌های فصل ۸ «واحد مرکزی پردازش»                     |
| ۲۷۳ | حل تست‌های فصل ۸                                      |
| ۲۷۵ | تست‌های فصل ۹ «پردازش خط لوله‌ای و برداری»            |
| ۲۷۷ | حل تست‌های فصل ۹                                      |
| ۲۷۹ | تست‌های فصل ۱۰ «معماری کامپیوتر و الگوریتم‌های حسابی» |
| ۲۸۲ | حل تست‌های فصل ۱۰                                     |
| ۲۸۴ | تست‌های فصل ۱۱ «سازمان ورودی - خروجی»                 |
| ۲۸۶ | حل تست‌های فصل ۱۱                                     |
| ۲۸۷ | تست‌های فصل ۱۲ «سازمان حافظه»                         |
| ۲۸۹ | حل تست‌های فصل ۱۲                                     |
| ۲۹۱ | منابع                                                 |

## حمایت داوطلبانه (Donation)

خواننده گرامی

تالیف، تدوین، آماده سازی محتوا، تایپ، صفحه آرایی و ویرایش های  
انجام شده کتاب حاضر، با هزینه نویسنده انجام شده است.  
در صورت تمایل به حمایت از این مجموعه، پیوند یا کد QR زیر را دنبال  
کنید.

<http://hpcc.ir/downloads/computer-architecture-solution/>



## پیشگفتار نویسنده‌گان

- درس معماری کامپیوتر به عنوان یک مبحث پایه‌ای رشته مهندسی و علوم کامپیوتر و سایر رشته‌های مرتبط مطرح است. به طوری که روند طراحی و ساخت سیستم‌های کامپیوتری را از ترکیب مباحث نرم‌افزاری و برنامه‌نویسی، و مباحث سخت‌افزاری، مدارهای منطقی و دیجیتال بازگو می‌نماید.
- کتاب حاضر به بررسی و حل مسائل درس معماری کامپیوتر، براساس کتاب معماری کامپیوتر «پروفسور موریس مانو»، ترجمه‌ی «دکتر قدرت سپیدنام»، می‌پردازد. در ضمن، سؤالات چهار گزینه‌ای برگزیده فصل‌های کتاب معماری کامپیوتر به همراه پاسخ تشریحی آنها نیز به کتاب پیوست شده است.
- سه فصل ابتدایی کتاب معماری کامپیوتر موریس مانو، مشتمل بر مباحث مدارهای منطقی و دیجیتال است که کتاب حاضر به تشریح مسائل این سه فصل نیز پرداخته است. بنابراین این کتاب می‌تواند برای مرور و تسلط بر مباحث مدارهای منطقی و دیجیتال به عنوان مقدمه و پیش‌نیاز طراحی و معماری کامپیوتر استفاده گردد.
- منبع اصلی مجموعه حاضر، جزوی راهنمای حل مسئله (Solution Manual) پروفسور موریس مانو است. اگرچه در بسیاری از مسائل و راه‌حل‌ها، این راهنمای نقص، اشتباهات محاسباتی و اشتباهاتی منطقی بوده و یا اینکه تنها دارای جواب آخر بوده‌اند؛ که در کتاب حاضر اقدام به رفع این اشتباه‌ها شده و توضیحات لازم در جواب‌ها داده شده و الگوریتم‌ها، روش‌های حل و شکل‌های ابتکاری بکار برده‌ایم. البته امیدواریم خوانندگان محترم با مطالعه دقیق و کامل کتاب، نویسنده‌گان این مجموعه را نسبت به نقص‌ها، کمبودها، اشتباه‌های احتمالی و نامفهوم بودن مطالب آگاه نمایند.

**با تشکر و آرزوی موفقیت، مروتی - کاظمی**



## فصل اول : مدارهای منطقی دیجیتال

۱- با استفاده از جدول درستی، صحت قضیه دمورگان را برای سه متغیر برسی کنید.

$$(ABC)' = A' + B' + C'$$

حل: طبق جدول درسی برای عبارت فوق داریم:

| A | B | C | A.B.C | (A.B.C)' | A' | B' | C' | A' + B' + C' |
|---|---|---|-------|----------|----|----|----|--------------|
| 0 | 0 | 0 | 0     | 1        | 1  | 1  | 1  | 1            |
| 0 | 0 | 1 | 0     | 1        | 1  | 0  | 0  | 1            |
| 0 | 1 | 0 | 0     | 1        | 1  | 0  | 1  | 1            |
| 0 | 1 | 1 | 0     | 1        | 1  | 0  | 0  | 1            |
| 1 | 0 | 0 | 0     | 1        | 0  | 1  | 1  | 1            |
| 1 | 0 | 1 | 0     | 1        | 0  | 1  | 0  | 1            |
| 1 | 1 | 0 | 0     | 1        | 0  | 0  | 1  | 1            |
| 1 | 1 | 1 | 1     | 0        | 0  | 0  | 0  | 0            |

۲- جدول درستی تابع OR انحصاری (تابع فرد) سه متغیره را بسازید:

$$x = A \oplus B \oplus C$$

حل: ابتدا OR انحصاری A و B را بدست آورده و سپس OR انحصاری حاصل آن

را با C محاسبه می کنیم.

$$A \oplus B \oplus C = (A \oplus B) \oplus C$$

| A | B | C | A $\oplus$ B | A $\oplus$ B $\oplus$ C |
|---|---|---|--------------|-------------------------|
| 0 | 0 | 0 | 0            | 0                       |
| 0 | 0 | 1 | 0            | 0                       |
| 0 | 1 | 0 | 1            | 1                       |
| 0 | 1 | 1 | 1            | 1                       |
| 1 | 0 | 0 | 1            | 1                       |
| 1 | 0 | 1 | 1            | 1                       |
| 1 | 1 | 0 | 0            | 0                       |
| 1 | 1 | 1 | 0            | 0                       |

|   |   |   |   |
|---|---|---|---|
| . | . | . | . |
| . | 1 | . | 1 |
| . | 1 | 1 | 1 |
| . | 1 | 1 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | . | 0 |
| 1 | 1 | 1 | 1 |

۱-۳- عبارات زیر را با جبر بول ساده کنید:

الف)  $A + AB'$       ب)  $AB + AB'$       ج)  $A'BC + AC$

د)  $A'B + ABC' + ABC$

حل:

(الف)  $A + AB = A(1 + B) = A$

(ب)  $AB + AB' = A(B + B') = A$

(ج)  $A'BC + AC = C(A'B + A) = C(A' + A)(B + A) = (A + B)C$

(د)  $A'B + ABC' + ABC = A'B + AB(C' + C) = A'B + AB = B(A' + A) = B$

۱-۴- عبارت های زیر را با جبر بول ساده کنید:

الف)  $(BC' + A'D)(AB' + CD')$       ب)  $AB + A(CD + CD')$

حل:

(الف)  $AB + A(CD + CD') = AB + AC(D + D') = A(B + C)$

(ب)  $(BC' + A'D)(AB' + CD') = \frac{ABB'C}{0} + \frac{A'AB'D}{0} + \frac{BCC'D'}{0} + \frac{A'CD'D}{0} = 0$

۱-۵- با قضیه دمورگان نشان دهید:

الف)  $(A + B)'(A' + B')' = 0$       ب)  $A + A'B + A'B' = 1$

حل:

$$(A+B)'(A'+B')' = (A'B')(AB) = 0$$

$$B) A + A'B + A'B' = A + A'(B + B') = A + A' = 1$$

۱-۶- با توجه به عبارت بولی  $F = x'y + xyz'$

الف) یک عبارت جبری برای متمم،  $F'$  بدست آورید.

$$F' = 0$$

$$G) F + F' = 1$$

حل:

$$(A) F = x'y + xyz'$$

$$F' = (x + y')(x' + y' + z) = x'y' + xy' + y' + xz + y'z = y'(1 + x' + x + z) + xz = y' + x$$

$$B) F \cdot F' = (x'y + xyz')(y' + xz) = 0 + 0 + 0 + 0 = 0$$

$$C) F + F' = x'y + xyz' + y' + xz(y + y') = x'y + xy(z' + z) + y'(1 + xz)$$

$$= x'y + xy + y' = y(x' + x) + y' = y + y' = 1$$

۱-۷- با توجه به تابع بولی  $F = xy'z + x'y'z + xyz$

الف) جدول درستی تابع را بدست آورید.

ب) نمودار منطقی را برای عبارت بولی اصلی رسم کنید.

ج) عبارت جبری را با جبر بول ساده کنید.

د) جدول درستی را با عبارت ساده شده تابع تشکیل داده و نشان دهید که همان جدول بخش (الف) است.

ه) نمودار منطقی را با عبارت ساده شده بدست آورده و تعداد کل گیتها را

با نمودار بخش (ب) مقایسه کنید.

حل:

(الف)

$$B) F = xy'z + x'y'z + xyz$$

$$\begin{array}{ccc|c} & & & F \\ X & y & z & \end{array}$$

|   |   |   |
|---|---|---|
| . | . | . |
| . | . | ۱ |
| . | ۱ | . |
| . | ۱ | ۱ |
| ۱ | . | . |
| ۱ | . | ۱ |
| ۱ | ۱ | . |
| ۱ | ۱ | ۱ |



۶ = تعداد گیت‌های تشکیل‌دهنده

(ج)

$$\begin{aligned}
 F &= xy'z + x'y'z + xyz \\
 &= y'z(x + x') + xz(y + y') \\
 &= y'z + xz
 \end{aligned}$$

(د)

| x | y | z | $y'z$ | $xz$ | $y'x + xz$ |
|---|---|---|-------|------|------------|
| . | . | . | .     | .    | .          |
| . | . | ۱ | ۱     | .    | ۱          |
| . | ۱ | . | .     | .    | .          |
| . | ۱ | ۱ | .     | .    | .          |
| ۱ | . | . | .     | .    | .          |
| ۱ | . | ۱ | ۱     | ۱    | ۱          |
| ۱ | ۱ | . | .     | .    | .          |
| ۱ | ۱ | ۱ | ۱     | ۱    | ۱          |

(ه)



= تعداد گیت‌های تشکیل‌دهنده ۴

۱-۸- توابع بولی زیر را با نقشه سه متغیره ساده کنید.

$F(x,y,z)$

$$F = \Sigma(1,2,3,6,7) \quad (ب)$$

$$F = \Sigma(0,2,3,4,6) \quad (د)$$

$$F = \Sigma(0,1,5,7) \quad (الف)$$

$$F = \Sigma(3,5,6,7) \quad (ج)$$



۱-۹- توابع بولی زیر را با نقشه چهار متغیره ساده کنید.

$F(A,B,C,D)$

$$F = \Sigma(3,7,11,13,14,15) \quad (ب)$$

$$F = \Sigma(0,2,4,5,6,7,8,10,13,15) \quad (د)$$

$$F = \Sigma(4,6,7,15) \quad (الف)$$

$$F = \Sigma(0,1,2,4,5,7,11,15) \quad (ج)$$

حل:

(الف)



(ب)



---


$$F = CD + ABC + ABD$$



۱-۱۰- عبارات زیر را ۱) به صورت جمع حاصلضربها و ۲) به صورت ضرب

حاصل جمعها ساده کنید:

الف)  $x'z' + y'z' + yz' + xy$

حل: ابتدا جدول کارنو هر کدام از توابع را رسم کرده، سپس حاصلضربها و حاصل جمعها را بدست می آوریم.

الف)

$F = xy + z' =$  حاصل جمع حاصل ضرب

$F' = x'z + y'z =$  حاصل ضرب حاصل جمع

$\Rightarrow F = (x + z')(y + z')$

|  |  |  |  |  |
|--|--|--|--|--|
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |

(ب)

|  |  |  |  |  |
|--|--|--|--|--|
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |

$$F = AC' + CD + B'D$$

$$F = (A+D)(C'+D)(A+B'+C)$$

توضیحات: در جدول کارنو عبارت (الف) و (ب)، دسته‌بندی ۱ها، حاصل‌جمع حاصل‌ضرب خود تابع را می‌سازد و دسته‌بندی ۰ها حاصل‌جمع حاصل‌ضرب متمم عبارت را می‌سازد که با استفاده از قضیه دمورگان، حاصل‌ضرب حاصل‌جمع عبارت معین می‌شود.

۱-۱۱-۱- توابع بولی زیر را به شکل جمع حاصل‌ضرب‌ها با نقشه چهار متغیره ساده

کنید. نمودار منطقی را

الف) با گیت‌های NAND رسم کنید.

$$F = \Sigma(0, 2, 8, 9, 10, 11, 14, 15)$$

حل:

(الف)



ب) ابتدا AND ها را به NAND تبدیل می کنیم:



۱-۱۲-۱- تابع بولی زیر را به شکل ضرب حاصل جمعها با نقشه چهار متغیره

ساده کنید. نمودار منطقی را

ب) با گیت‌های NOR رسم کنید.

الف) با گیت‌های OR-AND

$$F = \Sigma(2, 3, 4, 5, 6, 7, 11, 14, 15)$$

حل:

(الف)



$$F' = AC' + B'C' + AB'D'$$

$$F = (A' + C)(B + C)(A' + B + D)$$

ب) ابتدا OR ها را به NOR تبدیل می کنیم:



۱۳-۱- تابع بولی  $F$  را همراه با حالات بی اهمیت  $d$  به شکل ۱) جمع حاصلضربها و ۲) ضرب حاصلجمعها ساده کنید.

$$F(w, x, y, z)$$

$$F = \sum m(0, 1, 2, 3, 7, 8, 10)$$

$$F = \sum d(5, 6, 11, 15)$$

حل: با توجه به توضیحات سوال ۱۰ همین فصل داریم:



۱)  $F = x'z' + w'z$  : جمع حاصل ضربها

۲)  $F = (x' + z)(w' + z')$  : ضرب حاصل جمعها

۱۴-۱ با جدول ۲ عبارت بولی  $S$  (جمع) خروجی یک تمام جمع کننده به شکل جمع حاصل ضربها را بدست آورید. سپس با دستکاری‌های جبری نشان دهید که  $S$  می‌تواند به صورت OR انحصاری سه متغیره بیان شود.

$$S = x \oplus y \oplus z$$

حل: با توجه به جدول درستی NOR انحصاری،

$$\begin{aligned} S &= x'y'z + x'yz' + xy'z' + xyz \\ &= x'(y'z + yz') + x(y'z' + yz) \\ &= x'(y \oplus z) + x(y \oplus z)' \\ &= x \oplus y \oplus z \end{aligned}$$

۱۵-۱ یک مدار ترتیبی به نام تابع اکثریت به این صورت تعریف می‌شود که هر گاه مقدار متغیرهای ورودی ۱، بیشتر از ورودی‌های ۰ باشند، خروجی ۱ است، در غیر این صورت خروجی ۰ است. تابع اکثریت سه ورودی را طراحی کنید.

حل: جدول درستی را تشکیل داده و مقادیر مورد نیاز را به تابع تخصیص می‌دهیم سپس ساده‌سازی انجام می‌دهیم.

| X | y | z | F |
|---|---|---|---|
| · | · | · | · |
| · | · | 1 | · |
| · | 1 | · | · |
| · | 1 | 1 | 1 |
| 1 | · | · | · |
| 1 | · | 1 | 1 |
| 1 | 1 | · | 1 |
| 1 | 1 | 1 | 1 |



$$F = xy + xz + yz$$

۱۶-۱- یک مدار ترکیبی با سه متغیر  $x$  و  $y$  و  $z$  و سه خروجی  $A$  و  $B$  و  $C$  طراحی کنید. اگر ورودی‌های دودویی  $0, 1, 2$  یا  $3$  باشد، خروجی یکی بیشتر از ورودی است. وقتی ورودی‌ها  $4$  و  $5$  و  $6$  و  $7$  باشند، خروجی دودویی یکی کمتر از ورودی باشد.

حل:

| x | y | z | A | B | C |
|---|---|---|---|---|---|
| · | · | · | · | · | 1 |
| · | · | 1 | · | 1 | · |
| · | 1 | · | · | 1 | 1 |
| · | 1 | 1 | 1 | · | · |
| 1 | · | · | · | 1 | 1 |
| 1 | · | 1 | 1 | · | · |
| 1 | 1 | · | 1 | · | 1 |
| 1 | 1 | 1 | 1 | 1 | · |



با دقت در توابع A و B تشکیل شده در می‌یابیم A و B ، خروجی‌های Full adder می‌باشند.

۱۷\_۱- نشان دهید که یک فلیپ فلاب JK را با قرار دادن یک وارونگر بین ورودی‌های J و K می‌توان به یک فلیپ فلاب D تبدیل کرد.

حل:

طبق جداول تحریک فلیپ فلاب‌ها و با توجه به شکل زیر:



داریم:

زمانی که  $D=0 \Rightarrow J=0, K=1 \Rightarrow Q \rightarrow 0$

$D=1 \Rightarrow J=1, K=0 \Rightarrow Q \rightarrow 1$

- ۱۸-۱ - با اطلاعات موجود در جدول مشخصه فلیپ فلاپ JK در جدول شکل ۱-۲ (ب) جدول تحریک را برای فلیپ فلاپ JK به دست آورده و جواب خود را با جدول ۱-۳ مقایسه کنید.

حل: با توجه به جدول مشخصه فلیپ فلاپ JK جدول درستی را به شکل زیر

تشکیل می‌دهیم:

| J | K | $Q(t+1)$ | J | K | $Q(t)$ | $Q(t+1)$ |
|---|---|----------|---|---|--------|----------|
| . | . | $Q(t)$   | . | . | .      | .        |
| . | ۱ | .        | . | . | ۱      | ۱        |
| ۱ | . | ۱        | . | ۱ | .      | .        |
| ۱ | ۱ | $Q'(t)$  | . | ۱ | ۱      | .        |
|   |   |          | ۱ | . | .      | ۱        |
|   |   |          | ۱ | . | ۱      | ۱        |
|   |   |          | ۱ | ۱ | .      | ۱        |
|   |   |          | ۱ | ۱ | ۱      | .        |

سپس با توجه به حالات  $Q(t), Q(t+1)$  در جدول درستی بالا، مقادیر k و J مناسب را استخراج کرده تا جدول تحریک JK بدست آید:

| $Q(t)$ | $Q(t+1)$ | J | K |
|--------|----------|---|---|
| .      | .        | . | x |
| .      | ۱        | ۱ | x |
| ۱      | .        | x | ۱ |
| ۱      | ۱        | x | . |

که با جدول ۱-۳ برابر است.

۱-۱۹-۱- یک مدار ترتیبی دارای دو فلیپ فلاپ A و B ، دو ورودی x و y و یک خروجی z است. معادله های ورودی فلیپ فلاپ و نیز خروجی مدار به قرار زیرند:

$$D_A = x'y + xA$$

$$D_B = x'B + xA$$

$$z = B$$

الف) دیاگرام منطقی مدار را رسم کنید.

ب) جدول حالت را برپا کنید.

حل:

الف)  $D_B, D_A$  مشخص می‌کنند که فلیپ فلاپ پیشنهادی از نوع D است.



(ب)

| حالت فعلی |   | ورودی ها |   | حالت بعدی |   | خروجی |
|-----------|---|----------|---|-----------|---|-------|
| A         | B | x        | y | A         | B | Z     |
| .         | . | .        | . | .         | . | .     |

|   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| . | . | . | 1 | . | 1 | . | . |
| . | . | 1 | 0 | . | 0 | . | . |
| . | . | 1 | 1 | . | 0 | . | . |
| . | 1 | 0 | 0 | . | 1 | . | 1 |
| . | 1 | 0 | 1 | 1 | 1 | . | 1 |
| . | 1 | 1 | 0 | . | 0 | . | 1 |
| . | 1 | 1 | 1 | . | 0 | . | 1 |
| 1 | 0 | 0 | 0 | . | 0 | . | . |
| 1 | 0 | 0 | 1 | 1 | 0 | . | . |
| 1 | 0 | 1 | 0 | 1 | 1 | . | . |
| 1 | 0 | 1 | 1 | 1 | 1 | . | . |
| 1 | 1 | 0 | 0 | . | 1 | . | 1 |
| 1 | 1 | 0 | 1 | 1 | 1 | . | 1 |
| 1 | 1 | 1 | 0 | 1 | 1 | . | 1 |
| 1 | 1 | 1 | 1 | 1 | 1 | . | 1 |

۲۰-۱- یک پایین شمارنده دو بیتی طراحی کنید. این مدار ترتیبی دارای دو فلیپ فلاب و یک ورودی  $x$  است. وقتی  $x=0$  باشد، حالت فلیپ فلاب تغییر نمی کند. وقتی  $x=1$  باشد، ترتیب حالات  $11, 10, 01, 00$  و  $11$  و تکرار آن است.  
حل: از فلیپ فلاب JK استفاده می کنیم که هر دو حالت no-change و toggle را دارد.

شمارنده پایین رونده (down counter)



۲۱-۱- یک مدار ترتیبی با دو فلیپ فلاپ JK و دو ورودی E و x طراحی کنید.  
اگر  $E=0$  باشد، مدار بدون توجه به مقدار x در همان حالت می‌ماند. وقتی  $E=1$  و  $x=1$  است، مدار به دنباله حالات از ۰۰ به ۰۱، به ۱۰، به ۱۱ و ۰۰ و تکرار آن وارد می‌شود. وقتی  $E=1$  و  $x=0$  باشد. مدار به حالت انتقالی ۰۰ به ۱۱، به ۰۱، به ۰۰ و تکرار آن وارد می‌شود.

حل: این مدار یک شمارنده پایین و بالارونده است (up-down counter). در اینجا نقش فعال‌کننده (Enable) را دارد.

| حالت فعلی |   | ورودی‌ها |   | حالت بعدی |   | ورودی<br>فلیپ فلاپ‌ها |       |       |       |
|-----------|---|----------|---|-----------|---|-----------------------|-------|-------|-------|
| A         | B | E        | X | A         | B | $J_A$                 | $K_A$ | $J_B$ | $K_B$ |
| ۰         | ۰ | ۰        | ۰ | ۰         | ۰ | ۰                     | x     | ۰     | x     |
| ۰         | ۰ | ۰        | ۱ | ۰         | ۰ | ۰                     | x     | ۰     | x     |
| ۰         | ۰ | ۱        | ۰ | ۱         | ۱ | ۱                     | x     | ۱     | x     |
| ۰         | ۰ | ۱        | ۱ | ۰         | ۱ | ۰                     | x     | ۱     | x     |
| ۰         | ۱ | ۰        | ۰ | ۰         | ۱ | ۰                     | x     | x     | ۰     |
| ۰         | ۱ | ۰        | ۱ | ۰         | ۱ | ۰                     | x     | x     | ۰     |
| ۰         | ۱ | ۱        | ۰ | ۰         | ۰ | ۰                     | x     | x     | ۱     |
| ۰         | ۱ | ۱        | ۱ | ۱         | ۰ | ۱                     | x     | x     | ۱     |
| ۱         | ۰ | ۰        | ۰ | ۱         | ۰ | x                     | ۰     | ۰     | x     |
| ۱         | ۰ | ۰        | ۱ | ۱         | ۰ | x                     | ۰     | ۰     | x     |
| ۱         | ۰ | ۱        | ۰ | ۰         | ۱ | x                     | ۱     | ۱     | x     |
| ۱         | ۰ | ۱        | ۱ | ۱         | ۱ | x                     | ۰     | ۱     | x     |
| ۱         | ۱ | ۰        | ۰ | ۱         | ۱ | x                     | ۰     | x     | ۰     |

$$\begin{array}{cc|cc|cc|cc}
 1 & 1 & 0 & 1 & 1 & 1 & x & \\
 1 & 1 & 1 & 0 & 1 & 0 & x & \\
 1 & 1 & 1 & 1 & 0 & 0 & x & \\
 \end{array}$$

حال توابع ورودی فلیپ فلاپ ها را به ترتیب بدست می آوریم:



$$1) JA = BXE + B'X'E$$



$$2) KA = BXE + B'X'E$$



$$3) J_B = E$$



$$4) K_B = E$$

## فصل دوم: قطعات دیجیتال

۱- قطعه های TTL SSI بیشتر به صورت مدارهای مجتمع ۱۴ پایه عرضه می شوند. دو پایه برای منبع تغذیه در نظر گرفته شده و بقیه برای پایانه های ورودی و خروجی به کار می روند. چند مدار از نوع های زیر را در چنین بسته های می توان گذاشت؟

الف) معکوس کننده:

ب) گیت OR انحصاری دو ورودی:

ج) گیت OR سه ورودی:

د) گیت AND چهار ورودی:

ه) گیت NOR پنج ورودی:

و) گیت NAND هشت ورودی:

ز) فلیپ فلاپ JK ساعت دار با پاک کننده غیر همزمان:

حل:

الف) معکوس کننده:

گیت  $\frac{12}{2} = 6$   $\Rightarrow$  هر معکوس کننده ۲ پین دارد.

ب) گیت OR انحصاری دو ورودی:

گیت  $\frac{12}{3} = 4$  XOR دو ورودی ۳ پین دارد.

ج) گیت OR سه ورودی:

گیت  $\frac{12}{4} = 3$  OR سه ورودی ۴ پین دارد.

د) گیت AND چهار ورودی:

گیت  $\frac{12}{5} = 2$  AND چهار ورودی ۵ پین دارد.

ه) گیت NOR پنج ورودی:

گیت  $\frac{12}{6} = 2$  NOR پنج ورودی ۶ پین دارد.

و) گیت NAND هشت ورودی:

گیت  $\frac{12}{9} = 1$  NAND هشت ورودی ۹ پین دارد.

ز) فلیپ فلاپ JK ساعت دار با پاک کننده غیر همزمان:

با توجه به غیر همزمان بودن، پایه های Clock و Reset جداگانه برای هر فلیپ فلاپ

در نظر گرفته می شود پس:

فلیپ فلاپ  $\frac{12}{6} = 2$  هر فلیپ فلاپ JK ۶ پین

۲- تراشه های MSI موجود توابع دیجیتال ساده ای مانند دیکدر مولتی پلکسر، ثبات ها و شمارنده ها را ممکن می سازند. تراشه های زیر مدارهای مجتمع از نوع TTL هستند که این توابع را تولید می کنند. ویژگی های آنها را در کتاب راهنمایی افته و آنها را با تراشه های متناظر ارائه شده در این فصل مقایسه کنید.

الف) IC نوع ۷۴۱۵۵، دیکدر دوتایی ۲ به ۴

ب) IC نوع ۷۵۱۵۷، مولتی پلکسر چهار تایی ۲ به ۱ خطی

ج) IC نوع ۷۴۱۹۴، شیفت رجیستر چهار بیت دو طرفه با بار شدن موازی

د) IC نوع ۷۴۱۶۳، شمارنده دو دویی چهار بیت با بار شدن موازی و پاک شدن

همزمان

حل: جستجو و مقایسه با مدل های شکل های فصل ۲ کتاب

۳- یک دیکدر ۵ به ۳۲ را با چهار دیکدر ۳ به ۸ دارای ورودی تواناساز و یک دیکدر ۲ به ۴ بسازید. از بلاک دیاگرام مشابه شکل ۲-۴ استفاده کنید.

حل: از دیکدر ۲ به ۴ به منظور فعال سازی هر کدام از دیکدرهای ۳ به ۸ استفاده می شود.



۴-نمودار منطقی یک دیکدر ۲ به ۴ را فقط با گیت NOR رسم کنید. ورودی تواناساز را نیز در نظر بگیرید.

حل: در حالت کلی، برای ساخت گیت NOT از گیتهای NAND و NOR، ورودی به پایه‌های متصل به هم این گیتهای متصل می‌شود.



برای دیاگرام منطقی دیکدر ۲ به ۴ داریم :



۵- دیکدر شکل ۲-۳ را تغییر دهید طوری که مدار اگر  $E=1$  باشد فعال و اگر  $E=0$  باشد، غیرفعال باشد. جدول درستی را برای نوع تغییر یافته رسم کنید.  
حل: در صورت سوال، بایست شکل ۲-۳ ذکر شود که اشتباهاً ۲-۲ ذکر شده بود.  
این کار با حذف گیت NOT متصل به ورودی  $E$ ، امکان پذیر است.  
جدول درستی به شکل زیر است:

| E | A <sub>1</sub> | A <sub>0</sub> | D <sub>0</sub> | D <sub>1</sub> | D <sub>2</sub> | D <sub>3</sub> |
|---|----------------|----------------|----------------|----------------|----------------|----------------|
| · | X              | X              | 1              | 1              | 1              | 1              |
| 1 | ·              | ·              | 0              | 1              | 1              | 1              |
| 1 | ·              | 1              | 1              | 0              | 1              | 1              |
| 1 | 1              | ·              | 1              | 1              | 0              | 1              |
| 1 | 1              | 1              | 1              | 1              | 1              | 0              |

۶- نمودار منطقی یک انکدر با هشت ورودی و سه خروجی، که جدول درستی آن در جدول ۲-۲ آورده شده را رسم کنید. وقتی تمام ورودی‌ها ۰ باشند خروجی چیست؟ اگر فقط ورودی  $D$  برابر ۰ باشد، خروجی چیست؟ روشی پیشنهاد دهید که این دو حالت را متمایز کند.

حل: با توجه به جدول ۲-۲ داریم:



اگر همهٔ ورودی‌ها برابر ۰ و یا اگر فقط  $D_0 = 1$  باشد، خروجی‌های  $A_2A_1A_0$  برابر ۰۰۰ خواهد بود.

برای تمایز بین این دو حالت، می‌بایست یک خروجی اضافه برای تشخیص حالتی که همهٔ ورودی‌ها ۰ باشند در نظر بگیریم و آن را بیت **invalid** بنامیم. این بیت را می‌توان از طریق **NOR** همهٔ ورودی‌ها بدست آورد.

۷- یک مولتی‌پلکسر ۱۶ به ۱ را با دو مولتی‌پلکسر ۸ به ۱ و یک مولتی‌پلکسر ۲ به ۱ بسازید. برای هر سه مولتی‌پلکسر از بلاک دیاگرام استفاده کنید.

حل: ۴ بیت ورودی را  $S_3 S_2 S_1 S_0$  می‌نامیم. از سه بیت  $S_2 S_1 S_0$  برای انتخاب ورودی متناظر در مولتی‌پلکسر ۸ به ۱ استفاده می‌کنیم. از بیت  $S_3$  برای انتخاب ورودی موردنظر به وسیلهٔ مولتی‌پلکسر ۲ به ۱ استفاده می‌کنیم. پس داریم:



۸ - بلاک دیاگرام یک مولتی پلکسر را رسم کنید و کارکرد آن را با جدول تابع

توضیح دهید.

حل: برای مولتی پلکسر ۴ به ۱ داریم:



### جدول تابع

(select)

البته در صورت سوال کتاب لاتین، بلاک دیاگرام یک مولتی پلکسor دوگانه (Dual



(MUX) درخواست شده است که داریم:

| S <sub>1</sub> | S <sub>0</sub> | Y <sub>A</sub> | Y <sub>B</sub> |
|----------------|----------------|----------------|----------------|
| •              | •              | A <sub>0</sub> | B <sub>0</sub> |
| •              | 1              | A <sub>1</sub> | B <sub>1</sub> |
| 1              | •              | A <sub>2</sub> | B <sub>2</sub> |
| 1              | 1              | A <sub>3</sub> | B <sub>3</sub> |

۹- یک گیت AND دو ورودی را در ثبات شکل ۲-۷ جای دهید و خروجی این گیت را به ورودی‌های ساعت همه فلیپ فلاب‌ها وصل کنید. یکی از ورودی‌های گیت AND پالس‌های ساعت را از مولد پالس ساعت دریافت می‌کند. ورودی دیگر گیت AND، کنترل بار شدن موازی را فراهم می‌کند. کارکرد ثبات جدید را شرح دهید.

حل:



زمانی که ورودی "parallel load" ۱ است، امکان بار موازی رجیستر فراهم می‌آید و زمانی که این ورودی، ۰ است، خروجی گیت AND شده و اطلاعات رجیستر به طور تضمین شده، نگهداری خواهد شد. یعنی با تغییر احتمالی و اشتباہی ورودی‌های  $(I_0 - I_3)$ ، بارگذاری صورت نمی‌گیرد.

#### ۱۰- هدف گیت بافر در ورودی ساعت ثبات شکل ۸ - ۲ چیست؟

حل: با توجه به توضیحات صفحه ۵۲ کتاب، این گیت توان دریافتی لازم را از مولد ساعت کاهش می‌دهد. هر گاه پالس ساعت فقط به ورودی یک گیت در عوض چند گیت وصل شود، توان کمتری لازم است، ولی چنانچه این گیت بافر مورد استفاده قرار نگرفته و پالس ساعت مستقیماً به هر چهار ورودی وصل شود. توان بیشتری از مولد پالس اخذ خواهد شد. ساختمن این بافر می‌تواند به صورت زیر باشد.



#### ۱۱- به ثبات دارای امکان بار شدن موازی در شکل ۸ - ۲، امکان ورودی پاک کننده را اضافه کنید.

حل:



جدول تابع به صورت زیر است:

پاک کننده بارگذاری

| Load | Clear | D      | عمل            |
|------|-------|--------|----------------|
| ·    | ·     | $Q(t)$ | بلا تغییر      |
| ·    | 1     | ·      | پاک کردن به ۰  |
| 1    | X     | $I_0$  | بار کردن $I_0$ |

۱۲- مقدار اولیه محتوای یک ثبات ۱۱۰۱ است. ثبات شش بار با ورودی سری ۱۰۱۱۰۱ به راست شیفت داده می‌شود. محتوای ثبات پس از هر شیفت چیست؟

حل:



۱۳- فرق بین انتقال سری و موازی چیست؟ با یک شیفت رجیستر دارای بار

شدن موازی توضیح دهد چگونه می‌توان ورودی سری را به خروجی موازی و برعکس تبدیل کرد.

حل:

انتقال سریال: در هر زمان یک بیت انتقال، به وسیله شیفت

انتقال موازی: هر تعداد بیت به صورت همزمان

ورودی سری از طریق شیفت به خروجی موازی تبدیل شده و ورودی موازی از طریق بار موازی به خروجی سری از طریق شیفت تبدیل می‌شود. نیاز به یک شمارنده برای تعیین تعداد بیت «مثلاً ۸ بیت در هر کلمه» وجود دارد.

۱۴- شمارنده حلقوی یک شیفت رجیستر شکل ۲-۹ می‌باشد که خروجی سری اش به ورودی سری آن وصل شده است. با شروع از حالت اولیه ۱۰۰۰، رشته حالات چهار فلیپ فلاپ را پس از هر شیفت نشان دهد.

حل: اگر شیفت رجیستر به راست فرض شود داریم:



۱۵- یک شیفت رجیستر چهار بیتی دو طرفه با ویژگی بار شدن موازی طبق شکل ۲-۱۰ در یک مدار مجتمع، بسته‌بندی شده است.

(الف) بلاک دیاگرام مدار مجتمع را با تمام ورودی‌ها و خروجی‌ها رسم کنید. دو پایه برای منبع تغذیه قرار دهد.

(ب) با دو مدار مجتمع بلاک دیاگرام یک شیفت رجیستر ۸ بیتی با ویژگی بار شدن موازی را رسم کنید.

حل:

(الف)



(ب)



۱۶- در شمارنده دودویی ده بیتی، چند فلیپ فلاپ در شمارش بعدی متمم می‌شوند.

الف) ۱۰۰۱۱۰۰۱۱۱

ب) ۰۰۱۱۱۱۱۱۱۱

حل: در هر مورد، عدد با عدد ۱۰۰۰۰۰۰۰۱ جمع دودویی می‌شود و تعداد متمم‌ها حساب می‌شود.

$$\text{الف) ۴ مورد } 100110100 = 100110111 + 00000001$$

$$\text{ب) ۹ مورد } 010000000 = 010000001 + 000000001$$

۱۷- اتصالات لازم بین چهار شمارنده دودویی چهار بیتی با بار شدن موازی (شکل ۲-۱۲) برای ایجاد یک شمارنده دودویی ۱۶ بیتی با بار شدن موازی را نشان دهید. برای هر شمارنده چهار بیتی از یک بلاک دیاگرام استفاده کنید.

حل: نکته مهم در این سؤال، آن است که در رابطه با گسترش شمارنده‌ها بیت نقلی خروجی هر مرحله (شمارنده) به فعال‌ساز شمارش مرحله «شمارنده» بعدی متصل می‌شود و بیت‌های Clock، Load، Clear در همه شمارنده‌ها مشترک هستند.



۱۸- نشان دهید که چگونه یک شمارنده دودویی با بار شدن موازی شکل ۲-۱۲ را می‌توان به یک شمارنده تقسیم بر N تبدیل کرد.

(یعنی شمارنده‌ای که از ۰۰۰۰ تا N شمرده و به ۰۰۰۰ باز گردد).

به عنوان یک حالت خاص، مدار یک تقسیم بر ۱۰ را با شکل ۲-۱۲ و یک گیت AND خارجی رسم کنید.

حل: زمانی که لفظ تقسیم بر N گفته می‌شود. مفهوم این است که محتوای شمارنده

از  $0000$  تا خود  $N-1$  پیش رفته و بعد از آن  $0000$  به رجیستر Load می‌شود.  
طبق این توضیحات، در این سؤال داریم؛ شمارنده از  $1001$  تا  $0000$  پیش رفته و بعد از آن دارای  $0000$  می‌شود.



۱۹- واحدهای حافظه زیر با تعداد کلمات در تعداد بیت‌ها مشخص شده‌اند. در هر مورد چند خط آدرس و چند خط داده ورودی - خروجی نیاز است.

$$64k \times 8 \quad (2)$$

$$2k \times 16 \quad (\text{الف})$$

$$4G \times 64 \quad (4)$$

$$16M \times 32 \quad (\text{ج})$$

حل:

$$\text{الف) } 16 \text{ خط داده} \quad 11 \text{ خط آدرس}$$

$$\text{ب) } 8 \text{ خط داده} \quad 16 \text{ خط آدرس}$$

$$\text{ج) } 32 \text{ خط داده} \quad 24 \text{ خط آدرس}$$

$$\text{د) } 64 \text{ خط داده} \quad 32 \text{ خط آدرس}$$

۲۰- تعداد بایت‌هایی را که می‌توان در حافظه‌های مسئله ۱۹-۲ ذخیره کرد مشخص کنید.

حل:

$$2K \times 16 = 4K \text{ byte} = 4096 \text{ bytes}$$

$$64K \times 8 = 64K \text{ byte} = 2^{16} \text{ bytes}$$

$$16M \times 32 = 2^{24} \times 4 = 2^{26} \text{ bytes}$$

$$4G \times 64 = 2^{32} \times 8 = 2^{35} \text{ bytes}$$

۲۱- چند تراشه حافظه  $128 \times 8$  برای ساخت یک حافظه  $4096 \times 16$  نیاز است؟

حل: در این مسائل، ابتدا تعیین می‌کنیم که شکل حافظه نهایی براساس حافظه در

دسترس چگونه است. با توجه به تعداد بیت‌ها:

$$\Rightarrow \frac{4096 \times 16}{128 \times 8} = \frac{2^{12} \times 2^4}{2^7 \times 2^3} = 2^6 = 64 \quad \text{تراشه}$$

۲۲- با داشتن یک ROM  $32 \times 8$  بیتی و یک و لازم برای ساخت یک ROM  $128 \times 8$  و یک دیک

حل:

$$32 \times 8 = 2^5 \times 8 \quad 5 \text{ خط داده} \quad 8 \text{ خط آدرس}$$

$$128 \times 8 = 2^7 \times 8 \quad 7 \text{ خط داده} \quad 8 \text{ خط آدرس}$$

با استفاده از یک دیکدر  $2 \times 4$  و دو بیت با ارزش آدرس ROM  $128 \times 8$ ، فعال‌سازی

هر کدام از ROM های  $32 \times 8$  را انجام می‌دهیم.



۲۳- یک تراشه  $4096 \times 8$  ROM بیتی دارای دو ورودی تواناساز بوده و با منبع تغذیه ۵ ولت کار می‌کند. چند پایه برای بسته مدار مجتمع نیاز است؟ بلاک دیاگرام آن را رسم و پایانه‌های ورودی و خروجی را نام‌گذاری کنید.

حل:

$$4096 \times 8 = 2^{12} \times 8$$

پین ۲۴ = دو پین منبع تغذیه برای ACC و زمین + دو ورودی تواناساز

بدین ترتیب بسته مدار مجتمع را رسم و پایانه‌ها را نام‌گذاری می‌کنیم :



## فصل سوم: نمایش داده‌ها

۱- اعداد دودویی زیر را به دهدھی تبدیل کنید.

حل: با توجه به ارزش رقم‌ها در مبنای ۲:

$$(101110)_2 = 32 + 8 + 4 + 2 = 46$$

$$(1110101)_2 = 64 + 32 + 16 + 4 + 1 = 117$$

$$(110110100)_2 = 256 + 128 + 32 + 16 + 4 = 436$$

۲- اعداد زیر را، که پایه‌هایشان ۳، ۵، ۷ و ۱۰ به دهدھی تبدیل کنید.

حل:

با توجه به ارزش ارقام در پایه مربوطه:

$$(12121)_3 = 3^4 + 2 \times 3^3 + 3^2 + 2 \times 3 + 1 = 81 + 54 + 9 + 6 + 1 = 151$$

$$(4310)_5 = 4 \times 5^3 + 3 \times 5^2 + 5 = 500 + 75 + 5 = 580$$

$$(50)_4 = 5 \times 7 = 35$$

$$(198)_{12} = 12^2 + 9 \times 12 + 8 = 144 + 108 + 8 = 260$$

۳- اعداد دهدھی زیر را به دودویی تبدیل کنید.

حل:

$$(1231)_{10} = 1024 + 128 + 64 + 8 + 4 + 2 + 1 = 2^{10} + 2^7 + 2^6 + 2^3 + 2^2 + 2^1 + 2^0$$

بیت‌های متناظر با توان‌هایی از ۲ که ظاهر شده‌اند، ۱ و بقیه صفر هستند.

$$(1231)_{10} = 2^{10} + 2^7 + 2^6 + 2^3 + 2^2 + 2^1 + 2^0 = (10011001111)_2$$

روش دیگر استفاده از تقسیم متواالی است که در آن معکوس دنباله‌ی باقی‌مانده‌ها،

معادل عدد در مبنای دلخواه (در اینجا ۲) است.

The diagram shows the long division of 1231 by 2. The quotient is 10011001111 and the remainder is 0. The process is labeled 'قسمت' (Quotient).

تقسیم را تا جایی ادامه می‌دهیم که خارج قسمت از مبنای مورد نظر (۲) کوچکتر شود.

دنهاله : ۱۱۱۱۰۰۱۱۰۰۱

دنباله معکوس ۱۱۰۱۱۰۱۱۱

همانند مثال اول داریم:

$$(673)_{10} = 512 + 128 + 32 + 1 = 2^9 + 2^7 + 2^5 + 2^0 = \quad (1010100001)_2$$

$$\begin{aligned}(1998)_{10} &= 1024 + 512 + 256 + 128 + 64 + 8 + 4 + 2 \\&= 2^{10} + 2^9 + 2^8 + 2^7 + 2^6 + 2^3 + 2^2 + 2^1 \\&= (11111001110)_2\end{aligned}$$

همان‌طور که دیدید روش اول یک روش سرانگشتی برای محاسبه راحت‌تر است  
و لی روش دوم، یک الگوریتم دقیق است.

۴- اعداد دهدزی زیر را به مبنای مشخص شده تبدیل کنید.

الف) ۷۵۶۲ به هشت هشتی ب) ۱۹۳۸ به شانزده شانزدهی

ج) ۱۷۵ به دودویی

حل: می‌توان از همان روش تقسیم متولی استفاده کرد با در نظر گرفتن این که ارقام مبنای ۱۶، اعداد  $(A)$  تا  $15$  ( $F$ ) را در پر می‌گیرند.

پس داریم:

$$(7562)_{10} = (16612)_8$$

$$(1938)_{10} = (792)_{16}$$

$$(175)_{10} = (10101111)_2$$

۵- عدد شانزده شانزدهی F3A7C2 را به دو دویی و هشت هشتی تبدیل نمایید.

حل: با توجه به این که ۱۶ توان چهارم ۲ است، هر رقم مبنای ۱۶ معادل ۴ رقم مبنای ۲ است که با جایگزینی ارقام عدد با معادل دودویی آن داریم:

$$F3A7C2 = (1111\ 0011\ 1010\ 0111\ 1100\ 0010)$$

همچنین با توجه اینکه ۸ توان سوم ۲ است، هر سه رقم مبنای ۲ معادل یک رقم مبنای ۸ است پس با جایگزینی از سمت راست داریم:

$$111\ 100\ 111\ 010\ 011\ 111\ 000\ 010$$

که معادل است با

$$74723702$$

۶ - اگر جواب معادله درجه دوم  $x^2 - 10x + 31 = 0$  برابر  $x = 5$  و  $x = 8$  باشد،

پایه عددها چیست؟

حل:

$$(x^2 - 10x + 31)_r = [(x-5)(x-8)]_{10}$$

$$= x^2 - (5+8)_{10} x + (40)_{10}$$

با معادل قرار دادن ضرایب داریم:

$$(10)_r = (13)_{10}$$

$$0+r=13 \Rightarrow r=13$$

$$(31)_r = (40)_{10} \Rightarrow 1+3 \times r = 40 \Rightarrow 3r = 39 \quad \text{همچنین:}$$

$$\Rightarrow r=13$$

$$x^2 - (r+0)x + 3r+1 = 0 \Rightarrow 25 - 5r + 3r + 1 = 0 \quad : (x=5) \quad \text{یا}$$

$$\Rightarrow 2r = 26$$

$$r = 13$$

۷- مقدار همه بیت‌های یک ثبات ۱۲ بیتی که عدد ۲۱۵ دهدۀ را نگه می‌دارد:

(الف) به دودویی:

$$(215)_{10} = 128 + 64 + 16 + 4 + 2 + 1 =$$

$$(11010111)_2$$

$$\Rightarrow 000011010111$$

(ب) به هشت‌تی کد شده با دودویی:

$$\begin{array}{cccc} 000 & 011 & 010 & 111 \\ 0 & 3 & 2 & 7 \end{array}$$

(ج) به شانزده‌تی کد شده با دودویی:

$$\begin{array}{ccc} 0000 & 1101 & 0111 \\ 0 & D & 7 \end{array}$$

(د) به دهدۀ کد شده با دودویی:

$$\begin{array}{ccc} 0010 & 0001 & 0101 \\ 2 & 1 & 5 \end{array}$$

همان‌طور که می‌بینیم هشت‌تی و شانزده‌تی کد شده با دودویی یک عدد، با دودویی آن عدد معادل است.

۸- آرایش یک ثبات ۲۴ بیتی را که محتوایش عدد دهدۀ ۲۹۵ است:

(الف) به دودویی:  $(295)_{10} = 0000\ 0000\ 0001\ 0010\ 0111$

(ب) به BCD: 0000 0000 0000 0010 1001 0101

(ج) به ASCII با استفاده از هشت‌تی با توازن زوج:

$$10110010 \quad 00111001 \quad 00110101$$

در ۳ عدد دودویی بالا، بیت توازن زوج به با ارزشترین بیت توجه شود.

۹- نام خود را با یک کد ۸ بیتی به ASCII نوشه و بیت سمت چپ را  $\circ$  در نظر بگیرید. بین نام و نام خانوادگی خود از فضای خالی استفاده کنید و در صورت

استفاده از حرف اول نام، پس از آن نقطه بگذارید.

حل: Morris Mano

M(01001101) o(01101111) r(01110010) r(01110010) i(01101001) s(01110011)  
(01000000) M(01001101) a(01100001) n(01101110) o(01101111)

۱۰- کد ASCII زیر را رمزگشایی کنید:

1001010 1001111 1001000 1001110 0100000 1000100 1001111 1000101

حل: به ترتیب داریم

J O H N " D O E  
JOHN DOE

۱۱- متمم ۹ اعداد ددهدی هشت رقمی زیر را بدست آورید:

12349876 ; 00980100 ; 90009951 ; 00000000

حل: به ترتیب داریم

87650123 ; 99019899 ; 09990048 ; 99999999

۱۲- متمم ۱۰ اعداد ددهدی شش رقمی زیر با دست آورید.

123900 ; 090657 ; 100000 ; 000000

حل: به ترتیب داریم

876100 ; 909343 ; 900000 ; 000000

۱۳- متممهای ۱ و ۲ اعداد دودویی هشت رقمی زیر را به دست آورید.

حل:

10101110 , 10000001 , 10000000 , 00000001 , 00000000  
01010001 , 01111110 , 01111111 , 11111110 , 11111111 متمم ۱ :

01010010 , 01111111 , 10000000 , 11111111 , 00000000 متمم ۲ :

برای متمم ۱ به جای ،۰ و به جای ،۱ ، جایگزین می‌کنیم.

برای متمم ۲، از سمت راست شروع کرده، تا رسیدن به اولین ۱ صفرهای عدد را

بدون تغییر می‌گذاریم، همچنین اولین ۱ را بدون تغییر می‌گذاریم و تمام بیت‌های سمت

چپ اولین یک (از سمت راست) را متمم ۱ می‌کنیم.

۱۴- تفریق را با اعداد ددهی بدون علامت زیر و با متمم ۱۰ مفروق انجام

دهید:

الف) ۱۳۲۱ - ۵۲۵۰

$$\begin{array}{r} 5250 \\ +8679 \\ \hline 1\ 3929 \end{array}$$

که متمم ۱۰ آن، ۶۸۸۷ است.

ب) ۱۷۵۳ - ۸۶۴۰

صفر بودن رقم نقلی به معنی منفی بودن حاصل است که برای بدست آمدن حاصل

باید نتیجه را متمم ۱۰ کنیم.

$$\begin{array}{r} 1753 \\ +1360 \\ \hline 0\ 3113 \end{array}$$

که متمم ۱۰ آن، ۰۸۰۷ است.

ج) ۲۰-۱۰۰

مانند قسمت ب داریم:

$$\begin{array}{r} 020 \\ +900 \\ \hline 0\ 920 \end{array}$$

د) ۱۲۰۰-۲۵۰

$$\begin{array}{r} 1200 \\ +9750 \\ \hline 10950 \end{array}$$

۱۵- تفریق را با اعداد دودویی بدون علامت زیر و با متمم ۲ مفروق انجام

دهید.

الف) ۱۱۰۱۰-۱۰۰۰۰

$$\begin{array}{r}
 11010 \\
 +10000 \\
 \hline
 101010
 \end{array}
 \quad
 \begin{array}{l}
 26 - 16 = 10 \\
 \\
 \end{array}$$

ب)  $11010 - 1101$

$$\begin{array}{r}
 11010 \\
 +10011 \\
 \hline
 101101
 \end{array}
 \quad
 \begin{array}{l}
 26 - 13 = 13 \\
 \\
 \end{array}$$

ج)  $100 - 110000$

$$\begin{array}{r}
 000100 \\
 +010000 \\
 \hline
 1010100
 \end{array}$$

(4 - 48 = -44)

همانند سؤال قبل نیاز به متمم ۲ داریم. پس متمم ۲ می‌شود **-101100**

د)  $1010100 - 1010100$

$$\begin{array}{r}
 1010100 \\
 +0101100 \\
 \hline
 10000000
 \end{array}$$

**84-84=0**

۱۶- اعمال حسابی  $(-13) + (+42) - (-42)$  و  $(+42) - (-13)$  را در دودویی و با متمم

۲ علامت‌دار برای اعداد منفی انجام دهید.

حل:

$$\begin{array}{ll}
 +42 = 0101010 & +13 = 0001101 \\
 -42 = 1010110 & -13 = 1110011 \\
 (+42) 0101010 & (-42) 1010110 \\
 (-13) 1110011 & (+13) 0001101 \\
 \hline
 (+29) 0011101 & (-29) 1100011
 \end{array}$$

همان طور که می‌دانیم در صورتی که حاصل منفی باشد، به صورت متمم ۲ بدست می‌آید.

۱۷- اعمال حسابی  $(+80) + (+70) + (-80) + (-70)$  را با نمایش اعداد دودویی به شکل متمم ۲ علامت‌دار انجام دهید. هشت بیت برای نمایش هر عدد به همراه علامت آن بکار برید. نشان دهید که در هر دو مورد سرریز رخ می‌دهد، دو نقلی آخر نامساوی اند و علامت وارون می‌شود.

حل:

$$\begin{array}{r} +70 \\ +80 \\ \hline +150 \end{array} \quad \begin{array}{r} 01000110 \\ 01010000 \\ \hline 10010110 \end{array} \quad \begin{array}{r} -70 \\ -80 \\ \hline -150 \end{array} \quad \begin{array}{r} 10111010 \\ 10110000 \\ \hline 010101010 \end{array}$$

در محاسبه سمت چپ، جواب بزرگتر از ۱۲۷+ است. پس جواب منفی و سرریز رخ داده است.

در محاسبه سمت راست، جواب کوچکتر از ۱۲۸- است. پس جواب مثبت و سرریز رخ داده است.

۱۸- اعمال حسابی زیر را برای اعداد ددهی مشخص شده با استفاده از نمایش متمم ۱۰ علامت‌دار برای اعداد منفی انجام دهید.

الف)  $(-638) + (+785)$

$$\begin{array}{r} (-638) \\ (+785) \\ \hline (+147) \end{array} \quad \begin{array}{r} 9362 \\ +0785 \\ \hline 0147 \end{array}$$

ب)  $(-638) - (+185)$

$$\begin{array}{r} (-638) \\ (-185) \\ \hline (-823) \end{array} \quad \begin{array}{r} 9362 \\ +9815 \\ \hline 9177 \end{array}$$

که نیاز به متمم گیری دارد.

۱۹- یک عدد دودویی ممیز شناور ۳۶ بیتی دارای ۸ بیت همراه علامت برای نما و ۲۶ بیت همراه علامت برای مانیس است. مانیس یک کسر نرمال شده است. اعداد مانیس و نما به فرم مقدار علامت دار هستند. بزرگترین و کوچکترین عدد مثبتی که با این شکل می توان نشان داد، به جز صفر، کدامند؟

$$\text{بزرگترین : } (1-2^{-26}) \times 2^{+255}$$

$$\text{بزرگترین : } (2^{-1}) \times 2^{-255}$$

۲۰- عدد  $(+46.5)_{10}$  را به صورت یک عدد دودویی ممیز شناور ۲۴ بیتی نشان دهید. مانیس که کسر نرمال شده است ۱۶ بیت و نما ۸ بیت دارند.

$$46.5 = 32 + 8 + 4 + 2 + 0.5 = 2^5 + 2^3 2^2 + 2^1 + 2^{-1} = (101110.1)_2$$

پس داریم:

۰۱۰۱۱۱۰۱۰۰۰۰۰۰۰

و چون کسر را نرمال کرده ایم نما برابر است با:

$$00000110 (+6)$$

بیت نما ۸

۲۱- کد گری گاهی کد بازتابی گفته می شود زیرا مقدار بیت ها در دو طرف هر یک از توان های ۲ ، بازتاب یکدیگرند، مثلاً همانگونه که در جدول ۵ - ۳ ملاحظه می شود، مقدار سه بیت کم ارزش در دو طرف خطی که بین ۷ و ۸ کشیده می شود بازتاب یکدیگرند. با استفاده از این ویژگی کد گری به دست آورید:

الف) اعداد کد گری برای ۱۶ تا ۳۱ به عنوان ادامه جدول ۵-۳

ب) کد گری افزونی ۳ برای اعداد دهدی ۱۰ تا ۱۹ به عنوان ادامه جدول ۶ - ۳

حل:

الف:

| Decimal | Gray Code |
|---------|-----------|
| 16      | 11000     |
| 17      | 11001     |
| 18      | 11011     |
| 19      | 11010     |
| 20      | 11110     |
| 21      | 11111     |
| 22      | 11101     |
| 23      | 11100     |
| 24      | 10100     |
| 25      | 10101     |
| 26      | 10111     |
| 27      | 10110     |
| 28      | 10010     |
| 29      | 10011     |
| 30      | 10001     |
| 31      | 10000     |

نکته: یک روش ساده برای بدست آوردن کدگری یک عدد دودویی به این صورت است:

از سمت چپ شروع کرده، اولین رقم را عیناً می‌نویسیم و برای رقم‌های بعدی انحصاری رقم عدد اصلی و رقم سمت چپ آن را در نظر می‌گیریم. OR

مثال:

10110      1011001

↓  
دودویی  
گری

11101      1110101

پس ابتدا افزونی ۳ را محاسبه کرده و سپس کدگری آن را برای ستون بعد بدست

|       |          |                   |
|-------|----------|-------------------|
| دهدھی | افزونی ۳ | کدگری<br>افزونی ۳ |
|-------|----------|-------------------|

|    |       |       |
|----|-------|-------|
| ۹  | ۱۱۰۰  | ۱۰۱۰  |
| ۱۰ | ۱۱۰۱  | ۱۰۱۱  |
| ۱۱ | ۱۱۱۰  | ۱۰۰۱  |
| ۱۲ | ۱۱۱۱  | ۱۰۰۰  |
| ۱۳ | ۱۰۰۰۰ | ۱۱۰۰۰ |
| ۱۴ | ۱۰۰۰۱ | ۱۱۰۰۱ |
| ۱۵ | ۱۰۰۱۰ | ۱۱۰۱۱ |
| ۱۶ | ۱۰۰۱۱ | ۱۱۰۱۰ |
| ۱۷ | ۱۰۱۰۰ | ۱۱۱۱۰ |
| ۱۸ | ۱۰۱۰۱ | ۱۱۱۱۱ |
| ۱۹ | ۱۰۱۱۰ | ۱۱۱۰۱ |
| ۲۰ | ۱۰۱۱۱ | ۱۱۱۰۰ |
|    | ۱۱۰۰  | ۱۰۱۰۰ |

۲۲- عدد دهدهی ۸۶۲۰ را به شکل‌های زیر بدست آورید.

الف) BCD : 1000 0110 0010 0000

ب) افزودنی ۳ : 1011 1001 0101 0011

ج) کد ۲۴۲۱ : 1110 1100 0010 0000

د) دودویی: 8192+256+128+32+8+4

$$=10000110101100$$

۲۳- ده رقم BCD را با توازن زوج در سمت چپ آن (در کل پنج بیت در هر رقم) نشان دهید. این کار را با توازن فرد تکرار کنید.

حل:

دهدهی                          با توازن فرد                          BCD با توازن زوج

|   |        |       |
|---|--------|-------|
| ۰ | .....  | 10000 |
| ۱ | 10001  | 00001 |
| ۲ | 10010  | 00010 |
| ۳ | 00011  | 10011 |
| ۴ | 10100  | 00100 |
| ۵ | 001001 | 10101 |
| ۶ | 00110  | 10110 |
| ۷ | 10111  | 00111 |
| ۸ | 11000  | 01000 |
| ۹ | 01001  | 11001 |

توازن فرد، عکس توازن زوج است.

۲۴- عدد دهدھی ۳۹۸۴ را به صورت کد ۲۴۲۱ جدول ۳-۶ نشان دھید. تمام بیت‌های عدد کد شده را متمم کنید و نشان دھید که نتیجه همان متمم نه عدد ۳۹۸۴ با کد ۲۴۲۱ است.

حل:

$$3984 = 0011 \ 1111 \ 1110 \ 0100$$

که متمم آن می‌شود

$$1100 \ 0000 \ 0001 \ 1011 = 6015 \rightarrow$$

که همان متمم ۹ عدد ۳۹۸۴ است (این موضوع به دلیل خاصیت خود متممی کد ۲۴۲۱ است).

۲۵- نشان دھید که تابع OR انحصاری  $x = A \oplus B \oplus C \oplus D$  بک تابع فرد است. یکی راه این است که جدول درستی  $z = C \oplus D$  و  $y = A \oplus B$  را بدست آورده و سپس جدول درستی  $x = y \oplus z$  را بدست آورید. نشان دھید که  $x = 1$  است به

شرطی که تعداد ۱ ها در A، B، C و D فرد باشد.

حل:

| A | B | $Y = A \oplus B$ |
|---|---|------------------|
| 0 | 0 | 0                |
| 0 | 1 | 1                |
| 1 | 0 | 1                |
| 1 | 1 | 0                |

| C | D | $Z = C \oplus D$ |
|---|---|------------------|
| 0 | 0 | 0                |
| 0 | 1 | 1                |
| 1 | 0 | 1                |
| 1 | 1 | 0                |

| y | z | $x = y \oplus z$                                                             |
|---|---|------------------------------------------------------------------------------|
| 0 | 0 | 0                                                                            |
| 0 | 1 | 1 ← $\begin{cases} AB=00 \text{ یا } 11 \\ CD=01 \text{ یا } 10 \end{cases}$ |
| 1 | 0 | 1 ← $\begin{cases} AB=01 \text{ یا } 10 \\ CD=00 \text{ یا } 11 \end{cases}$ |
| 1 | 1 | 0                                                                            |

| ABCD                   |
|------------------------|
| 0001, 0010, 1101, 1110 |
| 0100, 0111, 1000, 1011 |

همواره تعداد فردی ۱ وجود دارد

۲۶- مدارهای یک سازنده توازن سه بیتی و بررسی کننده توازن چهار بیتی را با استفاده از بیت توازن زوج بدست آورید (مدارهای شکل ۳-۳ توازن فرد را به کار برده‌اند).

حل:

$$p = x \oplus y \oplus z \text{ و } x = y \oplus z$$

این مدارها همانند شکل ۳-۳ هستند با این تفاوت که حباب‌های متمم‌ساز در خروجی خود ندارند.





## فصل چهارم: انتقال ثبات‌ها و ریز عمل‌ها

- ۱- بلاک دیاگرام سخت‌افزاری مشابه شکل ۴-۲ (الف) که عبارت انتقال ثباتی زیر را پیاده‌سازی می‌کند رسم کنید:

$$yT_2 : R_2 \leftarrow R_1, R_1 \leftarrow R_2$$

حل: عبارت  $yT_2$  نشان‌دهنده‌ی لزوم فعال بودن همزمان  $y$  و  $T_2$  برای انجام عملیات‌ها است. پس:



توضیح آنکه در ارتباط با صحت داده‌های موجود در رجیسترها در عملیات جابجایی (swap)، این صحت با توجه به مفاهیم setup ، hold time، propagation time مربوط به سیگنال clock تفسیر می‌گردد.

- ۲- خروجی چهار ثبات  $R_0, R_1, R_2, R_3$  با یک مولتی‌پلکسر  $4 \times 1$  به ورودی‌های ثبات پنجم  $R_5$  وصل شده‌اند. هر ثبات هشت بیتی است. انتقال‌های لازم توسط چهار متغیر زمان‌بندی  $T_0$  تا  $T_3$  به صورت زیر تعیین می‌شود:

$$T_0 : R_5 \leftarrow R_0$$

$$T_1 : R_5 \leftarrow R_1$$

$$T_2 : R_5 \leftarrow R_2$$

$$T_3 : R_5 \leftarrow R_3$$

متغیرهای زمان دو به دو منحصراند. یعنی در هر زمان معین فقط یک متغیر ۱ است، در حالی که سه متغیر دیگر ۰ هستند. بلاک دیاگرامی رسم کنید که نشان‌دهنده پیاده‌سازی ساخت افزاری انتقال ثباتی باشد. اتصالات لازم برای چهار متغیر زمان‌بندی به خطوط انتخاب مولتی پلکسرو ورودی بار کردن ثبات  $R_5$  را نیز نشان دهد.

**حل:** جدول درستی را با توجه به توضیحات سؤال آماده می‌کیم:  $S_1$  و  $S_0$

ورودی‌های انتخاب MUX هستند.

| $T_0$ | $T_1$ | $T_2$ | $T_3$ | $S_1$ | $S_0$ | Load |
|-------|-------|-------|-------|-------|-------|------|
| ۰     | ۰     | ۰     | ۰     | X     | X     | ۰    |
| ۱     | ۰     | ۰     | ۰     | ۰     | ۰     | ۱    |
| ۰     | ۱     | ۰     | ۰     | ۰     | ۱     | ۱    |
| ۰     | ۰     | ۱     | ۰     | ۱     | ۰     | ۱    |
| ۰     | ۰     | ۰     | ۱     | ۱     | ۱     | ۱    |

$$\Rightarrow S_1 = T_2 + T_3$$

$$S_0 = T_1 + T_3$$

$$\text{Load} = T_0 + T_1 + T_2 + T_3$$

پس مدار به شکل زیر خواهد بود:



۳- عبارت کنترل شرطی زیر را با دو عبارت انتقال ثباتی با توابع کنترل نشان

دهید:

$$IF(P=1) \text{then } (R_1 \leftarrow R_2) \text{elseif } (Q=1) \text{then } (R_1 \leftarrow R_3)$$

حل:

$$P : R_1 \leftarrow R_2$$

$$P'Q : R_1 \leftarrow R_3$$

دلیل استفاده از ' $P$ ' در عبارت دوم، لفظ "else" در عبارت کنترل صورت سؤال است.

۴- برای اینکه سیستم گذرگاه شکل ۴-۳ داده را از هر ثبات به هر ثبات دیگر منتقل کند چه باید کرد؟ به ویژه اتصالاتی را که باید برای فراهم کردن یک مسیر از خروجی‌های ثبات  $C$  به ورودی‌های ثبات  $A$  وصل نمود نشان دهید.

حل: برای این کار، ۴ خط گذرگاه مشترک را به ورودی ۴ رجیستر وصل می‌نماییم.

همچنین به منظور انتخاب رجیستر مقصد، با استفاده از یک دیکدر  $2 \times 4$  و ورودی‌های Load,  $S'_1, S'_0$ ، رجیستر مقصد را فعال کرده تا داده از روی گذرگاه مشترک بر روی رجیستر مقصد بارگذاری شود.

برای نمونه، برای انتقال محتویات رجیستر C به رجیستر A  $S_1 S_0 = 10$ ، A را اعمال کرده تا رجیستر C مبدأ قرار گیرد. سپس Load رجیستر A را فعال کرده و کلک پالس به منظور انتقال «بارگذاری» اعمال می‌کنیم.

**۵ - یک سیستم گذرگاه مانند شکل ۳-۴ رسم کنید، ولی از بافرهای سه حالته و دیکدر به جای مولتی پلکسرا استفاده کنید.**

حل: دو روش طراحی با استفاده از بافر سه حالته می‌توان ارائه داد.

روش اول، به این صورت است که از بافرهای سه حالته برای انتخاب هر بیت از بیت‌های ۰، ام، اول، دوم و سوم در همه رجیسترها استفاده می‌شود. به شکل زیر:

بیت ۰ برای گذرگاه



بیت ۱ برای گذرگاه



تولید بیت‌های ۲ و ۳ برای گذرگاه مانند بالا طراحی شود.  
روش دوم، به این صورت است که از بافرهای سه حالت، برای فعال یا امپدانس بالا  
کردن یک رجیستر کامل استفاده می‌شود. به شکل زیر:



۶ - یک کامپیوتر دیجیتال دارای سیستم گذرگاه مشترک برای ۱۶ ثبات ۳۲ بیتی  
است. گذرگاه با مولتی پلکسرا ساخته شده است.

الف) در هر مولتی پلکسرا چند ورودی انتخاب وجود دارد.

ب) اندازه مولتی پلکسرا چیست.

ج) چند مولتی پلکسرا در گذرگاه است.

حل:

الف) ۴ خط ورودی برای مولتی پلکسرا برای انتخاب یکی از ۱۶ رجیستر

ب) مولتی پلکسرا  $16 \times 1$

ج) ۳۲ مالتی پلکسرا

۷- عبارت های زیر انتقال را در یک حافظه را مشخص می کنند. در هر حالت عمل حافظه را توضیح دهید.

$$R_5 \leftarrow M[R_5] \quad M[AR] \leftarrow R_3 \quad \text{الف) } R_2 \leftarrow M[AR]$$

حل:

الف) محتوای موجود در حافظه به آدرس AR خوانده شده و در  $R_2$  نوشته می شود.

ب) محتوای رجیستر  $R_3$  در خانه حافظه به آدرس AR نوشته می شود.

ج) محتوای موجود در حافظه به آدرس موجود در  $R_5$  ، خوانده شده و در  $R_5$  نوشته می شود. در ضمن مقدار قبلی  $R_5$  «آدرس مورد نظر از حافظه» از بین می رود.

۸- بلاک دیاگرام سخت افزاری را رسم کنید که عبارت های زیر را پیاده سازی می کند.

$$x + yz : AR \leftarrow AR + BR$$

که در آن AR و BR دو ثبات n بیتی، و x و y و z متغیر های کترلی هستند. گیت های منطقی را برای توابع کترلی قرار دهید. (توجه شود سمبول + در بخش کترل، عمل OR، و در ریز عمل جمع به معنی بعلاوه است)

حل:



۹- سخت افزاری را نشان دهید که عبارت زیر را پیاده سازی کند. برای تابع کنترل گیت های منطقی و برای شمارنده دودویی با ورودی توان اساز شمارش، بلاک دیاگرام را قرار دهید.

$$xyT_0 + T_1 + y'T_2 : AR \leftarrow AR + 1$$

حل:

می توان عمل  $AR \leftarrow AR + 1$  را با شمارش دودویی انجام داد. پس:



۱۰- عبارت انتقال ثباتی زیر را برای دو ثبات ۴ بیتی  $R_1$  و  $R_2$  در نظر بگیرید.

$$xT : R_1 \leftarrow R_1 + R_2$$

$$x'T : R_1 \leftarrow R_2$$

هر بار که  $T=1$  است، یا محتوای  $R_1$  به  $R_2$  اضافه می‌شود اگر  $x=1$  باشد یا به  $R_1$  انتقال می‌یابد اگر  $x=0$  باشد. دیاگرامی رسم کنید که پیاده‌سازی سخت‌افزاری دو عبارت را نشان دهد. برای دو ثابت ۴ بیتی، یک جمع‌کننده ۴ بیتی، و یک مولتی‌پلکسر چهار تایی ۱:۲ که ورودی‌ها به  $R_1$  را انتخاب می‌کند از بلاک دیاگرام استفاده کنید. در نمودار نشان دهید که متغیرهای کنترلی  $x$  و  $T$  چگونه ورودی‌های مولتی‌پلکسر و ورودی بار کردن ثابت  $R_1$  را انتخاب می‌کنند.

حل:



در ارتباط با Mux استفاده شده، ۴ $\times$ ۱ Mux که برای انتخاب هر کدام از ۴ بیت ورودی‌ها به صورت همزمان استفاده می‌شود و یک Quad Mux را تشکیل می‌دهد.  
۱۱- با یک شمارنده ۴ بیتی با بار شدن موازی مانند شکل ۱۱-۲ و یک جمع‌کننده ۴ بیتی مانند شکل ۶-۴، یک بلاک دیاگرام رسم کرده و چگونگی پیاده‌سازی عبارت‌های زیر را نشان دهید.

$$x : R_1 \leftarrow R_1 + R_2 \quad R_1 \text{ را به } R_2 \text{ اضافه کن}$$

$$x'y = R_1 \leftarrow R_1 + 1 \quad R_1 \text{ را افزایش بده}$$

که  $R_1$  یک شمارنده با بار شدن موازی و  $R_2$  یک ثبات ۴ بیت است.

حل:



نکته مهم در این سؤال آن است که فرض شده است  $y$  و  $x$  طبق طراحی Ctrl Unit همزمان ۱ نمی‌شوند. اگر این فرض را در نظر نگیریم، می‌بایست ورودی شمارنده را به شکل زیر طراحی کنیم.

$$\text{Incr.} \leftarrow y\bar{x}$$



۱۲- مدار جمع - تفریق کننده شکل ۷-۴ دارای مقدارهای زیر برای ورودی مدد

$M$  و ورودی‌های داده  $A$  و  $B$  است، در هر حالت، مقدارهای خروجی  $M$  ورودی‌های  $C_4, S_4, S_0, S_1, S_2, S_3$  را تعیین کنید.

|     | M | A   | B   |
|-----|---|-----|-----|
| الف | ۰ | ۰۱۱ | ۰۱۰ |
| ب   | ۰ | ۱۰۰ | ۱۰۰ |
| ج   | ۱ | ۱۱۰ | ۱۰۰ |
| د   | ۱ | ۰۱۰ | ۱۰۰ |
| هـ  | ۱ | ۰۰۰ | ۰۰۰ |

حل: طبق مدار جمع - تفریق کننده، در  $M=0$  عمل جمع و در  $M=1$  عمل تفریق انجام می‌پذیرد. پس:

| M | A           | B | خروجی مجموع | Carry       |
|---|-------------|---|-------------|-------------|
| ۰ | ۰۱۱ + ۰۱۰   |   | ۱۱۰۱        | ۰ $7+6=13$  |
| ۰ | ۱۰۰ + ۱۰۰۱  |   | ۰۰۰۱        | ۱ $8+9=17$  |
| ۱ | ۱۱۰۰ - ۱۰۰۰ |   | ۰۱۰۰        | ۱ $12-8=4$  |
| ۱ | ۰۱۰۱ - ۱۰۱۰ |   | ۱۰۱۱        | ۰ $5-10=-5$ |
| ۱ | ۰۰۰۰ - ۰۰۰۱ |   | ۱۱۱۱        | ۰ $0-1=-1$  |

۱۳- یک مدار ترتیبی کاهنده چهار بیتی را با چهار مدار تمام جمع کننده بسازید.

حل: برای اینکه خروجی  $A-1$  را از مدار شامل ۴ F.A حاصل کنیم می‌توانیم به روش زیر عمل کنیم:

$$A-1 = A + (1) \quad \text{مکمل ۲} = A + 1111$$

بنابراین مدار به شکل زیر خواهد بود:



Carry in

خروجی کاهش گر ۴ بیت

۱۴- فرض کنید که مدار چهار بیتی شکل ۴-۹ در یک مدار مجتمع قرار گرفته باشد. اتصالات لازم برای دو IC از این نوع را برای ساختن یک مدار حسابی ۸ بیتی نشان دهید.

حل: برای گسترش از ۴ بیت به ۸ بیت مدار حسابی، موارد زیر انجام می‌شود:

۱- اتصال رقم نقلی خروجی IC اول به رقم نقلی ورودی IC دوم

۲- اتصال  $S_0$  و  $S_1$  به انتخاب کننده‌های هر دو گروه MUX ها در دو IC

۳- اتصال رقم نقلی ورودی به رقم نقلی ورودی IC اول

پس:



۱۵- یک مدار حسابی با یک متغیر انتخاب  $S$  و دو خط ورودی  $n$  بیتی  $A$  و  $B$  طراحی کنید. مدار چهار عمل حسابی زیر را با توجه به نقلی ورودی  $C_{in}$  تولید می‌کند. بلاک دیاگرام را برای دو مرحله اول مدار رسم کنید.

|     |           |           |
|-----|-----------|-----------|
| $S$ | $Cin = 0$ | $Cin = 1$ |
|-----|-----------|-----------|

|   |                    |                                |
|---|--------------------|--------------------------------|
| . | $D = A + B$ (جمع)  | $D = A + 1$ (افزایش)           |
| ۱ | $D = A - 1$ (کاهش) | $D = A + \bar{B} + 1$ (تفرقیق) |

حل: طبق موارد گفته شده، جدول درستی را تشکیل می‌دهیم به قسمی که وضعیت

دو پایه  $S$  و  $C_{in}$  مشخص کند که چه ورودی‌هایی به F.A به وصل شوند.

| S | $C_{in}$ | $Y_1$ | $Y_2$     |              |
|---|----------|-------|-----------|--------------|
| . | .        | A     | B         | $(A+B)$ جمع  |
| . | ۱        | A     | .         | $A+1$ افزایش |
| ۱ | .        | A     | ۱         | $A-1$ کاهش   |
| ۱ | ۱        | A     | $\bar{B}$ | $A-B$ تفرقیق |

پس  $Y_1$  همیشه  $A$  و  $Y_2$  طبق نتایج بالا از طریق MUX به داده می‌شود. پس:



۱۶- مدار ترکیبی که هر یک از ۱۶ تابع منطقی جدول ۵ - ۴ را انتخاب و تولید می کند رسم کنید.

حل: با توجه به جدول، می توان با استفاده از  $4 \times 1$  MUX، هر کدام از  $F$  ها را با توجه به ورودی  $y$  و  $x$  تعیین کرد. برای نمونه، قسمت تولید  $F_0$  و  $F_1$  مدار به شکل زیر خواهد بود:



بقیه  $F$  ها ( $F_2 - F_{15}$ ) نیز به همین ترتیب ساخته خواهند شد؛ یعنی ورودی MUX های مربوط به آنها همان  $y$  و  $x$  برای انتخاب و مقادیر ایستای  $F_i$  در جدول ۵ - ۴ کتاب است.

۱۷- یک مدار دیجیتال که چهار عمل منطقی OR انحصاری، NOR انحصاری، NAND و NOR را انجام دهد طراحی کنید. دو متغیر انتخاب بکار برد. دیاگرام منطقی یک مرحله نمونه را نشان دهید.

حل:



۱۸- ثبات A ، عدد ۸ بیتی ۱۱۰۱۱۰۰۱ را نگهداری می‌کند. عملوند B و ریزعمل منطقی لازم را برای تغییر A به هر یک از مقدارهای زیر معین کنید.

الف) ۰۱۱۰۱۱۰۱      ب) ۱۱۰۱۱۰۱

حل: در این گونه مسائل با استفاده از آزمون و خطا می‌توان عملوند دوم و عملگر مورد نظر را یافت. اما با استفاده از ریزعمل منطقی XOR، می‌توان عملوند دوم را به صورت دقیق پیدا کرد. به طوری که



بنابراین:

$$\begin{array}{rcl}
 A & 11011001 & A = 11011001 \\
 B & 00100100 & \text{الف)} \\
 & \text{XOR} & \text{XOR } B = 10110100 \\
 A \oplus B & 11111101 & A \oplus B = 01101101
 \end{array}$$

$$A = 11011001 \text{ OR}$$

$$\begin{array}{r}
 B = 11111101 \\
 \hline
 \text{AVB} 1111101
 \end{array}$$

۱۹- ثبات‌های ۸ بیتی DR, CR, BR, AR ابتدا دارای مقدارهای زیراند.

$$AR = 11110010$$

$$BR = 11111111$$

$$CR = 10111001$$

$$DR = 11101010$$

محتوای هشت بیتی هر یک از ثبات‌ها را پس از اجرای هر یک از رشته ریز عمل‌ها مشخص کنید.

$$AB \leftarrow AR + BR$$

$$CR \leftarrow CR \wedge DR, BR \leftarrow BR + 1$$

$$AR \leftarrow AR - CR$$

حل:

(الف)

$$AR = 11110010$$

$$BR = \underline{11111111} +$$

$$AR \leftarrow 11110001, BR = 11111111, CR = 10111001$$

$$DR = 11101010$$

(ب)

$$CR = 10111001$$

$$DR = \underline{11101010} \text{ (AND)} \quad BR = 11111111$$

$$CR \leftarrow 10101000$$

$$, \quad \underline{\quad \quad \quad +1}$$

$$BR \leftarrow 00000000, AR = 11110001$$

$$, DR = 11101010$$

(ج)

$$AR = 11110001$$

$$CR = 10101000 -$$

$$AR \leftarrow \underline{01001001}$$

$$, BR = 00000000, CR = 10101000$$

$$, DR = 11101010$$

۲۰- یک ثبات هشت بیتی دارای عدد دودویی ۱۰۰۱۱۰۰ است. پس از یک

شیفت به راست حسابی مقدار ثبات چقدر است؟ با شروع از مقدار اولیه ۱۰۰۱۱۱۰۰، مقدار ثبات را پس از یک شیفت به چپ حسابی معین کنید، و بگویید

آیا سرریز وجود دارد؟

حل:

الف) شیفت به راست حسابی  $11001110$  ArithMetic Shift right

ب) شیفت به چپ حسابی  $00111000$  ArithMetic shift left

سرریز اتفاق افتاده است. زیرا عدد منفی به عدد مثبت تبدیل شده است (به دلیل تغییر بیت علامت)

۲۱- با شروع از مقدار اولیه  $R = 11011101$  دنباله مقدارهای دودویی را در R پس از یک شیفت به چپ منطقی و به دنبال آن یک شیفت به راست چرخشی، و سپس با یک شیفت به راست منطقی و در پایان یک شیفت به چپ چرخشی تعیین کنید.

حل: مقدار اولیه:  $11011101$

۱- شیفت به چپ منطقی  $10111010$

۲- شیفت به راست چرخشی  $01011101$

۳- شیفت به راست منطقی  $00101110$

۴- شیفت به چپ چرخشی  $01011100$

۲۲- مقدار H در شکل ۱۲-۴ چیست به شرطی که

$I_L = 0$ ,  $I_R = 1$ ,  $S = 1$ ,  $A = 1001$  باشد.

حل: طبق مدار شیفت،

$$\begin{array}{cccc} S=1 \Rightarrow & H_0 & H_1 & H_2 & H_3 \\ & A_1 & A_2 & A_3 & I_L \end{array}$$

بنابراین شیفت به چپ به شکل مقابل خواهد بود.

$$H = 10010 \Rightarrow 0010$$

شیفت به چپ

۲۳- چه چیزی در عبارات انتقال ثبات زیر نادرست است؟

الف)  $xT : AR \leftarrow \overline{AR}, AR \leftarrow 0$

ب)  $yT : R_1 \leftarrow R_2, R_1 \leftarrow R_3$

ج)  $zT : PC \leftarrow AR, PC \leftarrow PC + 1$

حل: توجه شود که علامت « و » به معنی اجرای همزمان است. پس در رابطه با عبارت (الف)، نمی‌توان یک رجیستر را همزمان مکمل و یا صفر کرد. در رابطه با عبارت (ب)، نمی‌توان دو مقدار را در یک رجیستر به صورت همزمان انتقال داد.

در رابطه با عبارت (ج)، نمی‌توان همزمان رجیستر PC را افزایش داد و مقدار AR را در آن قرار داد.

## فصل پنجم: سازمان و طراحی یک کامپیوتر پایه

۱- یک کامپیوتر از حافظه‌ای با  $256K$  کلمه ۳۲ بیتی استفاده می‌کند. یک دستورالعمل دودویی در یک کلمه از حافظه ذخیره شده است. دستورالعمل چهار بخش دارد. بیت غیرمستقیم، یک کد عملیاتی، یک کد ثبات برای تعیین یکی از ۶۴ ثبات و بخش آدرس.

الف) چند بیت در کد عملیاتی، کد ثبات و آدرس وجود دارد:

$$256K = 2^8 \times 2^{10} = 2^{18}$$

$$64 = 2^6$$

indirect : ۱ بیت غیرمستقیم

$$32 - (18 + 6 + 1) = 7$$

ب) قالب کلمه دستورالعمل را ترسیم و تعداد بیت در هر قسمت را معین کنید.

|   |        |          |         |      |
|---|--------|----------|---------|------|
| ۱ | ۷      | ۶        | ۱۸      | = ۳۲ |
| I | opcode | Register | Address |      |

پ) ورودی‌های داده و آدرس حافظه چند بیت وجود دارد؟

۳۲ بیت برای ورودی داده و ۱۸ بیت برای ورودی آدرس حافظه.

۲- تفاوت بین دستور با آدرس مستقیم و غیرمستقیم چیست؟ چند دسترسی به حافظه برای هر نوع دستورالعمل لازم است تا عملوند را به ثبات پردازشگر منتقل کند؟

حل:

آدرس دهی غیرمستقیم در صورت بیشتر بودن تعداد بیت داده از تعداد بیت آدرس حافظه در دستورالعمل می‌تواند امکان آدرس دهی فضای بزرگ‌تری از حافظه را به ما بدهد. (مثلاً ۱۶ بیت آدرس به جای ۱۲ بیت). همچنین نیاز به دستور برای بدست آوردن عملوند را از بین می‌برد و در یک دستور این کار را انجام می‌دهد. (این کار به

خصوص هنگام استفاده از اشاره‌گرها در زبان برنامه‌نویسی مفید است.)

- دستور با آدرس مستقیم دو دسترسی به حافظه نیاز دارد: خواندن دستورالعمل و خواندن عملوند

- دستور با آدرس غیرمستقیم سه دسترسی به حافظه نیاز دارد: خواندن دستورالعمل، خواندن آدرس مؤثر و خواندن عملوند.

**۳- ورودی‌های کنترل زیر در سیستم گذرگاه شکل ۴-۵** فعالند. برای هر مورد، انتقال ثباتی را کد در پالس ساعت بعدی اجرا می‌شود تعیین کنید.

حل:

|       | S <sub>2</sub> | S <sub>1</sub> | S <sub>0</sub> | ثبات | LD | حافظه  | جمع کننده |
|-------|----------------|----------------|----------------|------|----|--------|-----------|
| (الف) | ۱              | ۱              | ۱              |      | IR | خواندن | —         |
| (ب)   | ۱              | ۱              | ۰              |      | PC | —      | —         |
| (ج)   | ۱              | ۰              | ۰              |      | DR | نوشتن  | —         |
| (د)   | ۰              | ۰              | ۰              |      | AC | —      | جمع       |

الف) خواندن مقدار حافظه بر روی گذرگاه و بار شدن آن در IR

$$IR \leftarrow M[AR]$$

$$PC \leftarrow TR$$

ب) انتقال مقدار TR به PC به واسطه گذرگاه

ج) قرار گرفتن مقدار AC روی گذرگاه، نوشتن مقدار در حافظه و بار شدن آن در

$$DR \leftarrow AC, M[AR] \leftarrow AC : D$$

$$d) \text{ جمع کردن مقدار DR با AC: } AC \leftarrow AC + DR$$

**۴- انتقال ثبات‌های زیر قرار است در سیستم شکل ۴-۵** اجرا شوند. برای هر

انتقال: (۱) مقدار دودویی که باید به ورودی‌های انتخاب گذرگاه S<sub>2</sub>, S<sub>1</sub>, S<sub>0</sub> اعمال شود را تعیین کنید؛ (۲) ثباتی که کنترل LD آن باید فعال شود (اگر وجود دارد)؛ (۳) عمل نوشتن یا خواندن حافظه (اگر نیاز است)؛ و (۴) عمل در

جمع کننده و مدار منطقی (اگر وجود دارد).

IR N[AR] (ب)

AR ← PC (الف)

AC ← DR , DR ← AC (د)

M[AR] ← TR (ج)

حل:

|                        | (1)<br>S <sub>2</sub> S <sub>1</sub> S <sub>0</sub> | (2)<br>Load(LD) | (3)<br>Memory | (4)<br>Adder         |
|------------------------|-----------------------------------------------------|-----------------|---------------|----------------------|
| (a) AR ← PC            | 010 (PC)                                            | AR              | —             | —                    |
| (b) IR ← M[AR]         | 111 (M)                                             | IR              | Read          | —                    |
| (c) M[AR] ← TR         | 110 (TR)                                            | —               | Write         | —                    |
| (d) DR ← AC<br>AC ← DR | 100 (AC)                                            | DR and<br>AC    | —             | Transfer<br>DR to AC |

توضیح قسمت (د): توجه کنید که این دو عمل هم زمان می‌توانند انجام پذیرند چون یکی از گذرگاه استفاده کرده و دیگری نیاز به گذرگاه ندارد. همچنین با توجه به حساس بر لبه بودن ثبات‌ها و در نظر گرفتن زمان انتشار مقدارهای نامعتبر (در اثر تغییر مقدار هم زمان) در ثبات‌ها ثبت نمی‌شود.

۵ - توضیح دهید که چرا هیچ‌یک از ریز عمل‌های زیر نمی‌تواند در طول یک پالس ساعت در سیستم شکل ۴-۵ اجرا شود. رشته ریز عمل‌های لازم برای انجام عمل را تعیین کنید.

الف) PC : IR ← M[PC] مستقیماً نمی‌تواند آدرس را برای حافظه فراهم کند، آدرس باید به AR منتقل شود:

AR ← PC

IR ← M[AR]

ب) AC ← AC + TR عمل جمع باید با DR انجام شود. TR باید به DR منتقل شود.

DR ← TR

AC ← AC + DR

ج) (AC تغییر نمی‌کند)  $DR \leftarrow DR + AC$   
 حاصل جمع به AC منتقل می‌شود (نه DR). همچنین برای نگه داشتن مقدار AC  
 باید آن را به صورت موقت در DR (یا TR) ذخیره کنیم: (با توجه به قسمت (د) سؤال  
 (۴)

$$AC \leftarrow DR, DR \leftarrow AC$$

$$AC \leftarrow AC + DR$$

$$AC \leftarrow DR, DR \leftarrow AC$$

۶ - قالب های دستور کامپیوتر پایه شکل ۵ - ۵ و لیست دستورهای جدول ۵-۲  
 را در نظر بگیرید. برای هر یک از دستورهای ۱۶ بیتی، کد معادل جهار رقمی مبنای  
 شانزده را نوشه و به زبان ساده بگویید این دستور چه کاری انجام می‌دهد.

(الف)

$$\begin{array}{r} 0001 & 0000 & 0010 & 0100 \\ \text{ADD} & & (024)_{16} & \\ \hline & & (024)_{16} & = (1024)_{16} \end{array}$$

(ADD 024) AC با M[024] جمع مقدار خانه

(ب)

$$\begin{array}{r} 1 & 011 & 0001 & 0010 & 0100 \\ I & ST & & (124)_{16} & \\ \hline & & & & = (B124)_{16} \end{array}$$

(STAI 124) M[M[124]] ذخیره

(ج)

$$\begin{array}{r} 0111 & 0000 & 0010 & 0000 \\ \text{Register} & (\text{INC}) & AC & \text{افرایش} \\ \hline & & & \end{array} = (7020)_{16}$$

۷ - کدام دو دستور برای ۱ کردن فلیپ فلاپ E در کامپیوتر پایه به کار  
 می‌روند؟

حل:

برای ۱ کردن فلیپ فلاپ E ابتدا باید آن را پاک کنیم و سپس آن را متمم کنیم:

|     |             |
|-----|-------------|
| CLE | E پاک کردن  |
| CME | E متمم کردن |

۸- یک نمودار زمانبندی مشابه شکل ۵-۷ رسم کنید و فرض کنید SC در  $T_3$  باشد. برابر ۰ شود به شرط اینکه سیگنال کنترل  $C_7$  فعال باشد.

$$C_7 T_3 : \quad SC \leftarrow 0$$

$C_7$  با لبه پالس مربوط به  $T_1$  فعال می‌شود.

حل:



۹- محتوای AC در کامپیوتر پایه عدد مبنای شانزده A937 است و مقدار اولیه E برابر ۱ است. محتوای AC، E، PC، AR و IR در مبنای ۱۶ پس از اجرای دستور CLA چیست؟ عمل قبل را ۱۱ بار با هر یک از دستورات عمل‌های دسترسی به ثبات

تکرار کنید. مقدار اولیه PC را عدد مبنای شانزده ۰۲۱ فرض کنید.

حل:

| مقدار اولیه | E    | AC   | PC  | AR  | IR   |
|-------------|------|------|-----|-----|------|
| 1           | A937 | 021  | —   | —   |      |
| CLA         | 1    | 0000 | 022 | 800 | 7800 |
| CLE         | 0    | A937 | 022 | 400 | 7400 |
| CMA         | 1    | 56C8 | 022 | 200 | 7200 |
| CME         | 0    | A937 | 022 | 100 | 7100 |
| CIR         | 1    | D49B | 022 | 080 | 7080 |
| CIL         | 1    | 526F | 022 | 040 | 7040 |
| INC         | 1    | A938 | 022 | 020 | 7020 |
| SPA         | 1    | A937 | 022 | 010 | 7010 |
| SNA         | 1    | A937 | 023 | 008 | 7008 |
| SZA         | 1    | A937 | 022 | 004 | 7004 |
| SZE         | 1    | A937 | 022 | 002 | 7002 |
| HLT         | 1    | A937 | 022 | 001 | 7001 |

دقت کنید که در دستور SNA چون AC منفی است و شرط برقار است یک واحد به مقدار PC اضافه شده است. (دستور بعد اجرا نمی شود).

۱۰- دستورالعملی در آدرس ۰۲۱ کامپیوتر پایه دارای  $I=0$  ، کد عملیاتی AND و آدرس ۰۸۳ است (تمام ارقام در مبنای ۱۶ است). کلمه حافظه واقع در آدرس ۰۸۳ دارای عملوند B8F2 و محتوای AC هم A937 است. در طول سیکل دستور محتوای ثبات‌های زیر را در پایان فاز اجرا تعیین کنید: AC , DR, AR, PC و IR. مسئله را شش بار برای دستورالعمل دسترسی به حافظه دیگری تکرار کنید.

حل:

| مقدار اولیه | PC  | AR  | DR   | AC   | IR   |
|-------------|-----|-----|------|------|------|
| 021         | —   | —   | A937 | —    |      |
| AND         | 022 | 083 | B8F2 | A832 | 0083 |
| ADD         | 022 | 083 | B8F2 | 6229 | 1083 |
| LDA         | 022 | 083 | B8F2 | B8F2 | 2083 |
| STA         | 022 | 083 | —    | A937 | 3083 |
| BUN         | 083 | 083 | —    | A937 | 4083 |
| BSA         | 084 | 084 | —    | A937 | 5083 |
| ISZ         | 022 | 083 | B8F3 | A937 | 6083 |

۱۱- محتوای ثبات‌های SC و IR , DR , AR, PC در مبنای شانزده کامپیوتر پایه

وقتی که دستور غیرمستقیم ISZ دریافت و اجرا شود چیست؟ مقدار اولیه PC را 7FF در نظر بگیرید. محتويات حافظه در آدرس 7FF برابر EA9F میباشد. محتويات حافظه در آدرس A9F هم 0C35 میباشد. محتويات حافظه C35 برابر FFFF میباشد. پاسخ را به صورت جدولی با ۵ ستون با هر ستون برای یک ثبات، و هر سطر برای یک سیگنال زمانبندی تهیه کنید. محتوای هر ثبات را پس از لبه مثبت هر پالس ساعت نشان دهید.

حل:

| مقدار اولیه    | PC  | AR  | DR   | IR   | SC |
|----------------|-----|-----|------|------|----|
| T <sub>0</sub> | 7FF | —   | —    | —    | 0  |
| T <sub>1</sub> | 7FF | 7FF | —    | EA9F | 1  |
| T <sub>2</sub> | 800 | 7FF | —    | EA9F | 2  |
| T <sub>3</sub> | 800 | A9F | —    | EA9F | 3  |
| T <sub>4</sub> | 800 | C35 | —    | EA9F | 4  |
| T <sub>5</sub> | 800 | C35 | FFFF | EA9F | 5  |
| T <sub>6</sub> | 801 | C35 | 0000 | EA9F | 6  |
|                |     |     | 0000 | EA9F | 0  |

۱۲- محتوای PC در کامپیوتر پایه 3AF است (تمام اعداد در بنای شانزده). محتويات AC هم 7EC3 است. محتوای حافظه آدرس 3AF برابر 932E میباشد. محتوای حافظه در آدرس 32E برابر 09AC و در آدرس 9AC هم 8B9F است.

الف) دستورالعملی که در گام بعد دریافت و اجرا میشود چیست؟

حل: I او ریز عمل از روی بیت ها مشخص میشود.

$$9 = (1001)$$

$\Rightarrow \text{ADD I } 32E$

I=1 ADD

| حافظه |      |
|-------|------|
| 3AF   | 932E |
| 32E   | 09AC |
| 9AC   | 8B9F |

ب) عمل دودویی که در AC پس از اجرای دستورالعمل رخ می‌دهد چیست؟

$$AC = 7EC3 \text{ (جمع)}$$

$$DR = 8B9F \\ 0A62 \quad (E=1)$$

ج) محتوای ثبات‌های IR , AC , DR , AR, PC در مبنای شانزده چیست؟

همچنین مقدار E و I و SC در پایان سیکل دستورالعمل را تعیین کنید.

$$PC=3AF+1=3B0$$

$$AR = 9AC \quad IR = 932E$$

$$DR = 8B9F \quad E = 1$$

$$AC = 0A62 \quad I = 1$$

$$SC = 0000$$

۱۳- فرض کنید که شش دستور دسترسی به حافظه در کامپیوتر پایه در جدول

۴- با جدول زیر تعویض شوند. EA آدرس مؤثر واقع در AR در  $T_4$  است. فرض

کنید که جمع‌کننده و مدار منطقی شکل ۵-۴ می‌تواند عمل XOR را انجام دهد.

۵- بعلاوه فرض کنید که جمع‌کننده و مدار منطقی نمی‌توانند

$AC \leftarrow AC \oplus DR$  مستقیماً تفرق را انجام دهند. تفریق باید به کمک مکمل ۲ انجام شود. دنباله

عبارت انتقال ثباتی لازم برای اجرای هر دستور لیست شده را از  $T_4$  به بعد

مشخص کنید. دقت کنید که هیچ تغییری در AC نباید رخ دهد مگر اینکه

دستورالعمل تغییری را در آن معین کند. شما می‌توانید با استفاده از TR محتویات

AC را موقتً ذخیره و یا محتویات AC و DR را با هم جابجا کنید.

| توضیح | AC انحصاری با                   | نمایش سمبولیک | کد عمل سمبول |
|-------|---------------------------------|---------------|--------------|
| OR    | $AC \leftarrow AC \oplus M[EA]$ |               | XOR    ...   |

|            |     |                                             |                                    |
|------------|-----|---------------------------------------------|------------------------------------|
| <b>ADM</b> | ۰۰۱ | $M[EA] \leftarrow M[EA] + AC$               | جمع AC با حافظه                    |
| <b>SUB</b> | ۰۱۰ | $AC \leftarrow AC - M[EA]$                  | تفریق حافظه از AC                  |
| <b>XCH</b> | ۰۱۱ | $AC \leftarrow M[EA], M[EA] \leftarrow AC$  | تبادل AC با حافظه                  |
| <b>SEQ</b> | ۱۰۰ | If( $M[EA]=AC$ ) then $PC \leftarrow PC+1$  | گذر در صورت برابری                 |
| <b>BPA</b> | ۱۰۱ | if ( $AC > 0$ ) then ( $PC \leftarrow EA$ ) | انشعاب اگر AC مثبت و غیر صفر باشد. |

حل:

|            |                                                                                                        |  |
|------------|--------------------------------------------------------------------------------------------------------|--|
| <b>XOR</b> | $D_0T_4 : DR \leftarrow M[AR]$                                                                         |  |
|            | $D_0T_5 : AC \leftarrow AC \oplus DR, SC \leftarrow 0$                                                 |  |
| <b>ADM</b> | $D_1T_4 : DR \leftarrow M[AR]$                                                                         |  |
|            | $D_1T_5 : DR \leftarrow AC, AC \leftarrow AC + DR$                                                     |  |
|            | $D_1T_6 : M[AR] \leftarrow AC, AC \leftarrow DR, SC \leftarrow 0$                                      |  |
| <b>SUB</b> | $D_2T_4 : DR \leftarrow M[AR]$                                                                         |  |
|            | $D_2T_5 : DR \leftarrow AC, AC \leftarrow DR$                                                          |  |
|            | $D_2T_6 : AC \leftarrow \overline{AC}$                                                                 |  |
|            | $D_2T_7 : AC \leftarrow AC + 1$                                                                        |  |
|            | $D_2T_8 : AC \leftarrow AC + DR, SC \leftarrow 0$                                                      |  |
| <b>XCH</b> | $D_3T_4 : DR \leftarrow M[AR]$                                                                         |  |
|            | $D_3T_5 : M[AR] \leftarrow AC, AC \leftarrow DR, SC \leftarrow 0$                                      |  |
| <b>SEQ</b> | $D_4T_4 : DR \leftarrow M[AR]$                                                                         |  |
|            | $D_4T_5 : TR \leftarrow AC, AC \leftarrow AC \oplus DR$                                                |  |
|            | $D_4T_6 : \text{If } (AC = 0) \text{ then } (PC \leftarrow PC + 1), AC \leftarrow TR, SC \leftarrow 0$ |  |
| <b>BPA</b> | $D_5T_4 : \text{If } (AC = 0 \wedge AC(15) = 0)$                                                       |  |
|            | $\text{then } (PC \leftarrow AR), SC \leftarrow 0$                                                     |  |

## ۱۴- تغییرهای زیر را در کامپیوتر پایه انجام دهید.

- ۱- یک ثبات CTR (ثبت شمارنده) را به سیستم گذره‌گاه اضافه کنید و آن را با انتخاب  $S_2 S_1 S_0 = 000$  انتخاب نمایید.



۲- ISZ را با دستوری که یک عدد را در CTR بار می کند جایگزین کنید.

LDC Address :  $CTR \leftarrow M[Address]$

$D_6 T_4 : CTR \leftarrow M[AR], SC \leftarrow 0$

۳- یک دستور دسترسی به ثبات ICSZ اضافه کنید: CTR را یک واحد افزایش داده و از اجرای دستور بعدی اگر حاصل افزایش صفر باشد صرفنظر نماید. در مورد فایده این تغییر بحث کنید.

ICSZ  $D_7 I'T_3 B_{12} : CTR \leftarrow CTR + 1$

$D_7 I'T_4 B_{12} : \text{if } (CTR = 0) \text{then } (PC \leftarrow PC + 1) SC \leftarrow 0$

این کار دستور ISZ را که دسترسی به حافظه است به دستور ICSZ که دسترسی به ثبات است تبدیل می کند. دستور جدید ICSZ می تواند در زمان  $T_4$  به جای  $T_6$  اجرا شود که باعث هدر نرفتن ۲ سیکل می شود و روش دیگر پیاده سازی دستور ICSZ به این صورت است:

ICSZ:  $D_7 I'T_3 B_{12} : CTR \leftarrow CTR + 1, \text{if } (CTR = FFFF) \text{then } PC \leftarrow PC + 1, SC \leftarrow 0$

مزیت این پیاده سازی این است که در زمان  $T_3$  اجرا می شود و از هدر رفتن ۳ سیکل ساعت جلوگیری می کند. همچنین همانند دستورهای دسترسی به ثبات دیگر، در  $T_3$  اجرای آن تمام می شود.

توجه داشته باشید که برای اضافه کردن دستور ICSZ باید یکی از دستورات دسترسی به ثبات را حذف کنیم یا ۱ بیت به کد دستور العمل اضافه کنیم یا نحوه نمایش

دستورالعمل های دسترسی به ثبات را تغییر دهیم که نیاز به دیکد کردن خواهد داشت.

۱۵- واحد حافظه کامپیوتر پایه در شکل ۱۳-۵ را با یک حافظه  $65536 \times 16$  جایگزین کنید. این حافظه آدرس ۱۶ بیتی نیاز دارد. قالب دستورالعمل دسترسی به حافظه در شکل (۱۳-۵ الف) برای  $I=1$  ثابت می ماند و بخش آدرس در مکان های ۰ تا ۱۱ قرار دارد. اما وقتی  $I=0$  است (آدرس مستقیم) آدرس دستورالعمل با ۱۶ بیت در کلمه دیگری که به دنبال دستور آمده داده می شود. ریز عمل های زمان های  $T_2$ ,  $T_3$ ,  $T_4$  (و  $T_3$  اگر نیاز باشد) تغییر دهید تا با این پیکربندی هماهنگ باشد.

حل:



این طراحی از هدر رفتن  $T_3$  در حالت آدرس دهی مستقیم جلوگیری کرده و از آن برای آدرس دهی ۱۶ بیتی استفاده کرده که حافظه بزرگتری را پشتیبانی می کند.

۱۶- کامپیوتری از بک حافظه ۸ بیتی  $65536$  کلمه‌ای استفاده می‌کند. این کامپیوتر دارای ثبات‌های  $PC$ ,  $AR$ ,  $TR$ ,  $AC$  و  $DR$  (هر یک ۱۶ بیت) و  $IR$  (هر یک ۸ بیت) است. یک دستور دسترسی به حافظه شامل سه کلمه است: یک کد عملیات ۸ بیتی (یک کلمه) و یک آدرس ۱۶ بیتی (در دو کلمه بعدی). تمام عملوندها هشت بیتی هستند. بیت غیرمستقیم هم وجود ندارد.

(الف) بلاک دیاگرامی از کامپیوتر رسم کنید و ثبات‌ها و حافظه را همانند شکل ۳-۵ نشان دهید. (از یک گذرگاه مشترک استفاده نکنید).



(ب) جایگیری یک نمونه دستور سه کلمه‌ای را به همراه عملوند ۸ بیتی در حافظه نشان دهید.



پ) دنبایه ریز عمل ها برای دریافت یک دستور دسترسی به حافظه را لیست کنید و سپس عملوند را در DR قرار دهید. از سیگنال زمانی  $T_0$  شروع کنید.

$T_0: \quad IR \leftarrow M(PC), PC \leftarrow PC + 1$

$T_1: \quad AR(0-7) \leftarrow M[PC], PC \leftarrow PC + 1$

$T_2: \quad AR(8-15) \leftarrow M[PC], PC \leftarrow PC + 1$

$T_3: \quad DR \leftarrow M[AR]$

۱۷- یک کامپیوتر دیجیتال دارای ۱۹۳۸۹ حافظه ۴۰ بیتی در هر کلمه است قالب کد دستور از شش بیت برای عملگر و ۱۴ بیت برای آدرس تشکیل شده است. (بیت غیرمستقیم ندارد) دو دستورالعمل در یک کلمه جای داده شده‌اند و یک ثبات دستورالعمل ۴۰ بیتی IR هم در واحد کنترل وجود دارد. برنامه‌ای را برای فازهای برداشت و اجرا در این کامپیوتر بنویسید.



برنامه برداشت و اجرا به این صورت است:

- ۱- دستور دوگانه ۴۰ بیتی را از حافظه خوانده و در IR قرار بده، همچنین مقدار PC را یک واحد افزاش بده.
- ۲- کد دستور ۱ را دیکد کن.
- ۳- دستور ۱ را با استفاده از آدرس ۱ اجرا کن.
- ۴- کد دستور ۲ را دیکد کن.
- ۵- دستور ۲ را با استفاده از آدرس ۲ اجرا کن.
- ۶- به گام اول باز گرد.

۱۸- یک برنامه خروجی از آدرس ۲۳۰۰ نوشته شده است. این برنامه وقتی کامپیوتر یک وقفه را در  $FGO=1$  تشخیص دهد اجرا می‌شود. (در حالی که  $IEN=1$  است).

الف) چه دستوری باید در آدرس ۱ قرار گیرد؟

انشعاب بدون شرط به خانه ۲۳۰۰

BUN 2300

ب) دو دستور آخر برنامه خروجی چیست؟ فعال کردن وقفه‌ها

انشعاب بدون شرط با آدرس غیرمستقیم ۰

**ION 0**

BUN I  $\phi$

۱۹- عبارت انتقال ثباتی برای ثبات R و حافظه در یک کامپیوتر مطابق زیر

است (Xها توابع کترل هستند و به طور تصادفی رخ می‌دهند).

$X'_3 X_1 : R \leftarrow M[AR]$  بنویس [R کلمه حافظه را در

$X'_1 X_2 : R \leftarrow AC$  انتقال AC بر R

$X'_1 X_3 : M[AR] \leftarrow R$  R را در حافظه بنویس

حافظه دارای ورودی‌های داده، خروجی‌های داده، ورودی‌های آدرس و ورودی‌های کترل برای خواندن و نوشتن همانند شکل ۲-۱۲ است. پیاده سازی سختافزاری R و حافظه را به شکل بلاک دیاگرام بکشید. نشان دهید که چگونه توابع کترل  $X_1$  تا  $X_3$  ورودی R، ورودی مولتی پلکسرهایی که شما در دیاگرام وارد کردید، و ورودی‌های خواندن و نوشتن حافظه را انتخاب می‌کنند.

حل:



۲۰- دنباله عمل هایی که باید روی فلیپ فلاپ F انجام شوند (در کامپیوتر پایه به کار نرفته) با عبارت انتقال ثباتی تعیین شده‌اند.

$XT_3 : F \leftarrow 1$  ۱ در F نشانده شود.

$yT_1 : F \leftarrow 0$  با ۰ پاک شود.

$ZT_2 : F \leftarrow F$  مکمل

$WT_5 : F \leftarrow G$  مقدار G را به F انتقال بده

در غیر این صورت محتوای F نباید تغییر یابد. دیاگرام منطقی مربوط به اتصال گیت‌هایی که توابع کنترل و ورودی‌های فلیپ فلاپ F را تشکیل می‌دهند رسم کنید. از یک فلیپ فلاپ JK استفاده کرده و تعداد گیت‌ها را حداقل کنید.

حل:

با توجه به جدول تحریک JK، J باید در حالت‌های set یا مکمل یا انتقال از G فعال

باشد پس داریم:

$$J_F = XT_3 + ZT_2 + WT_5G$$

به همین ترتیب برای  $K_F$  داریم:

$$K_F = YT_1 + ZT_2 + WT_5G'$$



۲۱- مدار کنترل گیتی شمارنده برنامه PC را در کامپیوتر پایه بدست آورید.

از جدول ۶ - ۵ داریم:

$$(Z_{AC} = 1 \text{ if } AC = 0, \quad Z_{DR} = 1 \text{ if } DR = 0)$$

$$INC(PC) = RT_1 + RT_2 + D_6T_6Z_{DR} + PB_9(FGI)$$

$$+ PB_8(FGO) + rB_4 + (AC_{15})' + rB_3(AC_{15})$$

$$+ rB_2Z_{AC} + rB_1E'$$

$$LD(PC) = D_4T_4 + D_5T_5$$

$$CLR(PC) = RT_1$$



۲۲- مدار کنترل گینی ورودی نوشتن در حافظه را در کامپیووتر پایه بدهست آورید.

حل:

از جدول ۶ - ۵ داریم:

$$(M[AR] \leftarrow XX)$$

$$\text{Write} = D_3 T_4 + D_5 T_4 + D_6 T_6 + R T_1$$



۲۳- مدار منطقی کامل وقفه را در کامپیوتر پایه نشان دهید. از فلیپ فلاپ JK استفاده کنید و گیت‌ها را به حداقل برسانید.

حل:

از جدول ۶ - ۵ داریم:

$$(T_0 + T_1 + T_2)'(IEN)(FGI + FGO) : R \leftarrow 1$$

$$RT_2 ; R \leftarrow 0$$



۲۴- عبارت بولی را برای  $x_2$  (جدول ۷ - ۵ را بینید) بدست آورید. نشان دهید که  $x_2$  می‌تواند با یک گیت AND و یک گیت OR تولید شود.

حل:

$x_2$  خروجی PC را روی گذرگاه قرار می‌دهد.

از جدول ۵-۶ داریم:

$$R'T_0 : AR \leftarrow PC$$

$$RT_0 : TR \leftarrow PC$$

$$D_5T_4 : M[AR] \leftarrow PC$$

$$x_2 = R'T_0 + RT_0 + D_5T_4 = (R' + R)T_0 + D_5T_4$$

$$R + R' = 1$$



۲۵- عبارت بولی برای یک مدار گیتی که شمارنده SC را پاک کند بدست آورید. دیاگرام منطقی آن را رسم نموده و نشان دهید که چگونه خروجی به ورودی‌های INC و CLR از شمارنده SC وصل می‌شود. (شکل ۵-۶). تعداد گیت‌ها را حداقل نمایید.

حل:

از جدول ۵-۶ داریم:

$$CLR(SC) = RT_2 + D_7T_3(I' + I) + (D_0 + D_1 + D_2 + D_5)T_5 + (D_3 + D_4)T_4 + D_6T_6$$



## فصل ششم: برنامه‌نویسی کامپیوتر پایه

۱- برنامه زیر در واحد حافظه کامپیوتر پایه ذخیره شده است. محتوای AC ، IR ، PC را به شانزده شانزدهی در پایان اجرای هر دستورالعمل نشان دهید. تمام اعداد در جدول به شانزده شانزدهی هستند.

| مکان | دستورالعمل |
|------|------------|
| ۰۱۰  | CLA        |
| ۰۱۱  | ADD 016    |
| ۰۱۲  | BUN 014    |
| ۰۱۳  | HLT        |
| ۰۱۴  | AND 017    |
| ۰۱۵  | BUN 013    |
| ۰۱۶  | CIA5       |
| ۰۱۷  | 93C6       |

حل:

ابتدا ترتیب اجرای دستورالعمل‌ها را مطابق رویرو خواهیم داشت:

- 1- CLA
- 2- ADD 016
- 3- AND 017
- 4- HLT

حال رجیسترهاي AC و PC و IR در این ترتیب اجرا به صورت زیر خواهد بود.

| AC   | PC  | IR   | اجرای دستورالعمل |
|------|-----|------|------------------|
| 0000 | 011 | 7800 | CLA              |
| C1A5 | 012 | 1016 | ADD 016          |
| C1A5 | 014 | 4014 | BUN 014          |
| 8184 | 014 | 7001 | HLT              |
| 8184 | 015 | 0017 | AND 017          |

|      |     |      |         |
|------|-----|------|---------|
| 8184 | 013 | 4013 | BUN 013 |
|------|-----|------|---------|

کد شانزده شانزدهی دستورالعمل های کامپیوتر در جدول ۱-۶ کتاب موجود است.

۲- برنامه زیر لیستی از دستورالعمل ها در مبنای شانزده است. کامپیوتر با شروع از آدرس ۱۰۰ دستورالعمل ها را اجرا می کند. محتوای AC و کلمه حافظه درون آدرس ۱۰۳ هنگامی که کامپیوتر متوقف می شود چیست؟

حل: با استفاده از جدول «۱-۶» دستورالعمل ها را بدست می آوریم.

| مکان | دستورالعمل "Hex" | دستورالعمل |
|------|------------------|------------|
| 100  | 5103             | BSA 103    |
| 101  | 7200             | CMA        |
| 102  | 7001             | HLT        |
| 103  | 0000             | <u>101</u> |
| 104  | 7800             | CLA        |
| 105  | 7020             | INC        |
| 106  | C103             | BUN 103 I  |

در ارتباط با اجرای دستورالعمل ها، دستورالعمل ۱۰۳ BSA ، مکان ۱۰۱ در آدرس ۱۰۳ به عنوان آدرس برگشت ذخیره شده و PC از آدرس ۱۰۴ اجرای برنامه را ادامه می دهد. پس ترتیب اجرای دستورالعمل ها به صورت زیر خواهد بود:





همچنین مقدار AC در اجرای دستورالعمل‌ها نشان داده شده است.

- ۳- برنامه زبان اسembلی تولید شده با یک کامپایلر را از برنامه فرترن زیر بنویسید؛ متغیرها را عدد صحیح فرض کنید.

- 1)  $SUM = 0$
- 2)  $SUM = SUM + A + B$
- 3)  $DIF = DIF - C$
- 4)  $SUM = SUM + DIF$

حل: تک تک خطوط را به برنامه اسembلی مورد نظر تبدیل می‌کنیم.

- |                        |                                                                                                            |
|------------------------|------------------------------------------------------------------------------------------------------------|
| 1) $SUM = 0$           | $\left  \begin{array}{l} CLA \\ STA \quad SUM \end{array} \right.$                                         |
| 2) $SUM = SUM + A + B$ | $\left  \begin{array}{l} LDA \quad SUM \\ ADD \quad A \\ ADD \quad B \\ STA \quad SUM \end{array} \right.$ |
| 3) $DIF = DIF - C$     | $\left  \begin{array}{l} LDA \quad C \\ CMA \\ INC \\ ADD \quad DIF \\ STA \quad DIF \end{array} \right.$  |
| 4) $SUM = SUM + DIF$   | $\left  \begin{array}{l} LDA \quad SUM \\ ADD \quad DIF \\ STA \quad SUM \end{array} \right.$              |

- ۴- آیا حرف I می‌تواند به عنوان یک آدرس سمبولیک در برنامه زبان اسembلی

تعريف شده برای کامپیوتر پایه استفاده شود؟ پاسخ خود توضیح دهید.

حل: بله؛ استفاده از I به عنوان آدرس سمبولیک دو صورت می‌تواند داشته باشد.

۱) [دستورالعمل] I

۲) I [دستورالعمل]

برای نمونه در دستورالعمل بارگذاری LDA داریم:

۱) LDA I

۲) LDA I I

در عبارت ۱، I می‌تواند یک آدرس سمبولیک فرض شود. در عبارت ۲، I اول آدرس سمبولیک، و I دوم بیت غیرمستقیم (Indirect Reference) را نشان می‌دهد.

۵ - اگر سط्रی از کد برنامه دارای شبه دستورالعمل ORG یا END باشد، عنوان نیز داشته باشد، در مرور اول اسمبلر (شکل ۶-۱) چه رخداد خواهد داد. فلوچارت را تغییر دهید تا در صورت رخداد بالا پیغام خطأ در بر داشته باشد.

حل: عباراتی مانند ORG یا END در کد اسمبلی کامپیوتر پایه، نباید در مرورها به عنوان "Label" فرض شوند. برای اینکه، تمایز بین عبارات مثل ORG و END، و عنوانها "Label" برقرار باشد تا ORG و END تشخیص داده شوند، تغییرات زیر را برای کشف خطأ در مرور اول انجام می‌دهیم.



#### ۶ - سطري از کد يك برنامه زبان اسمبلي به شكل زير است:

**DEC -35**

- الف) نشان دهيد که برای ذخیره سطر کد به چهار کلمه حافظه نياز است و محتواي دودوئي آنها را نيز بنويسيد.
- ب) نشان دهيد که يك کلمه حافظه، مى تواند ترجمه شده دودوئي کد را ذخیره کند. همچنين محتواي دودوئي آن را ارایه دهيد.

**حل:**

- الف) هر کلمه ۱۶ بيت و دو بایت ظرفیت دارد. از طرفی حروف سطر، در حافظه دستورالعمل به صورت که ۸ بیتی نگهداری مى شود. پس:

| Memory Word<br>High      Low |         | کد مبنای ۱۶ |    | کد دودوئي           |
|------------------------------|---------|-------------|----|---------------------|
| D                            | E       | ۴۴          | ۴۵ | ۰۱۰۰ ۰۱۰۰ ۰۱۰۰ ۰۱۰۱ |
| C                            | “space” | ۴۳          | ۲۰ | ۰۱۰۰ ۰۰۱۱ ۰۰۱۰ ۰۰۰۰ |

|   |                                 |    |    |                     |
|---|---------------------------------|----|----|---------------------|
| - | ۳                               | ۲D | ۳۳ | ۰۰۱۰ ۱۱۰۱ ۰۰۱۱ ۰۰۱۱ |
| ۵ | CR<br>پایان جمله در<br>خط جاری) | ۳۵ | ۰D | ۰۰۱۱ ۰۱۰۱ ۰۰۰۰ ۱۱۰۱ |

ب) بدیهی است، مثلاً کد دودویی عدد ۳۵ در مبنای ۲، با کد نوشته شده در بالا متفاوت است.

$$\begin{aligned}(35)_{10} &= (0000 \ 0000 \ 0010 \ 0011)_2 \\ \Rightarrow (-35) &= (\text{FFDD})_{16}\end{aligned}$$

۷- الف) جدول سمبول آدرس تولید شده برای برنامه جدول ۶-۱۳ در حین مرور اول اسمبلر را بدست آورید.

ب) برنامه ترجمه شده را به شانزده شانزدهی بنویسید.

حل: الف) برنامه جدول (۶-۱۳)، برنامه سمبولیک برای جمع ۱۰۰ عدد است. طبق

فلوچارت ارائه شده برای مرور اول اسمبلر داریم:

|     |     |                                    |
|-----|-----|------------------------------------|
| LOP | ۱۰۵ | $(-100)_{10} = (\text{FF9C})_{16}$ |
| ADS | ۱۰B | $(75)_{10} = (0048)_{16}$          |
| PTR | ۱۰C | $(23)_{10} = (0017)_{16}$          |
| NBR | ۱۰D |                                    |
| CTR | ۱۰E |                                    |
| SUM | ۱۰F |                                    |

در عبارات بالا، مکان ۱۰۵، یعنی ۱۵ امین دستورالعمل بعد از دستورالعمل ORG ۱۰۰، بقیه نیز به همین ترتیب.

(ب)

| Loc | Hex  |          |       | Loc | Hex  |              |
|-----|------|----------|-------|-----|------|--------------|
| 100 | 210B | LDA      | ADS   | 10B | 0150 | ADS, HEX 150 |
| 101 | 310C | STA      | PTR   | 10C | 0000 | PTR, HEX 0   |
| 102 | 210D | LDA      | NBR   | 10D | FF9C | NBR, DEC-100 |
| 103 | 310E | STA      | CTR   | 10E | 0000 | CTR, HEX 0   |
| 104 | 7800 | CLA      |       | 10F | 0000 | SJH, HEX 0   |
| 105 | 910C | LOP, ADD | PTR I |     |      | ORG 150      |
| 106 | 610C | ISZ      | PTR   | 150 | 004B | DEC 150      |
| 107 | 610E | ISZ      | CTR   | :   | :    | :            |
| 108 | 4105 | BUN      | LOP   | :   | :    | :            |
| 109 | 310F | STA      | SUM   | 1B3 | 0017 | DEC 23       |
| 10A | 7001 | HLT      |       |     |      | END          |

## ۸- شبیه دستورالعمل BSSN (بلاک آغاز شده به وسیله سمبول) گاهی برای رزرو

N کلمه حافظه برای گروهی از عملوندها به کار می‌رود. مثلاً سطر

A , BSS10

به اسمبلر اطلاع می‌دهد که بلاکی از ۱۰ (دهدهی) مکان را با شروع از مکان متناظر با سمبول A خالی بگذارد. این مشابه جمله Dimension A(10) در فرترن است.

فلوچارت شکل ۱-۶ را برای پردازش این شبیه دستور تغییر دهید.

حل: برای اینکه رزرو ۱۰ کلمه حافظه در الگوریتم مرور اول اسمبلر کامپیوتر پایه صورت پذیرد، می‌بایست فاصله مقادیر "Location Counter" قبل و بعد، ۱۰ عدد باشد.

بنابراین تغییرات زیر را در فلوچارت مرور اول انجام می‌دهیم:



۹- فلوچارت شکل ۶-۲ را تغییر دهید که اگر یک دستور سمبولیک با برچسب تعریف نشده باشد، یک پیام خطای در بر گیرد.

حل: فلوچارت ۶-۴، مربوط به مرور دوم اسembler کامپیوتر پایه است. طبق سؤال

تغییر زیر را در فلوچارت انجام می دهیم:



۱۰- نشان دهید که چگونه جدول های non - MRI و MRI می توانند در حافظه ذخیره شوند.

حل: شیوه تنظیم دستورات دسترسی به حافظه و سایر دستورات در جداول MRI و non MRI مانند زیر خواهد بود:

(الف) ذخیره جدول دستورات دسترسی به حافظه (MRI)

برای مثال برای دستور ADD که یک دستور دسترسی به حافظه است داریم:

ADD (مقدار)

| Memory word | symbol        |       | Hex                     |    |
|-------------|---------------|-------|-------------------------|----|
| ۱           | A             | D     | ۴۱                      | ۴۴ |
| ۲           | D             | space | ۴۴                      | ۲۰ |
|             | مقدار (Value) |       | مقدار به شانزده شانزدهی |    |

(ب) ذخیره جدول دستورات (non MRI)

برای مثال برای دستور CMA داریم:

CMA

| Memory word | symbol  |       | Hex                     |    |
|-------------|---------|-------|-------------------------|----|
| ۱           | C       | M     | ۴۳                      | ۵۳ |
| ۲           | A       | space | ۴۱                      | ۲۰ |
|             | (Value) |       | مقدار به شانزده شانزدهی |    |

۱۱- برنامه اsemblی (معادل دودویی دستورالعمل‌ها) تولید شده به وسیله کامپایلر را برای عبارت شرطی زیر بدست آورید:

IF(A-B)10,20,30

حل:

توضیح: برنامه شروط زیر را چک کرده و انشعاب پیدا می‌کند:



ابتدا عمل تفریق را انجام داده سپس با استفاده از دستورالعمل‌های مقایسه و گذار مانند SNA و SPA ، انشعاب‌های لازم را انجام می‌دهیم: دو نمونه از برنامه‌هایی که به عنوان راه حل به ذهن می‌رسند: برنامه ۱ سمت چپ، و ۲ سمت راست.

|                              |           |
|------------------------------|-----------|
| LDA B                        | LDA B     |
| CMA                          | CMA       |
| INC                          | INC       |
| ADD A / انجام عمل تفریق      | ADD A     |
| SPA / گزار در صورت مثبت بودن | SNA       |
| BUN NUM10 / (A-B) < 0        | BUN NUM30 |
| SZA                          | SZA       |
| BUN NUM30 / (A-B) > 0        | BUN NUM10 |
| BUN NUM20 / (A-B) = 0        | BUN NUM20 |

توجه کنید، برنامه‌های فوق اشکال اساسی در برقراری شرط‌های مورد نظر دارند. در هر دو برنامه فرض کنید  $(A-B)=0$  ، چون  $(A-B)$  عدد مثبت نیست، (در برنامه (۱)) برنامه به NUM10 پرسخ خواهد کرد. همچنین در برنامه (۲) چون  $(A-B)$  عدد منفی نیست، برنامه به لیبل NUM30 پرسخ خواهد کرد. در هر دو حالت  $(A-B)=0$  شناسایی نخواهد شد. راه حل که این مشکل را نداشته باشد مانند زیر است:

```

LDA B
CMA
INC
ADD A
SPA
BUN ZeroOR Equal / (A-B) <= 0
BUN NUM 30 / (A-B) > 0
ZeroOREqual , SZA
BUN NUM 10 / (A-B) < 0
BUN NUM 20 / (A-B) = 0

```

۱۲- الف) توضیح دهید که اجرای برنامه زیر چه کاری انجام می‌دهد. مقدار

مکان CTR وقتی که کامپیوتر متوقف می‌شود چیست؟

ب) جدول سمبول‌های آدرس بدست آمده در مرور اول اسمبلر را بنویسید.

ج) کد شانزده شانزدهی (Hex) برنامه ترجمه شده را بنویسید.

#### کد برنامه

```

ORG 100
CLE
CLA
STA CTR
LDA WRD
SZA
BUN ROT
BUN STP
ROT , CIL
SZE
BUN AGN
BUN ROT
AGN , CLE
ISZ CTR
SZA

```

```
BUN ROT
STP , HLT
CTR , Hex 0
WRD , Hex   62C1
END
```

حل:

الف) این برنامه، تعداد رقم‌های ۱ موجود در عدد ذخیره شده در مکان WRD (در اینجا 62C1 شانزده شانزدهی) را می‌شمارد. پس داریم:

$$62C1 = (0110\ 0010\ 1100\ 0001)_2$$

تعداد ۱ های موجود در

بنابراین CTR خواهد بود:  $(0006)_16$

(ب) و (ج)

|     |      | ORG      | 100  |                                     |
|-----|------|----------|------|-------------------------------------|
| 100 | 7400 | CLE      |      |                                     |
| 101 | 7800 | CLA      |      |                                     |
| 102 | 3110 | STA      | CTR  | /Initialize counter to zero         |
| 103 | 2111 | LDA      | WRD  |                                     |
| 104 | 7004 | SZA      |      |                                     |
| 105 | 4107 | BUN      | ROT  |                                     |
| 106 | 410F | BUN      | STP  | / Word is zero; stop with CTR<br>=0 |
| 107 | 7040 | ROT, CIL |      | /Bring bit to E                     |
| 108 | 7002 | SZE      |      |                                     |
| 109 | 410B | BUN      | AGN  | /bit = 1, go to count it            |
| 10A | 4107 | BUN      | ROT  | /bit = 0, repeat                    |
| 10B | 7400 | AGN, CLE |      |                                     |
| 10C | 6110 | ISZ      | CTR  | /Increment counter                  |
| 10D | 7004 | SZA      |      | /check if remaining bits = 0        |
| 10E | 4107 | BUN      | ROT  | /No; rotate again                   |
| 10F | 7001 | STP, HLT |      | /yes; stop                          |
| 110 | 0000 | CTR, HEX | O    |                                     |
| 111 | 62C1 | WRD, HEX |      |                                     |
|     |      | END      | 62C1 |                                     |

۱۳- یک حلقه برنامه با استفاده از اشاره‌گر و شمارنده بنویسید که محتوای مکان

شانزده شانزدهی ۵۰۰ تا ۵FF را ۰ کند.

حل: در ارتباط با مقدار شمارنده، می‌بایست فاصله دهدگی ۵۰۰ تا ۵FF را در مبنای ۱۶ محاسبه کنیم.

$$\begin{aligned} 0 - F &= 16 \\ \Rightarrow 16 \times 16 &= (256)_{10} \\ 0-F &= 16 \end{aligned}$$

بنابراین  $CTR = 256 - CTR$  انتخاب می‌شود به عنوان شمارنده بالارونده.

در ضمن، در ارتباط با افزایش اشاره گر برای دسترسی به مکان‌های بعدی دو راه داریم:

۱) محتوا اشاره گر در رجیستر AC ریخته شده و از دستورالعمل INC استفاده کنیم.

۲) از دستورالعمل ISZ استفاده کنیم. زیرا اطمینان داریم مقدار اشاره گر، صفر نخواهد شد.

پس داریم:

```
ORG 100
LDA ADS
STA PTR
LDA NBR
STA CTR
CLA
LOP, STA PTR I
ISZ PTR
ISZ CTR
BUN LOP
HLT
ADS , HEX 500
PTR, HEX 0
NBR , DEC - 256
CTR , HEX 0
END
```

۱۴- برنامه‌ای بنویسید که دو عدد را با روش جمع تکراری، درهم ضرب کند.

مثالاً برای ضرب  $5 \times 4$ ، برنامه ۵ را چهار بار جمع کند، یعنی  $5 + 5 + 5 + 5$

حل: در این روش ضرب، طبق صورت سؤال، عدد دوم در شمارنده قرارداده می‌شود و عدد اول با خودش جمع می‌شود تا بعد از رسیدن شمارنده بالارونده به عدد ، حاصل ضرب آماده باشد.

دلیل استفاده از شمارنده بالارونده در برنامه‌های اسمبلی، این است که دستور العمل

قابل استفاده برای چک کردن پایان شمارنده، ISZ است. پس داریم: (برای مثال  $\frac{5}{B} \times \frac{4}{A}$ )

```

LDA    A
SZA
BUN   NZR
HLT
NZR , CMA
INC
STA    CTR
CLA
LOP , ADD  B
ISZ    CTR
BUN   LOP
HLT
A, DEC  4
B, DEC  5
CTR , HEX 0
END

```

۱۵- برنامه ضرب جدول ۱۴-۶ مقداردهی اولیه نشده است. پس از یکبار اجرای برنامه، مکان CTR مقدار صفر می‌گیرد. نشان دهید اگر برنامه دوباره از مکان ۱۰۰ شروع شود، حلقه ۶۵۵۳۶ بار تکرار خواهد شد. دستورهای لازم برای مقداردهی اولیه برنامه را اضاف کنید.

حل: با توجه به برنامه جدول ۱۴-۶ که برنامه ضرب دو عدد مثبت است، اولین باری که برنامه اجرا می‌شود، شمارنده از ۸-تا ۰، ۸ بار می‌شمارد تا ۸ بار حلقه اجرا شده و ۸ بار شیفت اجرا شود. اگر برنامه دقیقاً دوباره از آدرس ۱۰۰ تکرار اجرا شود، یعنی مقادیر متغیرها حفظ شود، با توجه به اینکه از دستور ISZ استفاده می‌شود و همچنین با توجه به اینکه CTR، یک متغیر ۱۶ بیتی است، برای اینکه دوباره ۰ شود

باید 65536 بار بشمارد. یعنی:



همچنین متغیر  $P$  نیز حاصلضرب در اجرای قبلی الگوریتم باقی خواهد ماند. برای رفع این اشکال،  $CTR$  و  $P$  را مقداردهی اولیه می‌کنیم:



۱۶- برنامه‌ای برای ضرب دو عدد مثبت بدون علامت ۱۶ بیتی بنویسید و حاصلضرب آنها را به صورت یک عدد بدون علامت با دقت مضاعف بدست آورید.

حل: در کتاب، جمع دو عدد با دقت مضاعف "double precision" توضیح داده شده است، در رابطه با برنامه ضرب دو عدد مثبت بدون علامت ۱۶ بیتی، چون نتیجه عمل ضرب حداکثر ۳۲ بیتی خواهد بود، بنابراین برای MultipliCand به دلیل نیاز به شیفت به چپ و همینطور برای حاصلضرب جزیی "Partial Product" متغیرهای ۳۲ بیتی اخذ خواهد شد. یعنی برای ۵ هر کدام از این دو مقدار، ما به دو کلمه از حافظه نیاز خواهیم

داشت.

بنابراین در جمع حاصلضرب جزئی با MultipliCand از جمع با دقت مضاعف و برای شیفت به چپ MutipliCand ، از شیفت به چپ در دو مکان از حافظه استفاده خواهیم کرد.

همچنین، شمارنده ما به جای ۸ ، ۱۶ - مقداردهی خواهد شد.

LOP , CLE

LDA

CIR

STA

SZE

BUN One

BUN Zero

One , LDA XL

ADD PL

STA PL

CLA

CIL

ADD XH

ADD PH

STA PH

CLE

Zero , LDA XL

CIL

STA XL

LDA XH

CIL

STA XH

ISZ CTR

BUN LOP

HLT

}

جمع با دقت مضاعف

X و P

مانند جدول ۶-۱۵ در کتاب

}

شیفت به چپ با دقت مضاعف X

«بیت E ، با ارزش‌ترین بیت XL را به

کم ارزش‌ترین بیت XH انتقال می‌دهد.»

۱۷- برنامه‌ای برای ضرب دو عدد علامت‌دار بنویسید. اعداد منفی ابتدا به صورت متمم ۲ علامت‌دار نشان داده می‌شوند. حاصلضرب باید با دقت ساده باشد و در صورت منفی بودن هم، به صورت متمم ۲ علامت‌دار نشان داده شود.

حل:

X Multipli Cand

x

### Y Multiplier Result

در عبارت بالا، بحث بسیار مهم، اصالت بیت‌های Multiplier است زیرا  $0 \times 1 = 0$  بودن این بیت‌ها، جمع موجود در الگوریتم ضرب را درگیر کرده و نتیجه را تغییر خواهد داد. بنابراین سعی ما در مثبت بودن Y یعنی Multiplier است.

بنابراین:

اگر Y مثبت باشد، همان ضرب معمولی انجام خواهد شد.

اگر Y منفی باشد، هر دو Y و X را مکمل ۲ کرده تا Y مثبت شود. سپس ضرب معمولی انجام می‌شود.

پس:



نکته در ارتباط با مقدار اولیه شمارنده،  $7 = CTR$  لحاظ شده است. دلیل این است که چون نهایتاً Y مثبت است، بیت  $Y_7$  یعنی با ارزش‌ترین بیت (بیت علامت) ۰ است. پس با ۷ بار شیفت ضرب حاصل خواهد شد.

۱۸- برنامه‌ای بنویسید که دو عدد با دقت مضاعف را از هم تفریق کند.

حل: طبق تعریف تفریق داریم:

$$A - B = A + (-B)$$

بنابراین بعد از مکمل ۲ کردن BL و BH در عین حفظ رقم نقلی، جمع با دقت مضاعف را انجام می‌دهیم. دلیل ذخیره رقم نقلی در رجیستر ذخیره موقت داده "Temp" این است که ما به AC برای ادامه مکمل ۲ کردن B نیاز داریم.

پس: ذخیره شود در

$$C \leftarrow A - B$$

```

CLE
LDA BL
CMA
INC
ADD AL
STA AL
CLA
CIA
CIL
STA TMP
LDA BH
CMA
ADD AH
ADD TMP
STA CH
HLT
TMP , Hex 0

```

۱۹- برنامه‌ای بنویسید که OR انحصاری منطقی دو عملوند منطقی را حساب

کند.

حل: می‌دانیم:

$$z = x \oplus y = xy' + x'y$$

حال دو روش برای بیان عبارت براساس AND و NOT داریم: (به این دلیل که دستورالعمل‌های AND و CMA برای ساخت ترکیبات منطقی استفاده می‌شوند).

۱- از راه جبربول:

$$z = xy' + x'y = [(xy')'. (x'y)']'$$

## ۲- رسم تابع منطقی با گیت‌های AND و NOT



برنامه بدین شرح خواهد بود:

```

LDA    y
CMA
AND   x
CMA
STA TMP/(xy)'
LDA    x
CMA
AND   y
CMA
AND   TMP
CMA
STA   z
HLT
x, .....
y, .....
z, .....
TMP, .....

```

۲۰- برنامه‌ای برای شیفت حسابی به چپ بنویسید که در صورت رخ دادن

سرریز به OVF انشعاب کند.

حل: با توجه به اینکه تنها شیفت چرخشی به چپ در دستورالعمل‌ها داریم "CIL" برای تشخیص سرریز «مثبت شدن عدد منفی یا منفی شدن عدد مثبت» می‌باشد، بیت موجود در رقم نقلی را با بیت علامت رجیستر، بعد از اجرای دستور CIL «در حالی که E را پاک کرده‌ایم»، مقایسه کنیم.

از روند نمای زیر می‌توان متوجه شد که OR انحصاری (1) و E، وجود رخداد

OVF را تعیین می‌نمایند. منظور از (1)، با ارزش ترین بیت AC است



با استفاده از مقایسه و پرسنها برنامه را به شکل زیر طراحی می‌کنیم:

|            |   |                         |
|------------|---|-------------------------|
| LDA X      |   |                         |
| CLE        | / | مقدمات شیفت به چپ حسابی |
| CIL        |   |                         |
| SZE        |   |                         |
| BUN ONE    |   |                         |
| SPA        |   |                         |
| BUN OVF    | / | شامل عدد منفی AC, E=0   |
| BUN EXIT   |   |                         |
| ONE , SNA  |   |                         |
| BUN OVF    | / | شامل عدد مثبت AC, E=1   |
| EXIT , HLT |   |                         |

۲۱- زیر روایی برای تفریق دو عدد بنویسید. در برنامه فراخواننده، مفروق و مفروق منه به دنبال دستورالعمل BSA آمده‌اند. حاصل تفریق به سومین مکان پس از BSA در برنامه اصلی باز می‌گردد.

حل: در حقیقت سؤال به دنبال یک زیرروال همراه با پارامتردهی به صورت گفته شده هست.

برای برنامه صدا زننده زیر روال داریم:

|           |   |             |
|-----------|---|-------------|
| BSA SUB   |   |             |
| Hex 12 34 | { | 4321 – 1234 |
| Hex 4321  | } |             |
| Hex 0     | / | نتیجه       |

زیر روال:

|           |   |                      |
|-----------|---|----------------------|
| SUB , Hex |   |                      |
| LDA SUB I | / | دریافت اولین پارامتر |

CMA

INC

ISZ

SUB /

افزایش اشاره‌گر برای دسترسی به پارامتر بعدی

ADD

SUB I /

پارامتر دوم جمع یا مکمل ۲ پارامتر اول

ISZ

SUB

STA SUB

ISZ SUB

BUN SUB I

۲۲- زیرروالی بنویسید که هر داده را در یک بلاک متمم کند. در برنامه

فراخواننده، دو پارامتر پس از دستورالعمل BSA آمده است: آدرس شروع بلاک و

تعداد کلمات بلاک.

حل: با فرض آنکه آدرس شروع  $16_{16}$  (100) و تعداد کلمات حافظه ۳۲ است، داریم:

برنامه صد زننده زیر روال:

BSA CMP

Hex 100

DEC 32

CMP , Hex 0

LDA CMP I

STA PTR

ISZ CMP

LDA CMP I

CMA

INC

CMA

INC

STA CTR / شمارنده

LOP, LDA PTR I

CMA

STA PTR I

ISZ PTR

ISZ CTR

BUN LOP

ISZ CMP

BUN CMP I

PTR .....

CTR .....

در دستورالعمل‌های بالا، CMP ISZ PTR ISZ صرفاً برای افزایش یک واحد استفاده شده‌اند.

۲۳- زیر روال بنویسید که E و AC را چهار بار به راست بچرخاند. اگر ابتدا محتوای AC برابر  $(079C)_{16}$  و E=1 باشد، محتوای آنها پس از اجرای زیر روال چیست؟

حل: طبق صورت سؤال داریم:

```
CR4 , Hex 0
CIR
CIR
CIR
CIR
BUN CR4 I
```

در رابطه با مقادیر داریم:

$$AC : (079C)_{16} = (0000 \ 0111 \ 1001 \ 1100)_2, \quad E = 1$$

بعد از چرخش اول

$AC = (1000 \ 0011 \ 1100 \ 1110)_2, \quad E = 0$

بعد از چرخش دوم

$AC = (0100 \ 0001 \ 1110 \ 0111)_2, \quad E = 0$

بعد از چرخش سوم

$AC = (0010 \ 0000 \ 1111 \ 0011)_2, \quad E = 1$

بعد از چرخش چهارم

بنابراین، بعد از اجرای زیر روال:

$$AC = (9079)_{16}, \quad E = 1$$

۲۴- برنامه‌ای بنویسید که کاراکترهای ورودی را بپذیرد، هر دو کاراکتر را در

یک کلمه فشرده کند و پشت سر هم در بافر حافظه ذخیره نماید. اولین آدرس بافر

$(400)_{16}$  و اندازه آن  $(512)_{10}$  است. اگر بافر سرریز کند کامپیوتر بایستی متوقف

می شود.

حل: فرض شود که زیر روال به اسم IN2 «جدول ۶-۲۰ کتاب» دریافت و فشرده

کردن دو کاراکتر در یک کلمه را برعهده دارد.

برنامه به صورت زیر است:

|           |       |   |                                                   |
|-----------|-------|---|---------------------------------------------------|
| LDA       | ADS   |   |                                                   |
| STA       | PTR   | / | تنظیم اشاره‌گر                                    |
| LDA       | NBR   |   |                                                   |
| STA       | CTR   | / | تنظیم شمارنده                                     |
| LOP , BSA | IN2   | / | بعد از اجرای این زیر روال، دو کاراکتر در AC هستند |
| STA       | PTR   | I |                                                   |
| ISZ       | PTR   | / | صرفًاً افزایش اشاره‌گر                            |
| ISZ       | CTR   | / | افراش و مقایسه شمارنده                            |
| BUN       | LOP   |   |                                                   |
| HLT       |       |   |                                                   |
| ADS , Hex | 400   |   |                                                   |
| PTR , Hex | 0     |   |                                                   |
| NBR , DEC | - 512 |   |                                                   |
| CTR , Hex | 0     |   |                                                   |

۲۵- برنامه‌ای بنویسید که دو کاراکتر در مکان WRD را باز کند. و آنها را در بیت‌های ۰ تا ۷ از مکان‌های CH1 و CH2 ذخیره کند. بیت ۹ تا ۱۵ باید صفر باشد.

حل: ابتدا زیر روال به نام SR8 را تعریف می‌کنیم که ۸ بار، محتویات رجیستر AC را به راست شیفت می‌دهد. می‌توانیم قبل از هر بار شیفت، CLE انجام دهیم و یا بعد از ۸ بار شیفت چرخشی، محتوا را با AND ، 00FF کنیم، تا نیمه بالایی رجیستر ۰ باشد.

```
SR8 , Hex 0
CIR
CIR
CIR
CIR
CIR
CIR
CIR
CIR
BUN SR8 I
```

برای برنامه اصلی داریم:

```
LDA WRD
AND MS1 / AND With 00FF
STA CH1
```

LDA WRD  
 AND MS2 / AND With FF00  
 CLE  
 BSA SR8

STA CH2  
 HLT  
 WRD , Hex ,...  
 CH1 , Hex, ...  
 CH2, Hex , ...  
 MS1 , Hex 00FF  
 MS2 , Hex FF00

۲۶- فلوچارتی را برای برنامه‌ای بدست آورید که وجود CR (در مبنای ۰D) را در بافر حافظه بررسی کند. بافر دارای ۲ کاراکتر در هر کلمه است. وقتی به کد دیده شود، برنامه آن را به بیت‌های ۰ تا ۷ مکان LNE منتقل می‌کند بدون آنکه بیت‌های ۸ تا ۱۵ تغییر کنند.

حل: کد CR در بافر، یا در کد بالا و یا در کد پایین هر کلمه از بافر قرار دارد. برای کد بالا، از AND با FF00 و برای کد پایین از AND با 00FF استفاده می‌کنیم.



۲۷- روال سرویس‌دهی SRV را از جدول ۲۳-۶ به کد شانزده شانزدهی معادلش ترجمه کنید. فرض کنید که روال از مکان ۲۰۰ شروع شده باشد.

حل:

| <u>Location</u> | <u>Hex code</u> |      |     |     |   |
|-----------------|-----------------|------|-----|-----|---|
| 200             | 3213            | SRV, | STA | SAC |   |
| 201             | 7080            |      | CIR |     |   |
| 202             | 3214            |      | STA | SE  |   |
| 203             | F200            |      | SKI |     |   |
| 204             | 4209            |      | BUN | NXT |   |
| 205             | F800            |      | INP |     |   |
| 206             | F400            |      | OUT |     |   |
| 207             | B215            |      | STA | PT1 | I |
|                 |                 |      | ISZ | PT1 |   |
| 208             | 6215            | NXT, | SKO |     |   |
| 209             | F100            |      |     |     |   |
| 20A             | 420E            |      | BUN | EXT |   |
| 20B             | A216            |      | LDA | PT2 | I |
| 20C             | F400            |      | OUT |     |   |
| 20D             | 6216            |      | ISZ | PT2 |   |
| 20E             | 2214            | EXT, | LDA | SE  |   |
| 20F             | 7040            |      | CIL |     |   |
| 210             | 2213            |      | LDA | SAC |   |
| 211             | F080            |      | ION |     |   |
| 212             | C000            |      | BUN | ZR0 | I |
| 213             | 0000            | SAC, | --- |     |   |
| 214             | 0000            | SE,  | --- |     |   |
| 215             | 0000            | PT1, | --- |     |   |
| 216             | 0000            | PT2  | --- |     |   |

۲۸- یک روال سرویس دهی وقفه که تمام عملیات لازم را انجام می دهد بنویسید  
ولی وسیله ورودی فقط اگر مکان MOD تماماً ۱ باشد، سرویس دهی شود. وسیله خروجی هم فقط اگر مکان MOD تماماً ۰ باشد سرویس دهی شود.

حل: همانند برنامه سرویس دهی جدول ۲۳-۶، با این تفاوت که، هنگام سرویس دهی به وسیله ورودی، با دستورالعمل  $ISZ_{16}$  بودن MOD (FFFF) بررسی می شود. و هنگام سرویس دهی به وسیله خروجی، با دستورالعمل  $SZA_{16}$  (FFFF) بودن MOD بررسی می شود.

SRV , STA SAC  
CIR

STA SE  
LDA MOD  
ISZ  
BUN NXT / MOD ≠ FFFF  
SKI  
BUN NXT  
INP  
OUT  
STA PT1 I  
ISZ PT1  
NXT , LDA MOD  
SZA  
BUN EXT / MOD ≠ φφφφ  
SKO  
BUN EXT  
LDA PT2 I  
OUT  
ISZ PT2  
EXT , .....

ادامه برنامه مانند جدول ۶-۲۳

## فصل هفتم: کنترل ریز برنامه‌نویسی شده

۱- تفاوت بین ریز پردازنده و ریز برنامه چیست؟ آیا می‌توان ریز پردازنده‌ای بدون یک ریز برنامه طراحی کرد؟ آیا همه‌ی کامپیوترهای ریز برنامه‌ریزی شده ریز پردازنده هستند؟

حل: یک ریز پردازنده یک پردازنده کوچک است (کامپیوتری بر روی یک تراشه). ریز برنامه، برنامه‌ای است شامل دنباله‌ای از ریز عمل‌ها، واحد کنترل یک ریز پردازنده می‌تواند به صورت سخت‌افزاری (سیم‌بندی) یا ریز برنامه‌ریزی شده باشد، براساس طراحی مورد نظر، لزومی ندارد یک کامپیوتر ریز برنامه‌ریزی شده ریز پردازنده باشد.

۲- تفاوت بین کنترل سخت‌افزاری و کنترل ریز برنامه‌نویسی شده را بیان کنید.

آیا می‌توان یک کنترل سخت‌افزاری مرتبط شده با یک حافظه کنترلی داشت؟

حل: واحد کنترل سخت‌افزاری کاملاً به صورت سخت‌افزاری پیاده‌سازی شده که دارای سرعت بالایی است اما در برابر تغییر مجموعه دستورها، انعطاف‌پذیر نیست و باید دوباره طراحی و پیاده‌سازی شود. واحد کنترل ریز برنامه‌نویسی شده ترکیبی از سخت‌افزار برای اجرای ریز عمل‌ها و حافظه‌ای شامل ریز عمل‌های است که انعطاف‌پذیری بیشتری در برابر تغییر مجموعه دستورها دارد و نیاز به طراحی و پیاده‌سازی مجدد ندارد (کافی است ریز برنامه آن را تغییر دهیم) اما سرعت کمتری نسبت به واحد کنترل سخت‌افزاری دارد. کنترل سخت‌افزاری، بنا به تعریف شامل حافظه کنترل نیست.

۳- این اصطلاحات را تعریف کنید: الف) ریز عمل، ب) ریز دستورالعمل، ج) ریز برنامه، د) ریز کد.

حل:

ریز عمل: یک عمل پایه کامپیوتر دیجیتال

ریز دستورالعمل: یک دستور ذخیره شده در حافظه کنترل

ریز برنامه: دنباله‌ای از ریز دستورالعمل‌ها

ریز کد: همان ریز برنامه است.

۴- سازمان یک کترل زیر برنامه‌نویسی شده که در شکل ۷-۱ نشان داده شده است دارای تأخیرهای انتشاری زیر است. ۴۰ns برای تولید آدرس بعدی، ۱۰ ns برای انتقال آدرس به داخل ثبات کترل آدرس و ۴۰ns برای دستیابی به حافظه کترلی ROM و ۱۰ns برای انتقال ریز دستورالعمل به ثبات کترل داده و ۴۰ns برای اجرای ریز عمل مورد نظر که به وسیله کلمه کترلی مشخص شده است. حداکثر فرکانس پالس ساعتی که کترول می‌تواند به کار ببرد چیست؟ اگر ثبات کترول داده بکار نرود، فرکانس ساعت چه خواهد بود؟

حل:



با توجه به شکل داریم:

زمان مورد نیاز برای انجام یک مرحله:

$$\text{حداقل زمان} = 10 + 40 + 10 + 40 = 100 \text{ ns}$$

CAR      ROM      Data Reg      Max (Micro Operations , Sequencer)

پس:

$$\text{فرکانس هر پالس ساعت} = \frac{1}{100 \times 10^{-9}} = \frac{1000}{100} \times 10^6 = 10 \text{ MHz}$$

اگر ثبات داده کنترل استفاده نشود:

$$\text{حداقل زمان} = 10 + 40 + 40 = 90 \text{ ns}$$

CAR      ROM      Max (Micro operations , sequencer)

که در این صورت یک فاز داریم و نیاز به 2 Clock نیز نداریم. فرکانس برابر است

با:

$$\text{فرکانس هر پالس ساعت} = \frac{1}{90 \times 10^{-9}} = 1101 \text{ MHz}$$

۵ - سیستم شکل ۷-۲ از یک حافظه کنترلی ۱۰۲۴ کلمه‌ای و هر کلمه ۳۲ بیتی استفاده می‌کند. ریز دستورالعمل دارای سه میدان است . میدان ریز عمل‌ها ۱۶ بیتی است.

الف) میدان آدرس انشعاب و میدان انتخاب چند بیتی هستند؟

پس به ۱۰ بیت آدرس نیاز داریم.

حافظه کنترل  $2 \times 32$

|        |      |         |
|--------|------|---------|
| ۶      | ۱۰   | ۱۶      |
| انتخاب | آدرس | ریز عمل |

ب) اگر ۱۶ بیت وضعیت وجود داشته باشد، چند بیت منطق انشعاب برای انتخاب یک بیت وضعیت لازم است؟

۴ بیت :  $2^4 = 16$  حالت

ج) چند بیت برای انتخاب ورودی مالتی پلکسor باقی مانده است؟

بیت  $6 - 4 = 2$

۶ - حافظه کنترل شکل ۷-۲ دارای ۴۰۹۶ کلمه ۲۴ بیتی است.

الف) در ثبات آدرس کنترل چند بیت وجود دارد؟  $2^{12} \times 24$  = حافظه کنترل

پس ثبات آدرس کترل ۱۲ بیتی است.

- ب) هر یک از چهار ورودی که به داخل مالتی پلکسر می‌روند چند بیتی‌اند؟  
 ۱۲ بیتی، چون وارد ثبات آدرس می‌شوند که شامل ۱۲ بیت آدرس است.  
 ج) تعداد ورودی‌های هر مالتی پلکسر چند است و چند مالتی پلکسر لازم است؟ برای هر بیت یک مالتی پلکسر نیاز داریم که از بین چهار ورودی مختلف انتخاب کند پس ۱۲ مالتی پلکسر ۴ به ۱ نیاز است.

۷- با استفاده از روال نگاشت که در شکل ۷-۳ توصیف شد، برای هر یک از کدهای عملیاتی زیر آدرس اولین ریز دستورالعمل را بنویسید.

الف) ۰۰۱۰ ؛ ب) ۱۰۱۱ ؛ ج) ۱۱۱۱

حل:

الف)  $0001000 = 8$

ب)  $0101100 = 44$

ج)  $0111100 = 60$

۸- یک روال نگاشت تنظیم کنید که هشت ریز دستورالعمل متواالی را برای هر روال در اختیار بگذارد. کد عملیاتی شش بیتی است و حافظه کترلی ۲۰۴۸ کلمه دارد.

حل:

بیت ۶ = کد عمل

بیت ۱۱ = آدرس حافظه کترل

رویه نگاشت به این صورت خواهد بود.

شیفت مورد نیاز  $= 2^3 = 8$

$$\Rightarrow 00 \left| \begin{array}{c} \text{xxxxxx} \\ \text{xxxxxx} \end{array} \right| 000$$

۹- توضیح دهید که چگونه با یک حافظه فقط خواندنی می‌توان عمل نگاشت از کد دستورالعمل به آدرس ریز دستورالعمل را انجام داد. مزیت این روش نسبت به روش شکل ۷-۳ چیست؟

حل: با استفاده از ROM مانند شکل زیر، که در آن  $n$  تعداد بیت کد عمل و  $m$  تعداد بیت آدرس حافظه کنترل است می‌توان این کار را انجام داد به این صورت که در هر خانه از ROM، آدرس شروع روال مربوط به آن در حافظه کنترل قرار داده شده باشد و بیت‌های کد عمل به ورودی ROM متصل باشد.

مزیت این روش استفاده بهتر از حافظه کنترل و عدم نیاز به پرسش برای روال‌های طولانی است (آدرس شروع هر روال لازم نیست مضربی از توان ۲ باشد و عددی دلخواه است).

  
۱۰- چرا در پیکربندی کامپیوتراً شکل  $2^n \times m$  خروجی داریم؟ آیا راه دیگری برای انتقال اطلاعات از چند منبع به یک مقصد مشترک وجود دارد؟

حل: زیرا در هر مرحله ورودی‌های DR و AR باید از بین ورودی‌های موجود انتخاب شود و برای این کار به مالتی پلکسراً نیاز داریم. پس دو مالتی پلکسراً یکی برای DR و دیگری برای AR نیاز است. راه‌های دیگر برای این کار استفاده از بافر سه حالته یا مدار گیتی (معادل یک مالتی پلکسراً) می‌باشد.

۱۱- با استفاده از جدول ۷-۱، برای ریز اعمال زیر، محتواهای ۹ بیت میدان ریز عمل را مشخص کنید.

(الف)

$$AC \rightarrow AC+1, DR \rightarrow DR+1$$

(ب)

$$PC \rightarrow PC+1, DR \leftarrow M[AR]$$

(ج)

$DR \leftarrow AC$ ,  $AC \leftarrow DR$

حل:

| F1  | F2  | F3  |       |       |      | (الف) |
|-----|-----|-----|-------|-------|------|-------|
| 011 | 110 | 000 | INCAC | INCDR | NOP  |       |
| 000 | 100 | 101 | NOP   | READ  | INCP | (ب)   |
| 100 | 101 | 000 | DRTAC | ACTDR | NOP  | (ج)   |

۱۲- با استفاده از جدول ۱-۷، ریز اعمال سمبیلیک زیر را به عبارات انتقال ثباتی و دودویی تبدیل کنید.

الف) READ , INCP

ب) ACTDR , DRTAC

ج) ARTPC , DRTAC , WRITE

حل:

الف) READ       $DR \leftarrow M[AR]$       F2=100      Binary  
 INCP       $PC \leftarrow PC+1$        $F_3 = 101$       000100101

ب) ACTDR       $DR \leftarrow AC$       F2=101      100101000  
 DRTAC       $AC \leftarrow DR$       F1=100

ج) ARTPC       $PC \leftarrow AR$        $F_3 = 110$   
 DRTAC       $AC \leftarrow DR$       F1=100      غیرممکن هر دو از F1 استفاده می‌کنند.  
 WRITE       $M[AR] \leftarrow DR$       F1=111

۱۳- فرض کنید که می‌خواهیم روال ADD بیان شده در جدول ۷-۲ را به دو ریز دستور العمل زیر تبدیل کنیم:

ADD:    READ    I    CALL    INDR2  
 ADD      U    IMP    FETCH

زیر روال INDR2 چه باید باشد؟

حل:

اگر  $I=0$  باشد، عملوند در ريز دستورالعمل اول خوانده شده و در ريز دستورالعمل دوم به AC اضافه می شود.

اگر  $I=1$  باشد، آدرس مؤثر در DR قرار می گيرد و كتترل برنامه به روal INDR2 می رود. زير روal INDR2 باید عملوند را در DR قرار دهد:

```
INDR2: DRTAR   U   IMP   NEXT
        READ    U   RET    --
```

۱۴- در زير ريز برنامه سمبليک يك دستورالعمل در کامپيوتر بخش ۳-۷ آمده است

```
ORG 40
NOP  S JMP FETCH
NOP  Z JMP FETCH
NOP  I CALL INDRCT
ARTPC U JMP FETCH
```

الف) عملی که هنگام اجرای دستورالعمل انجام می شود را مشخص کنيد.

همان طور که می بینیم ريز برنامه در صورتی که  $AC=0$  باشد کاری انجام نمی دهد و به روal FETCH پر ش می کند. در غير این صورت ( $AC>0$ ) اگر  $I=1$  باشد، ابتدا روal INDRCT را فراخوانی می کند تا آدرس مؤثر بدست آید و سپس محتواي AR را در PC قرار می دهد (انشعاب اگر AC مثبت و غير صفر باشد).  
if ( $AC > 0$ ) then ( $PC \leftarrow EA$ ) آدرس مؤثر است.

ب) چهار ريز دستورالعمل را به فرم معادل دودویی آنها تبدیل کنید.

40: 000 000 000 1000 1000000  
 41: 000 000 000 1100 1000000  
 (ب) 42: 000 000 000 0101 1000011  
 43: 000 000 110 0000 1000000

۱۵- کامپیوتر بخش ۳-۷ دارای ریز برنامه دودویی زیر است.

| آدرس | ریز برنامه دودویی   |
|------|---------------------|
| ۶۰   | ۱۰۰۰۰۱۰۰۰۰۱۰۰۰۱۱    |
| ۶۱   | ۱۱۱۰۰۰۰۰۱۰۱۱۰۰۰۰    |
| ۶۲   | ۰۰۱۰۰۱۰۰۰۱۰۱۰۰۱۱۱۱۱ |
| ۶۳   | ۱۰۱۱۰۰۰۱۱۱۰۱۱۱۰     |

الف) آن را به ریز برنامه سمبولیک، مطابق جدول ۲-۷، ترجمه کنید. (درFETCH آدرس ۶۴ و INDRCT در آدرس ۶۷ است).

(الف)

|     |              |   |      |          |
|-----|--------------|---|------|----------|
| 60: | CLRAC , COM  | U | JMP  | INDRCT   |
| 61: | WRITE, READ  | I | CALL | FETCH    |
| 62: | ADD, SUB     | S | RET  | 63(NEXT) |
| 63: | DRTAC, INCDR | Z | MAP  | 60       |

ب) تمام اشکالاتی را که با اجرای این ریز برنامه در کامپیوتر پیش می‌آید بنویسید.

۶۰ : نمی‌توان همزمان AC را پاک کرد و متمم کرد. همچنین با پرش به INDRCT کترل برنامه به خط ۶۱ بر نمی‌گردد.

۶۱ : نمی‌توان همزمان در حافظه نوشت و از آن خواند. همچنین CALL همانند JMP عمل می‌کند زیرا در پایان RET وجود ندارد.

۶۲ : نمی‌توان همزمان جمع و تفریق انجام داد. همچنین RET بدون توجه به S، اجرا می‌شود.

۶۳ : MAP بدون توجه به Z و ۶۰ اجرا می‌شود.

۱۶- دستورات زیر را به کامپیوتر بخشن ۳-۷ اضافه کنید (آدرس مؤثر است): برنامه سمبليک را برای هر روال مطابق جدول ۷-۲ بنویسید. (توجه کنید که مقدار AC نباید تغییر کند مگر این که دستور العمل، یک تغییر در AC را مشخص نماید).

| سمبل | کد عمل | شکل سمبليک                                      | شرح                                       |
|------|--------|-------------------------------------------------|-------------------------------------------|
| AND  | ۰۱۰    | $AC \leftarrow AC \wedge M[EA]$                 | AND                                       |
| SUB  | ۰۱۱    | $AC \leftarrow AC - M[EA]$                      | تفریق                                     |
| ADM  | ۰۱۰    | $M[EA] = M[EA] + AC$                            | جمع با حافظه                              |
| BTCL | ۰۱۱    | $AC \leftarrow AC \wedge \overline{M[EA]}$      | ماسک کردن بیت‌ها با مقدار حافظه           |
| BZ   | ۱۰۰    | if $(AC = 0)$ then $(PC \leftarrow EA)$         | انشعاب در صورت صفر <b>AC</b> بودن         |
| SEQ  | ۱۰۱    | if $(AC = M[EA])$ then $(PC \leftarrow PC + 1)$ | گذار در صورت برابری                       |
| BPNZ | ۱۰۱    | if $(AC > 0)$ then $(PC \leftarrow EA)$         | انشعاب اگر <b>AC</b> مثبت و غیر صفر باشد. |

حل: برنامه سمبليک روال‌ها به صورت زیر است:

| ORG 16         |              |          |            |                    |
|----------------|--------------|----------|------------|--------------------|
| AND :          | NOP          | I        | CALL       | INDRCT             |
|                | READ         | U        | JMP        | NEXT               |
| <u>ANDOP :</u> | <u>AND</u>   | <u>U</u> | <u>JMP</u> | <u>FETCH</u>       |
| ORG 20         |              |          |            |                    |
| SUB :          | NOP          | I        | CALL       | INDRCT             |
|                | READ         | U        | JMP        | NEXT               |
|                | SUB          | U        | JMP        | FETCH              |
| ORG 24         |              |          |            |                    |
| ADM :          | NOP          | I        | CALL       | INDRCT             |
|                | READ         | U        | JMP        | NEXT               |
|                | DRTAC, ACTDR | U        | JMP        | NEXT               |
|                | ADD          | U        | JMP        | <u>EXCHANGE +2</u> |
| (Table 7.2)    |              |          |            |                    |
| ORG 28         |              |          |            |                    |
| BICL :         | NOP          | I        | CALL       | INDRCT             |
|                | READ         | U        | JMP        | NEXT               |
|                | DRTAC, ACTDR | U        | JMP        | NEXT               |
|                | COM          | U        | JMP        | ANDOP              |
| ORG 32         |              |          |            |                    |
| BZ :           | NOP          | Z        | JMP        | ZERO               |
|                | NOP          | U        | JMP        | FETCH              |
| ZERO :         | NOP          | I        | CALL       | INDRCT             |
|                | ARTPC        | U        | JMP        | FETCH              |

|       | ORG 36       |   |      |        |
|-------|--------------|---|------|--------|
| SEQ : | NOP          | I | CALL | INDRCT |
|       | READ         | U | JMP  | NEXT   |
|       | DRTAC, ACTDR | U | JMP  | NEXT   |
|       | XOR (or SUB) | U | JMP  | BEQ1   |

  

|                | ORG 69       |   |     |       |
|----------------|--------------|---|-----|-------|
| BEQ 1 :        | DRTAC, ACTDR | Z | JMP | EQUAL |
|                | NOP          | U | JMP | FETCH |
| <u>EQUAL :</u> | INC PC       | U | JPM | FETCH |

  

|        | ORG 40 |   |      |        |
|--------|--------|---|------|--------|
| BPNZ : | NOP    | S | JMP  | FETCH  |
|        | NOP    | Z | JMP  | FETCH  |
|        | NOP    | I | CALL | INDRCT |
|        | ARTPC  | U | JMP  | FETCH  |

۱۷- یک روال ریز برنامه برای دستورالعمل ISZ (افزایش و عبور در صورت صفر بودن) که در فصل ۵ (جدول ۴-۵) تعریف شده بنویسید. از قالب ریز دستورالعمل بخش ۳-۷ استفاده کنید. توجه کنید که شرط وضعیت  $DR = 0$  در میدان CD کامپیوتر بخش ۳-۷ در دسترس نیست، با این وجود می‌توانید AC و DR را با هم تعویض کرده و با بیت Z چک کنید که آیا  $AC = 0$  است یا نه.

حل:

|               |              |   |      |                        |
|---------------|--------------|---|------|------------------------|
| ISZ :         | NOP          | I | CALL | INDRCT                 |
|               | READ         | U | JMP  | NEXT                   |
|               | INCDR        | U | JMP  | NEXT                   |
|               | DRTAC, ACTDR | U | JMP  | NEXT (or past, INDRCT) |
|               | DRTAC, ACTDR | Z | JMP  | ZERO                   |
|               | WRITE        | U | JMP  | FETCH                  |
| <u>ZERO :</u> | WRITE, INCPC | U | JMP  | FETCH                  |

۱۸- روال ریز برنامه سمبیلیک را برای دستورالعمل BSA (انشعاب و ذخیره آدرس) که در فصل ۵ تعریف شد بنویسید (جدول ۴-۵). از قالب ریز دستورالعمل بخش ۳-۷ استفاده کنید. تعداد ریز دستورالعمل‌ها را به کمینه ترین حالت برسانید.

حل:

|       |              |   |      |        |
|-------|--------------|---|------|--------|
| BSA : | NOP          | I | CALL | INDRCT |
|       | PCTDR, ARTPC | U | JMP  | NEXT   |
|       | WRITE, INCPC | U | JMP  | FETCH  |

۱۹- نشان دهید که چگونه خروجی‌های ۵ و ۶ دیکدر F3 در شکل ۷-۷ به شمارنده برنامه PC وصل می‌شوند.

حل: از جدول ۷-۱ داریم:

$$F3=101(5) \quad PC \leftarrow PC + 1$$

$$F3=110(6) \quad PC \leftarrow AR$$



۲۰- نشان دهید که چگونه یک میدان ۹ بیتی ریز عمل در ریز دستورالعمل را می‌توان به زیر میدان‌هایی تقسیم کرد تا ۴۶ ریز عمل را مشخص نمایند؟ چند ریز عمل می‌توان در یک ریز دستورالعمل مشخص کرد؟

حل:

یک زیر میدان ۵ بیتی می‌تواند  $2^5 - 1 = 31$  (NOP) ریز عمل را مشخص کند.

یک زیر میدان ۴ بیتی می‌تواند  $2^4 - 1 = 15$  ریز عمل را مشخص کند.

$$5 + 4 = 9$$

$$31 + 15 = 46$$

۲۱- کامپیوتری دارای ۱۶ ثبات، یک ALU (واحد محاسبه و منطق) با ۳۲ عمل و یک شیفت دهنده با هشت عمل است که همگی به یک سیستم گذرگاه مشترک متصل‌اند.

الف) برای یک ریز عمل کلمه کنترلی بنویسید.

| SRC1 | SRC2 | DEST | ALU | SHIFT |
|------|------|------|-----|-------|
| 4    | 4    | 4    | 5   | 3     |

ب) تعداد بیت‌ها را در هر میدان کلمه کنترلی مشخص کنید و یک طرح رمزگذاری کلی را ارائه نمایید.

۱۶ ثبات به چهار بیت برای انتخاب نیاز دارد. ۳۲ عمل ALU به ۵ بیت و ۸ عمل شیفت به ۳ بیت برای انکد کردن عمل نیاز دارند. برای هر عمل به سه ثبات نیاز داریم.

ج) بیت‌های کلمه کنترل ریز عمل  $R_4 \leftarrow R_5 + R_6$  را نشان دهید.

| R5   | R6   | R4   | ADD   | SHIFT |
|------|------|------|-------|-------|
| ۰۱۰۱ | ۰۱۱۰ | ۰۱۰۰ | ۰۰۱۰۰ | ۰۰۰   |

۲۲- فرض کنید که منطق ورودی توالی‌گر ریز برنامه شکل ۷-۴ چهار ورودی  $I_0, I_1, I_2$  و  $T$  (تست) و سه خروجی  $S_0, S_1$  و  $L$  را داراست. عملیات اجرا شده در واحد در جدول زیر لیست شده است. یک مدار منطقی ورودی با استفاده از حداقل تعداد گیت‌ها طراحی کنید.

| $I_2$ | $I_1$ | $I_0$ | عمل                                        |
|-------|-------|-------|--------------------------------------------|
| ۰     | ۰     | ۰     | افزایش CAR اگر $T=1$ ، پرش به AD اگر $T=0$ |
| X     | ۰     | ۱     | پرش به AD بدون شرط                         |
| ۱     | ۰     | ۰     | افزایش بدون شرط CAR                        |
| ۰     | ۱     | ۰     | پرش به AD اگر $T=1$ ، افزایش CAR اگر $T=0$ |

فراخوانی زیر روال اگر  $T=1$ ، افزایش CAR

|   |   |   |                             |
|---|---|---|-----------------------------|
| ۱ | ۱ | ۱ | $T=0$                       |
| ۰ | ۱ | ۱ | بازگشت بدون شرط از زیر روال |
| ۱ | ۱ | ۱ | نگاشت بدون شرط آدرس خارجی   |

حل:

| $I_2$ | $I_1$ | $I_0$ | $T$ | $S_1$ | $S_0$ | $L$ |         |
|-------|-------|-------|-----|-------|-------|-----|---------|
| 0     | 0     | 0     | 0   | 0     | 1     | 0   | AD1     |
| 0     | 0     | 0     | 1   | 0     | 0     | 0   | INC(0)  |
| 0     | 0     | 1     | 0   | 0     | 1     | 0   | AD(1)   |
| 0     | 0     | 1     | 1   | 0     | 1     | 0   | AD(1)   |
| 0     | 1     | 0     | 0   | 0     | 0     | 0   | INC(0)  |
| 0     | 1     | 0     | 1   | 0     | 1     | 0   | AD(1)   |
| 0     | 1     | 1     | 0   | 1     | 0     | 0   | RET(a)  |
| 0     | 1     | 1     | 1   | 1     | 0     | 0   | RET(a)  |
| 1     | 0     | 0     | 0   | 0     | 0     | 0   | INC(0)  |
| 1     | 0     | 0     | 1   | 0     | 0     | 0   | INC(0)  |
| 1     | 0     | 1     | 0   | 0     | 1     | 0   | AD(1)   |
| 1     | 0     | 1     | 1   | 0     | 1     | 0   | AD(1)   |
| 1     | 1     | 0     | 0   | 0     | 0     | 0   | INC(0)  |
| 1     | 1     | 0     | 1   | 0     | 1     | 1   | CALL(1) |
| 1     | 1     | 1     | 0   | 1     | 1     | 0   | MAP(3)  |
| 1     | 1     | 1     | 1   | 1     | 1     | 0   | MAP(3)  |



۲۳- یک افزایش‌گر ترکیبی ۷ بیتی برای توالی‌گر ریز برنامه شکل ۸-۷ طراحی کنید (شکل ۸-۴) با اضافه کردن یک ورودی کنترلی D افزایش‌گر را تغییر دهید. وقتی  $D=0$  است، مدار یک واحد افزایش می‌یابد، ولی وقتی  $D=1$  است مدار دو واحد افزایش می‌یابد.

حل:

الف) افزایش‌گر ترکیبی ۷ بیتی:



ب) مدار تغییر یافته:



۲۴- بین MUX2 و مدار منطقی ورودی در شکل ۷-۸ یک گیت OR انحصاری قرار دهید. یکی از ورودی‌های گیت از خروجی آزمایشی مالتی پلکسر وارد می‌شود. ورودی دیگر گیت از بیتی با نام P (به معنی قطبیت) در ریز دستورالعمل حاصل از حافظه کنترلی می‌آید. خروجی گیت به ورودی T در مدار منطقی ورودی متصل می‌شود. کنترل قطبیت P چه کاری انجام می‌دهد؟

حل:

P برای تعیین قطبیت بیت وضعیت انتخاب شده به کار می‌رود.



زمانی که  $G \oplus 0 = G$  زیرا  $T = G$  ،  $P = 0$

زمانی که  $G \oplus 1 = G'$  زیرا  $T = G'$  ،  $P = 1$

که در آن G مقدار بیت وضعیت انتخاب شده در MUX2 است.

## فصل هشتم: واحد مرکزی پردازش

۱- یک CPU با ساماندهی گذرگاه مشابه با شکل ۸-۲ دارای ۱۶ ثبات ۳۲ بیتی، یک ALU و یک رمزگشای مقصد است.

الف) چند مولتی پلکسor در گذرگاه A وجود دارد و اندازه هر مولتی پلکسor چقدر است.

ب) چند ورودی انتخاب کننده برای MUX A و MUX B لازم است.

ج) در دیکدر چند ورودی و خروجی وجود دارد؟

د) چند ورودی و خروجی داده، از جمله ورودی و خروجی رقم نقلی، در ALU وجود دارد.

ه) با فرض وجود ۳۵ عمل در ALU، کنترل را برای سیستم فرمولبندی کنید.

حل:

الف) رجیسترها ۳۲ بیتی و ۱۶ رجیستر  $\leftarrow$  ۳۲ مالتی پلکسor هر کدام  $16 \times 1$

ب) ۱۶ رجیستر  $\leftarrow$  هر MUX، ۴ ورودی برای انتخاب یکی از ۱۶ رجیستر

ج) ۱۶ رجیستر  $\leftarrow$  دیکدر ۴ به ۱۶

د) ورودی:  $32+32+1=65$

خروجی:  $32+1=33$

ه) ۱۶ رجیستر، بنابراین تعداد بیت‌ها  $\leftarrow$  SELD=4 ، SELB=4 ، SELA=4 و

$35 = \text{OPR} \leftarrow \text{بیت } 6$

پس،

|      |      |      |     |        |
|------|------|------|-----|--------|
| ۴    | +۴   | +۴   | +۶  | بیت ۱۸ |
| SELA | SELB | SELD | OPR |        |

۲- سیستم شکل ۸-۲ دارای تأخیرهای زمانی زیر است: ۳۰ ns برای انتشار در MUX ۸۰ ns برای عمل جمع در ALU ، ۲۰ ns تأخیر در دیکدر مقصدیاب و ۱۰ ns

برای ورود داده به ثبات مقصد، حداقل سیکل زمانی برای استفاده به عنوان پالس ساعت چقدر است؟

**حل:** طبق مدار، مدار ALU به نتیجه خروجی MUXها بستگی دارد. همچنین نوشتند در رجیستر مقصد به خروجی ALU نیاز دارد. طبق صورت سؤال:

خروجی ALU در (ns) ۱۰۰ آماده است.

خروجی دیکدر در (ns) ۲۰ آماده است.

$$\text{Max}(100, 20) = 100 \Rightarrow$$

$$30 + 80 + 10 = 120n (\text{sec})$$

در حقیقت خروجی دیکدر، حین تشکیل خروجی ALU، آماده شده است.

۳- کلمه کنترلی را که باید به پردازشگر شکل ۸-۲ اعمال شود تا ریز اعمال

زیر را پیاده سازی کند، مشخص کنید.

$$(a) R_1 \leftarrow R_2 + R_3$$

$$(b) R_4 \leftarrow R_4$$

$$(c) R_5 \leftarrow R_5 - 1$$

$$(d) R_6 \leftarrow \text{shLR}_1$$

$$(e) R_7 \leftarrow \text{input}$$

**حل:** جدول زیر را تشکیل می‌دهیم:

| دستور العمل                    | SEL A          | SEL B          | SEL D          | OPR  | کلمه کنترل دودویی |     |          |  |
|--------------------------------|----------------|----------------|----------------|------|-------------------|-----|----------|--|
| $R_1 \leftarrow R_2 + R_3$     | R <sub>2</sub> | R <sub>3</sub> | R <sub>1</sub> | ADD  | 010               | 011 | 00100010 |  |
| $R_4 \leftarrow \bar{R}_4$     | R <sub>4</sub> | —              | R <sub>4</sub> | COMA | 100               | ... | 10001110 |  |
| $R_5 \leftarrow R_5 - 1$       | R <sub>5</sub> | —              | R <sub>5</sub> | DECA | 101               | ... | 10100110 |  |
| $R_6 \leftarrow \text{SH1}R_1$ | R <sub>1</sub> | —              | R <sub>6</sub> | SHLA | 001               | ... | 11011000 |  |
| $R_7 \leftarrow \text{Input}$  | Iinput         | —              | R <sub>7</sub> | TSFA | ...               | ... | 11100000 |  |

۴- ریز عملیات اجراشونده در پردازشگر شکل ۸-۲ را وقتی که کلمات کنترل ۱۴ بیتی زیر اعمال می شود معین کنید.

(الف) ۰۰۱۰۱۱۰۰۱۰۱

(ب) .....00000

(ج) ۰۱۰۰۱۰۰۱۰۰۱۰۰

(د) .....0000010000010

(ه) ۱۱۱۱۰۰۱۱۱۰۰۰

حل: روند جواب این سؤال، عکس روند جواب سؤال قبل است. یعنی با داشتن کلمه کنترل دودویی، می بایست دستورالعمل مناسب را بنویسیم. پس جدول زیر را تشکیل می دهیم.

| ریز دستورالعمل                  | OPR  | SELD  | SELB  | SELA  | کلمه کنترلی دودویی | الف   |
|---------------------------------|------|-------|-------|-------|--------------------|-------|
| $R_3 \leftarrow R_1 - R_2$      | SUB  | $R_3$ | $R_2$ | $R_1$ | ۰۰۱ ۰۱۰ ۰۱۱ ۰۰۱۰۱  | (الف) |
| $Output \leftarrow Input$       | TSFA | None  | Input | Input | ...                | (ب)   |
| $R_2 \leftarrow R_2 \oplus R_2$ | XOR  | $R_2$ | $R_2$ | $R_2$ | ۰۱۰ ۰۱۰ ۰۱۰ ۰۱۱۰۰  | (ج)   |
| $Output \leftarrow Input + R_1$ | ADD  | None  | Input | Input | ۰۰۰ ۰۰۱ ۰۰۰ ۰۰۰۱۰  | (د)   |
| $R_3 \leftarrow Shr R_7$        | SHRA | $R_3$ | $R_4$ | $R_7$ | ۱۱۱ ۱۰۰ ۰۱۱ ۱۰۰۰۰  | (ه)   |

۵- فرض شود در پشته شکل ۸-۳،  $sp=000000$  باشد. چند تعداد داده در

پشته وجود دارد اگر:

(الف) FULL=1, EMPTY=0

(ب) FULL=0, EMPTY=1

حل:

(الف) پشته با ۶۴ داده پر شده است.

(ب) پشته خالی است (دادهای در پشته وجود ندارد)

۶ - پشته طوری سازمان یافته است که همیشه SP به مکان بعدی خالی در پشته اشاره می‌نماید این به آن معنی است که مقدار اولیه SP در شکل ۸-۴ می‌تواند ۴۰۰۰ بوده و اولین داده در پشته در مکان ۴۰۰۰ از پشته ذخیره شود. برای اعمال push و pop عملیات جزئی لازم را بنویسید.

حل: در هر زمان stack pointer به خانه خالی بالای داده‌ها اشاره می‌کند. پس:

$$\begin{array}{ll} \text{push : } 1 - M[SP] \leftarrow DR & \text{pop: } 1 - SP \leftarrow SP + 1 \\ 2 - SP \leftarrow SP - 1 & 2 - DR \leftarrow M[SP] \end{array}$$

۷ - عبارات محاسباتی را از میانوندی به RPN تبدیل کنید.

(الف)  $A * B * C * D + E * F$

(ب)  $A * B + A * (B * D + C * E)$

(ج)  $A + B * [C * D + E * (F + G)]$

(د)  $\frac{A * [B + C * (D + E)]}{F * (G + H)}$

حل: در تبدیل عبارات میانوندی به عبارات RPN، ابتدا درخت عبارت، براساس اولویت پایین به بالا رسم کرده و سپس پیمایش Postorder انجام می‌دهیم. (پیمایش ابتدا فرزند سمت چپ، سپس فرزند سمت راست و سپس پدر را پیمایش می‌کند).

مثال:

$$\begin{aligned} & 3 + 2 * (5 + 8) \\ \Rightarrow & \text{پیمایش} \\ & 3258 + * + \end{aligned}$$



به همین ترتیب برای این سؤال داریم:

(الف)  $AB * CD * EF * ++$

(ب)  $AB * ABD * CE * + * +$

- (ج)  $FG + E * CD * + B * A +$   
 (د)  $ABCDE + * + * FGH + * /$

۸- عبارت محاسباتی زیر را از RPN به میانوندی تبدیل کنید.

- |                     |      |
|---------------------|------|
| ABCDE + * - /       | الف) |
| ABCDE * / - +       | ب)   |
| ABC * / D - EF / +  | ج)   |
| ABCDEFG + * + * + * | د)   |

حل: روند پاسخ این سؤال، عکس سؤال قبل است. یعنی تبدیل فرم RPN به فرم میانوندی عبارت در این سؤال نیز برای عبارت یک پشته ترتیب داده و از چپ به راست عمل می‌کنیم:

در صورت برخورد با عملوند، آن را در پشته push می‌کنیم.

در صورت برخورد با عملگر، دو عنصر بالای پشته را چپ و راست عملگر قرار می‌دهیم و پس عبارت را محاسبه کرده، نتیجه را در پشته push می‌کنیم.

پس داریم:

$$\text{ABCDE} + * - / \Rightarrow \frac{A}{B - (D + E) * C}$$

$$\text{ABCDE} * / - + \Rightarrow A + B - \frac{C}{D * E}$$

$$\text{ABC} * / D - EF / + \Rightarrow \frac{A}{B * C} - D + \frac{E}{F}$$

$$\text{ABCDEFG} + * + * + * \Rightarrow (((F + G) * E + D) * C + B) * A$$

۹- عبارت محاسباتی عددی زیر را به RPN تبدیل و عملیات پشته را برای محاسبه نتیجه نشان دهید.

$$[(3+4)(10(2+6)+8)]$$

حل: ابتدا عبارت را به فرم RPN تبدیل کرده و سپس روند محاسبه عبارت با پشته را اجرا می‌کنیم.

$$(3+4)[10(2+6)+8]=616$$

$$\xrightarrow{\text{RPN}} 34+26+10*8+*$$

حال داریم: از چپ به راست در صورت برخورد با هر عملوند، آن را در پشته push کرده و در صورت برخورد با عملگر، عمل عملگر را با دو عنصر بالای پشته انجام می‌دهیم. در هر ستون، بالاترین داده، عنصر بالای پشته است. ترتیب برخورد با عملوندها و عملگرها در جدول از چپ به راست است.

|      |   |   |   |   |   |    |    |    |    |          |
|------|---|---|---|---|---|----|----|----|----|----------|
|      |   |   |   | ۶ |   | ۱۰ |    | ۸  |    |          |
| پشته |   | ۴ |   | ۲ | ۲ | ۸  | ۸  | ۸۰ | ۸۰ | ۸۸       |
|      | ۳ | ۳ | ۷ | ۷ | ۷ | ۷  | ۷  | ۷  | ۷  | ۶۱۶نتیجه |
|      | ۳ | ۴ | + | ۲ | ۶ | +  | ۱۰ | *  | ۸  | +        |

در اینجا دو نکته مهم وجود دارد.

- ۱- ما به تعداد عملوندها، در پشته عمل push انجام می‌دهیم.
- ۲- اینکه ظرفیت پشته را چقدر در نظر بگیریم «در اینجا ما ظرفیت را ۳ در نظر گرفته ایم» بستگی به آزمون و خطای در بدست آوردن مقدار عبارت با پشته دارد. در اینجا ظرفیت ۳ برای پشته کافی بوده است.
- ۱۰- سازمان یک حافظه به شکل FIFO (اولین ورودی اولین خروجی) است به این مفهوم که اولین داده ذخیره شده، اولین داده بازیابی شده است. نشان دهید چگونه یک حافظه FIFO با سه شمارنده کار می‌کند. یک شمارنده نوشتن، WC، آدرس نوشتن در حافظه را نگه می‌دارد. یک شمارنده خواندن RC آدرس خواندن در حافظه را حفظ می‌نماید. یک شمارنده فضای موجود در حافظه، ASC، تعداد کلمات ذخیره شده در FIFO را معین می‌نماید. ASC برای هر کلمه ذخیره شده یک واحد اضافه می‌شود و بر عکس برای کلمات دریافت شده یک واحد کم می‌گردد.

حل: ساختار FIFO بیانگر ساختار «صف» در ساختمان داده‌ها می‌باشد.

با توجه به سؤال، هر گاه عمل write صورت می‌پذيرد. يك واحد به شمارنده ASC اضافه می‌گردد و هر گاه عمل Read صورت می‌پذيرد، يك واحد از شمارنده ASC کم می‌گردد.

پس:

Write : IF(full=0)

$M[WC] \leftarrow DR$

$WC \leftarrow WC + 1$

$ASC \leftarrow ASC + 1$

Read : IF(empty=0)

$DR \leftarrow M[RC]$

$RC \leftarrow RC + 1$

$ASC \leftarrow ASC - 1$

از دو پرچم full و empty برای چک کردن پر یا خالی بودن صفت استفاده می‌شود.

۱۱- يك کامپيوتر دارای دستورالعمل‌های ۳۲ بیتی و آدرس ۱۲ بیتی است. اگر تعداد ۲۵۰ دستورالعمل دو آدرس وجود داشته باشد، چه تعداد دستورالعمل تک آدرسی را می‌توان تشکیل داد؟

حل: دستورالعمل‌ها ۳۲ بیتی

آدرس‌ها ۱۲ بیتی

$256 - 250 = 6 \leftarrow \text{opcode} \leftarrow 2^8 = 256 \leftarrow 250$  دستورالعمل

پس:

$$8 + 12 + 12 = 32 \text{ بیت}$$

|         |           |           |
|---------|-----------|-----------|
| Op-code | Address 1 | Address 2 |
|---------|-----------|-----------|

دستورالعمل‌های دو آدرسی

پس:

|         |         |
|---------|---------|
| Op-code | Address |
|---------|---------|

$$= 24576 = 6 \times 2^{12} = \text{ماکریم} \text{ تعداد دستورالعمل‌های تک آدرسی} \rightarrow$$

لازم به توضیح است این سؤال در ترجمه کتاب موریس مانو، لحاظ نشده است اما در متن انگلیسی آن مطرح شده است.

۱۲- برنامه‌ای بنویسید که عبارت ریاضی زیر را محاسبه کند.

$$X = A - B + C * (D * E - F)$$

$$G + H * K$$

الف) با استفاده از کامپیوتر با ثبات‌های عمومی و دستورات سه آدرسه

ب) با استفاده از کامپیوتر با ثبات‌های عمومی و دستورات دو آدرسه

ج) با استفاده از کامپیوتر نوع انباره‌ای با دستورات یک آدرسه

د) با استفاده از کامپیوتر با ساماندهی پشته با دستورات صفر آدرسه

حل: ابتدا فرم RPN را با توجه به مباحث مطرح شده به دست می‌آوریم. سپس طبق موارد گفته شده عمل می‌کنیم.

رم RPN: AB-CDE\*F-\*+GHK\*+/

| الف) با دستورات سه آدرسی              | ب) با دستورات دو آدرسی | ج) با دستورات تک آدرسی | د) با دستورات صفر آدرسی               | با استفاده از RPN |
|---------------------------------------|------------------------|------------------------|---------------------------------------|-------------------|
| SUB R <sub>1</sub> ,A,B               | MOV R <sub>1</sub> ,A  | MOV R <sub>1</sub> ,B  | SUB R <sub>1</sub> ,B                 | Load A            |
| MUL R <sub>2</sub> ,D,E               | SUB R <sub>1</sub> ,B  | MOV R <sub>2</sub> ,D  | SUB R <sub>2</sub> ,R <sub>2</sub> ,F | SUB B             |
| SUB R <sub>2</sub> ,R <sub>2</sub> ,F | MOV R <sub>2</sub> ,D  |                        |                                       | Store X           |

|        |                |                                    |                                                    |
|--------|----------------|------------------------------------|----------------------------------------------------|
| SUB    | <b>Load D</b>  | MUL R <sub>2</sub> ,E              | MUL R <sub>2</sub> ,R <sub>2</sub> ,C              |
| Push C | <b>MUL E</b>   | SUB R <sub>2</sub> ,F              | ADD R <sub>1</sub> ,R <sub>1</sub> ,R <sub>2</sub> |
| Push D | <b>SUB F</b>   | MUL R <sub>2</sub> ,C              | MUL R <sub>2</sub> ,H,K                            |
| Push E | <b>MUL C</b>   | ADD R <sub>1</sub> ,R <sub>2</sub> | ADD R <sub>2</sub> ,R <sub>2</sub> ,G              |
| MUL    | <b>ADD X</b>   | MOV R <sub>2</sub> ,H              | DIV X,R <sub>1</sub> ,R <sub>2</sub>               |
| Push F | <b>Store X</b> | MUL R <sub>2</sub> ,K              |                                                    |
| SUB    | <b>Load H</b>  | ADD R <sub>2</sub> ,G              |                                                    |
| MUL    | <b>MUL K</b>   | DIV R <sub>1</sub> ,R <sub>2</sub> |                                                    |
| ADD    | <b>ADD G</b>   | MOV X,R <sub>1</sub>               |                                                    |
| Push G | <b>Store T</b> |                                    |                                                    |
| Push H | <b>Load X</b>  |                                    |                                                    |
| Push K | <b>DIV T</b>   |                                    |                                                    |
| MUL    | <b>Store X</b> |                                    |                                                    |
| ADD    |                |                                    |                                                    |
| DIV    |                |                                    |                                                    |
| POP X  |                |                                    |                                                    |

۱۳- واحد حافظه کامپیوتر K ۲۵۶ ۳۲ بیتی دارد. کامپیوتر دارای قالب دستورات چهار میدانی است: میدان کد عملیاتی ، میدان روش آدرس دهی برای هفت روش موجود، میدان آدرس ثبات برای انتخاب یکی از ۶۰ ثبات پردازشگر، و آدرس حافظه، قالب دستور و تعداد بیت‌ها در هر میدان را اگر دستور در یک کلمه حافظه باشد معین کنید.

حل:

ظرفیت حافظه:  $2^{18} \times 2^{10} = 256k = 2^8$

تعداد رجیسترها:  $60 = 2^6$  بیت مشخص کردن رجیستر

تعداد مدهای آدرس دهی:  $8 = 2^3$  بیت مشخص کردن مد آدرس دهی

پس:

| op-code        | Mode | Resister | Address | = ۳۲ |
|----------------|------|----------|---------|------|
| ۵ + ۳ + ۶ + ۱۸ |      |          |         |      |

۱۴- یک دستور دو کلمه‌ای در حافظه و در آدرسی که با سمبول W مشخص شده ذخیره شده است. میدان آدرس دستور، (ذخیره شده در  $W+1$ ) با سمبول Y معین شده است. عملوند بکار رفته در هنگام اجرای دستور در آدرس Z قرار دارد. یک ثبات اندیس دارای مقدار X است. نشان دهید که چگونه Z از سایر آدرس‌ها محاسبه می‌شود اگر که روش آدرس دهی دستور به شکل زیر باشد.

الف) مستقیم    ب) غیرمستقیم    ج) نسبی    د) اندیس دار

حل: آدرس مؤثر در Z

الف) مستقیم:  $Z=Y$

ب) غیرمستقیم:  $Z=M[Y]$

ج) نسبی:  $Z=Y+W+Z$   
↓  
آدرس بعدی PC

و) اندیس دار:  $Z=Y+X$

۱۵- یک دستور العمل انشعاب از نوع نسبی در آدرس معادل دهدھی ۷۵۰ از یک حافظه ذخیره شده است انشعاب به آدرس ۵۰۰ صورت گرفته است.

الف) مقدار میدان آدرس نسبی دستور (معادل دهدھی) چقدر است؟

ب) مقدار میدان آدرس نسبی را به دودویی در ۱۲ بیت نشان دهید. (چرا باید

عدد به فرم مکمل ۲ باشد؟)

ج) مقدار دودویی در PC را پس از فاز برداشت (واکشی) بدست آورید و

مقدار ۵۰۰ را محاسبه کنید، سپس نشان دهید که مقدار دودویی در PC بعلاوه آدرس نسبی محاسبه شده در قسمت (ب) برابر عدد دودویی ۵۰۰ است.

حل: در خانه ۷۰۰ هستیم  $\leftarrow PC=751$  حال با چه آدرس نسبی باید به آدرس ۵۰۰ برویم؟  
(الف)

$500 - 751 = -251$  : آدرس نسبی  
(ب)

$-251 = 2's \text{ complement } (251) = 111100000101$   
(ج)

$$PC=751=001^011101111$$

$$RA : -251=111100000101$$

$$\Rightarrow 500 = PC + RA = 000111110100$$

۱۶- واحد کنترل وقتی که یک دستور با آدرس غیرمستقیم را برداشت و اجرا می کند، چند بار به حافظه مراجعه می نماید اگر الف) دستور از نوع محاسباتی بوده و یک عملوند را از حافظه لازم داشته باشد ب) دستور از نوع انشعاب باشد.

حل:

دستورالعمل حسابی:  $3 = \text{درباره} + \text{درباره} + \text{درباره}$   
درباره دستورالعمل از حافظه

دستورالعمل انشعاب:  $2 = \text{درباره} + \text{درباره} + \text{درباره}$   
دستورالعمل از حافظه

۱۷- میدان آدرس یک دستور با آدرس اندیس دار چه باشد تا مشابه یک دستور غیرمستقیم ثباتی گردد؟

حل: طبق تعریف داریم:

مد آدرس دهی ثباتی غیرمستقیم: محتویات  $R_1 = \text{آدرس مؤثر}$ ,  $R_1 = \text{ثبات}$

مد آدرس دهی شاخص دار: آدرس موجود در دستور العمل + محتویات  $R_1$  = آدرس مؤثر  
 ثبات  $R_1$  =

بنابراین برای برآورده کردن خواسته سؤال:  $\phi = \text{آدرس موجود در دستور العمل}$   
 ۱۸- یک دستور در مکان ۳۰۰ با میدان آدرسش در مکان ۳۰۱ ذخیره شده است.  
 میدان آدرس دارای مقدار ۴۰۰ است. یک ثبات پردازشگر  $R_1$  نیز حاوی عدد ۲۰۰ است. آدرس مؤثر را اگر روش آدرس دهی دستور (الف) مستقیم (ب) بلافصل (ج) نسبی (د) غیر مستقیم (ثباتی ه) شاخص دار با  $R_1$  به عنوان ثبات شاخص باشد به دست آورید.

حل:

(الف) مد آدرس دهی مستقیم: آدرس مؤثر = ۴۰۰

(ب) مد آدرس دهی بلافصل: آدرس مؤثر = ۳۰۱

(ج) مد آدرس دهی نسبی: آدرس مؤثر =  $302 + 400 = 702$

(د) مد آدرس دهی ثباتی غیر مستقیم: آدرس مؤثر = ۲۰۰

(ه) مد آدرس دهی شاخص دار: آدرس مؤثر =  $200 + 400 = 600$

۱۹- با فرض داشتن یک کامپیوتر ۸ بیتی، یک جمع با دقت مضاعف برای اعداد بدون علامت ۳۲ بیتی زیر با استفاده از دستور جمع با رقم نقلی را انجام دهید. هر بایت به صورت عدد دو رقمی مبنای ۱۶ می باشد.

$$(6E \ C3 \ 56 \ 78) + (13 \ 55 \ 6B \ 8F)$$

حل: برای این عبارت، دو رقم دو رقم شانزده شانزدهی را جمع کرده و در هر جمع، رقم نقلی را محاسبه کرده به بعدی می دهیم:

$$\begin{array}{r} 6E \quad C3 \quad 56 \quad 7A \\ 13 \quad 55 \quad 6B \quad 8F \\ \hline 82 \quad 18 \quad C2 \quad \phi9 \\ C=1 \quad C=0 \quad C=1 \quad C=0 \end{array}$$

رقم نقلی ورودی      رقم نقلی خروجی = ۰

۲۰- برای دو رشته اعداد دودویی  $10011100$  و  $10101010$ ، اعمال منطقی **XOR**, **OR**، **AND** را انجام دهید.

حل:

$$\begin{array}{r} \text{AND : } 10011100 \\ \quad 10101010 \\ \hline \quad 10001000 \end{array}$$

$$\begin{array}{r} \text{OR : } 10011100 \\ \quad 10101010 \\ \hline \quad 10111110 \end{array}$$

$$\begin{array}{r} \text{XOR : } 10011100 \\ \quad 10101010 \\ \hline \quad 00110110 \end{array}$$

۲۱- عدد ۱۶ بیتی  $10011011001101$  مفروض است. چه عملی باید انجام

داد تا:

- الف) ۸ بیت اول ۰ شود.
- ب) هشت بیت آخر ۱ شود.
- ج) هشت بیت وسط مکمل شود.

حل: فرض شود  $A = 1001101011001101$

الف) برای ۰ کردن تعدادی از بیت‌ها از عملگر AND استفاده می‌کنیم. (AND) مکان‌های بدون تغییر ۱ و مکان‌های مورد نظر برای  $A = (1001101011001101)$  Mask  
۰ شدن، ۰ در نظر می‌گیریم. پس:

$\text{AND } (A, 0000000011111111)$

ب) برای ۱ کردن تعدادی از بیت‌ها از عملگر OR استفاده می‌کنیم.

مکان‌های بدون تغییر و مکان‌های مورد نظر برای ۱ شدن، ۰ در نظر می‌گیریم.

پس:

$OR(A, 0000\ 00001111\ 1111)$

ج) برای مکمل کردن تعدادی از بیت‌ها از عملگر XOR استفاده می‌کنیم.

مکان‌های بدون تغییر، ۰ و مکان‌های مورد نظر برای مکمل کردن، ۱ در نظر

می‌گیریم پس:

$XOR(A, 0000\ 1111\ 1111\ 0000)$

۲۲- یک ثبات ۸ بیتی دارای مقدار  $11110110$  است و بیت نقلی نیز ۱ است.

هشت عمل شیفت موجود در جدول ۸-۹ را روی آنها پیاده کنید. هر بار مقدار اولیه عدد داده شده بالا باشد.

حل: داده اولیه:  $1111010$  و  $1 = Carry$  داریم:

SHR : ۰۰۱۱۱۱۰۱ (شیفت به راست منطقی)

SHL : ۱۱۱۱۰۱۱۰ (شیفت به چپ منطقی)

SHRA : ۰۰۱۱۱۱۰۱ (شیفت به راست حسابی)

تغییر بیت علامت  $\leftarrow$  رخداد سرریز  $< 11110110$  (شیفت به چپ حسابی)

ROR : ۱۰۱۱۱۱۰۱ (چرخش به راست)

ROL : ۱۱۱۱۰۱۱۰ (چرخش به چپ)

RORC : ۱۰۱۱۱۱۰۱ (چرخش به راست با نقلی)

ROLC : ۱۱۱۱۰۱۱۱ (چرخش به چپ با نقلی)

۲۳- اعداد علامت‌دار روبرو را به شکل اعداد دودویی را به صورت ۸ بیت

نمایش دهید،  $-83$  و  $+83$  و  $-63$  و  $+63$ .

الف) جمع  $(+83) + (-83)$  را به دودویی انجام و نتیجه را تفسیر کنید.

ب) تفریق  $(+83) - (-68)$  را به دودویی انجام و نشان دهید که سرریز رخ

می‌دهد.

ج) عدد دودویی ۶۸ را یکبار به راست شیفت دهید و مقدار شیفت داده شده را به دهدھی بدست آورید.

د) عدد دودویی ۸۳ را یکبار به چپ شیفت دهید و بینید آیا سرریز وجود دارد یا نه؟

حل: اعداد منفی را مکمل ۲ خواهیم کرد.

$$+83 : 01010011$$

$$+68 : 01000100$$

$$-83 : 10101101$$

$$-68 : 10111100$$

(الف)

$$\begin{array}{r} -83 \\ +68 \\ \hline -15 \end{array}$$

$$\begin{array}{r} 10101101 \\ 01000100 \\ \hline 11110001 \end{array}$$

ب) تشخیص سریز با XOR کردن دو رقم نقلی آخر صورت می‌پذیرد.

$$-68 - (+83) = -68 + (-83)$$

$$\Rightarrow -68 \quad 10111100$$

$$\begin{array}{r} -83 \\ 10101101 \\ \hline 01101001 \end{array}$$

با توجه به دو رقم نقلی آخر، سرریز رخداده است.

(ج)

$$-68 : 10111100 \Rightarrow 11011110 : -34$$

(د)

$$-83 : 10101101 \Rightarrow 01011010 : -166$$

بیت علامت تغییر کرده است. پس سرریز رخداده است.

۲۴- نشان دهید مداری که خرجی ۰ را در شکل ۸-۸ چک می‌کند، یک

گیت NOR است.

حل: برای تشخیص ۰ بودن جواب ALU، می‌بایست بیان کنید که تک تک بیت‌های جواب ۰ هستند.

$Z = F'_0 + F'_1 + F'_2 + F'_3 + F'_4 + F'_5 + F'_6 + F'_7 = (F_0 + F_1 + F_2 + F_3 + F_4 + F_5 + F_6 + F_7)' \quad : \text{NOR}$

۲۵- یک کامپیوتر ۸ بیت دارای یک ثبات R است. مقادیر بیت‌های وضعیت C و S و Z و V (شکل ۸-۸) را پس از اجرای هر یک از دستورات زیر معین کنید.

مقدار اولیه R در هر مورد ۷۲ در مبنای شانزده است. اعداد زیر نیز در مبنای شانزده هستند.

الف) عملوند بلافصل C6 را با R جمع کنید.

ب) عملوند بلافصل 1E را با R جمع کنید.

ج) عملوند بلافصل 9A را از R کم کنید.

د) R را با R, XOR نمایید.

حل: متذکر می‌شویم مواردی که رخداد سرریز را موجب می‌شوند، فعلاً جمع و منها و شیفت حسابی به راست هستند. برای یافتن مقدارها، دو رقم نقلی آخر محاسبه و بیت علامت محاسبه اهمیت دارند.

$$\begin{array}{r} 01110010 \\ +00011110 \\ \hline 10010000 \end{array} \quad \text{ب)$$

$$C=0, S=1, Z=0, V=1$$

$$\begin{array}{r} 01110010 \\ +11000110 \\ \hline 00111000 \end{array} \quad \text{الف)}$$

$$C=1, S=0, Z=0, V=0$$

$$\begin{array}{r} 01110010 \\ \text{AND } 10001100 \\ \hline 00000000 \end{array} \quad \text{د)}$$

$$\begin{array}{r} R - 9A = R + (-9A) \\ -9A = 01100110 \\ +01110010 \\ \hline 11011000 \end{array} \quad \text{ج)}$$

$$C=0, S=0, Z=1, V=0$$

$$C=0, S=1, Z=0, V=1$$

(ه)

$$\begin{array}{r} 01110010 \\ \text{XOR} + 01110010 \\ \hline 00000000 \end{array}$$

$$C=0, S=0, Z=1, V=0$$

۲۶- دو عدد بدون علامت توسط رابطه  $A-B$  با هم مقایسه شده‌اند. بیت نقلی به عنوان بیت قرض پس از مقایسه در بیشتر کامپیوترهای تجاری در نظر گرفته می‌شود، به طوری که اگر  $B < A$  باشد  $C=1$  است. نشان دهید که نسبت اندازه  $A$  نسبت به  $B$  از وضعیت  $C$  و  $Z$  طبق جدول مربوط به این مسئله و (جدول ۸-۱۱) قابل استنتاج است.

حل: طبق سؤال، وضعیت‌های شرطی جدول ۸-۱۱، برای  $A$  و  $B$  بدون علامت، از طریق بیت‌های  $C$  و  $Z$  تعیین می‌گردد.(مقایسه با  $(A-B)$ )

پس داریم:

$$C=1 \Leftrightarrow A < B \Rightarrow C=0 \Leftrightarrow A \geq B$$

$$Z=1 \Leftrightarrow A = B \Rightarrow Z=0 \Leftrightarrow A \neq B$$

بنابراین:

$$A > B \Leftrightarrow (A \geq B) \text{ AND } (A \neq B) : C=0 \text{ AND } Z=0 : (C'Z')=1$$

$$A \leq B \Leftrightarrow (A < B) \text{ OR } (A = B) : C=1 \text{ OR } Z=1 : (C+Z)=1$$

پس:

| رابطه      | وضعیت بیت‌ها |
|------------|--------------|
| $A > B$    | $(C'Z')=1$   |
| $A \geq B$ | $C=0$        |

|            |               |
|------------|---------------|
| $A < B$    | $C = 1$       |
| $A \leq B$ | $(C + Z) = 1$ |
| $A = B$    | $Z = 1$       |
| $A \neq B$ | $Z = 0$       |

۲۷- دو عدد علامت‌دار به شکل مکمل ۲ با هم طبق رابطه  $A - B$  مقایسه شده‌اند. با توجه به نتیجه مقایسه بیت‌های وضعیت  $S$  و  $Z$  و  $V$  و  $0$  و  $1$  خواهند شد. (دقیق کنید که اگر سرریز رخ دهد تغییر علامتی وجود خواهد داشت). نشان دهید که اندازه نسبی  $A$  نسبت به  $B$  با توجه به بیت‌های وضعیت در جدول مربوط به این مسئله (و جدول ۸-۱۱) قابل استنتاج است.

حل: طبق سؤال، وضعیت‌های شرطی جدول ۸-۱۱، برای  $A$  و  $B$  علامت‌دار از طریق بیت‌های  $S$ ،  $V$  و  $Z$  تعیین می‌گردد.

داریم:

$$A \geq B \Rightarrow (A - B) \geq 0 \Rightarrow \begin{cases} S = 1, V = 1 \\ S = 0, V = 0 \end{cases} \Rightarrow (S \oplus V) = 0$$

$$A < B \Rightarrow \begin{cases} S = 1, V = 0 \\ S = 0, V = 1 \end{cases} \Rightarrow (S \oplus V) = 1$$

$$A > B \Rightarrow (A \geq B) \text{ AND } (A \neq B) \Rightarrow (S \oplus V) = 0 \quad \text{and} \quad Z = 0$$

$$A \leq B \Rightarrow (A < B) \text{ OR } (A = B) \Rightarrow (S \oplus V) = 1 \quad \text{OR} \quad Z = 1$$

پس:

| رابطه      | وضعیت بیت‌ها                                    |
|------------|-------------------------------------------------|
| $A > B$    | $(S \oplus V) = 0 \quad \text{and} \quad Z = 0$ |
| $A \geq B$ | $(S \oplus V) = 0$                              |

$$A < B \quad (S \oplus V) = 1$$

$$A \leq B \quad (S \oplus V) = 1 \quad \text{or} \quad Z = 1$$

$$A = B \quad Z = 1$$

$$A \neq B \quad Z = 0$$

۲۸- لازم است یک مدار دیجیتال با چهار ورودی  $C$  و  $S$  و  $V$  و  $Z$  با ۱۰ خروجی طراحی شود، که هر یک مربوط به یک شرط انشعاب در مسئله ۲۶ و ۲۷ است. (حالات مساوی و نامساوی در هر دو جدول یکی است). نمودار منطقی مدار با استفاده از دو گیت OR، یک XOR و پنج معکوس‌کننده را رسم کنید.

حل: برای طراحی مدار منطقی رابطه‌های گفته شده، از نتایج بدست آمده در پاسخ سوالات ۲۶ و ۲۷ استفاده کرده و با استفاده از بیت‌های  $S$ ،  $V$ ،  $Z$ ،  $C$  به عنوان ورودی، مدار را طراحی می‌نماییم.





۲۹- دو عدد ۸ بیتی  $A = 01000001$  و  $B = 10000100$  مفروض اند.

- الف) معادل دهدھی هر عدد را با فرض اینکه (۱) آنها بدون علامت و (۲) علامتدار هستند بدست آورید.
- ب) دو عدد دودویی را جمع کنید و نتیجه را تفسیر کنید با این فرض که (۱) بدون علامت و (۲) علامت دارند.
- ج) مقادیر بیت‌های  $C$  و  $Z$  و  $S$  و  $V$  را پس از جمع مشخص کنید.
- د) دستورات انشعابی شرطی که شرط آنها برقرار است را از جدول (۱۱-۸) لیست کنید.

حل:

$$A = 01000001$$

$$\begin{array}{r} + B = 10000100 \\ \hline 11000101 \end{array}$$

(ب)

$$65 + 132 = 197 \quad \text{بدون علامت: } A \text{ و } B \text{ مثبت}$$

$$65 - 124 = -59 \quad \text{علامتدار: } A \text{ مثبت، } B \text{ منفی}$$

ج) با توجه به قسمت الف  $C = 0, Z = 0, S = 1, V = 0$

د) رابطه‌های انشعابی برقرار:

$$C=0 \Rightarrow BNC$$

$$Z=0 \Rightarrow BNZ$$

$$S=1 \Rightarrow BM$$

$$V=0 \Rightarrow BNV$$

۳۰- برنامه‌ای در یک کامپیوتر دو عدد بدون علامت A و B را با انجام عمل

A-B و تصحیح بیت‌های وضعیت مقایسه می‌کند. اگر A=01000001 و

B=10000100 باشد،

الف) اختلاف را محاسبه و نتیجه دودویی را تفسیر کنید.

ب) مقادیر بیت‌های وضعیت C (فرض) و Z را معین کنید.

ج) دستورات انشعاب شرطی را از جدول ۸-۱۱ که اتفاق می‌افتد را لیست کنید.

حل:

(الف)

$$\begin{array}{r} A - B = A + (-B) \\ A = 01000001 \quad 65 \\ B = 10000100 \quad 132 \\ \hline A - B \quad \quad \quad 10111101 \quad -67 \end{array}$$

(ب)

Z=0 , C=1 رقم قرض در تفریق

(ج)

$$A=65 , B=132 \Rightarrow A < B \Rightarrow BL , BLE , BNE$$

↓ ↓ ↓  
مخالف کوچکتر مساوی کوچکتر

۳۱- برنامه‌ای در یک کامپیوتر دو عدد علامت‌دار A و B را با پیش قالب بنده

عمل A-B تصحیح بیت‌های وضعیت مقایسه می‌کند. اگر A=01000001 و

$B = 10000100$  باشد.

الف) اختلاف را محاسبه و نتیجه دودویی را تفسیر کنید.

ب) مقادیر بیت‌های S و Z را معین کنید.

ج) دستورات انشعباب شرطی را از جدول ۸-۱۱ که اتفاق می‌افتد لیست کنید.

حل: A و B علامت‌دار هستند.

$$\begin{array}{r}
 A = 01000001 : 65 \\
 - B = 10000100 : 124 \\
 \hline
 A - B = 10111101
 \end{array}
 \quad
 \begin{array}{r}
 01000001 \\
 + 01111100 \\
 \hline
 10111101
 \end{array}
 \quad \text{الف)$$

ب) با توجه به قسمت الف:

ج)

$A = 65, B = -124 \Rightarrow A > B \Rightarrow \text{BGT, BGE, BNE}$

مخالف کوچکتر مساوی بزرگتر

۳۲- محتويات بالاترین مکان حافظه یک پشته ۵۳۲۰ است. محتوای اشاره‌گر پشته (SP) نیز ۳۵۶۰ می‌باشد. یک دستور فراخوانی دو کلمه‌ای در آدرس ۱۱۲۰ حافظه قرار دارد و در آدرس ۱۱۲۱ هم میدان آدرس آن یعنی ۶۷۲۰ ذخیره شده است. محتوای PC و SP و بالاترین مکان پشته چیست؟

الف) قبل از برداشتن دستور فراخوانی از حافظه

ب) پس از اجرای دستور فراخوانی

ج) پس از بازگشت از زیر روال

حل:

| PC            | SP   | مقدار بالای<br>TOS → stack |
|---------------|------|----------------------------|
| مقدار ابتدایی |      |                            |
| ۱۱۲۰          | ۳۵۶۰ | ۵۳۲۰                       |

  

|                        |      |      |      |
|------------------------|------|------|------|
| بعد از فراخوانی "Call" | ۶۷۲۰ | ۳۵۵۹ | ۱۱۲۲ |
|------------------------|------|------|------|

۱۱۲۲      ۳۵۶۰      ۵۳۲۰      بعد از بازگشت "Return"

### ۳۳- اختلاف عمدۀ بین دستور انشعاب، فراخوانی و وقفه برنامه چیست؟

حل: دستورالعمل انشعاب: انشعاب به قسمتی از حافظه بدون بازگشت به قسمت

قبلی

زیر روال و فراخوانی آن: انشعاب به زیر روال و سپس بازگشت به برنامه اصلی  
وقفه نرمافزاری: انشعاب به یک روتین اجرای وقفه «آدرس وقفه به صورت سختافزاری مشخص می‌گردد» و امکان بازگشت به برنامه اصلی

۳۴- پنج مثال از وقفه خارجی و پنج مثال از وقفه داخلی را ارائه نمایید. فرق بین وقفه نرمافزاری و فراخوانی زیر روال چیست؟

حل: منابع «وقفه» خارجی، دستگاه‌های ورودی و خروجی، زمان‌سنج‌ها، مدارهای مربوط به کنترل منبع تغذیه (power) و... را شامل می‌شوند. پس می‌توان موارد زیر را به عنوان وقفه خارجی لیست کرد:

- وقفه دستگاه ورودی و خروجی برای درخواست ارسال داده
- وقفه دستگاه ورودی و خروجی برای اعلام پایان ارسال داده
- وقفه قطع برق از منبع تغذیه
- وقفه تایمر برای افتادن در حلقه‌های نامتناهی
- وقفه انقضای زمان یک رخداد

منابع وقفه داخلی، کاربرد غیر مجاز و اشتباه دستورات و داده‌ها هستند؛

مثال‌هایی از وقفه داخلی عبارت‌اند از:

- سرریز شدن رجیسترها مانند پشته "stack overflow"
- تقسیم بر صفر شدن در یک عبارت حسابی
- اجرای کد عملیاتی نامعتبر

- اجرای دستورالعمل با آدرس توقیف شده «آدرس مربوط به یک پردازه دیگر در حافظه»

- سر ریز شدن پشته

تفاوت وقفه‌های نرمافزاری و فراخوانی زیر روال‌ها به شرح زیر است:

- ۱- آدرس وقفه‌ها به صورت سخت‌افزاری مشخص می‌گردد در صورتی که آدرس فراخوانی زیر روال‌ها به صورت دستورالعمل در حافظه مشخص می‌گردد.
  - ۲- حین اجرای وقفه‌های نرمافزاری، مواردی مانند PC، رجیسترها پردازند و بیت‌های وضعیت "PSW" ذخیره می‌گردند و سپس بازیابی می‌شوند. در حالی که حین فراخوانی زیر روال، تنها PC ذخیره و سپس بازیابی می‌شود.
- ۳۵- کامپیوتری با انتقال PC و PSW (کلمه وضعیت برنامه) به یک وقفه پاسخ می‌دهد و سپس PSW جدیدی را از مکان IAD که توسط آدرس وقفه مشخص می‌شود می‌خواند. اولین آدرس برنامه سرویس وضعیت از IAD+1 خوانده می‌شود.
- الف) رشته عملیات جزئی را برای سیکل وقفه لیست کنید.

ب) رشته عملیات را برای بازگشت از زیر روال وقفه لیست کنید.

حل: کلمه وضعیت بیت‌های برنامه "PSW" و شمارنده دستورالعمل "PC" ذخیره و بازیابی می‌شوند. همچنین طبق ماهیت پشته که LIFO است، در هنگام ذخیره ابتدا PSW و سپس PC ذخیره می‌شود و هنگام بازیابی، ابتدا PC و سپس PSW بازیابی می‌شوند.

(الف)

$SP \leftarrow SP - 1$

$M[SP] \leftarrow PSW$

$SP \leftarrow SP - 1$

$M[SP] \leftarrow PC$

"Temp" TR  $\leftarrow$  IAD

$PSW \leftarrow M[TR]$

$TR \leftarrow TR + 1$

$PC \leftarrow M[TR]$   
 ↓  
 ابتدای فاز برداشت دستورالعمل

(ب)

$PC \leftarrow M[SP]$

$SP \leftarrow SP + 1$

$PSW \leftarrow M[SP]$

$SP \leftarrow SP + 1$

۳۶— مثال‌هایی از کامپیوتراهای دارای قالب دستورات متغیر عبارت‌اند از  
 VAX11 و IBM370 و Intel 386 قالب دستورات یکی از آنها را با دستورات با طول  
 ثابت RISCI مقایسه کنید.

حل: برای نمونه قالب دستورالعمل‌های IBM 370 در اینجا اشاره می‌شود:

۶ نوع قالب دستورالعمل دارد به شرح زیر:

|    |         |                |                |
|----|---------|----------------|----------------|
| RR | Op-code | R <sub>1</sub> | R <sub>2</sub> |
|----|---------|----------------|----------------|

|    |         |                |                |                |                |
|----|---------|----------------|----------------|----------------|----------------|
| RX | Op-code | R <sub>1</sub> | X <sub>2</sub> | B <sub>2</sub> | D <sub>2</sub> |
|----|---------|----------------|----------------|----------------|----------------|

|    |         |                |                |                |                |
|----|---------|----------------|----------------|----------------|----------------|
| RS | Op-code | R <sub>1</sub> | R <sub>3</sub> | B <sub>2</sub> | D <sub>2</sub> |
|----|---------|----------------|----------------|----------------|----------------|

|    |         |                |                |                |
|----|---------|----------------|----------------|----------------|
| SI | Op-code | I <sub>2</sub> | B <sub>1</sub> | D <sub>1</sub> |
|----|---------|----------------|----------------|----------------|

|    |         |   |                |                |                |                |
|----|---------|---|----------------|----------------|----------------|----------------|
| SS | Op-code | L | B <sub>1</sub> | D <sub>1</sub> | B <sub>2</sub> | D <sub>2</sub> |
| S  | Op-code |   | B <sub>2</sub> | D <sub>2</sub> |                |                |

بقیه موارد جستجو شده و مقایسه‌ها انجام شود.

۳۷- سه کامپیوتر از دریچه‌های ثبات زیر استفاده می‌کنند، سایز دریچه‌ها و تعداد کل ثبات در هر ثبات چقدر است؟

|                | کامپیوتر ۱ | کامپیوتر ۲ | کامپیوتر ۳ |
|----------------|------------|------------|------------|
| ثبات‌های عام   | ۱۰         | ۸          | ۱۶         |
| ثبات‌های محلی  | ۱۰         | ۸          | ۱۶         |
| ثبات‌های مشترک | ۶          | ۸          | ۱۶         |
| تعداد دریچه‌ها | ۸          | ۴          | ۱۶         |

حل: طبق تعاریف داریم:

$$\left. \begin{array}{l} \text{Computer1 : } 10+12+10=32 \\ \text{Computer2 : } 8+16+8=32 \\ \text{Computer3: } 16+32+16=64 \end{array} \right\} \begin{array}{c} \text{ساizer پنجره} \\ \downarrow \quad \downarrow \quad \downarrow \\ \text{عمومی مشترک شخصی} \end{array} = L+2C+G$$

$$\leftarrow (L+C)W+G = \begin{array}{c} \text{ساizer رجیستر فایل} \\ \searrow \\ \text{تعداد پنجره} \end{array}$$

$$\text{Computer 1 : } (10+6)8+10=138$$

$$\text{Computer2 : } (8+8)4+18=72$$

$$\text{Computer3 : } (16+16)16+16=528$$

۳۸- مثالی از یک دستور کامپیوتر I RISC که اعمال زیر را انجام دهد ارائه کنید.

الف) یک ثبات را کاهش می‌دهد.

ب) یک ثبات را مکمل می‌کند.

ج) علامت محتوای ثبات را معکوس می‌کند.

د) یک ثبات را  $^0$  می‌کند.





۲- یکنما دار فاصله - زمان برای یک خط لوله شش قطعه‌ای رسم کنید که زمان پردازش هشت وظیفه را نشان دهد.

| قطعه | 1              | 2              | 3              | 4              | 5              | 6              | 7              | 8              | 9              | 10             | 11             | 12             | 13             |
|------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 1    | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> | T <sub>7</sub> | T <sub>8</sub> |                |                |                |                |                |
| 2    |                | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> | T <sub>7</sub> | T <sub>8</sub> |                |                |                |                |
| 3    |                |                | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> | T <sub>7</sub> | T <sub>8</sub> |                |                |                |
| 4    |                |                |                | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> | T <sub>7</sub> | T <sub>8</sub> |                |                |
| 5    |                |                |                |                | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> | T <sub>7</sub> | T <sub>8</sub> |                |
| 6    |                |                |                |                |                | T <sub>1</sub> | T <sub>2</sub> | T <sub>3</sub> | T <sub>4</sub> | T <sub>5</sub> | T <sub>6</sub> | T <sub>7</sub> | T <sub>8</sub> |

$(k + n - 1)t_p = 6 + 8 - 1 = 13$  پالس ساعت

۳- تعداد سیکل‌های ساعتی که برای ۲۰۰ وظیفه در یک خط لوله شش قطعه‌ای لازم است را معین کنید.

حل:

اگر  $k$  تعداد قطعه و  $n$  تعداد وظیفه باشد، پس از  $k$  سیکل ساعت اجرای دستور اول تمام می‌شود و  $n-1$  دستور باقی‌مانده هر کدام در یک سیکل ساعت به پایان می‌رسند. پس داریم:

سیکل ساعت  $= k+n-1 = 62+200-1 = 205$  = تعداد سیکل ساعت مورد نیاز

۴- یک سیستم غیر خط لوله‌ای برای پردازش یک وظیفه  $50 \text{ ns}$  زمان نیاز دارد.

همان وظیفه در یک خط لوله شش قطعه‌ای به یک سیکل ساعت  $10 \text{ nano-second}$  نیازمند است. نسبت افزایش سرعت خط لوله برای  $100$  وظیفه را معین کنید.

حداکثر تسریع قابل دسترسی چقدر است؟

حل:

$$S = \frac{\text{زمان اجرای غیر خط لوله‌ای}}{\text{زمان اجرای خط لوله‌ای}} = \frac{ntn}{(k+n-1)tp} = \frac{100 \times 50}{(6+99) \times 10} = \frac{500}{105} = 4,76$$

$$t_n = 50 \text{ ns}, k = 6, t_p = 10 \text{ ns}, n = 100$$

$$S_{\max} = \lim_{n \rightarrow \infty} \frac{nt_n}{(k+n-1)tp} = \frac{t_n}{t_p} = \frac{50}{10} = 5$$

۵- خط لوله شکل ۹-۲ دارای زمانهای انتشار زیر است:  $40 \text{ ns}$  برای خواندن

عملوند از حافظه به ثبات  $R_2, R_1, 45 \text{ ns}$  برای انتشار سیگنال در ضرب کننده،  $5 \text{ ns}$

برای انتقال به  $R_3$  و  $15 \text{ ns}$  برای جمع دو عدد و قرار دادن آن در  $R_5$

الف) حداقل سیکل ساعتی که می‌توان به کار برد چقدر است؟

$$t_p = 45 + 5 = 50$$

حداقل  $t_p$  برابر است با حداکثر زمان انتشار قطعه‌ها

ب) یک سیستم غیر خط لوله‌ای می‌تواند همین عمل را با حذف  $R_3$  و  $R_4$  انجام دهد. ضرب و جمع عملوندها بدون استفاده از خط لوله چقدر طول می‌کشد؟

$$t_n = 40 + 45 + 15 = 100 \text{ ns}$$

ج) تسریع عملکرد خط لوله را برای ۱۰ وظیفه و نیز برای ۱۰۰ وظیفه محاسبه کنید.

K=3

$$S = \frac{nt_n}{(k+n-1)t_p} = \frac{10 \times 100}{(3+9)50} = 1.67 \quad \text{برای } n=10$$

$$S = \frac{100 \times 100}{(3+99)50} = 1.96 \quad \text{برای } n=100$$

د) بیشینه افزایش سرعت قابل دستیابی چقدر است؟

$$S_{\max} = \frac{t_n}{t_p} = \frac{100}{50} = 2$$

۶- می خواهیم یک خط لوله ضرب ممیز شناور که دو عدد صحیح دودویی هشت بیتی را ضرب می کند طراحی کنیم. هر قطعه از تعدادی گیت AND و یک جمع کننده دودویی شبیه به ضرب کننده آرایه در شکل ۱۰-۱۰ تشکیل شده است.

الف) در هر قطعه چند گیت AND وجود دارد و جمع کننده با چه اندازه ای نیاز است؟

با مراجعه به بحث ضرب کننده آرایه‌ای در بخش ۳-۱۰ می‌بینیم که برای هر قطعه ۸ گیت AND و یک جمع کننده ۸ بیتی لازم است.

ب) چند قطعه در خط لوله است: ۷ قطعه در خط لوله وجود دارد (با توجه به ضرب کننده آرایه‌ای)

ج) اگر تأخیر انتشار در هر قطعه 30ns باشد، زمان متوسط لازم برای ضرب دو عدد ممیز ثابت در خط لوله چقدر است؟

$$\frac{\text{زمان اجرای خط لوله‌ای}}{\text{تعداد تکلیف‌ها}} = \frac{k+n-1}{n} t_p = \frac{(n+6)30}{n}$$

$n = 10$  : برای  $t_{avg} = 48$  ns

$n = 100$  : برای  $t_{avg} = 31.8$  ns

$n = \infty$  : برای  $t_{avg} = 30$  ns

۷- زمان تأخیر چهار قطعه در خط لوله شکل ۶-۹ به صورت زیر است:

$t_r = 5$  ns ,  $t_4 = 45$  ns ,  $t_3 = 95$  ns ,  $t_2 = 30$  ns ,  $t_1 = 50$  ns

الف) جمع ۱۰۰ جفت عدد در خط لوله چقدر طول می‌کشد؟

(زمان لازم برای قطعه ۳)  $= 95 + 5 = 100$  ns

$$\Rightarrow t_p = 100 \text{ ns}$$

$k = 4$

زمان لازم برای جمع ۱۰۰ جفت عدد

$$= (k+n-1)t_p = (4+99)100 = 10300 \text{ ns}$$

ب) چگونه می‌توان زمان کل را به نصف زمان محاسبه شده در قسمت (الف)

کاهش داد؟

قطعه ۳ را به دو قطعه با تأخیرهای 50 ns و 45 ns تقسیم می‌کنیم. در این حالت

داریم:

$$t_p = 50 + 5 = 55 \text{ ns}$$

و  $k = 5$

$$= (k+n-1)t_p = (5+99)55 = 5720 \text{ ns}$$

که تقریباً نصف زمان محاسبه شده در قسمت الف است.

۸- چگونه می‌توانید جمع کننده ممیز شناور خط لوله‌ای شکل ۶-۹ را برای

جمع ۱۰۰ عدد ممیز شناور  $X_1 + X_2 + \dots + X_{300}$  به کار بگیرید؟

حل: خروجی جمع کننده را در یک مسیر بازخوردی به ورودی  $B \times 2^b$  وصل

می‌کنیم و از ورودی  $A \times 2^a$  برای داده‌های  $X_1$  تا  $X_{100}$  استفاده می‌کنیم. (از شمایی

مانند خط لوله جمع کننده در شکل ۹-۱۲ استفاده می‌کنیم).

۹- یک خط لوله دستورالعمل شش قطعه‌ای را برای یک کامپیوتر فرمول بندی کنید. عملیات که در هر قطعه باید انجام شود را مشخص کنید.

حل: یک طراحی می‌تواند شامل قطعه‌های زیر باشد (خط لوله، به شش قطعه تقسیم شده است):

- |                               |                                    |
|-------------------------------|------------------------------------|
| ۱- برداشت دستور از حافظه (FI) | ۲- دیکدر دستور (DE)                |
| ۳) محاسبه آدرس مؤثر (EA)      | ۴- برداشت عملوند از حافظه (FO)     |
| ۵) اجرای دستور (EX)           | ۶ - ذخیره نتیجه در مکان مناسب (WB) |

۱۰- چهار روش سختافزاری ممکن را که می‌تواند در خط لوله دستورالعمل برای کمینه کردن افت عملکرد ناشی از انشعاب دستور به کار رود، شرح دهد.

حل:

۱- دریافت زودهنگام دستور مقصد: در این روش علاوه بر دستور بعد، دستور مقصد نیز دریافت و ذخیره می‌شود؛ اگر شرط انشعاب برقرار باشد خط لوله از دستور مقصد انشعاب ادامه کار می‌دهد. روش کامل‌تر این است که از هر دو جهت عمل برداشت دستور ادامه یابد تا تصمیم انشعاب گرفته شود. نه آن زمان واحد کنترل درباره رشته صحیح دستورالعمل‌ها برای ادامه برنامه تصمیم می‌گیرد.

۲- بکارگیری بافر مقصد انشعاب (BTB): یک حافظه اشتراکی است که در قطعه برداشت خط لوله کار گذاشته می‌شود. هر ورودی به BTB مت Shank از آدرس انشعاب اجرا شده قبلی و دستور مقصد برای آن انشعاب است. این بافر چند دستور بعد از انشعاب را نیز ذخیره می‌کند. وقتی که خط لوله دستور انشعاب را دیکد می‌کند BTB را برای آدرس دستورالعمل جستجو می‌نماید. اگر آدرس در BTB باشد، دستور مستقیماً در دسترس است و برداشت پیش هنگام دستور برای مسیر جدید ادامه می‌یابد. اگر دستور در BTB نباشد خط لوله به رشته دستور جدیدی شیفت نموده و دستور مقصد را در BTB ذخیره می‌کند. مزیت این روش این است که دستورات انشعابی که قبلاً اتفاق افتاده‌اند بدون توقف در خط لوله موجودند.

۳- استفاده از بافر حلقه، این بافر یک فایل ثبات کوچک و سریع است که تحت نظر قطعه برداشت دستور خط لوله می‌باشد. وقتی که یک حلقه در برنامه شناسایی شود در یک بافر حلقه به طور کامل همراه با انشعابات ذخیره می‌شود. بنابراین حلقه برنامه می‌تواند مستقیماً و بدون دستیابی به حافظه اجرا شود. تا اینکه آخرین انشعباب موجب خروج از حلقه شود.

۴- پیش‌بینی انشعباب: یک خط لوله با پیش‌بینی انشعباب نتیجه حاصل از انشعباب را قبل از اجرای آن به کمک مدارهای منطقی اضافی پیش‌بینی می‌نماید. خط لوله سپس شروع به دریافت پیش‌هنگام رشته دستورات مسیر پیش‌بینی شده می‌نماید. یک پیش‌بینی صحیح زمان تلف شده به وسیله انشعباب را از بین می‌برد.

۱۱- چهار دستور رادر برنامه زیر در نظر بگیرید. فرض کنید که اولین دستور العمل از مرحله ۱ در خط لوله شکل ۸-۹ آغاز شود. عملیات انجام شده در قطعه چهار، در چهار مرحله را مشخص کنید.

Load  $R_1 \leftarrow M[312]$

ADD  $R_2 \leftarrow R_2 + M[313]$

INC  $R_3 \leftarrow R_3 + 1$

STORE  $M[314] \leftarrow R_3$

حل:

مرحله ۴

|    |    |    |    |
|----|----|----|----|
| FI | DA | FO | EX |
| FI | DA | FO |    |
| FI | DA |    |    |
|    |    | FI |    |

قطعه EX : انتقال کلمه حافظه به  $R_1$

قطعه FO : خواندن  $M[313]$

قطعه DA : دیکد دستور افزایش (INC)

قطعه FI : برداشت دستور STORE از حافظه

۱۲- برنامه‌ای را مثال بزنید که موجب برخورد داده در خط لوله سه قطعه‌ای

بخش ۵ - ۹ گردد.

حل:

Load:  $R1 \leftarrow \text{Memory}$

Increment :  $R1 \leftarrow R1+1$



.۱۲- در E بارگذاری می‌شود و نمی‌توان همزمان آن را افزایش داد.

۱۳- مثالی ارائه نمایید که در آن در خط لوله سه قطعه‌ای بخش ۵ - ۹ از تأخیر

بار کردن استفاده کند.

حل:

یک دستور NO-OP بین دو دستور مثال سؤال ۱۲ قرار می‌دهیم:

|                               |   |   |     |
|-------------------------------|---|---|-----|
| $R1 \leftarrow \text{Memory}$ | I | A | E   |
| NOP                           | - | - | -   |
| $R1 \leftarrow R1+1$          |   | I | A E |

۱۴- برنامه‌ای مثال بزنید که موجب جریمه انشعاب در خط لوله سه قطعه‌ای

بخش ۵ - ۹ گردد.

حل:

101 Add  $R_2$  to  $R_3$

102 Branch to 104

103 Increment  $R_1$

104 Store  $R_1$



اتلاف زمان ناشی از انشعاب در خط لوله

۱۵- مثالی ارائه دهید که در آن از انشعاب با تأخیر در خط لوله سه قطعه‌ای

#### بخش ۵ - ۹ استفاده شود.

حل: از مثال مسئله ۹-۱۴ استفاده می‌کنیم.

|     |                                      |     |       |
|-----|--------------------------------------|-----|-------|
| 101 | Branch to                            | 105 | I A E |
| 102 | ADD R <sub>2</sub> to R <sub>3</sub> |     | I A E |
| 103 | NO-operation                         |     | I A E |
| 104 | Incremet R <sub>1</sub>              |     |       |
| 105 | Store R <sub>1</sub>                 |     | I A E |

۱۶- ضرب دو ماتریس ۴۰×۴۰ را در یک پردازنده برداری در نظر بگیرید.

الف) چند جمله ضرب در هر حاصلضرب داخلی وجود دارد و چند حاصلضرب داخلی باید حساب شود.

در هر ضرب داخلی ۴۰ ضرب نیاز است و  $40^2 = 1600$  ضرب داخلی باید محاسبه شود (هر ضرب داخلی برای یک المان ماتریس حاصلضرب)

ب) چند عمل ضرب - جمع برای محاسبه ماتریس لازم است؟

$40^2$  ضرب داخلی داریم که هر یک ۴۰ عمل ضرب - جمع نیاز دارند:

$$40 \times 40^2 = 40^3 = 64000$$

۱۷- در شکل ۹-۱۲ وقتی که ماتریس‌های ۶۰×۶۰ در هم ضرب شوند چند سیکل ساعت برای پردازش حاصلضرب داخلی در خط لوله نیاز است؟ چند

### حاصلضرب داخلی وجود دارد و چند سیکل ساعت برای محاسبه ماتریس حاصلضرب نیاز است؟



پس برای محاسبه ماتریس به  $3600 \times 72 = 259200$  سیکل ساعت نیاز است.

### ۱۸- آدرس‌های مربوط به یک آرایه ۱۰۲۴ کلمه، که قرار است در حافظه شکل

۹- ذخیره شوند را تعیین نمایید.

حل: با توجه به ساختار شکل ۹- آدرس‌های مربوط به آرایه به صورت زیر

هستند:

|   |   |    |       |      |      |               |   |   |      |      |               |   |    |      |               |               |
|---|---|----|-------|------|------|---------------|---|---|------|------|---------------|---|----|------|---------------|---------------|
| 0 | 4 | 8  | 12    | .... | 1020 | 1             | 6 | 9 | .... | 1021 | 2             | 6 | 10 | .... | 1022          |               |
|   |   |    |       |      |      | آرایه حافظه ۱ |   |   |      |      | آرایه حافظه ۲ |   |    |      | آرایه حافظه ۳ |               |
| 3 | 7 | 11 | ..... |      | 1023 |               |   |   |      |      |               |   |    |      |               | آرایه حافظه ۴ |
|   |   |    |       |      |      |               |   |   |      |      |               |   |    |      |               |               |

۱۹- محاسبه‌ای برای پیش‌بینی وضع هوا به ۲۵۰ میلیارد عمل ممیز شناور نیاز دارد. مسئله در یک ابر کامپیوتر با سرعت اجرایی ۱۰۰ مگافلاپس پردازش می‌شود. چقدر زمان برای انجام محاسبات طول می‌کشد؟

حل:

$$\text{دقیقه} = \frac{250 \times 10^9}{100 \times 10^6} = 2500 \text{ ثانیه} \quad \text{زمان اجرا}$$

۲۰- کامپیوتری را با چهار پردازنده خط لوله‌ای ممیز شناور در نظر بگیرید.

فرض کنید که هر پردازنده از سیکل زمان ۴۰ ns استفاده می‌کند. برای اجرای ۴۰۰ عمل ممیز شناور چقدر وقت نیاز است؟ اگر همین عمل با استفاده از یک پردازنده خط لوله‌ای تکی با سیکل ساعت ۱۰ns انجام شود آیا تفاوتی وجود خواهد

داشت؟

حل:

۴۰۰ عمل را بین چهار پردازنده تقسیم می‌کنیم. داریم:

$$= \frac{400}{4} \times 40 = 4000 \text{ ns}$$

با استفاده از یک پردازنده با سیکل 10ns ۱۰ داریم:

$$= 400 \times 10 = 4000 \text{ ns}$$

## فصل دهم: معماري کامپیوتر و الگوريتم های حسابی

۱- اگر در شکل ۱۰-۱ به جای  $A + \bar{B} + 1$  عمل  $B + \bar{A}$  (متمن ۱ عدد  $A$  بعلاوه  $B$ ) را انجام دهیم، متمن ساز نیاز نیست. الگوريتمی به شکل فلوچارت برای جمع و تفریق اعداد دودویی ممیز ثابت با نمایش اندازه علامت دار بدست آورید که در آن اندازه ها با دو ریز عمل  $A \leftarrow \bar{A}$  و  $\bar{E} \leftarrow A + B$  تفریق شوند.

حل: با توجه به تعریف متمن در اعداد داریم: (فرم متمن ۲)

$$A - B = A + \bar{B} + 1$$

بنابراین در صورت سؤال:

$$B + \bar{A} = B - A - 1$$

بنابراین فلوچارت زیر را داریم:





۲- هر یک از مسیرهای فلوچارت شکل ۱۰-۲ را شماره‌گذاری کنید و سپس کل مسیری که الگوریتم هنگام محاسبه اعداد با نمایش اندازه علامت‌دار زیر طی می‌کند را تعیین نمایید. در هر مورد مقدار AVF را بنویسید. بیت سمت چپ در عدهای زیر نماینده بیت علامت است.

$$\text{ب) } 1011111 + 1101101$$

$$\text{الف) } 0101101 + 0011111$$

$$\text{د) } 0101101 - 0101101$$

$$\text{ج) } 0101101 - 0011111$$

$$\text{ه) } 1011111 - 0101101$$

حل: با توجه به شکل ۱۰-۲، المان‌های محاسباتی را شماره‌گذاری کرده و سپس موارد محاسباتی داده شده در سؤال را با دنباله‌ای از المان‌های محاسباتی مشخص می‌کنیم.



با توجه به ۶ بیتی بودن اعداد، در نمایش متمم (۲)، محدوده ظرفیت نتیجه از  $-2^6$  تا  $2^6 - 1$  است. پس  $63 \leq$  نتیجه  $\leq 64$ ، پس نتایج خارج از این محدوده، AVF را (۱) خواهد کرد.

حال داریم:

$$(+45) + (+31) = 76 \quad (1) \rightarrow (3) \rightarrow (7) \quad \text{AVF} = 1 \quad (\text{الف})$$

$$(-31) + (-45) = -76 \quad (1) \rightarrow (3) \rightarrow (7) \quad \text{AVF} = 1 \quad (\text{ب})$$

$$(+45) - (+31) = 14 \quad (2) \rightarrow (6) \rightarrow (9) \rightarrow (10) \quad \text{AVF} = 0 \quad (\text{ج})$$

$$(+45) - (-45) = 0 \quad (2) \rightarrow (6) \rightarrow (9) \rightarrow (10) \quad \text{AVF} = 0 \quad (\text{د})$$

$$(-31) - (+45) = -76 \quad (2) \rightarrow (5) \rightarrow 7 \quad \text{AVF} = 1 \quad (\text{ه})$$

۳- عمل های حسابی زیر را با عدهای دو دویی و عدهای منفی در نمایش متمم (۲) علامت دار انجام دهید. برای جای دادن هر عدد همراه با علامتش از ۷ بیت استفاده کنید. در هر حالت، با بررسی نقلی ورودی و خروجی از بیت علامت

وجود سریز را بررسی کنید.

$$(b) (-35) + (-40) \quad (f) (+35) + (+40)$$

$$(g) (-35) - (+40)$$

حل: می‌دانیم

$$A - B = A + (-B)$$

بنابراین موارد ب و ج نتیجه یکسانی را بدست خواهند داد.

(الف) E و F، دو رقم نقلی آخر

$$\begin{array}{r} +35 \\ +40 \\ \hline +75 \end{array} \quad \begin{array}{r} 0100011 \\ 0101000 \\ + \\ 1001011 \end{array} \quad \begin{array}{l} E=0, F=1 \\ E \oplus F = 1 \Rightarrow \end{array} \quad \begin{array}{l} \text{رخداد سرریز} \\ (b) \end{array}$$

$$\begin{array}{r} -35 \\ -40 \\ -70 \\ \hline 1011101 \\ 1011000 \\ + \\ 0110101 \end{array} \quad \begin{array}{l} E=1, F=0 \\ E \oplus F = 1 \Rightarrow \end{array} \quad \begin{array}{l} \text{رخداد سرریز} \\ (b) \end{array}$$

۴- عدهای دودویی را با نمایش متمم ۲ علامت دار در نظر بگیرید. هر عدد  $n$  بیت دارد: یک بیت برای علامت و  $n-1$  بیت برای اندازه (یا مقدار) عددی منفی مانند  $x$ - به صورت  $(2^k - x) + 2^k$  نمایش داده می‌شود که در آن اولین  $2^k$  نشان‌دهنده‌ی بیت علامت و  $(2^k - x)$  متمم ۲ عدد  $x$  است. عدد مثبت به صورت  $x+0$  نمایش داده می‌شود، که ۰ بیت علامت و  $x$  مقدار  $k$  بیتی آن است. با این سمبول‌های کلی، ثابت کنید که مجموع  $(\pm x) + (\pm y)$  را می‌توان با جمع عدهایی شامل بیت‌های علامت آنها و حذف نقلی خروجی از بیت علامت شکل داد. به بیان دیگر الگوریتم جمع دو عدد دودویی با نمایش متمم ۲ علامت‌دار را ثابت کنید.

حل: برای هر کدام از حالات  $(\pm x) + (\pm y)$  سمبول‌ها را جایگزین کرده و اثبات‌ها را

انجام می‌دهیم.

| ردیف | عبارت         | نمایش با سمبولهای درخواستی سؤال در سیستم مکمل (۲) | نمایش نتیجه مورد انتظار در سیستم مکمل (۲)                   |
|------|---------------|---------------------------------------------------|-------------------------------------------------------------|
| ۱    | $(+x) + (+y)$ | $(0+x) + (0+y)$                                   | $0 + (x+y)$                                                 |
| ۲    | $(+x) + (-y)$ | $(0+x) + 2^k + (2^k - y)$                         | $0 + (x-y)$ if $x \geq y$<br>$2^k + 2^k - (y-x)$ if $x < y$ |
| ۳    | $(-x) + (+y)$ | $2^k + (2^k - x) + (0+y)$                         | $0 + (y-x)$ if $y \geq x$<br>$2^k + 2^k - (x-y)$ if $y < x$ |
| ۴    | $(-x) + (-y)$ | $(2^k + 2^k - x) + (2^k + 2^k - y)$               | $2^k + 2^k - (x+y)$                                         |

حال برای تک تک ردیفها داریم:

-۱

$$(0+x) + (0+y) = 0 + (x+y)$$

-۲

$$2^k + 2^k = 2^{k+1} \rightarrow \text{رقم نقلی } (x-y)$$

-۳ مثل مورد ۲

$$2^k + 2^k = 2^{k+1} \rightarrow \text{رقم نقلی } (y-x)$$

-۴

$$2^{k+1} + 2^{k+1} = 2^{k+2} \rightarrow \text{رقم نقلی } (x+y) - \text{صرف نظر از رقم نقلی}$$

۵ - یک رویه سخت افزاری برای آشکارسازی سرریز با مقایسه علامت مجموع

و علامت‌های مضاف و مضاف علیه بسازید. عدها در نمایش متمم (۲) علامت‌دار هستند.

حل: در عبارت روبرو، در رابطه با تعریف رخداد سرریز داریم:

$A + B$ 

سرريز زمانی رخ می دهد که:

۱) هر دو عدد مثبت، علامت مجموع منفی

۲) هر دو عدد منفی، علامت مجموع مثبت

پس جدول زير را داريم:

| $A_S$ | علامت $A$         |   |   |
|-------|-------------------|---|---|
| $B_S$ | علامت $B$         |   |   |
| $T_S$ | علامت مجموع $T_S$ |   |   |
| .     | .                 | . | . |
| .     | .                 | ۱ | ۱ |
| .     | ۱                 | . | . |
| .     | ۱                 | ۱ | . |
| ۱     | .                 | . | . |
| ۱     | .                 | ۱ | . |
| ۱     | ۱                 | . | ۱ |
| ۱     | ۱                 | ۱ | . |

پس:

$$OV = T_S' B_S' A_S + T_S B_S A_S'$$

پس مدار منطقی زير را خواهيم داشت:



۶ - الف)  $(-6) + (-9) = -15$  را با عدهای دودویی با نمایش متمم ۱ علامت دار فقط پنج بیتی برای هر عدد (با بیت علامت) انجام دهید. نشان دهید که رویه آشکارسازی سرریز با بررسی دو نقلی آخر در این مورد به نتیجه نمی‌رسد.

ب) رویه اصلاح شده‌ای را برای آشکارسازی سرریز وقته که اعداد متمم ۱ استفاده می‌شوند پیشنهاد کنید:

حل: الف) برای مثال نقض، مثال زیر را در نظر بگیرید:

$$-9 = (10110)_2$$

$$-6 = (11001)_2$$

$$\begin{array}{r} -9 & 10110 \\ + -6 & 11001 \\ \hline -15 & 01111 \end{array}$$

در این عمل، دو رقم نقلی آخر متفاوت بوده پس OR انحصاری آنها ۱ برمی‌گرداند. در حالی که قاعده‌تاً ما نباید سرریز را داشته باشیم زیرا نتیجه منفی است.

ب) با توجه به مثال نقض بالا، ما نتیجه را برای "1.....0111" شدن چک می‌کنیم.

پس:



۷- الگوریتمی را به شکل فلوچارت برای جمع و تفریق دو عدد دودویی ممیز ثابت وقتی که عدهای منفی به صورت متمم ۱ هستند بدست آورید.

حل: با توجه به حل سؤال قبل و ترکیب آن با الگوریتم جمع و تفریق اعداد منفی متمم ۲ در صفحه ۳۳۶ کتاب، فلوچارت زیر را خواهیم داشت: M و N دو رقم نقلی آخر نتیجه هستند.



سرریز داریم

سرریز نداریم

۸ - ثابت کنید ضرب دو عدد  $n$  رقمی در پایه  $r$ ، حاصلضربی بزرگتر از  $2n$  رقم تولید نمی‌کند. نشان دهید که این به معنی آن است که سرریزی در عمل ضرب رخ نمی‌دهد.

حل: می‌دانیم بیشترین مقدار قابل نمایش برای یک عدد  $n$  رقمی  $1 - r^n$  و برای یک عدد  $2n$  رقمی،  $1 - r^{2n}$  است. بنابراین ماکریم حاصل ضرب دو عدد  $n$  رقمی در یکدیگر برابر است با:

$$(r^n - 1) \times (r^n - 1) = r^{2n} - 2r^n + 1 < r^{2n} - 1$$

$$\Rightarrow \dots \Rightarrow r^n > 1$$

با توجه به اینکه مینا از ۲ شروع می‌شود یعنی  $n \geq r$  و به ازای  $r \geq 1$  یعنی اعداد ۱ رقمی به بالا این شرط همیشه سازگار است، سریز رخ نمی‌دهد.

**۹- محتوای ثبات‌های E و A و Q و SC (مطابق جدول ۱۰-۲ کتاب)** را در حین روند ضرب دو عدد دودویی ۱۱۱۱ (مضروب) و ۱۰۱۰۱ (مضروب فیه) نشان دهید. علامت‌ها در نظر گرفته نشده‌اند.

حل: همانند روال موجود در جدول ۱۰-۲ داریم:

|                                       | E | A     | Q                                       | S <sub>C</sub> |
|---------------------------------------|---|-------|-----------------------------------------|----------------|
| مضروب فیه در Q                        | ۰ | ..... | ۱۰۱۰۱                                   | ۱۰۱            |
|                                       |   | ۱۱۱۱۱ |                                         |                |
| B ، Q <sub>n</sub> = 1                | ۰ | ۱۱۱۱۱ |                                         |                |
| شیفت EAQ به راست                      |   | ۰۱۱۱۱ | ۱۱۰۱۰                                   | ۱۰۰            |
| و شیفت EAQ به راست Q <sub>n</sub> = 0 |   | ۰۰۱۱۱ | ۱۱۱۰۱                                   | ۰۱۱            |
| B و جمع Q <sub>n</sub> =1             |   | ۱۱۱۱۱ |                                         |                |
|                                       | ۱ | ۰۰۱۱۰ |                                         |                |
| شیفت EAQ به راست                      | ۰ | ۱۰۰۱۱ | ۰۱۱۱۰                                   | ۰۱۰            |
| و شیفت EAQ به راست Q <sub>n</sub> = 0 |   | ۰۱۰۰۱ | ۱۰۱۱۱                                   | ۰۰۱            |
| B و جمع Q <sub>n</sub> = 1            |   | ۱۱۱۱۱ |                                         |                |
|                                       | ۱ | ۰۱۰۰۰ |                                         |                |
| شیفت EAQ به راست                      |   |       | AQ = ۱۰۱۰۰۱۰۱۱<br>= (651) <sub>10</sub> | ...            |

**۱۰- محتوای ثبات‌های E و A و Q و SC (مطابق شکل ۱۰-۱۲)** را در حین روند تقسیم (الف) ۱۰۱۰۰۱۱ بر ۱۰۱۱ و (ب) ۰۰۰۱۱۱۱ بر ۰۰۱۱ نشان دهید.

(از مقسوم ۸ بیتی استفاده کنید.)

حل: همانند روال شکل (۱۰-۲)، نتایج به صورت زیر خواهد بود:

$$B = 1011, \quad \bar{B} + 1 = 0101, \quad DVF = 0$$

| E | A           | Q    | SC  |
|---|-------------|------|-----|
| 0 | 1010        | 0011 | 100 |
| 1 | 0100        | 0110 |     |
|   | <u>0101</u> |      |     |
| 1 | 1001        | 0111 | 011 |
| 1 | 0010        | 1110 |     |
|   | <u>0101</u> |      |     |
| 1 | 0111        | 1111 | 010 |
| 0 | 1111        | 1110 |     |
|   | <u>0101</u> |      |     |
| 1 | 0100        | 1111 | 001 |
| 0 | 1001        | 1110 |     |
|   | <u>0101</u> |      |     |
| 0 | 1110        | 1110 |     |
|   | <u>1011</u> |      |     |
| 1 | 1001        | 1110 |     |

خارج فسمت باقی مانده

$$B = 0011 \quad \bar{B} + 1 = 1101 \quad (\text{ب})$$

| E | A           | Q    | SC   |
|---|-------------|------|------|
|   | 0000        | 1111 | 100  |
| 0 | 0001        | 1110 |      |
|   | <u>1101</u> |      |      |
| 0 | 1110        | 1110 |      |
|   | <u>0011</u> |      |      |
| 1 | 0001        |      | 011  |
| 0 | 0011        | 1100 |      |
|   | <u>1101</u> |      |      |
| 1 | 0000        | 1101 | 010  |
| 0 | 0001        | 1010 |      |
|   | <u>1101</u> |      |      |
| 0 | 1110        | 1010 |      |
|   | <u>0011</u> |      |      |
| 1 | 0001        |      | 001  |
| 0 | 0011        | 0100 |      |
|   | <u>1101</u> |      |      |
| 1 | 0000        | 0101 | 000  |
|   | باقي مانده  | خارج | قسمت |

۱۱- نشان دهید که جمع  $B + \bar{A} + 1$  مقدار اولیه A را می دهد. با

رقم نقلی پایانی چه باید کرد؟

حل: طبق تعریف متمم (۲)

$$A + \bar{B} + 1 \Rightarrow A + Z^u - B = Z^n + A - B$$

حال با  $B$  جمع می‌کنیم:

$$(2^K + A - B) + B = 2^n + A$$

از رقم نقلی صرف نظر می‌کنیم  $A \Leftarrow$

۱۲- چرا علامت باقیمانده پس از تقسیم باید با علامت مقسوم یکسان باشد؟

حل: چهار حالت تقسیم با علامت‌های مختلف را برای مثال زیر در نظر می‌گیریم:

$$\frac{A}{B} = Q + \frac{R}{B}$$

$$\frac{+52}{+5} = +10 + \frac{+2}{+5} = +10,4 \quad (1)$$

$$\frac{+52}{-5} = -10 + \frac{+2}{-5} = -10,4 \quad (2)$$

$$\frac{-52}{+5} = -10 + \frac{-2}{+5} = -10,4 \quad (3)$$

$$\frac{-52}{-5} = +10 + \frac{-2}{-5} = +10,4 \quad (4)$$

با توجه به حالت‌های مختلفی می‌بینیم علامت باقی مانده (۲) مانند علامت مقسوم است. (۵۲)

۱۳- یک ضرب‌کننده آرایه‌ای طراحی کنید که دو عدد چهار بیتی را در هم

ضرب کند. از گیت AND برای جمع‌کننده دودویی استفاده کنید.

حل: با توجه به شکل (۱۰-۱۰) مدار زیر را خواهیم داشت (ورودی دوم گیت‌های

AND ، بیت‌های  $b_0, b_1, b_2, b_3$  هستند):

$$\begin{array}{ccc} a_3 a_2 a_1 a_0 & * & b_3 b_2 b_1 b_0 \\ C_7 C_6 C_5 C_4 C_3 C_2 C_1 C_0 = & & \text{نتیجه} \end{array}$$



با توجه به شکل می‌بینیم که در ضرب ۴ بیت در ۴ بیت در ۱۶ گیت AND و ۳ جمع کننده ۴ بیتی نیاز است. در حالت کلی اگر ضرب شونده  $k$  بیتی و ضرب کننده  $J$  بیتی باشد، برای ضرب آرایه‌ای به  $J \times K$  تا گیت AND و  $J-1$  عدد جمع کننده  $K$  بیتی نیاز است.

۱۴- روند قدم به قدم ضرب با الگوریتم بوت را (مثل جدول ۳-۱۰) هنگامی که اعداد دودویی زیر در هم ضرب می‌شوند نشان دهید. فرض کنید ثبات‌های پنج بیتی اعداد علامت‌دار را نگه می‌دارند. مضروب در هر دو حالت +۱۵ و -۱۵ است.

$$\text{الف) } (+15) \times (+13) \quad \text{ب) } (-13) \times (+15)$$

حل: با توجه به تعریف الگوریتم ضرب Booth داریم:

۱- ضرب شونده از حاصلضرب جزیی تفریق می‌شود اگر به اولین یک (از سمت راست) در ضرب‌کننده برسیم.

۲- ضرب شونده به حاصلضرب جزیی افزوده می‌شود اگر به اولین صفر (در یک رشته صفر) در ضرب‌کننده برسیم.

۳- حاصلضرب جزیی تغییر نمی‌کند وقتی بیت ضرب‌کننده با بیت قبلی مشابه باشد.  
روند را برای مورد (ب) داریم:

$$(+15) * (-13) = -195 = (1100111101)_2$$

$$BR = 011111(+15) \quad \overline{BR} + 1 = 10001(-15), Q_R = 10011 \quad (-13)$$

| $Q_n$ | $Q_{n+1}$ |           | AC           | QR    | $Q_{n+1}$ | SC  |
|-------|-----------|-----------|--------------|-------|-----------|-----|
|       |           |           | .....        | 10011 | .         | 101 |
| 1     | .         | تفریق     | <u>10001</u> |       |           |     |
|       |           |           | 10001        |       |           |     |
|       |           | شیفت راست | 11000        | 11001 | 1         | 100 |
| 1     | 1         | شیفت راست | 11100        | 01100 | 1         | 011 |
| .     | 1         | جمع       | <u>01111</u> |       |           |     |
|       |           | شیفت راست | 00101        | 10110 | .         | 010 |
| .     | .         | شیفت راست | 00010        | 11011 | .         | 001 |

|   |   |           |              |      |   |     |  |
|---|---|-----------|--------------|------|---|-----|--|
| ۱ | . | تفریق     | <u>۱۰۰۰۱</u> |      |   |     |  |
|   |   |           | ۱۰۰۱۱        |      |   |     |  |
|   |   | شیفت راست | ۱۱۰۰۱        | ۱۱۱۰ | ۱ | ۰۰۰ |  |
|   |   |           | -۱۹۵         |      |   |     |  |

۱۵- الگوریتمی را به شکل فلوچارت برای روش غیر بازیافتنی تقسیم دودویی ممیز ثابت بدست آورید.

حل: دقت کنید، در روش nonrestoring، اگر حاصل تفریق منفی شود،  $B$  به آن اضافه نمی‌شود، حاصل منفی به سمت چپ شیفت می‌یابد و پس  $B$  به آن اضافه می‌شود.

مثلاً در حالت  $A < B$ ، در حالت ابتدا  $A-B$  شده، سپس با  $B$  جمع می‌شود. یعنی  $A-B+B$  که  $A$  بازیابی می‌شود، پس  $2A-B$  محاسبه می‌شود، اما در حالت  $A-B$  را با  $B$  جمع نمی‌کنیم. و مستقیم  $2A-B$  nonrestoring



۱۶- الگوریتمی برای محاسبه ریشه دوم عدد دودویی ممیز ثابت به دست آورید.

حل: اگر روبرو را داشته باشیم:

$$\sqrt{A} = B$$

اگر  $A \geq K$  بیتی باشد، برای  $B = \frac{K}{2}$  (عدد صحیح شده) بیت در نظر خواهیم گرفت.

از طرفی در رابطه با قضیه جذر داریم:  $\sqrt{A} \leq \frac{A}{2}$   
در حالت کلی داریم:

$$B^2 + R = A$$

الگوریتم پیشنهادی به شرح زیر است:

از عدد  $\frac{A}{2}$  (عدد صحیح شده) شروع کرده و تعداد عدد را در  $A$  پیدا می‌کنیم. هر گاه تعداد عدد در  $A$  با خود برابر شد، عدد همان جذر  $A$  خواهد بود. در غیر این صورت یکی از عدد کم کرده و دوباره تست می‌کنیم.

مثال: محاسبه ریشه دوم عدد ۲۸ :

از ۱۴ شروع می‌کنیم:

| عدد | تعداد در ۲۸ | نتیجه                            |
|-----|-------------|----------------------------------|
| 14  | 2           | $14 \neq 2$                      |
| 13  | 2           | $13 \neq 2$                      |
| 12  | 2           | $12 \neq 2$                      |
| 11  | 2           | $11 \neq 2$                      |
| 10  | 2           | $10 \neq 2$                      |
| 9   | 3           | $9 \neq 3$                       |
| 8   | 3           | $8 \neq 3$                       |
| 7   | 4           | $7 \neq 4$                       |
| 6   | 4           | $6 \neq 4$                       |
| 5   | 5           | $5 = 5 \Rightarrow 5^2 + 3 = 28$ |

۱۷- یک عدد دودویی ممیز شناور هفت بیت برای نمای بایاس شده‌اش دارد.

مقدار ثابت بایاس ۶۴ است.

الف) لیست بایاس شده تمام نمایها را از  $-64$  تا  $+63$  بدست آورید.

ب) نشان دهید که یک مقایسه‌گر مقدار هفت بیتی می‌تواند برای مقایسه اندازه نسبی دو نما بکار رود.

ج) نشان دهید که پس از جمع دو نمای بایاس شده لازم است  $64$  را کم کنیم تا مجموع نمایها به شکل بایاس شده بدست آید. چگونه می‌توان  $64$  را با جمع کردن مقدار متمم  $2$  آن تفریق کرد؟

د) نشان دهید که پس از تفریق دو نمای بایاس شده لازم است  $64$  را اضافه کنیم تا تفاضل بایاس شده نمایها را داشته باشیم.

حل:

(الف)

$$\begin{array}{r} e -64 -63 \dots -1 0 1 \dots 62 63 \\ \hline e+64 \phi 1 \dots 63 64 65 \dots 126 127 \end{array}$$

ب) بدینهی است تعداد بیت نمایش محدوده  $(-64 - 63)$  برابر با تعداد بیت برای نمایش محدوده  $(0 - 127)$  است.

$$2^7 = 128$$

ج) مشخص است باید  $64$  کم شود.

$$(e_1 + 64) + (e_2 + 64) = (e_1 + e_2 + 64) + 64$$

د) مشخص است باید  $64$  اضافه شود.

$$(e_1 + 64) - (e_2 - 64) = e_1 + e_2$$

۱۸- الگوریتمی به شکل فلوچارت برای مقایسه دو عدد دودویی علامت‌دار وقتی که عدهای منفی به شکل متمم  $2$  علامت‌دار باشند به دست آورید.

الف) با استفاده از عمل تفریق با عدهای متمم  $2$  علامت‌دار

ب) با مرور و مقایسه جفت بیت‌ها از چپ به راست

حل: دقت شود هر گاه علامت دو عدد متفاوت بود، عدد که بیت علامت آن صفر

است، بزرگتر است.

الف) در غیر این صورت طبق روال عمل خواهیم کرد.



ب) از سمت بیت‌های با ارزش‌تر تساوی بودن را چک می‌کنیم و به سمت بیت‌های کم ارزش‌تر حرکت می‌کیم.



۱۹- مسئله ۱۸ را برای اعداد دودویی مقدار علامت‌دار تکرار کنید.

حل:

(الف)



ب) در رابطه با سیستم مقدار علامتدار داریم:

برای اعداد مثبت آنکه بیت با ارزش تر (۱) باشد بزرگ‌تر است.

برای اعداد منفی آنکه بیت با ارزش تر (۱) باشد کوچک‌تر است.



۲۰- فرض کنید  $n$ ، تعداد بیت‌های مانیس در یک عدد دودویی ممیز شناور است. هنگامی که مانیس‌ها در جمع و تفریق هم ردیف می‌شوند، اختلاف نمایان ممکن است بزرگ‌تر از  $n-1$  باشد. اگر این حالت رخ دهد، مانیس با نمای کوچک‌تر کلأاً از ثبات شیفت داده می‌شود. هم ردیف کردن مانیس را در شکل (۱۵-۱۰) با اضافه کردن یک توالی شمارشی که تعداد شیفت‌ها را می‌شمارد اصلاح کنید. اگر تعداد شیفت‌ها بزرگ‌تر از  $n-1$  باشد، بزرگ‌ترین عدد برای تعیین نتیجه بکار خواهد رفت.

حل: این مطلب را با یک مثال نمایش می‌دهیم. فرض شود دو عدد زیر برای عمل

جمع آماده می‌شوند.

$$A = 0,11011 \times 2^5$$

$$B = 0,10111 \times 2^{10}$$

در  $A+B$  ، می‌بایست به نمای  $A$  ، ۵ واحد اضافه شود و مانتیس  $A$  ، ۵ بار شیفت به راست انجام شود که عملاً مانتیس از بین خواهد رفت.

بنابراین با استفاده از شمارنده SC و اضافه کردن حلقه‌های بررسی شیفت مانتیس، در الگوریتم شکل ۱۰-۱۵ کتاب، درخواست سؤال را برآورده می‌کنیم.



۲۱- رویه هم ردیف کردن ماتریس‌ها در جمع و یا تفریق اعداد ممیز شناور

می‌تواند به صورت زیر بیان شود:

نمای کوچک‌تر را از بزرگ‌تر تفریق کنید و ماتریسی را که دارای نمای کوچک‌تر است به تعداد تفاضل نمایان به راست شیفت دهید. نمای مجموع (یا تفاضل) برابر با نمای بزرگ‌تر است. بدون استفاده از مقایسه‌کننده مقدارها، با فرض

نماهای بایاس شده، و در نظر گرفتن اینکه فقط AC را می‌توان جابجا کرد، الگوریتمی را به شکل فلوچارت برای هم ردیف کردن ماتریس‌ها و قرار دادن نمای بزرگ‌تر در AC بدست آورید.

حل:



۲۲- نشان دهید که سرریز مانتیس بعد از عمل ضرب ممکن نیست.

حل: از دو جنبه می‌توان این نتیجه را بررسی کرد.

۱- مانتیس‌های نرمال شده، عدد اعشاری کوچکتر از ۱ هستند. مثلاً  $0.1001 \times 0.1101$ ؛ از طرفی می‌دانیم ضرب اعداد کوچکتر از ۱ همیشه کوچکتر از ۱ خواهد بود بنابراین سرریز پیش نخواهد آمد و تنها زیر ریز پیش خواهد آمد.

۲- زمانی که دو عدد  $n$  بیتی درهم ضرب شوند، نتیجه حداکثر  $2^n$  بیتی خواهد بود. این قضیه را در سؤال ۸ همین فصل اثبات کرده‌ایم.

۲۳- نشان دهید در تقسیم دو عدد نرمال شده ممیز شناور با مانتیس کسری همواره خارج قسمت نرمال شده خواهد داد؛ به شرط اینکه قبل از عمل تقسیم، هم‌ردیف کردن مقسوم انجام شود.

حل: دقت شود هر دو مانتیس‌ها نرمالیزه هستند.

$$\frac{A}{B} = \frac{0.1\dots\dots\dots}{0.1\dots\dots\dots}$$

دو شرط زیر را بررسی می‌کنیم:

۱)  $A \geq B \Rightarrow 1\dots\dots\dots \Rightarrow$  جواب به صورت رویرو خواهد بود.

۲)  $A < B \Rightarrow 0.1\dots\dots\dots \Rightarrow$  جواب به صورت رویرو خواهد بود.

۲۴- فلوچارت شکل ۱۰-۱۷ را برای تهیه باقیمانده نرمال شده ممیز شناور در تعیین دهید. مانتیس باید یک کسر باشد.

حل: در تقسیم ممیز شناور داریم:

$$\begin{aligned} \frac{A}{B} &= \frac{m_A \times 2^{e_A}}{m_B \times 2^{e_B}} = \frac{0.1xxxx}{0.1yyyy} \times 2^{e_A - e_B} \\ &= 0.1zzzz \times 2^{e_A - e_B} + \frac{0.00000rrrrr}{0.1yyyy} \times 2^{e_A - e_B} \end{aligned}$$

حال داریم:



۲۵- در الگوریتم‌های عمل‌های حسابی ممیز شناور در بخش ۵-۱۰ امکان سرریز یا فروریز در نما نادیده گرفته می‌شود.

(الف) سه فلوچارت را مرور کنید و جاهایی را که سرریز نما ممکن است رخ دهد پیدا کنید.

(ب) قسمت (الف) را برای فروریز تکرار کنید. فروریز نما هنگامی رخ می‌دهد که نما از کوچکترین عددی که بتواند در ثبات جا گیرد کمتر شود.

ج) نشان دهید که سرریز یافروریز نما می‌تواند با سخت‌افزار آشکار شود.

حل:

الف) جاهایی که نمایها اضافه می‌شوند (جمع می‌شوند).

جاهایی که نمایها افزایش می‌یابند (یکی زیادتر می‌شوند).

ب) جاهایی که نمایها منها می‌شوند.

جاهایی که نمایها کاهش می‌یابند (یکی کم می‌شوند).

ج) می‌توان با چک کردن رقم نقلی نهایی بعد از عمل جمع و رقم نقلی بعد از اعمال کاهش یا افزایش، سرریز یا فروریز را آشکار کرد.

۲۶- اگر نمایش عدد صحیح را برای مانیس عده‌های ممیز شناور در نظر بگیریم، در حین ضرب و تقسیم با مشکلات خاصی رویرو می‌شویم. اجازه بدهید تعداد بیت‌های بخش مانیس  $(n-1)$  باشد.

برای نمایش صحیح:

الف) نشان دهید که اگر حاصلضرب با دقت معمولی بکار رود، باید  $(n-1)$  به نمای حاصلضرب در AC اضافه شود.

ب) نشان دهید که اگر از مقسوم با مانیس دقت معمولی استفاده شود، باید هنگامی که Q برابر  $0$  می‌شود.  $(n-1)$  از نمای مقسوم کم شود.

حل: الف) می‌دانیم ضرب دو عدد  $(n-1)$  بیتی، یک عدد حداقل  $(n-1)^2$  بیتی بوجود خواهد آورد. با توجه به مفهوم نرمال بودن و همچنین ظرفیت مانیس که  $(n-1)$  بیتی است، می‌بایست از  $(n-1)$  بیت سمت راست صرف نظر کرده و  $(n-1)$  به نمای اضافه کنیم.

مثال:

$n-1=3$  بیت

در ضرب رویرو

$$(111 \times 2^2) * (110 \times 2^2)$$

$$111 \times 110 = 101010 \times 2^4 = 101 \times 2^7$$

ب) در رابطه با تقسیم هم همین قضیه وجود دارد.

۲۷- سخت افزاری را که برای جمع و تفریق دو عدد دهدی در نمایش اندازه علامت دار به کار می روید نشان دهید. چگونگی آشکارسازی سرریز را نشان دهید.

حل:

۲۷) سخت افزار جمع و تفریق مشتمل بر سخت افزار معمول و تکمیل است (شکل ۱۰-۶)

نماین اتفاقات که  $A = SC + Q$ ،  $B = EA$  نیز طراز صورت  $E$  هم ممکن است

به صورت تکمیلی واحد  $E$  می شود. با بررسی سخت افزار جمع و تفریق مدهوت زیر مطالعه می شود:

|       |                                                                                               |            |
|-------|-----------------------------------------------------------------------------------------------|------------|
| $B_3$ | $\begin{array}{ c c c c } \hline 3 & 2 & 1 & 0 \\ \hline 1 & 0 & 1 & 0 \\ \hline \end{array}$ | $B$        |
| $E$   | $\leftarrow BCD$                                                                              | و این حساب |
| $A_3$ | $\begin{array}{ c c c c } \hline 3 & 2 & 1 & 0 \\ \hline 1 & 0 & 1 & 0 \\ \hline \end{array}$ | $A$        |

با مادر سرریز  $V = A \oplus (A_3 \cdot B_3)$  می باشد  $(A_3 \cdot B_3)$  بمعنی  $(A_3 \cdot B_3) = 1$  می باشد. مادر سرریز  $E = E(A_3, B_3)$  می باشد. مادر سرریز  $E$  را با تکمیل و دفعه و سیمیز با استفاده از جدول تابع  $E$  می خواهیم ساخت

| $E$ | $A_3$ | $B_3$ | $E(A_3 \oplus B_3)$ | سرریز ( $V$ ) |
|-----|-------|-------|---------------------|---------------|
| 0   | 0     | 0     | 0                   | 0             |
| 0   | 0     | 1     | 1                   | 0             |
| 0   | 1     | 0     | 0                   | 0             |
| 0   | 1     | 1     | 1                   | 0             |
| 1   | 0     | 0     | 0                   | 0             |
| 1   | 0     | 1     | 1                   | 0             |
| 1   | 1     | 0     | 0                   | 0             |
| 1   | 1     | 1     | 1                   | 0             |
| 1   | 0     | 0     | 0                   | 1             |
| 1   | 0     | 1     | 1                   | 1             |
| 1   | 1     | 0     | 1                   | 1             |
| 1   | 1     | 1     | 0                   | 1             |
| 1   | 0     | 0     | 0                   | 1             |
| 1   | 0     | 1     | 1                   | 1             |
| 1   | 1     | 0     | 1                   | 1             |
| 1   | 1     | 1     | 0                   | 1             |
| 1   | 0     | 0     | 0                   | 1             |


  
 $E = \sum m(0,1,2,4,5,6,7)$


  
 $E = \overline{A_3} \overline{B_3} + \overline{A_3} B_3 + A_3 \overline{B_3} + A_3 B_3$

$V = E(O \oplus A_3 \oplus B_3)$  مطالعه:

۲۸- نشان دهید که  $673 - 356$  با جمع  $673$  با متمم  $10$  عدد  $356$  و چشم پوشی از نقلی پایانی انجام می شود. بلاک دیاگرام سه مرحله از واحد حسابی دهدۀ را رسم کنید و نشان دهید چگونه این عمل پیاده سازی می شود. تمام بیت های ورودی و خروجی واحد حساب را لیست کنید.

حل:

$$\begin{array}{r} 673 - 356 = 317 \\ \Rightarrow 673 \\ + \frac{644}{\phantom{6}317} \end{array}$$

مکمل  $10$  )  $(356) = 644$

و نقلی ۱

با استفاده از یک سویچ  $M$  مشخص می کنیم تفریق یا جمع انجام می شود به شکل

روبرو:



برای سه واحد حسابی دهدزی داریم:



۲۹- نشان دهید که به جای جمع کننده دودویی چهار بیتی پایین رتبه در شکل ۱۰-۱۰ می توان یک تمام جمع کننده و دو نیم جمع کننده گذاشت.

حل: دقیق شود زمانی می توانیم به جای H.A. از F.A. استفاده کنیم که یا رقم نقلی ورودی نداشته باشیم و یا رقم نقلی خروجی نداشته باشیم.  
با توجه به شکل ۱۰-۱۰ کتاب، می توانیم داشته باشیم:



۳۰- با تکنیک‌های طراحی مدارهای ترکیبی، توابع بولی متمم ساز ۹ و اعداد BCD شکل ۱۰-۱۹ را بدست آورید. دیاگرام منطقی آن را رسم کنید.

حل: جدول زیر را داریم:

|   | فروودی ها                                                   | خروجی ها                                                    |   |
|---|-------------------------------------------------------------|-------------------------------------------------------------|---|
|   | B <sub>8</sub> B <sub>4</sub> B <sub>2</sub> B <sub>1</sub> | X <sub>8</sub> X <sub>4</sub> X <sub>2</sub> X <sub>1</sub> |   |
| 0 | 0 0 0 0                                                     | 1 0 0 1                                                     | 9 |
| 1 | 0 0 0 1                                                     | 1 0 0 0                                                     | 8 |
| 2 | 0 0 1 0                                                     | 0 1 1 1                                                     | 7 |
| 3 | 0 0 1 1                                                     | 0 1 1 0                                                     | 6 |
| 4 | 0 1 0 0                                                     | 0 1 0 1                                                     | 5 |
| 5 | 0 1 0 1                                                     | 0 1 0 0                                                     | 4 |
| 6 | 0 1 1 0                                                     | 0 0 1 1                                                     | 3 |
| 7 | 0 1 1 1                                                     | 0 0 1 0                                                     | 2 |
| 8 | 1 0 0 0                                                     | 0 0 0 1                                                     | 1 |
| 9 | 1 0 0 1                                                     | 0 0 0 0                                                     | 0 |

طبق جدول، برای  $X_1, X_2, X_4, X_8$  جداول کارنو را تشکیل داده تا مدار منطقی بهینه شده را بدست آوریم:



حال مدارهای منطقی را با فرمولهای بدست آمده تشکیل می‌دهیم.



۳۱- نیاز است برای دو رقم دهدۀ در کد افزونی ۳ (جدول ۶-۳) یک جمع کننده طراحی شود. نشان دهید که تصحیح پس از جمع دو رقم با جمع کننده چهار بیتی به صورت زیر است:

- الف) رقم نقلی خروجی برابر نقلی تصحیح نشده است.
- ب) اگر نقلی خروجی برابر ۰ باشد، ۱۱۰۱ اضافه می‌شود و نقلی حاصل از این جمع نادیده گرفته می‌شود. نشان دهید که جمع کننده افزونی ۳ می‌تواند با هفت جمع کننده و دو وارونگر ساخته شود.

حل:

| Dec<br>(جمع دو عدد) | Z تصحیح نشده | Y تصحیح شده (خروچی) |
|---------------------|--------------|---------------------|
| 0                   | 0110         | 0011                |
| 1                   | 0111         | 0100                |
| 2                   | 1000         | 0101                |
| 3                   | 1001         | 0110                |
| 4                   | 1010         | 0111                |
| 5                   | 1011         | 1000                |
| 6                   | 1100         | 1001                |
| 7                   | 1101         | 1010                |
| 8                   | 1110         | 1011                |
| 9                   | 1111         | 1100                |

|    |       |       |
|----|-------|-------|
| 10 | 10000 | 10011 |
| 11 | 10001 | 10100 |
| 12 | 10010 | 10101 |
| 13 | 10011 | 10110 |
| 14 | 10100 | 10111 |
| 15 | 10101 | 11000 |
| 16 | 10110 | 11001 |
| 17 | 10111 | 11010 |
| 18 | 11000 | 11011 |
| 19 | 11001 | 11100 |

دقت شود زمانی که جمع دو عدد بین ۰ تا ۹ دسیمال شود، رقم نقلی نداریم.

$$Y = Z - 3 = Z + 13 - 16 \quad (\text{نادیده گرفتن رقم نقلی})$$

رقم نقلی خروجی = رقم نقلی تصحیح نشده

$$Y = Z + 3$$



۳۲- مداری برای یک متمم ساز ۹، هنگامی که ارقام دهدھی به شکل کد افروزی  
۳ نمایش داده می‌شوند، بدست آورید. یک ورودی کنترل مدعی می‌کند آیا رقم

متهم شده است یا نه. مزیت این کار نسبت به کد BCD چیست؟

حل: در ارتباط با مزیت کد افزونی سه نسبت به کد BCD برای استفاده در ساخت متهم ساز ۹، می‌دانیم کد افزونی ۳ خود مکمل است. بنابراین برای بدست آوردن متهم ۹، کافی است متهم هر رقم را بنویسیم.  
برای مدار داریم:

|               |                            |
|---------------|----------------------------|
| $M = 0$       | for $X = B$                |
| $M = 1$       | for $X = 9's$ comp. of $B$ |
| $M \quad B_i$ | $x_i = B_i \oplus M$       |
| $0 \quad 0$   | $0 \quad \} x_i = B_i$     |
| $0 \quad 1$   | $1 \quad \} x_i = B'_i$    |
| $1 \quad 0$   | $1 \quad \} x_i = B'_i$    |
| $1 \quad 1$   | $0 \quad \} x_i = B'_i$    |



در این مدار با استفاده از سوییچ  $M$  و ۱ کردن آن می‌توان مکمل هر بیت را بدست آورد.

۳۳- سخت افزار به کار رفته برای جمع و تفریق دو عدد دهدھی با نمایش متهم ۱۰ علامت دار عددھای منفی را نشان دھید. نشان دھید چگونه سرریز آشکار می شود. الگوریتمی به شکل فلوچارت تهیه کنید و خود را از درستی تولید پاسخ آن مطمئن سازید.

حل: اساس کار الگوریتم درخواستی مانند الگوریتم داده شده برای جمع و تفریق در سیستم متهم (۲) دودویی است. (فلوچارت شکل ۱۰-۲)  
در ضمن در ارتباط با تشخیص خطای سرریز داریم:



۳۴- محتوای ثبات‌های  $A$  و  $E$  و  $Q$  و  $SC$  را در حین ضرب دهدهی (شکل

۱۰-۲۲) الف)  $470 \times 152$  و ب)  $999 \times 199$  بدست آورید. ثبات‌ها را سه رقمی

فرض کنید و دومین عدد را مضروب فیه در نظر بگیرید.

حل: برای نمونه (الف) را حل می‌نماییم

الف)  $B = 470$  مضروب فیه

|                          | Ae | A   | Q   | sc |
|--------------------------|----|-----|-----|----|
| Initial                  | 0  | 000 | 152 | 3  |
| $Q_L \neq 0$             | 0  | 470 | 151 |    |
| $Q_L \neq 0$             | 0  | 940 | 150 |    |
| $Q_L = 0, d \text{ shr}$ | 0  | 094 | 015 | 2  |
|                          | 0  | 564 | 014 |    |
| $Q_L \neq 0$             | 1  | 034 | 013 |    |
|                          | 1  | 504 | 012 |    |
|                          | 1  | 974 | 011 |    |
|                          | 2  | 444 | 010 |    |
| $Q_L = 0, d \text{ shr}$ | 0  | 244 | 401 | 1  |
| $Q_L \neq 0$             | 0  | 714 | 400 |    |
| $Q_L = 0, d \text{ shr}$ | 0  | 071 | 440 | 0  |

۳۵- محتوای ثبات‌های A و E و Q و SC را در حین تقسیم دهدی (شکل

۲۳-۱۰) نشان دهید. ثبات‌ها را دو رقمی در نظر بگیرید.

حل:

| E | AC | A  | Q  | SC | E  | AC | A  | Q  | SC |
|---|----|----|----|----|----|----|----|----|----|
| 0 | 0  | 16 | 80 | 2  | -- | 0  | 80 | 50 | 1  |
|   | 1  | 68 | 00 |    | -- | 9  | 68 |    |    |
|   | 9  | 68 |    |    | 1  | 0  | 48 | 51 |    |
| 1 | 1  | 36 | 01 |    |    | 9  | 68 |    |    |
|   | 9  | 68 |    |    | 1  | 0  | 16 | 52 |    |
| 1 | 1  | 04 | 02 |    |    | 9  | 68 |    |    |
|   | 9  | 68 |    |    | 0  | 9  | 84 |    |    |
| 1 | 0  | 72 | 03 |    |    | 0  | 32 |    |    |
|   | 9  | 68 |    |    | 1  | 0  | 16 | 52 | 0  |
| 1 | 0  | 40 | 04 |    |    |    |    |    |    |
|   | 9  | 68 |    |    |    |    |    |    |    |
| 1 | 0  | 08 | 05 |    |    |    |    |    |    |
|   | 9  | 68 |    |    |    |    |    |    |    |
| 0 | 9  | 76 |    |    |    |    |    |    |    |
| - | 0  | 32 |    |    |    |    |    |    |    |
| 1 | 0  | 08 | 05 | 1  |    |    |    |    |    |

خارج قسمت باقی مانده

۳۶- نشان دهید که زیر ثبات  $A_e$  در شکل (۱۰-۲۱) در پایان الف) ضرب دهدی که در شکل (۱۰-۲۲) مشخص است، و (ب) در تقسیم شکل (۱۰-۲۳)، صفر است.

حل: الف) در شکل (۱۰-۲۲)، در پایان عملیات ضرب، محتویات رجیستر  $A$  شیفت به راست داده می شود تا مقدار  $A_e$  صفر شود.

ب) در شکل (۱۰-۲۳) در پایان عملیات تقسیم،  $B$ ، به مقدار  $(A + \bar{B} + 1)$  اضافه می شود. طبق سیستم اعداد BCD،  $A_e$  مقدار ۹ را دارد. وقتی  $B = 0$  اضافه می شود، رقم نقلی تولید می شود و  $A_e = 0$  می شود.

۳۷- الگوریتم های حساب ممیز شناور در بخش های (۵-۱۰) را از داده های

دودویی به داده‌های دهدزی تغییر دهید. در یک جدول شیوه تفسیر هر یک از نمادهای ریز عمل‌ها را بنویسید.

حل: با در نظر گرفتن جدول (۱۰-۱) سمبول‌ها را انتخاب می‌کنیم و همچنین با در نظر گرفتن الگوریتم‌های بخش (۴-۱۰)، و در نظر گرفتن مانعیس در الگوریتم‌های ضرب و تقسیم، تبدیلات لازم را انجام می‌دهیم.



## فصل یازدهم: سازمان ورودی- خروجی

۱- آدرس‌های واگذار شده به چهار ثبات واسطه I/O در شکل ۱۱-۲ برابر با معادل دو دویی اعداد ۱۲، ۱۳، ۱۴ و ۱۵ است. مدار خارجی لازم بین یک آدرس I/O هشت بیتی از CPU و در ورودی‌های CS، RS1 و RS0 از مدار واسطه وصل شونده را نشان دهید.

حل:

|      |                                     |                               |                                                                                                    |
|------|-------------------------------------|-------------------------------|----------------------------------------------------------------------------------------------------|
|      | A <sub>7</sub> ..... A <sub>2</sub> | A <sub>1</sub> A <sub>0</sub> | CS = A <sub>2</sub> A <sub>3</sub> A' <sub>4</sub> A' <sub>5</sub> A' <sub>6</sub> A' <sub>7</sub> |
| 12 = | 000011                              | 0 0                           | ⇒ RS <sub>1</sub> = A <sub>1</sub>                                                                 |
| 13 = | 000011                              | 0 1                           | RS <sub>0</sub> = A <sub>0</sub>                                                                   |
| 14 = | 000011                              | 1 0                           |                                                                                                    |
| 15 = | 000011                              | 1 1                           |                                                                                                    |
|      |                                     | ↓      ↓                      | RS <sub>1</sub> RS <sub>0</sub>                                                                    |

(بیت‌های A<sub>7</sub> تا A<sub>2</sub> یکسان‌اند که با استفاده از یک AND 6 ورودی به CS متصل می‌شوند و دو بیت آخر همان RS1 و RS0 هستند).

۲- شش واحد واسط از نوعی که در شکل ۱۱-۲ نشان داده شده به یک CPU که از آدرس I/O هشت بیتی استفاده می‌کند متصل‌اند. هر یک از شش ورودی انتخاب تراشه CS به خط آدرس متفاوتی متصل است، بنابراین خط با ارزش‌تر آدرس به ورودی CS اولین واحد واسط و ششمین خط آدرس به ششمین واحد واسط متصل است. دو خط آدرس کم ارزش‌تر به RS1 و RS0 از هر شش واحد واسط متصل‌اند. آدرس هشت بیتی ثبات‌های هر واسطه را تعیین کنید.

حل:

| واسطه | A درگاه  | B درگاه  | ثبت کنترل | ثبت وضعیت |
|-------|----------|----------|-----------|-----------|
| # 1   | 10000000 | 10000001 | 10000010  | 10000011  |
| 2     | 01000000 | 01000001 | 01000010  | 01000011  |
| 3     | 00100000 | 00100001 | 00100010  | 00100011  |
| 4     | 00010000 | 00010001 | 00010010  | 00010011  |
| 5     | 00001000 | 00001001 | 00001010  | 00001011  |
| 6     | 00000100 | 00000101 | 00000110  | 00000111  |

۳- چهار وسیله جانبی که خروجی قابل درکی برای انسان داشته باشد نام ببرید.

حل: چاپگر - پلاتر - صفحه نمایش - خروجی صدا

۴- نام کامل خود را به ASCII با هشت بیت برای هر کاراکتر و یک ۰ در سمت چپ ترین مکان بنویسید. بین قسمت‌های مختلف نام یک فاصله بگذارد و نیز در صورت به کار بردن مخفف، پس از آن نقطه بگذارد.

حل:

|          |          |          |          |        |
|----------|----------|----------|----------|--------|
| M        | A        | N        | O        | (MANO) |
| 01001101 | 01000001 | 01001110 | 01001111 |        |

۵- تفاوت I/O مجزا با I/O نگاشت چیست؟ خوبی‌ها و بدی‌های هر یک را بگویید.

حل: در I/O مجزا برای هر دو بخش حافظه و I/O از یک گذرگاه مشترک استفاده می‌شود ولی هر کدام خطوط کنترل جداگانه دارند و برای نوشتن و خواندن از I/O دستورالعمل‌های مخصوص وجود دارد اما در I/O نگاشت هر دو بخش حافظه و I/O از گذرگاه و خطوط کنترل مشترک استفاده می‌کنند و دستورالعمل جداگانه‌ای برای ورودی و خروجی وجود ندارد.

I/O مجزا این مزیت را دارد که آدرس‌های حافظه و I/O را طوری از هم جدا می‌کند که حافظه به وسیله آدرس‌های تخصیص یافته در مدار واسطه تحت تأثیر قرار نمی‌گیرد زیرا حافظه و I/O هر کدام فضای آدرس مربوط به خود را دارند. عیب این روش وجود دستورهای مجزا برای خواندن و نوشتن در I/O است. در I/O نگاشت دستورالعمل خاصی برای I/O وجود ندارد و CPU قادر است داده‌های I/O واقع در

ثبات واسطه را با همان دستوراتی که برای حافظه به کار می‌رond دستکاری کند. عیب این روش آن است که در صورت بروز خطا در محاسبه آدرس حافظه، I/O تحت تأثیر قرار می‌گیرد و بر عکس.

۶ - مشخص کنید کدام یک از موارد زیر یک فرمان کترل، وضعیت یا انتقال داده است.

(الف) گذر از دستور العمل بعدی اگر پرچم یک باشد. ← فرمان وضعیت (وضعیت یک پرچم چک می‌شود.)

(ب) جستجوی یک رکورد خاص روی یک دیسک مغناطیسی ← فرمان کترل (هد مغناطیسی را روی دیسک جابه‌جا می‌کند.)

(ج) بررسی آماده بودن یا نبودن وسیله I/O ← فرمان وضعیت (آماده بودن وسیله را بررسی می‌کند)

(د) حرکت کاغذ چاپگر به ابتدای صفحه بعد ← فرمان کترل (کاغذ را جابه‌جا می‌کند.)

(ه) خواندن ثبات وضعیت واسط ← فرمان انتقال داده (مقدار یک ثبات خوانده می‌شود.)

۷- یک واحد واسط تجاری برای خطوط دست‌دهی مربوط به انتقال داده‌ها از وسیله I/O به واحد واسط از نام‌های مختلفی استفاده می‌کند. خط دست‌دهی ورودی واسط STB (مخف استروب یا فعال‌ساز) و خط دست‌دهی خروجی واسط IBF (مخف پر بودن بافر ورودی) نام‌گذاری شده است. وجود یک سیگنال سطح بالا روی IBF نشان می‌دهد که داده توسط واسط پذیرفته شده است. پس از سیگنال خواندن I/O از طرف CPU از طریق ثبات داده، IBF به سطح پایین می‌رود.

(الف) یک بلاک دیاگرام که CPU، واسط و وسیله I/O همراه با اتصال‌های لازم بین آنها را نشان دهد رسم کنید.



ب) یک دیاگرام زمانی برای انتقال دستدهی رسم کنید.



ج) برای انتقال از وسیله به واسط و از واسط به CPU یک نمودار دنباله رخدادها رسم کنید.



۸ - یک CPU با فرکانس ساعت 20 MHz به یک واحد حافظه که زمان دسترسی آن ۴۰ ns است وصل شده است. نمودارهای زمانی خواندن و نوشتן آنها را با فعالکننده‌های READ و WRITE تهیه کنید. در نمودار زمانی آدرس را نیز نشان دهید.

حل:

$$20 \text{ MHz} = 20 \times 10^6 \text{ Hz} \Rightarrow T = \frac{10^{-6}}{20} = 50 \text{ ns}$$

بنابراین دیاگرام به صورت زیر است:



۹- مدار واسط ارتباطی غیرهمگام شکل ۸ - ۱۱ بین یک CPU و یک چاپگر  
وصل شده است. فلوچارتی رسم کنید که دنباله عمل های فرستادن کاراکتر از  
CPU به چاپگر را نشان دهد.

حل: (ثبات ها مربوط به شکل ۸ - ۱۱ هستند. پرچم خروجی یک بیت در ثبات  
وضعیت است).



۱۰- حداقل شش وضعیت مختلف را برای ۱ کردن بیت‌های ثبات وضعیت در یک واسط ارتباطی غیرهمگام ارایه دهید.

حل:

۱- پرچم خروجی زمانی که ثبات انتقال خالی است.

۲- پرچم ورودی زمانی که ثبات دریافت پر است.

۳- فعال کردن وقفه اگر یک پرچم فعال است.

۴- خطای توازن

۵- خطای کادریندی

## ۶ - خطای بازنویسی

۱۱- اگر واسط به پایانه‌ای وصل باشد که به یک بیت توقف نیاز دارد، چند بیت در ثبات شیفت فرستنده شکل ۸-۱۱ وجود دارد؟ با استفاده از کد اسکی توازن زوج بیت‌های ثبات شیفت را وقتی که حرف W ارسال شود مشخص کنید.

حل:

۱۰ بیت: بیت شروع + ۷ بیت اسکی + بیت توازن + بیت توقف

از جدول ۱۱-۱ داریم:

کد اسکی W: ۱۰۱۱۱

با توازن زوج: ۱۱۰۱۰۱۱۱

با بیت شروع و توقف: ۱۱۱۰۱۰۱۱۱۰

۱۲- بر روی یک خط 1200-Baud با هر یک از روش‌های زیر چند کاراکتر در هر ثانیه فرستاده می‌شود؟ (کد کاراکترها را هشت بیتی فرض کنید).

(الف) ارسال سری همگام (همزمان)

$$\text{کاراکتر بر ثانیه} = \frac{1200}{8} = 150$$

(ب) ارسال غیر همگام (با دو بیت توقف)

$$\text{کاراکتر بر ثانیه} = \frac{1200}{11} = 109$$

(ج) ارسال سری غیر همگام (با یک بیت توقف)

$$\text{کاراکتر بر ثانیه} = \frac{1200}{10} = 120$$

۱۳- اطلاعاتی با سرعت m بایت در ثانیه به یک بافر FIFO وارد می‌شود. اطلاعات پاک شده از آن نیز n بایت در ثانیه است، یعنی ظرفیت بافر ۱۲ بایت است.

(الف) اگر  $n > m$  باشد چه مدت طول می‌کشد تا بافر خالی، پر شود؟

ظرفیت بافر

بایت k

اختلاف سرعت ورود و پاک شدن ثانیه / بایت  $(m-n)$

= زمان پر شده = \_\_\_\_\_

$$\text{ثانیه} = \frac{12}{m-n}$$

ب) اگر  $m < n$  چقدر طول می‌کشد تا بافر پر، خالی شود؟

همانند زمان پر شدن داریم:

$$\text{ثانیه} = \frac{12}{n-m}$$

ج) اگر  $m = n$  باشد آیا بافر FIFO لازم است؟

خیر، زمانی به بافر نیاز داریم که اختلاف سرعت وجود داشته باشد و لازم باشد یکی منتظر دیگری بماند.

۱۴- بیت‌های ثبات کنترل FIFO در شکل ۱۱-۹ عبارتند از  $F_1F_2F_3F_4 = 0011$

رشته عمل‌های داخلی را هر گاه یک داده از FIFO حذف و سپس داده جدیدی وارد شود تعیین کنید.

حل: با توجه به شکل ۱۱-۹ داریم:

|                                     |          |                                |
|-------------------------------------|----------|--------------------------------|
| حالت اولیه                          | $F=0011$ | $\text{output} \leftarrow R_4$ |
| بعد از حذف ۱                        | $F=0010$ |                                |
| بعد از حذف ۰                        | $F=0001$ | $R_4 \leftarrow R_3$           |
| بعد از ورود ۱                       | $F=1001$ | $R_1 \leftarrow \text{input}$  |
| داده وارد شده به انتهای صف می‌رود.) | $F=0101$ | $R_2 \leftarrow R_1$           |
|                                     | $F=0011$ | $R_3 \leftarrow R_2$           |

۱۵- مقدارهای «ورودی آماده» و «خروجی آماده» و بیت‌های کنترل  $F_1$  تا  $F_4$  در

شکل ۱۱-۹ در وضعیت‌های زیر چیست؟

«ورودی  
آماده»      «خروجی  
آماده»

$F_1 - F_4$

- |   |   |      |                                    |
|---|---|------|------------------------------------|
| ۱ | ۰ | ۰۰۰  | الف) وقتی بافر خالی است.           |
| ۰ | ۱ | ۱۱۱  | ب) وقتی بافر پر است.               |
| ۱ | ۱ | ۰۰۱۱ | ج) وقتی بافر حاوی دو قلم داده است. |

۱۶- یک بلاک دیاگرام مشابه شکل ۱۱-۱۰ را برای جابجایی داده از CPU به یک واسطه و سپس به یک وسیله I/O رسم کنید. رویه‌ای برای ۱ کردن و ۰ کردن بیت پرچم ارائه دهید.

حل:



رویه ۱ کردن و صفر کردن پرچم.

=0 flag اگر ثبات داده پر باشد. (بعد از نوشتن توسط CPU)

=1 flag اگر ثبات داده خالی باشد (بعد از انتقال به وسیله جانبی)

هنگامی که flag صفر می‌شود، Data Ready فعال شده و داده روی گذرگاه I/O قرار می‌گیرد. هنگامی که flag شود؛ acknowledge ۱ کرده و خط دست‌دهی Ready را غیرفعال می‌کند.

۱۷- با پیکربندی شکل مسئله ۱۱-۱۶ فلوچارتی (مشابه شکل ۱۱-۱۱) برای برنامه CPU جهت خروجی داده بدست آورید.

حل:



#### ۱۸- خوبی اصلی استفاده از جابجایی داده به کمک وقفه در برابر جابجایی تحت کنترل برنامه بدون وقفه چیست؟

حل: انتقال تحت کنترل برنامه به دلیل تفاوت سرعت انتقال اطلاعات بین CPU و وسیله I/O روش کارایی نیست (زمان CPU را هدر می‌دهد) اما در انتقال به کمک وقفه CPU مدامی که مشغول اجرای یک برنامه است پرچم را وارسی نمی‌کند و هنگام ۱ شدن پرچم، وقفه‌ای اجرای برنامه جاری را متوقف می‌کند و ۱ شدن پرچم را به CPU اطلاع می‌دهد در این حالت CPU روال سرویس وقفه را انجام می‌دهد و دوباره به برنامه اصلی باز می‌گردد که باعث تلف نشدن وقت CPU برای بررسی فعال شدن

پرچم می شود.

**۱۹-** در بیشتر کامپیوترها وقفه فقط پس از اجرای دستورالعمل جاری تشخیص داده می شود. امکان پذیرش وقفه را در هر زمانی در حین اجرای دستور بررسی کنید. در مورد مشکلاتی که ممکن است بروز کند بحث کنید.

**حل:** اگر وقفه‌ای در حین اجرای یک دستور تشخیص داده شود، لازم است که علاوه بر ثبات‌های پردازنده، تمام اطلاعات ثبات‌های کنترل نیز ذخیره شود (در پایان اجرای دستور مقدار ثبات‌های کنترل مهم نیستند و نیازی به ذخیره آنها نیست) این کار باعث می شود ذخیره‌ی وضعیت CPU بسیار پیچیده‌تر شود. همچنین اجرای دستوراتی مانند ION که باید بطور کامل انجام شوند نیز ممکن است دچار اختلال شود.

**۲۰-** در سیستم وقفه اولویت‌دار چرخشی شکل ۱۱-۱۲، هر گاه پس از درخواست وقفه وسیله ۲ به CPU و قبل از تصدیق به وسیله CPU، وسیله ۱ درخواست وقفه کند چه می شود؟

**حل:**

- ۱- در ابتدا وسیله ۲ یک درخواست وقفه به CPU می فرستد.
- ۲- قبل از این که CPU تصدیق کند وسیله ۱ درخواست وقفه به CPU می فرستد.
- ۳- بعد از این که CPU تصدیق می کند، وسیله‌ی ۱ دارای اولویت است و آدرس آن فعال شده و به CPU ارسال می شود.

**۲۱-** کامپیوتری را بدون سخت‌افزار وقفه اولویت‌دار در نظر بگیرید. هر یک از چند منبع می توانند به کامپیوتر وقفه دهند، هر درخواست وقفه موجب ذخیره آدرس برگشت و انشعاب به یک روال مشترک وقفه می گردد. توضیح دهید چگونه می توان در برنامه سرویس‌دهی وقفه، اولویت برقرار کرد.

**حل:**

برای این کار، در روال مشترک وقفه، هنگام چک کردن منبع وقفه (شرط if-else)،

منابع را از اولویت بالا به پایین بررسی می‌کنیم. این کار باعث می‌شود اگر دو وقفه همزمان اتفاق افتاده باشد در هنگام بررسی منع با اولویت بالاتر انتخاب شود.

۱۱-۲- با روش‌های طراحی مدارهای ترکیبی، عبارت‌های بولی در جدول ۱۱-۲ را برای کدگذار اولویت بدست آورید. نمودار منطقی مدار را رسم کنید.

حل:

| $I_0$ | $I_1$ | $I_2$ | $I_3$ | $x$ | $y$ | $I_{st}$ |
|-------|-------|-------|-------|-----|-----|----------|
| 1     | X     | X     | X     | 0   | 0   | 1        |
| 0     | 1     | X     | X     | 0   | 1   | 1        |
| 0     | 0     | 1     | X     | 1   | 0   | 1        |
| 0     | 0     | 0     | 1     | 1   | 1   | 1        |
| 0     | 0     | 0     | 0     | X   | X   | 0        |

ساده‌سازی: ←





۲۳- سخت افزار وقفه اولویت دار موازی را برای سیستمی با هشت منبع وقفه طراحی کنید.

حل:



۲۴- جدول درستی انکدر  $3 \times 8$  اولویت را بدست آورید. فرض کنید که سه خروجی xyz از انکدر اولویت برای تهیه آدرس بردار به و به شکل 101xyz00 بکار روند. هشت آدرس بردار را با شروع از آن که بالاترین اولویت را دارد بنویسید.

حل:

| $l_0$ | $l_1$ | $l_2$ | $l_3$ | $l_4$ | $l_5$ | $l_6$ | $l_7$ | x | y | z | lst |
|-------|-------|-------|-------|-------|-------|-------|-------|---|---|---|-----|
| 1     | x     | x     | x     | x     | x     | x     | x     | 0 | 0 | 0 | 1   |
| 0     | 1     | x     | x     | x     | x     | x     | x     | 0 | 0 | 1 | 1   |
| 0     | 0     | 1     | x     | x     | x     | x     | x     | 0 | 1 | 0 | 1   |
| 0     | 0     | 0     | 1     | x     | x     | x     | x     | 0 | 1 | 1 | 1   |
| 0     | 0     | 0     | 0     | 1     | x     | x     | x     | 1 | 0 | 0 | 1   |
| 0     | 0     | 0     | 0     | 0     | 1     | x     | x     | 1 | 0 | 1 | 1   |
| 0     | 0     | 0     | 0     | 0     | 0     | 1     | x     | 1 | 1 | 0 | 1   |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1 | 1 | 1 | 1   |
| 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | x | x | x | 0   |

| دودویی    | مبنا ۱۶ |
|-----------|---------|
| 1010 0000 | A0      |
| 1010 0100 | A4      |
| 1010 1000 | A8      |
| 1010 1100 | AC      |
| 1011 0000 | B0      |
| 1011 0100 | B4      |
| 1011 1000 | B8      |
| 101 11100 | BC      |

۲۵- در شکل ۱۴-۱۱ چه باید کرد تا چهار مقدار VAD برابر با ۷۶، ۷۷، ۷۸، ۷۹ باشد؟

حل:

$$76 = (01001100)_2$$

پس کافی است ۶ عدد صفر را با ۰۱۰۱۱ جایگزین کنیم تا اعداد مورد نظر بدست آید.

۲۶- برای بررسی زمانی که منبع در حال سرویس دهی به وقfe قبلی به کامپیوتر به وسیله همان منبع، وقfe می‌دهد، چه برنامه‌ای نیاز است؟

حل: ابتدا بیت ماسک مربوط به منبع وقfe را فعال می‌کنیم که بتواند دوباره وقfe بدهد. برای تشخیص، در شروع روال سرویس مقدار آدرس بازگشت را در پشته بررسی می‌کنیم. اگر این مقدار، آدرسی درون برنامه سرویس منبع باشد، بدین معنی است که همان منبع در هنگام سرویس دهی دوباره وقfe ایجاد کرده است.

۲۷- چرا خط‌های کنترل خواندن و نوشتمن در کنترل کننده DMA دو طرفه است؟ در چه شرایطی و به چه منظوری از آنها به عنوان ورودی استفاده می‌شود؟

در چه شرایطی و به چه منظوری از آنها به عنوان خروجی استفاده می‌شود؟

حل: هنگامی که CPU با کنترل کننده DMA ارتباط برقرار می‌کند، خطوط خواندن و نوشتمن به عنوان ورودی از CPU به DMA استفاده می‌شوند. این کار امکان برقراری ارتباط با ثبات‌های DMA را برای CPU فراهم می‌کند.

هنگامی که کنترل کننده DMA با حافظه ارتباط برقرار می‌کند، خطوط خواندن و نوشتمن به عنوان خروجی از DMA به حافظه استفاده می‌شوند و عمل خواندن یا نوشتمن را مشخص می‌کنند.

۲۸- می‌خواهیم ۲۵۶ کلمه را از یک دیسک مغناطیسی به بخشی از حافظه که از آدرس ۱۲۳۰ شروع می‌شود جابجا کنیم. جابجاگایی با DMA طبق شکل ۱۸-۱۱

### صورت می‌گیرد، روند این کار چگونه خواهد بود؟

حل: الف) CPU، DMA را با انتقال مقادیر زیر مقداردهی اولیه می‌کند:

۲۵۶ به ثبات شمارنده کلمه

۱۲۳۰ به ثبات آدرس DMA

بیت‌هایی به ثبات کترل برای مشخص کردن عمل نوشتند

ب) ۱- وسیله I/O یک درخواست DMA می‌فرستد.

۲- DMA درخواست گذرگاه (BR) به CPU می‌فرستد.

۳- CPU با اعطای گذرگاه (BG) (PASX) می‌دهد.

۴- محتوای ثبات آدرس DMA روی گذرگاه آدرس قرار می‌گیرد.

۵- DMA سیگنال «تصدیق DMA» را به وسیله I/O می‌فرستد و خط کترل نوشتند حافظه را فعال می‌کند.

۶- کلمه داده توسط وسیله I/O روی گذرگاه داده قرار می‌گیرد.

۷- ثبات آدرس DMA یک واحد افزایش پیدا کرده و ثبات شمارنده کلمه DMA یک واحد کاهش می‌یابد.

۸- مراحل ۴ تا ۷ برای انتقال هر کلمه تکرار می‌شود.

۹- یک کترل‌کننده DMA کلمه‌های ۱۶ بیتی را با سرقت سیکل به حافظه منتقل می‌کند. این کلمه‌ها از وسیله‌ای دریافت می‌شود که کاراکترها را با سرعت ۲۴۰۰ کاراکتر در ثانیه می‌فرستد. CPU دستورها را با سرعت یک میلیون در ثانیه برداشت و اجرا می‌کند. CPU در اثر جابجایی به شیوه DMA تا چه اندازه کند می‌شود؟

حل: CPU در هر  $(1\mu s)^6 = 1,10^6$  بار (یا بیشتر) بر حافظه مراجعه می‌کند. کاراکترها در هر  $1,2400 \times 1,6\mu s = 4,6\mu s$  دریافت می‌شوند. دو کاراکتر ۸ بیتی بسته‌بندی شده در کلمه ۱۶ بیتی هر  $416,6 \times 3\mu s = 833,3\mu s$  دریافت می‌شوند. پس هر  $\frac{833}{3}$  سیکل از CPU، یک سیکل برای دریافت کاراکتر استفاده می‌شود. بنابراین حداقل کاهش سرعت

CPU برابر است با:

$$\frac{1}{833,3} \times 100 = 0,12\%$$

**۳۰- چرا DMA به هنگام درخواست جابجایی به حافظه نسبت به CPU به هنگام درخواست جابجایی به حافظه اولویت دارد؟**

حل: CPU می‌تواند برای برداشت دستورها و داده از حافظه بدون هیچ آسیبی به جز از دست دادن زمان منتظر بماند اما DMA معمولاً داده را از وسیله‌ای انتقال می‌دهد که نمی‌تواند متوقف شود چون جریان ورودی اطلاعات ادامه دارد و ممکن است داده‌هایی از بین برود.

**۳۱- فلوچارتی شبیه ۱۱-۲۰ برای IBM 370 رسم کنید و ارتباط CPU با گذرگاه جابجایی I/O را توضیح دهید.**

حل:



CPU مستقیماً از طریق خطوط کنترل اختصاصی با کانال‌ها و از طریق نواحی رزرو شده ذخیره‌سازی در حافظه بطور غیرمستقیم تبادل اطلاعات می‌کند. شکل ۱۱-۲۱ در کتاب قالب کلمات مربوط به عملکرد کانال را نشان می‌دهد.

۳۲- آدرس یک پایانه متصل به یک پردازنده انتقال داده از دو حرف الفبای انگلیسی یا یک حرف و به دنبال آن یکی از ده رقم تشکیل شده است. چند آدرس مختلف می‌توان ایجاد کرد؟

۲۶ حرف و ۱۰ رقم وجود دارد:

$= 26 \times 26 + 26 \times 10 = 936$  تعداد آدرس ممکن

۳۳- رویه‌ای را برای خط جابجایی دنباله کاراکترها، به منظور ارتباط بین یک پردازنده جابجایی داده و یک پایانه دوردست طراحی کنید. پردازنده می‌پرسد که پایانه در حال کار است یا خیر. پایانه با بله و خیر به آن پاسخ می‌دهد. اگر پاسخ بلی باشد پردازنده بلاکی از متن برای آن می‌فرستد.

حل: پردازنده آدرس ترمینال را همراه با کد ENQ (پرسش) (۰۰۰۰ ۰۱۰۱) می‌فرستد.

ترمینال با ACK (تصدیق) یا NAK (عدم تصدیق) پاسخ می‌دهد یا اینکه در طول یک فاصله زمانی پاسخ نمی‌دهد. اگر پردازنده یک ACK دریافت کرد، یک بلاک از متن را می‌فرستد.

۳۴- یک ارتباط جابجایی داده از قرارداد مبتنی بر کاراکتر با شفافیت داده‌های بکارگیری کاراکتر DLE استفاده می‌کند. پیام متنی که فرستنده بین STX و ETX می‌فرستد به صورت زیر است:

DLE STX DLE DLE ETX DLE DLE ETX DLE ETX

داده‌های شفاف متنی را به صورت دودویی بنویسید.

حل:



۳۵- کمترین تعداد بیت‌هایی که یک کادر در قرارداد مبتنی بر بیت دارد چقدر است؟

حل: ۳۲ بیت بین پرچم‌ها؛ ۴۸ بیت همراه با پرچم‌ها (با توجه به قرارداد مبتنی بر بیت)

۳۶- نشان دهید چگونه روش درج صفر در قرارداد مبتنی بر بیت، وقتی که یک صفر و به دنبال آن ده بیت معادل دودویی ۱۰۲۳ فرستاده می‌شود کار می‌کند.

حل:

اطلاعاتی که قرار است فرستاده شود (۱۰۲۳):

بعد از درج صفر، اطلاعاتی که فرستاده می‌شود:

اطلاعات دریافت شده بعد از حذف صفر:

۰۱۱۱۱۱۱۱۱۱

۰۱۱۱۱۱۰۱۱۱۱۰

۰۱۱۱۱۱۱۱۱۱۱

## فصل دوازدهم: سازمان حافظه

۱- الف) چند تراشه Ram،  $128 \times 8$  برای ساخت یک حافظه با ظرفیت  $2048$  لازم است؟

ب) چند خط گذرگاه آدرس نیاز است تا  $2048$  بایت حافظه دستیابی شود؟  
چند خط از این خط ها برای همه تراشه ها مشترک است؟

پ) چند خط برای انتخاب تراشه باید دیکد شود؟ اندازه دیکدر را تعیین کنید.

حل:

$$\text{الف) تعداد تراشه Ram مورد نیاز: } \frac{2048}{128} = 16$$

$$\text{ب) ۱۱ خط آدرس نیاز داریم} \Rightarrow 2^{11}$$

برای دیکدر انتخاب و فعال سازی هر کدام از تراشه های Ram، ۴ خط احتیاج است



$$\text{پس خطوط آدرس مشترک} = 11 - 4 = 7$$

پ) همان طور که گفته شد، دیکدر ۴ به ۱۶ نیاز خواهد بود.

۲- کامپیوتری از یک RAM با ظرفیت  $1024 \times 1$  استفاده می کند.

الف) چند تراشه نیاز است و چگونه خط های آنها باید متصل شود تا  $1024$  بایت حافظه حاصل شود.

ب) چند تراشه برای تهیه  $16k$  بایت حافظه نیاز است؟ توضیح دهید که چگونه تراشه ها باید به گذرگاه حافظه وصل شوند.

حل:

الف) برای ساخت تراشه RAM،  $1024 \times 8$  از تراشه رم  $1024 \times 1$ ، ۸ تراشه به صورت موازی به هم متصل می شوند. مانند شکل زیر:



ب) در کل،  $128 = 16 \times 8$  تراشه Ram  $1024 \times 1$  لازم است.

$$16k = 2^4 \times 2^{10} = 2^{14} \Rightarrow 14 \text{ خط آدرس خواهیم داشت:}$$

که ۱۰ خط آدرس برای آدرس دهی تراشه ها و ۴ خط آدرس برای انتخاب یکی از ۱۶ تراشه به وسیله یک دیکدر ۴ به ۱۶ استفاده می شود.

۳- یک تراشه ROM با  $1024 \times 8$  بیت دارای چهار ورودی انتخاب بوده و با منبع تغذیه ۵ ولتی کار می کند برای بسته IC چند پایه نیاز است. بلاک دیاگرام را رسم کرده و پایانه های ورودی و خروجی را در ROM نام گذاری کنید.

حل:

$$1024 = 2^{10} \Rightarrow 10 \text{ خط آدرس}$$



۴- سیستم حافظه شکل ۱۲-۴ را به

گسترش دهید. نقشه حافظه - آدرس را رسم کنید. تعیین کنید که اندازه دیکدر باید چقدر باشد.

حل:

تعداد تراشه RAM:

$$\frac{4096}{128} = 32$$

تعداد تراشه ROM:

$$\frac{4096}{512} = 8$$

از ۱۶ خط آدرس که CPU در اختیار می‌گذارد به ۱۲ خط آدرس نیاز داریم زیرا:

$$4096 = 2^{12}$$

همچنین از بیت ۱۳ خط آدرس برای انتخاب ROM استفاده می‌شود.

پس داریم:

## بیت‌های آدرس

| تراشه | محدوده آدرس | ۱۶ | ۱۵ | ۱۴ | ۱۳ | ۱۲ | ۱۱            | ۱۰ | ۹ | ۸ | ۷-۱ |
|-------|-------------|----|----|----|----|----|---------------|----|---|---|-----|
| RAM   | 0000-0FFF   | •  | •  | •  | •  |    | دیکدر ۵ به ۳۲ |    |   |   | ×   |
| ROM   | 1FFF-4000   | •  | •  | •  | ۱  | ۸  | دیکدر ۳ به ۸  |    |   | × |     |

در این بحث یک نکته مهم وجود دارد. در این مثال ما از بیت‌های با ارزش کمتر برای خطوط مشترک آدرس دهی و از بیت‌های با ارزش بیشتر برای انتخاب تراشه‌ها استفاده کردیم. به این روش High order Interleaving می‌گویند. حسن این روش در مفهوم تحمل خطا در خرابی احتمالی تراشه‌ها می‌باشد.

روش دیگر که بر عکس روش قبلی، از بیت‌های با ارزش کمتر برای انتخاب تراشه‌ها استفاده می‌شود Low order Interleaving نام دارد. حسن این روش در امکان بکارگیری آدرس‌های درخواستی دسترسی به حافظه‌ها به صورت موازی و در یک زمان است. زیرا آدرس‌های متوالی در تراشه‌های متفاوت قرار دارند.

۵ - کامپیوتری از تراشه‌های RAM با  $256 \times 8$  و ROM با  $1024 \times 8$  استفاده

می کند. سیستم کامپیوترا به  $2k$  بایت از RAM و چهار واحد واسطه، که هر یک چهار ثبات دارد، نیاز دارد. از پیکربندی I/O نگاشت حافظه استفاده شده است. به دو بیت با ارزش تر گذرگاه آدرس  $00$  برای RAM  $1$  برای ROM و  $10$  برای ثبات های واسطه اختصاص داده می شود.

الف) چند تراشه RAM و ROM لازم است.

ب) نقشه حافظه - آدرس را برای سیستم رسم کنید.

پ) محدوده آدرس را بر حسب شانزده شانزدهی برای RAM و ROM و مدار واسطه تعیین کنید.

حل:

تعداد تراشه های RAM مورد نیاز:

$$\frac{2048}{256} = 8 \quad , \quad 2048 = 2^{11} \quad , \quad 256 = 2^8$$

تعداد تراشه های ROM مورد نیاز:

$$\frac{4096}{1024} = 4 \quad , \quad 4096 = 2^{12} \quad , \quad 1024 = 2^{10}$$

چهار واحد واسطه که هر کدام  $4$  رجیستر دارد.

$$4 \times 4 = 16 = 2^4$$

پس داریم:

|               |             | سیستم های آدرس |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|---------------|-------------|----------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
|               |             | 16             | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| تراشه های RAM | 0000 - 0FFF | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | X | X | X | X | X | X | X |
| ROM           | 4000 - 4FFF | 0              | 1  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | X | X | X | X | X | X | X |
| Interface     | 8000 - 800F | 1              | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

نمودار آدرس

۶- یک کامپیوتر دارای گذرگاه آدرس ۱۶ بیتی است. ۱۵ خط اول آدرس‌ها برای انتخاب یک بانک ۳۲k بایتی حافظه به کار رفته است. بیت با ارزش تر آدرس برای انتخاب یک ثبات که محتوای گذرگاه داده را دریافت می‌کند بکار رفته است. توضیح دهید چگونه می‌توان از این پیکربندی استفاده کرده و ظرفیت حافظه را به هشت بانک ۳۲k بایتی افزایش داد تا یک بانک ۲۵۶k بایتی حاصل شود.

حل:  $32k = 2^5 \times 2^{10} = 2^{15}$  خط آدرس

پس ۱۵ خط آدرس برای دسترسی به داده‌های هر کدام از بانک‌های ۳۲k بایتی داریم. برای استفاده از بیت با ارزش‌ترین، برای انتخاب ثبات محتوای گذرگاه به صورت زیر عمل می‌کنیم:

| ثبت محتوای گذرگاه | شماره بانک ۳۲K بیتی |
|-------------------|---------------------|
| .....1            | ۱                   |
| .....10           | ۲                   |
| ....100           | ۳                   |
| ...1000           | ۴                   |
| ..10000           | ۵                   |
| .100000           | ۶                   |
| 1000000           | ۷                   |
| 10000000          | ۸                   |

۷- یک سیستم دیسک مغناطیسی دارای پارامترهای زیر است:

$T_s$  = زمان متوسط برای قرار گرفتن هد مغناطیسی روی یک شیار

$R$  = سرعت چرخش دیسک برحسب دور بر ثانیه

$N_t$  = تعداد بیت‌ها در شیار

$N_s$  = تعداد بیت‌ها در قطاع

زمان متوسط  $T_a$  که برای خواندن یک قطاع نیاز است چقدر است؟

حل: زمان متوسط =

زمان متوسط لازم برای قرار گرفتن هد مغناطیسی روی یک شیار

+ متوسط زمانی که طول می‌کشد دیسک با چرخش خود، هد را در مکان مناسب

جای دهد = نصف یک چرخش کامل

+ زمانی که طول می‌کشد، اطلاعات از سکتور خوانده شود.

پس:

$$T_a = T_s + \frac{1}{2R} + \frac{N_s}{N_t} \times \frac{1}{R}$$

۸- سرعت جابجایی یک نوار مغناطیسی هشت شیاره که سرعتش ۱۲۰ اینچ در

ثانیه و تراکم آن ۱۶۰۰ بیت در اینچ است چقدر است؟

حل: دقت شود که ۸ بیت مربوط به یک کاراکتر، دقیقاً همزمان خوانده می‌شود (به

دلیل ماهیت نوار مغناطیسی) بنابراین داریم:

کاراکتر در ثانیه  $192000 = 1600 \times 120$  = نرخ انتقال

۹- تابع متمم منطق انتباری یک کلمه را در حافظه انجمانی بدست آورید. به بیان

دیگر، نشان دهید که  $M'_i$  مجموع توابع OR انحصاری است. دیاگرام منطقی را

برای  $M'_i$  رسم نموده و با یک وارونگر آن را پایان دهید تا  $M_i$  بدست آید.

حل: در ابتدا باید گفت مفهوم  $\prod_{g=1}^n$  ضرب همه عبارت‌ها به ازای g های از ۱ تا n

می‌باشد. همچنین مفهوم  $\sum_{g=1}^n$  مجموع همه عبارت‌ها به ازای وهای از ۱ تا  $n$  می‌باشد.

داریم:

$$\begin{aligned} M_i &= \prod_{j=1}^n ((A_j F_{ij} + A'_j F'_{ij}) + K'_j) \\ &= \prod_{j=1}^n ((A_j \oplus F_{ij})' + K'_j) \\ &\text{ طبق قاعده کوئان } M'_i = \sum_{j=1}^n (A_j \oplus F_{ij}) K_j \end{aligned}$$

برای رسم مدار منطقی، برای یک بیت داریم: (بیت ۱)



۱۰- تابع بول را برای منطق انطباق یک کلمه با یک حافظه انجمنی با در نظر گرفتن یک بیت نشانه که مشخص می‌کند کلمه فعال است یا غیرفعال را بدست آورید.

حل: این بیت نشانه را به عنوان یکی از پایه‌های یک گیت منطقی AND به کار می‌بریم تا فعال بودن یا نبودن کلمه، مشخص شود. پس:

$T_i$  : بیت نشانه

| $M_i T_i$ | وضعیت              |
|-----------|--------------------|
| ۰ ۰       | نه فعال و نه منطبق |
| ۰ ۱       | فعال و غیرمنطبق    |
| ۱ ۰       | منطبق و غیرفعال    |



۱۱- چه مدار منطقی اضافی نیاز است تا نتیجه عدم انطباق را برای یک کلمه در حافظه انجمانی، وقتی که همه بیت‌های کلید صفر است مشخص کند؟

حل: با توجه به مدار داده شده برای حافظه انجمانی «تدعیگر»، هر گاه  $\phi_j = k_j$  باشد، مقایسه بیت‌ها تأثیر نخواهد داشت. پس اگر همه بیت‌های key، صفر باشد، تطابق حاصل خواهد شد. برای برآورده کردن خواسته سؤال، صرفاً لازم است حداقل یکی از بیت‌های key ۱ باشد پس:

$$M_{i(\text{new})} = \left( \prod_{g=1}^n (A_i F_{ig} + A'_g F'_{ig} + K'_g) \right) \cdot (K_1 + K_2 + \dots + K_n)$$

۱۲- الف) دیاگرام منطقی تمام سلول‌های یک کلمه در حافظه انجمانی را رسم کنید. منطق خواندن و نوشتن شکل ۱۲-۸ و منطق انطباق شکل ۱۲-۹ را نیز اضافه کنید.

ب) دیاگرام منطقی تمام سلول‌های عمودی یک ستون (ستون J) را در حافظه انجمانی رسم کنید. یک خط خروجی مشترک برای همه بیت‌هایی که در یک ستون وجود دارند اضافه کنید.

ج) با استفاده از دیاگرام‌های الف و ب نشان دهید که اگر خروجی  $M_i$  به خط خواندن همان کلمه وصل شود، کلمه منطبق خوانده خواهد شد، مشروط بر اینکه فقط یک کلمه با آرگومان پوشانده شده مطابقت داشته باشد.

حل:

الف و ب) شکل اول برای کلمه اول، و شکل دوم برای ستون J:



ج) لازم به توضیح است، هر گاه  $M_i$  و ۱ شود، پایه **Read** مربوط به  $C_i$  فعال شده و خواندن آن صورت می‌پذیرد. پس:



۱۳- با استفاده از بلاک دیاگرام نشان دهید چگونه می‌توان کلمات منطبق متعدد را از حافظه انجمی خواند؟

حل: ذکر این نکته مهم است که قاعده‌تاً امکان خواندن تعداد بیش از ۱ کلمه از حافظه انجمی بطور همزمان و در یک لحظه وجود ندارد. برای این کار باید ترتیبی دهیم تا با هر سیکل، یکی از کلمات منطبق از حافظه خوانده شود. بنابراین از یک شمارنده که بتواند در هر سیکل، یکی از کلمات منطبق را برای خروج انتخاب کند، استفاده می‌کنیم.

پس:



۱۴- منطق یک سلول و نیز یک کلمه کامل را برای یک حافظه انجمنی، همراه با نشانگری برای موقعی که آرگومان پوشش نیافته بزرگتر از (اما نه مساوی با) کلمه موجود در حافظه انجمنی باشد، بدست آورید.

حل: در رابطه با نشانگر مورد نظر، هدف مقایسه  $A$  و  $F_i$  ها است. بنابراین

می توانیم موارد زیر را داشته باشیم:

$$G_i = 1 \quad \text{IF} \left\{ \begin{array}{l} \text{بیت اول } A_1 \text{ و } F_{i1} = 0 \\ \text{یا} \end{array} \right.$$

بیت اول A و  $F_{11}$  برابر و بیت دوم A، ۱ و  $F_{12} = 0$

۱۰

$F_{i3} = 0$  و  $D_2$  با  $F_{i1}$  و  $F_{i2}$  برابر و بیت سوم A ، ۱ و

..... }  
..... }

پس داریم:

$$X_j = A_j F_{ij} + A'_j F'_{ig}$$

$$G_i = (A_i F_{i1} + K'_1)(X_1 A_2 F_{i2} + K'_2)(X_1 X_2 A_3 F_{i3} + K'_3) \dots (X_1 X_2 \dots X_{n-1} A_n F_{in} + K'_n)$$

پس برای مدار داریم:



۱۵- یک حافظه نهان انجمنی دو تایی از بلاک‌های چهار کلمه‌ای استفاده می‌کند. حافظه نهان می‌تواند در مجموع ۲۰۴۸ کلمه از حافظه اصلی را در خود جای دهد. اندازه حافظه اصلی  $128 \times 32$  است.

الف) همه اطلاعات لازم برای ساختن این حافظه نهان را فرمول بندی کنید.

ب) اندازه حافظه نهان چقدر است؟

حل: حافظه نهان از نوع انجمنی "Associative" و دوتایی "two-way"، و به صورت بلاک‌های ۴ کلمه‌ای است.

\* در متن انگلیسی کتاب معماری کامپیوتر، اندازه حافظه اصلی،  $128k \times 32$  عنوان شده است. پس داریم:

$$128k = 2^{17}$$

الف) تعداد سطرهای حافظه نهان  $= 2^{10} \Rightarrow$  در هر سطر حافظه نهان دو کلمه و

$$2048 = 2^{11}$$

پس:

|       |        |
|-------|--------|
| TAG   | Index  |
| ۷ بیت | ۱۰ بیت |

ب) اندازه حافظه حافظه نهان بر حسب تعداد بیت مدنظر است. یک سطر حافظه نهان را رسم می‌کنیم.

|       |        |       |        |
|-------|--------|-------|--------|
| Tag1  | Data2  | Tag2  | Data 2 |
| ۷ بیت | ۳۲ بیت | ۷ بیت | ۳۲ بیت |

در هر سطر حافظه نهان،  $(2^7 + 32)$  بیت داده وجود دارد. پس اندازه حافظه نهان بر حسب تعداد بیت:

$$1024 \times 2(7 + 32) = 1024 \times 78 = 79872$$

۱۶- زمان دستیابی یک حافظه نهان  $100\text{ns}$  و حافظه اصلی  $1000\text{ns}$  است.

پیش‌بینی می‌شود ۸۰ درصد درخواستهای حافظه برای خواندن و ۲۰ درصد بقیه برای نوشتمن می‌باشد. نسبت برد برای دستیابی‌های خواندن فقط ۰/۹ است. رویه کامل‌نویسی استفاده می‌شود.

الف) زمان دستیابی متوسط سیستم فقط با در نظر گرفتن سیکل خواندن چقدر است؟

ب) زمان دستیابی متوسط سیستم برای درخواست‌های خواندن و نوشتمن چقدر است؟

ج) نسبت برد با در نظر گرفتن سیکل‌های نوشتمن چقدر است؟

حل: منظور از نسبت برد، Hit Ratio است.

در حالت کلی برای زمان دستیابی متوسط سیستم داریم:

$$t_a = ht_c + (1-h)(t_c + t_m)$$

$t_c$  زمان دستیابی حافظه نهان =

$t_m$  زمان دستیابی حافظه اصلی =

احتمال وجود داده در حافظه نهان =

حال داریم:

(الف)

$$t_a = ht_c + (1-h)(t_c + t_m) = 0,9 \times 100 + 0,1 \times 1100 = 200\text{ns}$$

ب) از قسمت الف، برای خواندن، زمان متوسط دستیابی را ns 200 بدست آوریم.

حال داریم: (خواندن 200ns و نوشتمن 1000ns)

$$t_a = 0,2 \times 1000 + 0,8 \times 200 = 360\text{ns}$$

ج) از ۸۰ درصد دستورات که خواندن هستند، ۰/۹ آنها در حافظه نهان هستند پس:

$$h = 0,8 \times 0,9 = 0,72$$

۱۷- یک مجموعه حافظه نهان انجمانی چهار تایی در هر مجموعه چهار کلمه

دارد. یک رویه جایگزینی بر پایه الگوریتم قدیمی‌ترین مورد استفاده ( LRU ) با

شمارنده‌های دو بیتی متاظر با هر یک از کلمه‌های مجموعه پیاده‌سازی می‌شود. بنابراین مقداری در محدوده ۰ تا ۳ برای هر کلمه ثبت می‌شود. وقتی بردی رخ دهد (Hit)، شمارنده متاظر با کلمه دسترسی ۰ می‌گردد. شمارنده‌هایی که مقدار قبلی آنها کمتر از مقدار شمارنده مورد دسترسی است، ۱ واحد افزایش می‌یابند و بقیه تغییر نمی‌کنند. اگر باخت رخ دهد (Miss)، کلمه‌ای که مقدار شمارنده آن ۳ است حذف می‌شود، کلمه جدید در محل آن قرار داده می‌شود و شمارنده آن ۰ می‌گردد. سه شمارنده دیگر ۱ واحد افزاش می‌یابند. برای دنباله دسترسی‌های زیر روند را انجام دهید.

A B C D B E D A C E C E →

حل:

داریم:

| ورود   | ۳ | ۲ | ۱ | ۰ | مقادیر شمارنده |
|--------|---|---|---|---|----------------|
| ABCD   | A | B | C | D |                |
| Hit B  | A | C | D | B |                |
| Miss E | C | D | B | E |                |
| Hit D  | C | B | E | D |                |
| Miss A | B | E | D | A |                |
| Miss C | E | D | A | C |                |
| Hit E  | D | A | C | E |                |
| Hit C  | D | A | E | C |                |
| Hit E  | D | A | C | E |                |

۱۸- یک کامپیوتر دیجیتال دارای واحد حافظه  $64k \times 16$  و یک حافظه نهان  $1k$  کلمه‌ای است. حافظه نهان از نگاشت مستقیم (Direct) استفاده می‌کند و سایز بلاک

چهار کلمه است.

الف) در میدان‌های نشانه، شاخص، بلاک، و کلمه قالب آدرس چند بیت وجود دارد؟

ب) در هر کلمه حافظه نهان چند بیت وجود دارد، و آنها چگونه به توابع مختلف کاری تقسیم شده‌اند؟

ج) حافظه نهان چند بلاک را در خود جای می‌دهد.

حل:

حافظه اصلی ۱۶ خط آدرس و ۱۶ خط داده  $64k = 2^6 \times 2^{10} = 2^{16}$  حافظه

الف) دقیق شود برای آدرس، ما TAG و Index و تعداد کلمه‌های در یک بلاک را

در نظر می‌گیریم.

تعداد بیت‌های آدرس دهی حافظه نهان  $1k = 2^{10}$  حافظه نهان

تعداد بیت‌های TAG  $\Rightarrow 16 - 10 = 6$

$$6 + 8 + 2 = 16$$

>> سایز بلاک چهار کلمه



ب) دقیق شود برای کلمه حافظه نهان، TAG L ، داده و بیت VALID را در نظر

می‌گیریم.

|       |       |        |        |
|-------|-------|--------|--------|
| 1 بیت | 6 بیت | ۱۶ بیت | 23 بیت |
| V     | TAG   | DATA   |        |

(ج)

حافظه نهان  $= 1k = 1024$

بلاک  $\frac{1024}{4} = 256$  تعداد بلاک  $\Rightarrow$  در هر بلاک ۴ کلمه

۱۹- یک فضای آدرس با ۲۴ بیت و فضای حافظه متناظر با آن با ۱۶ بیت

مشخص می شود.

الف) چند کلمه در فضای آدرس وجود دارد؟

ب) چند کلمه در فضای حافظه وجود دارد؟

ج) اگر یک صفحه از  $2k$  کلمه ساخته شده باشد، چند صفحه و بلاک در فضای حافظه وجود دارد؟

حل: در بحث حافظه مجازی سیستم های کامپیوتری، منظور از فضای حافظه متناظر،

فضای آدرس دهی حافظه فیزیکی است. یعنی حافظه اصلی یا RAM منظور از فضای آدرس، حافظه مجازی یا منطقی، و به عبارت دیگر اندازه برنامه (process) در کامپیوتر می باشد. بنابراین داریم:

الف) فضای آدرس:  $2^4$  بیت  $\Rightarrow$

$$2^{24} = 16M \quad \text{کلمه}$$

ب) فضای حافظه:  $16$  بیت  $\Rightarrow$

$$2^{16} = 64K \quad \text{کلمه}$$

ج) طبق تعاریف بالا:

$$\frac{16M}{2K} = 8K \text{ pages} \quad \text{تعداد صفحه}$$

$$\frac{64K}{2K} = 32 \quad \text{تعداد بلاک یا قاب}$$

۲۰- یک حافظه مجازی دارای یک صفحه  $1K$  کلمه ای است. در این حافظه  $8$  صفحه و چهار بلاک وجود دارد. جدول صفحه های حافظه انجمنی حاوی داده های زیر است.

لیستی از آدرس های مجازی (به دهدھی) تهیه کنید که در صورت استفاده CPU از آن موجب فقدان صفحه (Page Fault) شوند.

| صفحه | بلک |
|------|-----|
| ۰    | ۳   |
| ۱    | ۱   |
| ۴    | ۲   |
| ۶    | ۰   |

حل: سایز صفحات،  $1K$  می‌باشد؛ بنابراین سایر قاب‌های حافظه اصلی نیز  $1K$  می‌باشد. با توجه به جدول داده شده می‌توانیم به طور دقیق مشخص کنیم که صفحاتی که الان نام برده شده‌اند، چه آدرس‌هایی را پوشش می‌دهند:

| صفحه | محدوده آدرس پوشاننده (دهدهی) | بلک |
|------|------------------------------|-----|
| ۰    | ۰_۱۰۲۳                       | ۳   |
| ۱    | ۱۰۲۴_۲۰۴۷                    | ۱   |
| ۴    | ۴۰۹۶_۵۱۱۹                    | ۲   |
| ۶    | ۶۱۴۴_۷۱۶۷                    | ۰   |

یعنی آدرس‌های مجازی که CPU اعلان می‌دهد، اگر در محدوده‌های بالا باشد، صفحات متناظر وجود خواهند داشت. بنابراین می‌توان گفت آدرس‌های مربوط به سایر صفحات که در جدول صفحه نیستند موجب بروز فقدان صفحه می‌شوند:

| صفحه | محدوده آدرس مربوطه که موجب فقدان صفحه می‌شوند. |
|------|------------------------------------------------|
| ۲    | ۲۰۴۸_۳۰۷۱                                      |
| ۳    | ۳۰۷۲_۴۰۹۵                                      |
| ۵    | ۵۱۲۰_۶۱۴۳                                      |
| ۷    | ۷۱۶۸_۸۱۹۱                                      |

۲۱- یک سیستم حافظه مجازی دارای فضای آدرس  $8K$  کلمه یک فضای حافظه

۴K کلمه، و صفحات و بلاک‌های ۱K کلمه است (شکل ۱۸-۱۲) تغییرات دسترسی صفحه زیر در طول یک فاصله زمانی معین رخ می‌دهد. ( فقط تغییر صفحه ها نوشته شده است. اگر یک صفحه دوباره مورد دسترسی قرار گرفته باشد دو بار نوشته نشده است).

4 2 0 1 2 6 1 4 0 1 0 2 3 5 7 →

چهار صفحه مستقیم در حافظه اصلی را پس از هر تغییر دسترسی صفحات تعیین کنید به شرطی که الگوریتم جایگزینی مورد استفاده (الف) FIFO و (ب) LRU باشد.

حل: برای هر کدام از الگوریتم‌ها، جدول صفحه را رسم می‌نماییم:

منظور از H ، Hit و منظور از M ، Miss صفحات است

(الف) FIFO

|            | ۱ | ۲ | ۳ | ۴ | ۵ | ۶ | ۷ | ۸ | ۹ | ۱۰ | ۱۱ | ۱۲ | ۱۳ | ۱۴ | ۱۵ |
|------------|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|
|            | ۴ | ۲ | ۰ | ۱ | ۱ | ۶ | ۶ | ۴ | ۴ | ۴  | ۲  | ۳  | ۵  | ۷  |    |
| -          | ۴ | ۲ | ۰ | ۰ | ۱ | ۱ | ۶ | ۶ | ۶ | ۶  | ۴  | ۲  | ۳  | ۵  |    |
| -          | - | ۴ | ۲ | ۲ | ۰ | ۰ | ۱ | ۱ | ۱ | ۱  | ۶  | ۴  | ۲  | ۳  |    |
| -          | - | - | ۴ | ۴ | ۲ | ۲ | ۰ | ۰ | ۰ | ۰  | ۱  | ۶  | ۴  | ۲  |    |
| Page Fault | M | M | M | M | H | M | H | M | H | H  | M  | M  | M  | M  |    |

(ب) LRU

|   | ۱ | ۲ | ۳ | ۴ | ۵ | ۶ | ۷ | ۸ | ۹ | ۱۰ | ۱۱ | ۱۲ | ۱۳ | ۱۴ | ۱۵ |
|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|
|   | ۴ | ۲ | ۰ | ۱ | ۱ | ۱ | ۱ | ۱ | ۱ | ۱  | ۱  | ۱  | ۱  | ۱  | ۵  |
| - | ۴ | ۲ | ۰ | ۰ | ۰ | ۰ | ۴ | ۴ | ۴ | ۴  | ۴  | ۴  | ۳  | ۳  | ۳  |

|               |   |   |   |   |   |   |   |   |   |   |   |
|---------------|---|---|---|---|---|---|---|---|---|---|---|
|               | - | - | ۴ | ۲ | ۲ | ۲ | ۲ | ۰ | ۰ | ۰ | ۷ |
|               | - | - | - | ۴ | ۴ | ۶ | ۶ | ۶ | ۶ | ۲ | ۲ |
| Page<br>Fault | M | M | M | M | H | M | H | M | H | M | M |

۲۲- دو آدرس منطقی را از شکل ۱۲-۲۴ (الف) که سبب دستیابی به حافظه فیزیکی در آدرس فیزیکی شانزده شانزدهی AF۱۲ می شود تعیین کنید.

حل: با توجه به قسمت الف شکل ۱۲-۲۴، محدوده آدرس ۰۱۲۰۰ - ۰۱۲FF شامل بلاک ۱۲ حافظه فیزیکی می باشد. حال مطابق با جدول صفحه، صفحات ۳۵ و A3 به این بلاک اشاره می کنند. مطابق با جدول قطعات، قطعات ۶ و F به شامل این دو صفحه می شوند. بنابراین می توان دو آدرس منطقی زیر را نام برد:

600 AF

F00AF

۲۳- فضای آدرس منطقی در یک سیستم کامپیوتری دارای ۱۲۸ قطعه است. هر قطعه می تواند تا ۳۲ صفحه ۴K کلمه ای داشته باشد. حافظه فیزیکی ۴K بلاک K کلمه در هر بلاک است. قالب آدرس های فیزیکی و منطقی را تنظیم کنید.

حل: قالب منطقی

$$\text{قطعه} = 2^7 \Rightarrow 128 \text{ بیت}$$

$$\text{صفحه} = 2^5 \Rightarrow 32 \text{ بیت}$$

$$\text{کلمه} = 2^2 \times 2^{10} = 2^{12} \text{ بیت}$$

پس:

| Segment | Page  | Word   |
|---------|-------|--------|
| ۷ بیت   | ۵ بیت | ۱۲ بیت |

قالب فیزیکی:

$$4K = 2^2 \times 2^{10} = 2^{12} \text{ بیت}$$

$$4K = 2^{12} \Rightarrow 12 \text{ بیت کلمه}$$

پس:



۳۶- معادل دودویی آدرس منطقی تنظیم شده در مسئله ۱۲-۲۳ را برای قطعه ۳۶

و کلمه ۲۰۰۰ در صفحه ۱۵ بنویسید.

حل: با توجه به سؤال ۱۲-۲۳، آدرس منطقی، ۲۴ بیت می‌باشد. قطعه ۷ بیت، صفحه ۵ بیت و کلمه ۱۲ بیت را اختصاص می‌دهد.

$$\text{قطعه } 36_2 \Leftarrow (0100100)_2$$

$$\text{صفحه } 15_2 \Leftarrow (01111)_2$$

$$\text{کلمه } 2000_2 \Leftarrow (011\ 111010000)_2$$

پس: آدرس منطقی برابر است با:

$$(0100100\ 01111\ 011111010000)$$

۲۴ بیت

## تست‌های فصل ۴ «انتقال ثبات‌ها و ریز عمل‌ها»

- ۱- به منظور ساخت یک گذرگاه مشترک، که تعداد ۳۲ ثبات (Register) ۱۶ بیتی را به هم‌دیگر وصل بنماید، حداقل سخت‌افزار لازم چیست؟  
 (مهندسی کامپیوتر - سراسری ۸۰)

الف) ۱۶ عدد MUX هر کدام با ۴ خط انتخاب

ب) ۳۲ عدد MUX هر کدام با ۴ خط انتخاب

ج) ۱۶ عدد MUX هر کدام با ۵ خط انتخاب

د) ۳۲ عدد MUX هر کدام با ۵ خط انتخاب

- ۲- کدام یک از انتقال بین رجیسترها غلط است؟

(آزاد - ۸۱)

الف)  $YT : R_1 \leftarrow R_2, R_2 \leftarrow R_1$       ب)  $XT : AR \leftarrow \overline{AR}, AR \leftarrow 0$

NT:  $PC \leftarrow PC + 1$       د) ZT:  $PC \leftarrow AR, AR \leftarrow AR - 1$       ج)  $ZT : PC \leftarrow AR, AR \leftarrow AR - 1$

- ۳- در شکل زیر کدام یک از موارد انتقال رجیستری (RTL) قابل اجرا است؟

(مهندسی کامپیوتر - سراسری ۸۳)



#### ۴- کدام عبارت صحیح است؟

(مهندسی IT - سراسری ۸۷)

الف) برای پیاده‌سازی گذرگاه مشترک با وجود ۸ ثبات ۱۶ بیتی، جهت پیاده‌سازی با روش بافر سه حالت، به ۸ بافر ۱۶ بیتی و یک رمزگشای  $3 \times 8$  نیاز است و جهت پیاده‌سازی با MUX ۱۶ به  $8 \times 1$  MUX نیاز است.

ب) برای پیاده‌سازی گذرگاه مشترک با وجود ۸ ثبات ۱۶ بیتی، جهت پیاده‌سازی با روش بافر سه حالت به ۸ بافر ۱۶ بیتی و یک رمزگشای  $4 \times 16$  نیاز است و جهت پیاده‌سازی با MUX ۱۶ به  $8 \times 1$  MUX نیاز است.

ج) برای پیاده‌سازی گذرگاه مشترک با وجود ۸ ثبات ۱۶ بیتی، جهت پیاده‌سازی با روش بافر سه حالت به ۱۶ بافر ۸ بیتی و یک رمزگشای  $4 \times 16$  نیاز است و جهت پیاده‌سازی با MUX ۱۶ به  $8 \times 1$  MUX نیاز است.

د) برای پیاده‌سازی گذرگاه مشترک با وجود ۸ ثبات ۱۶ بیتی، جهت پیاده‌سازی با روش بافر سه حالت به ۱۶ بافر ۸ بیتی و یک رمزگشای  $3 \times 8$  نیاز است و جهت پیاده‌سازی با MUX ، به  $16 \times 1$  MUX نیاز است.

## حل تست‌های فصل ۴

۱- گزینه‌ی ج صحیح است.

در حالت کلی اگر  $K$  رجیستر  $n$  بیتی داشته باشیم، برای ساخت گذرگاه مشترک به تعداد  $n$  که هر کدام  $k \times 1$  هستند نیاز داریم. در ضمن تعداد خطوط انتخاب  $\lceil \log_2^n \rceil$  MUX ها، خواهد بود.

۲- گزینه‌ی الف صحیح است.

امکان ندارد در یک زمان، متمم یک رجیستر و مقدار صفر را در همان رجیستر ذخیره کرد. در اینگونه موارد تداخل (conflict) پیش می‌آید. مانند

$$XT : PC \leftarrow AR, PC \leftarrow PC + 1$$

لازم به ذکر است امکان جابجایی محتوای دو رجیستر در یک زمان وجود دارد.

۳- گزینه‌ی ج صحیح است.

با توجه به مدار اگر  $x = 0$  باشد،  $R_2 = R_1 + R_2$  و اگر  $1$  باشد،  $R_1 = R_1 + R_2$ ، آماده انتقال است. در ضمن در صورتی انتقال انجام می‌شود که پایه  $load(T)$  فعال باشد.

۴- گزینه‌ی ج صحیح است.

در حالت کلی اگر  $k$  رجیستر  $n$  بیتی داشته باشیم برای ساخت گذرگاه مشترک با استفاده از روش بافر، به یک رمزگشای  $n \times n$  و همچنین  $m \times n$  بافر سه حالته نیاز داریم.

## تست‌های فصل ۵ «سازمان و طراحی یک کامپیوتر»

۱- در شکل داده شده جهت انجام عملیات  $R_1 \leftarrow R_4 + R_3, R_1 \leftarrow R_1 + R_2$  به ترتیب چند پالس ساعت لازم است؟

(مهندسی کامپیوتر - سراسری ۸۱)

(مشا به مهندسی کامپیوتر - سراسری ۷۹)

الف) ۲ و ۳

ب) ۳ و ۴

ج) ۴ و ۳

د) ۳ و ۴



۲- در طراحی قالب دستورالعمل‌های یک کامپیوتر، ۴ بیت برای رمز عمل (opcode)، ۲ بیت برای ثبات و دو فیلد ۱۵ بیتی برای آدرس وجود دارد. با توجه به قالب دستورالعمل، مشخصات این کامپیوتر چیست؟

(آزاد - ۸۲)

الف) ۲۵۶ دستورالعمل مختلف، ۲ ثبات قابل استفاده توسط کاربر، فضای آدرس ۳۲KB

حافظه 32KB

ب) ۱۶ دستورالعمل مختلف، ۱۲۸ ثبات قابل استفاده توسط کاربر، فضای آدرس 4KB

حافظه 4KB

ج) ۱۶ دستورالعمل مختلف، ۶ ثبات قابل استفاده توسط کاربر، و فضای آدرس  
حافظه 2KB  
د) هیچکدام

۳- با فرض اينكه در طى فازهای  $T_0$  و  $T_1$  عمل واکشى (Fetch) و ديكد  
دستورالعمل به صورت مقابل انجام شده است؟

$T_0 : DR \leftarrow M[PC]$

$T_1 : IR \leftarrow DR, PC \leftarrow PC + 1, \text{Decode}$

مشخص کنيد دستور STA کدام مجموعه‌ی گزاره‌های زير است؟

(مهندسی IT - سراسری ۸۴)

الف)  $T_2 : DR \leftarrow M[PC], DR \leftarrow AC$        $T_2 : AR \leftarrow DR, PC \leftarrow PC + 1$

$T_3 : M[AR] \leftarrow DR, \text{ goto } T_0$        $T_3 : M[AR] \leftarrow AC, \text{ goto } T_0$

$T_2 : DR \leftarrow M[PC]$

$T_2 : DR \leftarrow M[PC]$

$T_3 : AC \leftarrow DR, PC \leftarrow PC + 1$

ج)  $T_3 : AR \leftarrow DR, PC \leftarrow PC + 1$

$T_4 : M[AR] \leftarrow AC, \text{ goto } T_0$

$T_4 : M[AR] \leftarrow AC, \text{ goto } T_0$

۴- کدام دستورالعمل غيرکنترلي است؟

(آزاد - ۸۴)

JUMP (د)

MORE (ج)

SKIP (ب)

CALL (الف)

۵- برای قالب دستورالعمل  $\boxed{\quad, I, \boxed{\quad, \quad}} \quad \boxed{\quad, \quad}$  کد عمل ۰۰۰۱ با شرح

AC < 0 then  
کدام نماد تداعی می‌شود؟ (EA آدرس موثر است)  
(PC  $\leftarrow$  EA)

(آزاد - ۸۳)

BRANCH (د)

EXCHANGE (ج)

STORE (ب)

ADD (الف)



## حل تست‌های فصل ۵

۱- گزینه‌ی ب صحیح است.

در هر دو عملیات، تعداد یکسانی پالس ساعت نیاز است. در پالس اول، مقدار رجیستر اول آماده عملیات می‌شود، در پالس دوم، مقدار رجیستر دوم آماده عملیات می‌شود، و در پالس سوم عمل جمع انجام شده و نتیجه بازنویسی می‌شود.

۲- گزینه‌ی د صحیح است.

با توجه به توضیحات، قابل دستورالعمل به صورت زیر است.

|        |      |        |        |
|--------|------|--------|--------|
| ۴      | ۲    | ۱۵     | ۱۵     |
| opcode | ثبات | آدرس ۱ | آدرس ۲ |

پس داریم:

$2^2 = 4$  تعداد ثبات برای کار

$2^4 = 16$  تعداد دستورالعمل مختلف

$2^{15} = 32KB$  فضای آدرس دهی حافظه

که هیچکدام از گزینه‌های ۱، ۲ و ۳ را شامل نمی‌شود.

۳- گزینه‌ی ج صحیح است.

دستور STA، محتوای انباره (AC) را در حافظه ذخیره می‌کند. در این سؤال، دستورات دو کلمه‌ای هستند، و کلمه دوم، آدرس را مشخص می‌کند. بنابراین، ابتدا فیلد آدرس از حافظه خوانده شده و پس محتوای انباره، در آن آدرس از حافظه ذخیره می‌شود.

۴- گزینه‌ی ج صحیح است.

هر سه دستور SKIP، JUMP، CALL، مسیر عادی اجرای برنامه را عوض می‌کنند.

CALL : رفتن به آدرس شروع زیر برنامه

JUMP : پرش به آدرس مورد نظر از حافظه

SKIP : پرش از دستور بعدی در صورت پذیرفته شده شرط

۵ - گزینه‌ی د صحیح است.

با توجه به عبارت if ، دستور یک پرش شرطی خواهد

بود.

## تست‌های فصل ۶ «برنامه‌نویس کامپیووتر پایه»

۱- مجموعه سه دستورالعمل زیر در پردازنده ۸۰۸۶ چه می‌کند؟

XOR AX,BX

XOR BX , AX

XOR AX, BX

(آزاد - ۷۸)

الف) محتوای ثبات AX را با AX+BX تبدیل می‌کند.

ب) محتوای ثبات AX را با BX عوض می‌کند.

ج) محتوای ثبات BX را با BX+AX تبدیل می‌کند.

د) در نهایت هیچ تغییری در محتوای دو ثبات داده نمی‌شود.

۲- مجموعه دستورات زیر چه عمل را انجام می‌دهند؟

1- MOV bx,ax

2- SHR ax

3- SHR ax

4- SHR ax

5- AND bx,07

(علوم کامپیووتر - ۸۲)

الف) محتوای رजیستر ax را بر ۸ تقسیم کرده و خارج قسمت را در رجیستر bx و باقی‌مانده را در رجیستر ax قرار می‌دهد.

ب) محتویات رجیستر ax را بر ۸ تقسیم می‌کند و خارج قسمت را در رجیستر ax قرار داده و تمام بیت‌های خارج قسمت به جز سه بیت اول را صفر می‌کند.

ج) محتویات رجیستر ax را بر ۸ تقسیم می‌کند و فقط خارج قسمت را در رجیستر ax قرار می‌دهد و باقی‌مانده را محاسبه نمی‌کند.

د) محتویات رجیستر ax را بر ۸ تقسیم کرده و خارج قسمت را در رجیستر ax و

باقیمانده را در رجیستر bx قرار می‌دهد.

## حل تست‌های فصل ۶

۱- گزینه‌ی ب صحیح است.

از طریق جبر بول می‌توان اثبات کرد که نتیجه اجرای برنامه، تعویض محتوای دو رجیستر AX و BX است برای مثال داریم، اگر AX = 1001 و BX = 0011 باشند:

$$AX = 1001$$

$$BX = 0011$$

$$XOR\ AX, BX \Rightarrow AX = 1010, BX = 0011$$

$$XOR\ BX, AX \Rightarrow AX = 1010, BX = 1001$$

$$XOR\ AX, BX \Rightarrow AX = 0011, BX = 1001$$

۲- گزینه‌ی د صحیح است.

می‌دانیم در نتیجه یک شیفت به چپ، ضرب در ۲، و در نتیجه یک شیفت به راست، تقسیم بر ۸ حاصل می‌شود. بنابراین  $ax \div 8$  تقسیم می‌شود.

در ضمن  $and\ bx, 07$  ، باعث صفر شدن ۵ بیت با ارزش بیشتر محتوای رجیستر bx ، که همان ax اولیه است، می‌شود و ۳ بیت کم ارزش ax که بیانگر باقی مانده تقسیم بر ۸ است را نگه می‌دارد.

## تست‌های فصل ۷ «کنترل ریز برنامه‌نویسی شده»

۱- دلیل استفاده از ریز برنامه‌سازی (Microprgramming) در طراحی واحد

کنترل CPU چیست؟

(مهندسی کامپیوتر - سراسری ۷۱)

الف) طراحی واحد کنترل سیستماتیک شود.

ب) بتوان به آسانی خطاهای طراحی را برطرف نمود و فهرست دستورهای زبان ماشین را تغییر داد.

ج) بتوان برنامه نوشته شده به زبان ماشین کامپیوتر دیگری را اجرا نمود.

د) هر سه مورد

۲- نمودار بلوکی مدار و سیگنال‌های کنترل لازم برای انجام عملیات جمع و تفریق شکل زیر نشان داده شده است. در صورتی که در طراحی واحد کنترل آن از روش ریز برنامه‌سازی استفاده کنیم. تعداد ریز دستورالعمل‌های (Microinstruction) لازم برای انجام عمل  $A-B$  را به دست آورید.

(مهندسی کامپیوتر - سراسری ۷۳)



الف) یک ریز دستورالعمل

ب) دو ریز دستورالعمل

ج) سه ریز دستورالعمل

د) چهار ریز دستورالعمل

۳- کدامیک از عبارات زیر در مورد ساختارهای ریز برنامه‌ریزی شده

درست است؟ (Hard wired) و سیم‌کشی (Micropogrammed)

## (مهندسی کامپیوتر - سراسری ۷۸)

الف) پردازنده‌های از نوع "Microprogrammed" قابلیت انعطاف بیشتری از لحاظ تغییرات احتمالی در آینده دارند و معمولاً دستورالعمل‌های پیچیده‌تری و سرعت کمتری نسبت به نوع "Hard wired" دارند.

ب) پردازنده‌های از نوع "Microprogrammed" نمی‌توانند از امکان pipeline استفاده کنند. در صورتی که نوع "Hard wired" این امکان را دارد و علت سرعت بیشتر آن نیز همین است.

ج) پردازنده‌های از نوع "Microprogrammed" سرعت بیشتری از دید اجرای دستورالعمل نسبت به نوع "Hard wired" دارند.

د) پردازنده‌های از نوع "Hard wired" دارای سرعت بیشتری نسبت به نوع "Microprogrammed" هستند که علت عدمه آن استفاده از "pipelining" در ساختار اینگونه پردازنده‌ها است.

**۴- در مورد ریز برنامه‌سازی "Microprogramming" کدام‌یک از جمله‌های زیر صحیح است؟**

## (آزاد - ۷۸)

## (مشابه مهندسی IT - سراسری ۸۴)

الف) ریز برنامه‌سازی برای سیستماتیک کردن طراحی واحد کنترل به کار می‌رود و در طراحی پردازنده‌های با کارایی بالای امروزی کاربرد زیاد دارد.

ب) ریز برنامه‌سازی برای مهیا‌سازی زمینه تغییر و اضافه کردن دستورات زبان ماشین مناسب است ولی به دلیل مشکل بودن، در طراحی کامپیوترهای امروزی به کار نمی‌رود.

ج) ریز برنامه‌سازی مزایای فراوانی دارد، ولی به دلیل سرعت کم در طراحی پردازنده‌های سریع امروزی به کار نمی‌رود.

د) ریز برنامه‌سازی این امکان را در اختیار می‌گذارد که بتوان برنامه نوشته شده به زبان ماشین کامپیوتر دیگری را اجرا نمود و به همین دلیل در طراحی واحد کنترل پردازنده‌های امروزی به کار گرفته می‌شود.

## حل تست‌های فصل ۷

۱- گرینه‌ی د صحیح است.

کترل دنباله عملیات به وسیله ریز دستورالعمل‌ها، مستقل از زبان ماشین کامپیوترهای مختلف است و دارای قابلیت تغییر، توسعه و رفع خطا است.

۲- گرینه‌ی ج صحیح است.

ابتدا رجیستر صفر شده، پس با A جمع شده، و پس از B کم می‌شود تا A-B انجام شود.

$$1) R \leftarrow 0$$

$$2) R \leftarrow R + A$$

$$3) R \leftarrow R - B$$

۳- گرینه‌ی الف صحیح است.

در حالت کلی در ارتباط با مقایسه پردازنده‌های ریز برنامه‌نویسی شده و سیم‌بندی

داریم:

| واحد کترل ریز<br>برنامه‌سازی شده | واحد کترل سیم‌بندی | معیارها                        |
|----------------------------------|--------------------|--------------------------------|
| کم                               | زیاد               | سرعت اجرا                      |
| کم                               | زیاد               | پیچیدگی سخت‌افزار              |
| زیاد                             | کم                 | سهولت تغییر و توسعه            |
| کم                               | زیاد               | میزان استفاده کنونی            |
| بله                              | بله                | امکان استفاده pipeline در آنها |

۴- گرینه‌ی ج صحیح است.

با توجه به توضیحات سؤال قبل

## تست‌های فصل ۸ « واحد مرکزی پردازش »

۱- برای محاسبه تابع  $(4+2\times 5)/(1+3\times 2-4)$  با استفاده از stack، چه تعداد دستورالعمل push و حداقل تعداد کلمه لازم در stack برای انجام این عمل چقدر است؟

(مهندسی کامپیوتر - سراسری ۷۴)

- الف) ۷ مرتبه push و حداقل ۵ کلمه      ب) ۶ مرتبه push و حداقل ۳ کلمه
- ج) ۸ مرتبه push و حداقل ۴ کلمه      د) ۷ مرتبه push و حداقل ۴ کلمه

۲- با فرض مقادیر خانه‌های حافظه زیر و داشتن یک پردازنده دارای یک انباشتگر (Acumulator) و میدان تک آدرس در دستورالعمل، انباشتگر پس از اجرای هر یک از دستورات زیر چه مقداری خواهد داشت؟

(مهندسی کامپیوتر - سراسری ۷۵)

- |                      |                                |
|----------------------|--------------------------------|
| a: load immediate ۲۰ | - کلمه ۲۰ حافظه مقدار ۴۰ دارد. |
| b: load indirect ۲۰  | - کلمه ۳۰ حافظه مقدار ۵۰ دارد. |
| c: load direct ۳۰    | - کلمه ۴۰ حافظه مقدار ۶۰ دارد. |
| d: load indirect ۳۰  | - کلمه ۵۰ حافظه مقدار ۷۰ دارد. |
- الف) ۲۰ و ۴۰ و ۳۰ و ۷۰  
 ج) ۲۰ و ۴۰ و ۳۰ و ۵۰ و ۷۰

۳- با فرض داشتن یک ماشین پشت‌های (stack machine) مشخص کنید دستورات زیر کدام عبارت را اجرا می‌کند؟

(مهندسی کامپیوتر - سراسری ۷۶)

- الف)  $X = (A * B / D - C) + (C + A - B * F / E)$
- ب)  $X = (A * B - C) / D + (C / E + A - B * F)$
- ج)  $X = (A / D * B - C) + (A - B * F * C / E)$

$$X = (A * B / C - D + A - B * F * C / E) \quad (d)$$

Push A  
 Push B  
 Mul  
 Push C  
 SUB  
 Push D  
 DIV  
 Push C  
 Push E  
 DIV  
 Push A  
 ADD  
 Push B  
 Push F  
 MUL  
 SUB  
 ADD  
 Popx

۴- کدام مجموعه از عملیات ذیل می‌تواند یک پشته (stack) را پیاده‌سازی

نماید؟ عملیات push و pop برای یک ثبات به نام A صورت می‌پذیرد؟

(مهندسی کامپیوتر - سراسری ۷۹)

| Push A                                           | Pop A                                            |     |
|--------------------------------------------------|--------------------------------------------------|-----|
| $SP \leftarrow SP - 1$<br>Mem[SP] $\leftarrow A$ | $A \leftarrow Mem[SP]$<br>$SP \leftarrow SP + 1$ | (۱) |
| $SP \leftarrow SP + 1$<br>Mem[SP] $\leftarrow A$ | $A \leftarrow Mem[SP]$<br>$SP \leftarrow SP - 1$ | (۲) |
| $Mem[SP] \leftarrow A$<br>$SP \leftarrow SP - 1$ | $SP \leftarrow SP + 1$<br>$A \leftarrow Mem[SP]$ | (۳) |

الف) ۱ و ۲      ب) ۲ و ۳      ج) ۱ و ۳      د) هر سه

۵- تفاوت کامپیوترهای RISC و CISC کدام است؟ (CPI) یعنی تعداد متوسط

پالس ساعت به ازاء اجرای هر دستور(عمل)

(مهندسی کامپیوتر - سراسری ۸۰)

الف) در RISC تعداد دستورات کمتر، طول برنامه بزرگتر و CPI کمتر از CISC است.

ب) در RISC تعداد دستورات بیشتر و طول برنامه تقریباً هم اندازه و CPI کمتر از CISC است.

ج) در RISC تعداد دستورات بیشتر، طول برنامه کوچکتر و CPI بیشتر از CISC است.

د) در RISC تعداد دستورات کمتر، طول برنامه کوچکتر و CPI کمتر از CISC است.

## حل تست‌های فصل ۸

۱- گزینه‌ی د صحیح است.

با توجه به توضیحات حل مسئله (۸-۹) فصل واحد مرکزی پردازش، تعداد push در پشتی برابر تعداد عملوندهای عبارت است. برای تشخیص حداقل ظرفیت پشتی فرم RPN عبارت را تشکیل داده، و محاسبه را انجام می‌دهیم.

فرم RPN :

$825 \times + 132 \times + 4 - /$

وضعیت پشتی: حداقل سایز پشتی = ۴

۲- گزینه‌ی د صحیح است.

a : load immediate 20  $\Rightarrow AC = 20$

b : load indirect 20  $\Rightarrow AC = M[M[20]] = 60$

c : load direct 30  $\Rightarrow AC = M[30] = 50$

d : load indirect 30  $\Rightarrow AC = M[M[30]] = 70$

۳- گزینه‌ی ب صحیح است.

ابتدا از روی دنباله برنامه، فرم PRN عبارت را پیدا می‌کنیم.

RPN عبارت =  $AB * C - D / CE / A + BF * - +$

حال طبق توضیحات حل مسئله ۸ از فصل ۸، فرم میانوندی را از فرم RPN بدست

آمد، بدست می‌آوریم.

عبارت میانوندی =  $(A * B - C) / D + (C / E + A - B * F)$

۴- گزینه‌ی د صحیح است.

حالت (۱) : پشته از آدرس های بالا به پایین رشد می کند و SP به بالاترین عنصر پشته اشاره می کند.

حالت (۲) : پشته از آدرس های پایین به بالا رشد می کند و SP به بالاترین عنصر پشته اشاره می کند.

حالت (۳) : پشته از آدرس های بالا به پایین رشد می کند و SP به مکان بالای بالاترین عنصر پشته اشاره می کند.

۵ - گزینه‌ی الف صحیح است.

مفهوم CPI به معنای تعداد کلاک مورد نیاز برای اجرای هر کدام از دستورات است. و در کل به ساده‌تر بودن یک دستور اشاره می کند.

علاوه بر این، در رابطه با مقایسه کامپیوترهای RISC و CISC داریم:

| CISC   | RISC | معیار                             |
|--------|------|-----------------------------------|
| زیاد   | کم   | تعداد دستورات                     |
| متفاوت | ثابت | طول دستورات                       |
| کم     | زیاد | (تعداد خطوط کد برنامه) طول برنامه |
| کم     | زیاد | تعداد ثبات پردازنده               |
| خیر    | بلی  | استفاده از پنجره‌های ثبات همپوشان |
| زیاد   | کم   | تعداد مد آدرس دهی                 |

## تست‌های فصل ۹ «پردازش خط لوله‌ای و پردازی»

۱- یک واحد محاسباتی لوله‌ای (pipeline) دارای پنج قسمت (stage) با زمان اجرای ۳۶، ۳۹، ۲۳، ۲۸ و ۶۴ نانوثانیه است. اگر از ثبات‌هایی با تأخیر ۱ نانوثانیه در بین قسمت‌های مختلف لوله استفاده شده باشد، حداکثر تسریع این واحد محاسباتی نسبت به تأخیر غیر خط لوله‌ای چقدر است؟

(مهندسی کامپیوتر - سراسری ۷۹)

(مشابه مهندسی کامپیوتر - سراسری ۸۵)

- الف) ۲/۹۲      ب) ۳/۵      ج) ۵      ۷/۹۲

۲- یک برنامه موازی به ۱۰۰ ثانیه برای اجرا روی یک کامپیوتر با یک پردازنده دارد. اگر ۴۰٪ محاسبات برنامه ذاتاً سریال باشد، بهترین زمان برای اجرای این برنامه روی یک سیستم با ۲ و ۴ پردازنده چیست؟

(علوم کامپیوتر - ۸۱)

- الف) ۲ پردازنده برابر ۷۰ ثانیه، ۴ پردازنده برابر ۵۵ ثانیه  
ب) ۲ پردازنده برابر ۲۰ ثانیه، ۴ پردازنده برابر ۱۰ ثانیه  
ج) ۲ پردازنده برابر ۳۰ ثانیه، ۴ پردازنده برابر ۱۵ ثانیه  
د) ۲ پردازنده برابر ۵۰ ثانیه، ۴ پردازنده برابر ۲۵ ثانیه

۳- اگر  $k$  تعداد مراحل یک سیستم خط لوله‌ای (pipelined) باشد. آنگاه این سیستم خط لوله‌ای نسبت به یک سیستم بدون خط لوله حداکثر چند برابر سریعتر می‌باشد؟

(مهندسی IT - آزاد ۸۴)

- الف)  $2k+1$       ب)  $k$       ج)  $2k$       د)  $2k-1$

۴- مشکلات خط لوله (pipeline) دستورالعمل کدام است؟  
(مهندسی کامپیوتر - آزاد ۸۴)

- الف) مشکل همزمانی دسترسی به حافظه
- ب) وابستگی داده‌ها
- ج) مشکلات انشعاب
- د) هر سه گزینه درست است.

## حل تست‌های فصل ۹

۱- گزینه‌ی الف صحیح است.

زمان اجرا بدون خط لوله: در این محاسبه، زمان‌های داده شده را با هم جمع می‌کنیم و از تأخیر لچ‌ها صرف‌نظر می‌کنیم زیرا نیاز نیستند.

$$= (64 + 28 + 23 + 39 + 36)n = 190n$$

زمان اجرا با راهاندازی خط لوله = ابتدا کلاک را تعیین می‌کنیم:

$$T = 64 + 1 = 65 \text{ ns}$$

$$= \text{زمان اجرای } n \text{ کار با خط لوله} = (k + (n - 1))T = (5 + (n - 1))65$$

تسريع برابر است با:

$$S_{\max} = \frac{190n}{5 \times 65 + (n - 1)65}, \quad n \rightarrow \infty \Rightarrow S_{\max} = \frac{190}{65} = 2,92$$

۲- گزینه‌ی الف صحیح است.

اگر  $t$  زمان اجرا روی یک پردازنده باشد، زمان اجرا با  $P$  پردازنده برابر است با:

$$t_p = \left( f + \frac{1-f}{p} \right) t$$

که  $f$  درصد از برنامه است که ذاتاً سریال می‌باشد.

$$f = \frac{40}{100}$$

$$\Rightarrow t_p = \left( \frac{40}{100} + \frac{\frac{60}{100}}{2} \right) 100 = 70$$

$$t_p = \left( \frac{40}{100} + \frac{\frac{60}{100}}{4} \right) 100 = 55$$

$$p = 4$$

۳- گزینه‌ی ب صحیح است.

حداکثر تسريع در استفاده از خط لوله زمانی بدست می آید که اولاً زمان اجرای مرحله ها با هم برابر باشد و ثانیاً تعداد کارها ( $n$ ) را به سمت بی نهايت سوق دهيم.

$$\lim_{n \rightarrow \infty} \frac{nkT}{(k + (n - 1))T} = k$$

۴- گزينه‌ي د صحیح است.

أنواع مشكلات موجود در خط لوله عبارت‌اند از:

۱- همزمانی دسترسی به منابع مشترک مثل حافظه یا ALU یا...

۲- وابستگی داده‌ای به طوری که دستور کنونی به نتیجه اجرای دستور قبلی نیاز

دارد.

۳- مشکل مربوط به دستورات انشعاب

## تست‌های فصل ۱۰ «معماری کامپیوتر و الگوریتم‌های حسابی»

- ۱- نتیجه حاصل از انجام محاسبات در ALU ممکن است باعث set شدن برخی فلیپ فلاپ‌ها در رجیستر وضعیت شود. اگر برای نمایش اطلاعات از سیستم مکمل استفاده شود، کدام‌یک از عبارات زیر به ترتیب وجود overflow در جمع و نتیجه صفر را تشخیص می‌دهد؟

(مهندسی کامپیوتر - سراسری ۷۱)

- الف) رقم نقلی نتیجه، AND منطقی بیت‌های نتیجه  
ب) OR انحصاری ارقام نقلی تولید شده از موضع sign - bit و ماقبل آن، NOR  
ج) OR انحصاری ارقام نقلی تولید شده از موضع sign - bit و ماقبل آن، AND  
د) رقم نقلی نتیجه، NAND منطقی بیت‌های نتیجه
- ۲- می‌خواهیم دو عدد علامت‌دار را (با قرار دادن مکمل ۲‌ها) در هم ضرب کنیم.

**Multiplicand =A**

**Multiplier =B**

(مهندسی کامپیوتر - سراسری ۷۱)

- الف) علامت A و B را مثبت می‌کنیم و سپس ضرب می‌کنیم و پس از آن در صورت لزوم علامت را اصلاح می‌کنیم.  
ب) اگر A منفی بود آن را مثبت می‌کنیم، ضرب را با گسترش علامت انجام می‌دهیم، حاصل ضرب را در صورت لزوم تغییر علامت می‌دهیم.

ج) اگر  $B$  منفی بود، آن را مثبت کرده، ضرب را با گسترش علامت انجام می‌دهیم، حاصلضرب را در صورت لزوم تغییر علامت می‌دهیم.

د) ضرب را با گسترش علامت انجام می‌دهیم.

### ۳- الگوريتم Booth دارای کدام يك از ويزگي هاي زير است؟

(مهندسي کامپيوتر - سراسري ۷۳)

الف) سرعت محاسبه با تعداد ۱ها متناسب است.

ب) تعداد عمليات جمع برابر نصف تعداد ۱ها و عمليات جابجايی (shift) برابر تعداد بيت‌ها است.

ج) تعداد زوج بيت‌های صفر و یک، یا یک و صفر، تعداد جمع‌ها و تعداد کل بيت‌ها، تعداد عمليات جابجايی را تعیین می‌کند.

د) سرعت محاسبه با تعداد بيت‌ها متناسب است.

### ۴- در عمل تقسيم در چه صورت divide – overflow رخ می‌دهد؟

(علوم کامپيوتر - ۸۰)

الف) فقط زمانی که تقسيم به صفر انجام شود.

ب) عدد موجود در نيمه بالاي خارج قسمت از مقسوم عليه بزرگتر باشد.

ج) باقيمانده يك عدد منفي باشد.

د) هيچکدام

۵- در انجام کدام يك از چهار عمل اصلی روی مانيس اعداد با مميز شناور، سرريز رخ نمي‌دهد؟

(آزاد - ۷۹)

الف) جمع      ب) ضرب      ج) تفريق      د) تقسيم

۶- در يك سистем نمايش اعداد حقيقي به شكل مميز شناور به صورت زير است:

|   |        |      |
|---|--------|------|
| S | مانتیس | توان |
|---|--------|------|

در یک سیستم دیگر به صورت زیر نمایش داده می‌شود.

۳۱ ۳۰ ۷ ۰

|   |        |      |
|---|--------|------|
| S | مانتیس | توان |
|---|--------|------|

کدام یک از جملات زیر درباره محدوده اعداد حقیقی و دقت مدل دوم نسبت به مدل صحیح می‌باشد؟

(مهندسی IT – سراسری ۸۳)

الف) هر دو محدوده و دقت کاهش می‌یابد.

ب) هر دو محدوده و دقت افزایش می‌یابد.

ج) محدوده افزایش و دقت کاهش می‌یابد.

د) محدوده کاهش و دقت افزایش می‌یابد.

۷- در اعداد ممیز شناور کوچکترین نما را به عدد صفر اختصاص می‌دهیم برای

اینکه:

(سراسری ۸۳ – مهندسی IT)

الف) به نمایش نرمال شده دست پیدا کنیم.

ب) خطای محاسبات حداقل شود.

ج) با مقدار افزودن نما حاصل صفر تولید شود.

د) تشخیص صفر توسط مدارات داخل پردازنده ساده‌تر صورت گیرد.

## حل تست‌های فصل ۱۰

۱- گزینه‌ی ب صحیح است.

تشخیص overflow از طریق OR انحصاری دو رقم نقلی آخر امکان‌پذیر است. همچنین برای تشخیص صفر بودن بکار ببریم که تنها در صورتی ۱ شود که همه ورودی‌ها ۰ باشد.

۲- گزینه‌ی ج صحیح است.

به دلیل اینکه صفر و ۱ بودن بیت‌های Multiplier در الگوریتم ضرب، جمع شدن و یا عدم جمع شدن حاصلضرب جزیی را باعث می‌شوند. سعی ما بر این است که Multiplier ، مثبت باشد. پس اگر مثبت بود ضرب را انجام می‌دهیم و اگر منفی بود، دو راه داریم:

یا هر دو Multiplier و Multiplicand را تغییر علامت می‌دهیم و ضرب را انجام می‌دهیم.

یا Multiplier را مثبت کرده و بعد از انجام عمل ضرب، حاصلضرب را تغییر علامت می‌دهیم.

۳- گزینه‌ی ج صحیح است.

با توجه به الگوریتم و سرعت عملیات ضرب و تعداد عملیات جمع، وابسته به تعداد زوج بیت‌های ۰۰، ۰۱ و ۱ در عدد است.

۴- گزینه‌ی د صحیح است.

مواردی که باعث می‌شوند در عمل تقسیم، سرریز رخ دهد عبارت‌اند از:

- زمانی که مقسوم علیه ۰ باشد.

- زمانی که نیمه بالای مقسوم از مقسوم علیه بزرگتر یا مساوی باشد.

لفظ « فقط » در گزینه‌ی الف، باعث غلط بودن این گزینه است.

۵- گزینه‌ی ب صحیح است.

مطابق با تو ضیحات حل مسئله‌ی ۱۰-۲۲ فصل «الگوریتم‌های حسابی و معماری کامپیوتر» سرریز مانیس بعد از عمل ضرب ممکن نیست.

۶- گزینه‌ی ج صحیح است.

در اعداد ممیز شناور، که به فرم  $(-1)^s \times 0,100 \times 2^e$  هستند، بیت‌های بیشتر برای مانیس دقت عدد را افزایش می‌دهد زیرا باعث می‌شود تعداد بیشتری رقم اعشاری داشته باشیم. از طرفی بیت‌های بیشتر برای نما، باز  $\cdot$  نمایش را زیاد می‌کند چون در قسمت توان عدد، واقع شده است.

۷- گزینه‌ی ب صحیح است.

دلیل استفاده از نمای بایاس شده کاهش خطای محاسبات و همچنین مقایسه راحت‌تر بین اعداد ممیز شناور است.

## تست‌های فصل ۱۱ «سازمان ورودی – خروجی»

۱- عمل Direct Memory Access (DMA) در میکروپردازهای به چه منظور

است؟

(مهندسی کامپیوتر – سراسری ۷۱)

الف) انتقال اطلاعات بین دستگاه‌های جانبی

ب) انتقال اطلاعات بین دستگاه جانبی و حافظه از طریق میکروپردازهای

ج) انتقال مستقیم اطلاعات از دستگاه جانبی به حافظه

د) هیچکدام

۲- برای انتقال داده‌های هشت بیتی روی دو سیم از یک بیت شروع (start)، یک بیت ختم (STOP) و یک بیت توازن زوج (Even Parity) استفاده می‌شود. سرعت انتقال (Baude rate) برابر با ۱۲۰۰ بیت بر ثانیه می‌باشد. برای انتقال پیاپی ۱k بایت اطلاعات، چند ثانیه وقت مورد نیاز است؟

(مهندسی کامپیوتر – سراسری ۸۱)

۶/۸۳

۷/۶۸

۸/۵۳

۹/۳۹

الف) سیکل ربایی (cycle stealing) مربوط به کدام مفهوم زیر است؟

(آزاد ۷۷)

$T_{wait}$

DMA

HALT

NMI

۴- دادن حق تقدم به وقفه ایجاد شده توسط دستگاه‌های جانبی به کدام طریق انجام می‌گیرد؟

(آزاد ۸۴)

الف) وقفه زنجیری

ب) وقفه تقدم موازی

ج) هر دو گزینه‌ی ۱ و ۲

د) هیچکدام

۵- کدام گزینه در مورد روش‌های I/O صحیح نیست؟

**(مهندسی IT - سراسری ۸۵)**

- الف) روش programmed I/O پردازنده اصلی را درگیر عملیات I/O می‌کند.
- ب) روش Interrupted I/O پردازنده اصلی را درگیر عملیات I/O می‌کند.
- ج) روش DMA I/O پردازنده اصلی را درگیر عملیات I/O می‌کند. (در حین I/O)
- د) روش I/O با استفاده از هم پردازنده خاص I/O امکان نوشتن برنامه‌های مختلف از دستورات پردازنده اصلی و هم پردازنده I/O را می‌دهد.

## حل تست‌های فصل ۱۱

۱- گزینه‌ی ج صحیح است.

روش DMA ، از درگیر کردن CPU در جزئیات عمل انتقال اطلاعات بین دستگاه جانبی و حافظه جلوگیری می‌کند.

۲- گزینه‌ی الف صحیح است.

با توجه به بیت‌های شروع، ختم و توازن، هر بایت اطلاعات به صورت یک بسته‌ی

۱۱ بیتی منتقل می‌شود. پس:

$$1024 \times 11 = 11264 \text{ bit} \Rightarrow \frac{11264}{1200} = 0,386$$

۳- گزینه‌ی ج صحیح است.

کنترل‌کننده DMA به چند روش عمل انتقال اطلاعات بین حافظه و I/O را انجام می‌دهد که یکی از روش‌ها سیکل ربایی است. در این روش بعد از تبادل ۱ کلمه اطلاعات، گذرگاه دوباره در اختیار CPU قرار می‌گیرد.

۴- گزینه‌ی ج صحیح است.

دادن حق تقدم به وقفه ایجاد شده به سه روش زیر قابل انجام است.

- سرکشی (polling)

- زنجیره‌ای (Daisy – chain)

- موازی

۵ - گزینه‌ی ج صحیح است.

در روش I/O Interrupted ، صرفاً از بررسی‌های پشت سرهم توسط CPU جلوگیری به عمل می‌آید، اما CPU اجرای درخواست را بر عهده خواهد داشت.

## تست‌های فصل ۱۲ «سازمان حافظه»

۱- یک پردازنده دارای  $n$  خط آدرس  $J$  خط داده است. فقط یک تراشه‌ی حافظه با  $m$  خط آدرس و  $J$  خط داده را مستقیماً به پردازنده وصل کرده‌ایم ( $m > n$ ، هر کلمه  $J$  بیتی از این تراشه با چند آدرس قابل دسترسی است؟

(مهندسی کامپیوتر - سراسری ۸۱)

- الف)  $2^{n-m}$       ب)  $2^{\phi}$   
ج)  $2^{n-m-1}$       د) قابل محاسبه نیست.

۲- سیستمی را که دارای دو سطح حافظه است، در نظر بگیرید.  $M_1$  حافظه پنهان (cache) سیستم است و  $M_2$  حافظه اصلی. زمان دسترسی به cache برابر  $20\text{ns}$  و ضریب hit برابر  $95\%$  است. زمان دسترسی به حافظه  $M_2$  باید چقدر باشد تا زمان مؤثر دسترسی به اطلاعات به صورت کلی  $40\text{ns}$  باشد؟

(علوم کامپیوتر - ۷۹)

- الف)  $400\text{ns}$       ب)  $42\text{ns}$       ج)  $210\text{ns}$       د)  $21\text{ns}$

۳- در یک پردازنده سرعت  $5\text{ mhz}$  است و بس داده‌ای آن  $32$  بیتی می‌باشد. در طراحی جدید این پردازنده، سرعت را به  $20\text{ mhz}$  رسانده‌اند ولی بس داده‌ای آن را  $8$  بیتی کرده‌اند. ماکزیمم speed-up به دست آمده در طراحی جدید نسبت به قبل به چه صورت است؟

(علوم کامپیوتر - ۸۰)

- الف)  $2$  برابر شده است.      ب) speed-up ثابت مانده است.  
ج)  $4$  برابر شده است.      د)  $14$  برابر شده است.

۴- کدام‌یک از موارد زیر از مزایای استراتژی write through است؟

(مهندسی IT - آزاد ۸۴)

- الف) اطلاعات را می‌توان با سرعت cache نوشت.
- ب) از پهنانی باند انتقالی حداکثر استفاده به عمل می‌آید.
- ج) برخورد با حالت Miss در حافظه cache راحت‌تر و ساده‌تر می‌باشد.
- د) موارد ۲ و ۳

۵ - در صورتی که دسترسی به حافظه نهان (cache) از طریق نگاشت مستقیم (Direct Mapping) به روش مقابل باشد، مشخص کنید به ترتیب حجم حافظه اصلی، حافظه نهان و محل استقرار آدرس  $(000B3A4F)_H$  چیست؟  
 (مهندسی کامپیوتر - سراسری ۸۴)

|       |        |        |
|-------|--------|--------|
| tag   | Block  | offset |
| ۷ بیت | ۲۱ بیت | ۴ بیت  |

الف) Block  $(164)_{10}$ , 4GB, 2KB      Block  $(164)_{10}$ , 4GB, 2KB

ج) Block  $(160)_{10}$ , 4GB, 2KB      Block  $(160)_{10}$ , 4GB, 2KB

۶- تفاوت اصلی بین (DRAM) Dynamic Ram و (SRAM) Static Ram چیست؟

(علوم کامپیوتر - ۸۴)

الف) SRAM سریع‌تر و احتیاج به refresh دارد و DRAM کندر و احتیاج به Refresh ندارد.

ب) SRAM کندر و احتیاج به refresh دارد و DRAM سریع‌تر و احتیاج به refresh ندارد.

ج) SRAM کندر و احتیاج به refresh ندارد و DRAM سریع‌تر و احتیاج به refresh دارد.

د) SRAM سریع‌تر و احتیاج به refresh ندارد و DRAM کندر و احتیاج به refresh دارد.

## حل تست‌های فصل ۱۲

۱- گزینه‌ی ب صحیح است.

$$\frac{2^n}{2^m} = 2^{n-m} \quad 2^{n-m}$$

پس هر خانه با آدرس قابل دسترسی است.

۲- گزینه‌ی الف صحیح است.

$$t = h \cdot t_c + (1-h)(t_c + t_m)$$

در رابطه بالا داریم :

$$t_c \text{ زمان دسترسی به حافظه نهان} =$$

$$t_m \text{ زمان دسترسی به حافظه} =$$

$$\Rightarrow 40 = \frac{95}{100} \times 20 + \frac{5}{100}(20 + t_m) \Rightarrow 40 = 19 + 1 + \frac{5t_m}{100}$$

۳- گزینه‌ی ب صحیح است.

طبق تعریف، پهنانی باند حافظه با عرض گذرگاه (باس) و همچنین فرکانس پردازنده رابطه مستقیم دارد.

$$\frac{BW_2}{BW_1} = \frac{8}{32} \times \frac{20}{5} = 1$$

پس تغییر در پهنانی باند حافظه و در نتیجه آن، سرعت انتقال پدید نمی‌آید.

۴- گزینه‌ی ج صحیح است.

دو استراتژی در نوشتن در حافظه نهان وجود دارد:

- write-through = کلمه تغییر یافته در حافظه نهان، در حافظه نیز نوشته می‌شود.

(به هنگام می‌شود.)

- write-back = تا زمانی که کلمه داخل حافظه نهان است، در حافظه اصلی به روز

نمی‌شود و در صورت حذف کلمه از حافظه نهان، حافظه اصلی به روز می‌شود.

استراتژی اول، اگرچه سرعت نوشتن را پایین می‌آورد اما از یکسان بودن محتوای حافظه نهان و حافظه اصلی اطمینان داریم.

۵ - گزينه‌ي د صحیح است.

تعداد کل بیت‌ها ۳۲ بیت است پس حجم حافظه اصلی:

$$2^{32} = 4\text{GB}$$

حجم تعداد بیت‌های block و offset ۷+۴ = ۱۱ = پس حجم حافظه نهان (کش):

$$2^{11} = 2\text{KB}$$

برای تشخیص بلاک مورد اشاره داریم:

$$(B3A4F)_H = (101100111010 \ 0100 \ 1111)_2$$

Block            offset

$$= (36)_{10}$$

۶ - گزینه‌ي د صحیح است.

حافظه Dynamic Ram به دلیل نیاز به Refresh کندتر است.

## منابع

- 1- M.Morris Mano , Computer System Architecture : Solution Manual
- 2- M.Morris Mano , Computer System Architecture, 3<sup>rd</sup> Edition,