





# طراحي كامييوتري سيستم هاي ديجيتال

(سال تحصیلی ۹۸-۹۷، نیمسال اول)

## تمرین چهارم: مدلسازی رفتاری و سنتز طرح

## ۱-۱- طراحي واحد تقسيم كننده فركانس

هدف از این تمرین طراحی واحدی است که با استفاده از یک کلاک مرجع (Clk\_Ref)، سیگنال ورودی (Clk\_in) را دریافت کند و به شکلی سیگنال خروجی (Clk\_out) را تولید نماید که فرکانس سیگنال خروجی حاصل تقسیم فرکانس سیگنال ورودی بر ضریب (Div\_fact) باشد. در ادامه نحوه ی کار این مدار توضیح داده خواهد شد.

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

entity این ساختار به شکل زیر قابل تعریف است:

```
ENTITY Freq_Div IS
PORT ( Div_Fact
                     : IN
                             integer;
                             std_logic
        Rst
                     : IN
        Clk_Ref
                     : IN
                             std_logic
        Clk_in
                             std_logic;
                     : IN
        Clk_out
                     : OUT
                             std_logic;
                    : OUT std_logic;
        Ready
END Freq_Div;
```

همانطور که در ساختار فوق قابل مشاهده است، این مدار دارای سیگنالهای Rst و Ready نیز میباشد. با فعال شدن سیگنال Rst، کلیه خروجیها مدار برابر صفر خواهند شد. سیگنال Ready نیز در زمانی که کلاک خروجی به فرکانس مورد نظر رسیده باشد، به اندازه یک پالس کلاک مرجع فعال ('1') خواهد شد.

#### **۱–۲** شبیهسازی

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

در شبیه سازی خواسته شده فرکانس کلاک مرجع را 100MHz در نظر بگیرید و براین اساس شبیه سازی را با دو فرکانس متفاوت برای سیگنال ورودی و دو ضریب تقسیم متفاوت به ازای هر فرکانس انجام دهید.

#### **۱–۳** سنتز

پس از اطمینان از نتایج شبیه سازی، طرح خود را با استفاده از ابزار سنتز شرکت ISE) Xilinx (سنتز نمایید و خروجی های خروجی های تولید شده توسط ابزار سنتز، شامل میزان استفاده از منابع و همچنین شماتیک مدار سنتز شده را گزارش نمایید.

### ۱-۴- بخش امتیازی

به منظور انجام این بخش، باید به جای تعریف کلاک مرجع به عنوان یکی از ورودیهای مدار، این ســیگنال را با اســتفاده از منبع کلاک داخلی FPGA، تولید نمایید. (توضیحات تکمیلی این بخش در کلاس حل تمرین داده خواهد شد).

## ۱-۵- نکات فنی

- ۱- نام سیگنال ها دقیقاً به همان صورتی که در صورت تمرین تعریف شده است، استفاده شود.
- ۲- گزارش طرح باید شامل توضیح کامل کد ها و تصاویر مربوط به شکل موجهای خروجی حاصل از مرحله شبیه سازی باشد.