

دانشكده مهندسي كامپيوتر

دکتر مهدی فاضلی بهار ۱۴۰۰

# تمرین دوم طراحی سیستم های دیجیتال

مبينا كاشانيان- اميرحسين قاسمي

تاریخ تحویل: ۱۷ اردیبهشت ۱۴۰۰ ساعت ۲۳:۵۹:۵۹



### نكات

- در صورت مشاهده ی هرگونه تقلب یا کپی از اینترنت، نمره تمرین هر دو گروه ۱۰۰ منظور خواهد شد.
  - سوالات خود را از طریق گروه تلگرام مطرح کنید.
    - انجام تمرین به صورت گروهی میباشد.
    - مهلت تحويل تمرين قابل تمديد نخواهد بود.
      - تحويل تمرين از طريق سايت مي باشد



# **Questions**

#### Full Adder | 4-bit ripple adder (20)

یک Full Adder با سطوح زیر طراحی کنید:

- Structural •
- Data flow •
- Behavioral •
- Data flow با استفاده از Full Adder طراحی شده با طراحی  $4 ext{-bit}$  ripple adder برای طراحی های فوق Test bench بنویسید.

#### Circuit Design (20)

مدار زیر را در سطح Structural پیاده سازی کنید و توضیح دهید که چه عملکردی دارد.



شكل ١: مدار خواسته شده

## Carry-Lookahead Adder Design (20)

یک Test bench بیتی را طراحی کنید و Test bench را بنویسید.



#### Signed Multiplier (20)

فرض کنید دو عدد ۸ بیتی علامت دار (Signed) داریم ضرب این دو را پیاده سازی کنید. در طراحی خود باید استفاده از گیت های AND و NAND استفاده کنید همچنین برای این سوال باید . بنویسید Test bench

#### Divider Design (20)

با توجه به رابطه ی زیر

$$a = q \times b + r \tag{1}$$

با داشتن مقادیر a,b میخواهیم مقادیر q,r را به دست بیاوریم با توجه به توضیحات بالا پیاده سازی خود را انجام دهید. برای این سوال Test bench بنویسید.

راهنمایی: سیگنال start برای نشان دادن شروع تقسیم می باشد و سیگنال busy نشان دهنده ی این است که تقسیم کننده نمیتواند عملیات تقسیم جدیدی را شروع کند سیگنال ready نشان دهنده ی این است که q,r آماده شده است و سیگنال count برای این استفاده میشود که تعداد دفعات تقسیم را کنترل کند.

موفق باشيد.