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

## نیمسال اول ۹۹–۹۸





تاریخ تحویل ۱۳۹۸/۱۰/۲۷

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

الف)

```
reg a, b;
always @(posedge clk)
begin
a \le b;
b = a;
end
```

ب)

```
reg [1:0] count;
reg B;
wire A;
assign A = count[1];
always @(posedge clk)
begin
       if (reset)
               count \le 2'b0;
       else
               count \le count + 1;
end
```

۲) میخواهیم تابع زیر را بر روی یک FPGA پیادهسازی کنیم. این FPGA از تعداد زیادی LUTهای ۳ و ۴ ورودی تشکیل شده است. مساحت و تاخیر LUT ها، به تعداد ورودیهای آنها وابسته است. به عنوتن مثال مساحت LUT های سه و چهار ورودی به ترتیب ۳ و ۴ واحد سطح است.

$$f(a,b,c,d) = c(\bar{d}+a) + \bar{d}b$$

الف) بهترین پیادهسازی را از نظر مساحت ارائه کنید.

ب) بهترین پیادهسازی را از نظر تاخیر ارائه کنید.

۳) یک شمارنده جانسون چهار بیتی بر روی FPGA زیر پیاده سازی کنید.

FSM ،ASM و بلوک دیگرام را رسم نمایید.



#### مستندات

۱. ماژول ها و test bench های کامپایل شده به همراه screenshot از صفحه

#### قوانين

- ۱. زمان بندی تمرینات را رعایت فرمایید.
- ۲. در طول ترم، شما ۳ روز تاخیر مجاز دارید.
- ۳. تا زمانی که تمرینات در کلاس حل تمرین حل نشده باشند می توانید تحویل دهید.
  - ۴. از تقلب به شدت بپرهیزید، در صورت تقلب نمره هر دو طرف صفر می گردد.
- ۵. پاسخ های خود را به صورت یک فایل فشرده شده در سایت ادمودو بفرستید. نام فایل الزاما باید به فرم <br/>
  HW7\_FullName\_st.id> باشد. (در صورت عدم رعایت این موارد تمرین شما تصحیح نمی گردد.)

### زمانبندی

جمعه ساعت ۵۹:۲۳، ۱۳۹۸/۱۰/۲۷.

### سامانههای ار تباطی

در صورت هرگونه اشکال، سوالات خود را از طریق سامانه ادمودو مطرح کنید.

#### موفق باشيد

حسین امینی نیوشا استیری امیر حسین امینیمهر