

## **آزمون میان ترم درس طراحی کامپیوتری** سیستمهای دیجیتال

نسخه: ۱

## ١- سوالات

۱- با توجه به hardware زیر یک طراحی structural به زبان Verilog بنویسید.



Υ – در این سوال قصد داریم ماژولهای مختلف را با استفاده از Verilog برای یک آرایه ۱۵ تایی از اعداد ۸ بیتی پیادهسازی کنیم:

الف) یک ماژول پیادهسازی کنید که میانگین دادهها را حساب کند.

ب)یک ماژول پیادهسازی کنید که میانه این مجموعه از دادهها را محاسبه کند.

ج) یک ماژول پیادهسازی کنید که مقدار مُد را در این مجموعه دادهها به دست آورد.

۱ مور وطعه کدهای زیر زیر A, B, C و A, B, C و کر زمان A, B, C صفر هستند. اگر مقدار A, B, C و A, B تغییر کند، زمانهایی را که مقادیر A, B و A, B تغییر خواهند کرد را مشخص کرده و مقادیر نسبت داده شده به آنها را نشان دهید:

الف)

```
always @(D)
begin
#5 A <= 1;
B <= A + 1;
#10 C <= B;
end
```

ب)

```
always @(D)
begin
A <= #5 1;
B <= A + 1;
C <= #10 B;
end
```

## ۴ - ساعت زنگ دار

در این سوال باید شما باید مداری برای یک ساعت زنگدار طراحی کنید. این مدار دارای یک سیگنال clk است که گذر ثانیه را مشخص می کند. برای نشان دادن ساعت توسط این مدار ۸ بیت برای دقیقه خواهیم داشت که ۴ بیت آن برای رقم کم ارزش و ۴ بیت دیگر برای رقم پر ارزش خواهد بود و برای ساعت نیز ۴ بیت برای رقم ارزش و ۲ بیت برای رقم پر ارزش خواهد بود و برای ساعت نیز ۴ بیت برای رقم ارزش و ۲ بیت برای رقم پر ارزش آن نیاز خواهیم داشت. سیگنال reset تمام مقادیر دقیقه و ساعت را صفر خواهد کرد. اگر سیگنال set\_clock برابر ۱ باشد می توانیم ساعت دلخواه خود را ورودی داده و تنظیم کنیم. هم چنین اگر ساعت را تنظیم می کنیم. هر زمان در طول کار ساعت اگر به زمان مشخص شده برسیم، سیگنال alarm\_on برابر ۱ خواهد شد و تا زمانی که stop\_alarm تنظیم نشود این هشدار هم چنان روشن خواهد بود. مدار این سوال را با استفاده از زبان Verilog پیاده سازی کنید.