# به نام خدا



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

استاد: مهندس فصحتی

اعضای گروه:

ارشيا ايزدياري 401105656

عليرضا ميرركنى 401106617

# دانشكده مهندسي كامپيوتر دانشگاه صنعتي شريف – تابستان 1403

# گزارش پروژه

در این پروژه، هدف طراحی یک مدار برای مدیریت پارکینگ می باشد. این مدار باید موارد زیر را پشتیبانی کند:

- 1) اولویت فضای پارکینگ با اساتید و کارمندان دانشگاه است و این ظرفیت بر اساس آمار حداکثر 500 خودرو تعیین گردیده است.
- 2) با توجه به اینکه فضای کل پارکینگ 700 خودرو است، از ساعت 8 تا 13 فقط 200 ظرفیت خالی برای ورود آزاد مجاز است.
- (3 از ساعت 13 تا 16، به ازای هر ساعت ظرفیت ورود آزاد 50 خودرو افزایش می یابد و در ساعت 16 ظرفیت ورود آزاد به 500 خودرو می رسد (به عبارت دیگر ظرفیت آزاد در ساعت 13 برابر 250 خودرو، در ساعت 15 برابر 300 خودرو خواهد بود).

در ادامه هر کدام از ورودی ها و خروجی های مدار را به تفصیل بررسی می نماییم.

| نام ورودی          | نوع ورودی    | توضيحات                                  |
|--------------------|--------------|------------------------------------------|
| clk                | wire تک بیتی | به منظور تعیین ساعت استفاده می شود.      |
| car_entered        | wire تک بیتی | ورود یک خودرو را نمایش می دهد.           |
| is_uni_car_entered | wire تک بیتی | آیا خودرو وارد شده متعلق به دانشگاه است؟ |
| car_exited         | wire تک بیتی | خروج یک خودرو را نمایش می دهد.           |
| is_uni_car_exited  | wire تک بیتی | آیا خودرو خارج شده متعلق به دانشگاه است؟ |

| نام خروجی            | نوع خروجي         | توضيحات                                             |  |
|----------------------|-------------------|-----------------------------------------------------|--|
| uni parkod car       | vector يازده بيتى | تعداد خودرو های متعلق به دانشگاه که در پارکینگ پارک |  |
| uni_parked_car       | علامت دار         | شده اند.                                            |  |
| parked car           | vector یازدہ بیتی | تعداد خودرو های متعلق به ظرفیت آزاد که در پارکینگ   |  |
| parked_car           | علامت دار         | پارک شده اند.                                       |  |
| uni vacated chace    | vector یازدہ بیتی | تعداد فضا های خالی متعلق به دانشگاه                 |  |
| uni_vacated_space    | علامت دار         | تعداد فضا های حالی متعلق به دانستاه                 |  |
| vacated space        | vector یازدہ بیتی | تعداد فضا های خالی متعلق به ظرفیت آزاد              |  |
| vacated_space        | علامت دار         | تعداد فضا های حالی متعلق به طرفیت اراد              |  |
| uni_is_vacated_space | wire تک بیتی      | آیا فضای خالی برای دانشگاه موجود است؟               |  |

| is_vacated_space | wire تک بیتی | آیا فضای خالی برای ظرفیت آزاد موجود است؟ |
|------------------|--------------|------------------------------------------|
| valid            | wire تک بیتی | آیا وضعیت پارکینگ، وضعیت معتبری است؟     |

دقت کنید که تمامی سیگنال هایی که فقط می توانند مقادیر 0 یا 1 را داشته باشند (هم در ورودی و هم در خروجی)، از uni\_vacated\_space ،parked\_car ،uni\_parked\_car های wire تک بیتی در نظر گرفته شده اند. خروجی های vacated\_space و vector را بردار (vector) هایی علامت دار به طول 11 در نظر گرفته ایم. علت این است که بیشینه مقدار هر کدام از این متغیر ها برابر 700 می باشد (که به 10 بیت برای نگهداری آن نیاز داریم) و از طرفی ممکن است مقدار برخی از آن ها منفی شود (به طور مثال اگر ساعت 7 باشد و 500 ماشین آزاد در پارکینگ پارک کرده باشند، در ساعت 8 که ظرفیت آزاد برابر 200 ماشین می شود مقدار متغیر vacated\_space برابر 200 خواهد شد)، به همین خاطر تمامی این متغیر ها را علامت دار در نظر گرفتیم تا در انجام عملیات های حسابی مشکلی ایجاد نشود (دقت کنید که parked\_car هیچ گاه منفی نخواهد شد).

به منظور طراحی مدار، از تعدادی متغیر کمکی استفاده کردیم. در ادامه به بررسی این متغیر های کمکی می پردازیم:

| نام متغير كمكى             | نوع متغير كمكى | توضيحات                                        |
|----------------------------|----------------|------------------------------------------------|
| number of entered care     | vector يازده   | تعداد کل خودرو های مربوط به ظرفیت آزاد که وارد |
| number_of_entered_cars     | بیتی علامت دار | پارکینگ شده اند.                               |
| number of entered unicars  | vector يازده   | تعداد کل خودرو های مربوط به دانشگاه که وارد    |
| number_of_entered_uni_cars | بیتی علامت دار | پارکینگ شده اند.                               |
| number of evited care      | vector يازده   | تعداد کل خودرو های مربوط به ظرفیت آزاد که از   |
| number_of_exited_cars      | بیتی علامت دار | پارکینگ خارج شده اند.                          |
| number of evited unicars   | vector يازده   | تعداد کل خودرو های مربوط به دانشگاه که از      |
| number_of_exited_uni_cars  | بیتی علامت دار | پارکینگ خارج شده اند.                          |
| uni narkod car tmn         | vector يازده   | متغیر کمکی برای نگهداری تعداد خودرو های        |
| uni_parked_car_tmp         | بیتی علامت دار | متعلق به دانشگاه که در پارکینگ پارک شده اند.   |
| narked car tmn             | vector يازده   | متغیر کمکی برای نگهداری تعداد خودرو های        |
| parked_car_tmp             | بیتی علامت دار | ظرفیت آزاد که در پارکینگ پارک شده اند.         |
| capacity                   | integer        | ظرفیت پارکینگ برای خودرو های آزاد              |
| minute                     | integer        | تعداد دقیقه سپری شده از ساعت جاری              |
| hour                       | integer        | نشان می دهد در چه ساعتی از روز هستیم.          |

دقت کنید که علت تعریف برخی از این متغیر های کمکی، این است که اگر مقدار متغیری در چند بلاک always مورد تغییر قرار بگیرد، ابزار سنتز دیگر قادر به سنتز کردن کد وریلاگ نخواهد بود. به طور مثال، علت تغییر متغیر های

number\_of\_entered\_cars و number\_of\_exited\_cars به جای تغییر مستقیم parked\_car در بلاک always در بلاک های always، همین موضوع می باشد.

در ادامه به بررسی توصیف مدار با استفاده از زبان وریلاگ می پردازیم.

کد زیر توصیف مدار را با استفاده از زبان وریلاگ نمایش می دهد. این ماژول در فایل PARKING.v در پوشه verilog قرار گرفته است.

```
module PARKING (
    input clk,
    input car_entered,
    input is uni car entered,
    input car_exited,
    input is_uni_car_exited,
    output signed [10 : 0] uni parked car,
    output signed [10 : 0] parked_car,
    output signed [10 : 0] uni_vacated_space,
    output signed [10 : 0] vacated_space,
    output uni_is_vacated_space,
    output is vacated space,
    output valid
);
    reg signed [10 : 0] number_of_entered_cars = 0;
    reg signed [10 : 0] number of entered uni cars = 0;
    reg signed [10 : 0] number_of_exited_cars = 0;
    reg signed [10 : 0] number of exited uni cars = 0;
    reg signed [10 : 0] uni_parked_car_tmp;
    reg signed [10 : 0] parked_car_tmp;
    integer capacity = 0;
    integer minute = 0;
    integer hour = 0;
    assign uni_parked_car = uni_parked_car_tmp;
    assign parked_car = parked_car_tmp;
    assign uni vacated space = 700 - capacity - uni parked car tmp;
    assign vacated_space = capacity - parked_car_tmp;
    assign uni_is_vacated_space = (700 > capacity + uni_parked_car_tmp);
    assign is_vacated_space = (capacity > parked_car_tmp);
    assign valid = (uni_vacated_space >=0 && vacated_space >= 0);
    always @(posedge clk) begin
        minute <= minute + 1;</pre>
```

```
if (minute == 600) begin
            minute <= 0;
            hour <= hour + 1;</pre>
        end
        if (hour == 24) begin
            hour <= 0;
        end
        if (hour >= 8 && hour < 13) begin
            capacity <= 200;
        end
        else if (hour >= 13 && hour <= 15) begin
            capacity <= 200 + (hour - 12) * 50;
        end
        else begin
            capacity <= 500;
        end
    end
    always @(posedge car_entered) begin
        number_of_entered_uni_cars <= number_of_entered_uni_cars +</pre>
((is uni car entered & uni is vacated space) ? 1 : 0);
        number_of_entered_cars <= number_of_entered_cars + ((~is_uni_car_entered</pre>
& is_vacated_space) ? 1 : 0);
    end
    always @(posedge car exited) begin
        number_of_exited_uni_cars <= number_of_exited_uni_cars +</pre>
((is_uni_car_exited & (uni_parked_car > 0)) ? 1 : 0);
        number_of_exited_cars <= number_of_exited_cars + ((~is_uni_car_exited &</pre>
(parked_car > 0)) ? 1 : 0);
    end
    always @(number of entered uni cars, number of entered cars,
number_of_exited_uni_cars, number_of_exited_cars) begin
        uni_parked_car_tmp = number_of_entered_uni_cars -
number_of_exited_uni_cars;
        parked_car_tmp = number_of_entered_cars - number_of_exited_cars;
    end
endmodule
```



#### بخش اول: تعیین ورودی ها، خروجی ها و تعریف متغیر های کمکی

```
module PARKING (
   input clk,
    input car entered,
    input is_uni_car_entered,
    input car_exited,
    input is_uni_car_exited,
   output signed [10 : 0] uni_parked_car,
   output signed [10 : 0] parked car,
   output signed [10 : 0] uni_vacated_space,
   output signed [10 : 0] vacated space,
   output uni_is_vacated_space,
   output is_vacated_space,
   output valid
);
   reg signed [10 : 0] number_of_entered_cars = 0;
   reg signed [10 : 0] number_of_entered_uni_cars = 0;
    reg signed [10 : 0] number of exited cars = 0;
   reg signed [10 : 0] number_of_exited_uni_cars = 0;
   reg signed [10 : 0] uni parked car tmp;
   reg signed [10 : 0] parked_car_tmp;
   integer capacity = 0;
    integer minute = 0;
   integer hour = 0;
```

در ابتدای گزارش، توضیحات کاملی در ارتباط با متغیر ها ارائه گردید؛ به همین دلیل از توضیحات بیشتر برای این بخش صرف نظر می کنیم.

## بخش دوم: تعيين مقدار خروجي ها

```
assign uni_parked_car = uni_parked_car_tmp;
assign parked_car = parked_car_tmp;
assign uni_vacated_space = 700 - capacity - uni_parked_car_tmp;
assign vacated_space = capacity - parked_car_tmp;
assign uni_is_vacated_space = (700 > capacity + uni_parked_car_tmp);
assign is_vacated_space = (capacity > parked_car_tmp);
assign valid = (uni_vacated_space >= 0 && vacated_space >= 0);
```

در این بخش مقدار متغیر های خروجی را با استفاده از متغیر های کمکی تعیین کرده ایم.

مقدار خروجی های uni\_parked\_car و uni\_parked\_car را به ترتیب برابر مقدار متغیر های کمکی uni\_parked\_car و uni\_parked\_car\_tmp قرار می دهیم. مقدار خود این متغیر های کمکی را نیز در یک بلاک number\_of\_entered\_uni\_cars که در ادامه آن را بررسی خواهیم نمود، با تغییر متغیر های کمکی number\_of\_exited\_cars تعیین می number\_of\_exited\_cars و number\_of\_exited\_cars تعیین می

```
مقدار متغیر های uni_vacated_space و vacated_space از روابط زیر محاسبه می شود:
```

uni\_vacated\_space = 700 - free capacity - number of parked uni cars vacated\_space = free capacity - number of parked free cars

مقدار متغیر های uni\_is\_vacated\_space و is\_vacated\_space نیز از روابط زیر محاسبه می شوند:

```
uni_is_vacated_space \Leftrightarrow uni_vacated_space > 0
```

- $\Leftrightarrow$  700 free capacity number of parked uni cars > 0
- $\Leftrightarrow$  700 > free capacity + number of parked uni cars

is\_vacated\_space  $\Leftrightarrow$  vacated\_space > 0

- $\Leftrightarrow$  free capacity number of parked free cars > 0
- ⇔ free capacity > number of parked free cars

مقدار متغیر کمکی valid نیز زمانی برابر 1 می شود که هر دوی مقادیر uni\_vacated\_space و vacated\_space نامنفی باشند که به وضوح در عبارت assign مربوط به این متغیر، این نکته رعایت شده است.

## بخش سوم: تغییر دقیقه، ساعت و تعیین ظرفیت آزاد پارکینگ با توجه به ساعت

```
always @(posedge clk) begin
    minute <= minute + 1;

if (minute == 600) begin
        minute <= 0;
        hour <= hour + 1;
end

if (hour == 24) begin
        hour <= 0;
end

if (hour >= 8 && hour < 13) begin
        capacity <= 200;
end</pre>
```

در این بخش، موارد زیر انجام می شوند:

- با هر لبه بالارونده کلاک مقدار متغیر minute یک واحد افزایش می یابد.
- در صورتی که مقدار متغیر minute برابر 600 شود، مقدار متغیر hour یک واحد افزایش می یابد (به عبارت دیگر هر ساعت را معادل 600 کلاک و هر دقیقه را معادل 10 کلاک در نظر گرفته ایم).
- در صورتی که مقدار متغیر hour برابر 24 شود، یعنی به انتهای روز رسیده ایم و مقدار این متغیر به 0 ریست می شود.
- با توجه به ساعتی که در آن هستیم، ظرفیت آزاد پارکینگ تعیین می شود (بین ساعات 8 تا 12، این ظرفیت برابر 200 + (hour 12) \* 50 این ظرفیت از رابطه 50 \* (hour 12) + 200 + (hour 12).
   محاسبه می گردد. در سایر ساعات این ظرفیت برابر 500 خودرو می باشد).

#### بخش چهارم: ورود ماشین به پارکینگ

در صورتی که ماشینی وارد پارکینگ شود (مقدار ورودی car\_entered برابر 1 شود)، این بلاک فعال می شود.

اگر ماشین وارد شده از نوع دانشگاهی باشد (is\_uni\_car\_entered برابر 1 باشد) و ظرفیت دانشگاهی در پارکینگ وجود داشته باشد (is\_uni\_vacated\_space برابر 1 باشد)، مقدار متغیر number\_of\_entered\_uni\_cars یک واحد افزایش می یابد.

اگر ماشین وارد شده از نوع دانشگاهی نباشد (is\_uni\_car\_entered برابر 0 باشد) و ظرفیت آزاد در پارکینگ وجود داشته باشد (is\_vacated\_space یک واحد افزایش می باشد)، مقدار متغیر number\_of\_entered\_cars یک واحد افزایش می یابد.

#### بخش ینجم: خروج ماشین از پارکینگ

در صورتی که ماشینی از پارکینگ خارج شود (مقدار ورودی car\_exited برابر 1 شود)، این بلاک فعال می شود.

اگر ماشین خارج شده از نوع دانشگاهی باشد (is\_uni\_car\_exited برابر 1 باشد) و ماشینی از نوع دانشگاهی در پارکینگ وجود داشته باشد (uni\_parked\_car مثبت باشد)، مقدار متغیر number\_of\_exited\_uni\_cars یک واحد افزایش می یابد.

اگر ماشین خارج شده از نوع دانشگاهی نباشد (is\_uni\_car\_exited برابر 0 باشد) و ماشینی از نوع ظرفیت آزاد در پارکینگ وجود داشته باشد (parked\_car مثبت باشد)، مقدار متغیر number\_of\_exited\_cars یک واحد افزایش می یابد.

#### بخش ششم: بروزرسانی تعداد ماشین های پارک شده (متغیر های کمکی)

هرگاه هر یک از سیگنال های number\_of\_entered\_uni\_cars تغییر کنند، این بلاک اجرا میشود و تعداد number\_of\_exited\_cars تغییر کنند، این بلاک اجرا میشود و تعداد ماشین های پارک شده در پارکینگ (هم ماشین های دانشگاهی و هم ماشین های آزاد) بروزرسانی خواهند شد.

دقت کنید که تعداد ماشین های دانشگاهی پارک شده در پارکینگ (uni\_parked\_car\_tmp) از تفاضل تعداد کل ماشین های دانشگاهی خارج شده ماشین های دانشگاهی وارد شده (number\_of\_entered\_uni\_cars) و تعداد کل ماشین های دانشگاهی خارج شده (number\_of\_exited\_uni\_cars) به دست می آید.

همچنین تعداد ماشین های ظرفیت آزاد پارک شده در پارکینگ (parked\_car\_tmp) از تفاضل تعداد کل ماشین های ظرفیت آزاد خارج شده (number\_of\_entered\_cars) و تعداد کل ماشین های ظرفیت آزاد خارج شده (number\_of\_exited\_cars) به دست می آید.

|   | در ادامه ماژول تحریک نوشته شده به منظور بررسی صحت مدار را مشاهده می کنید. این ماژول در فایل TB.v در پوشه |
|---|----------------------------------------------------------------------------------------------------------|
|   |                                                                                                          |
|   | verilog قرار دارد.                                                                                       |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
|   |                                                                                                          |
| L |                                                                                                          |
| h |                                                                                                          |

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

برای سنتز از نرم افزار Quartus استفاده کردیم؛ به این شکل که یک پروژه (با نام SYNTHESIZE) تحت FPGA ای به نام Arria II GX ایجاد کردیم، سپس فایل PARKING.v را (که حاوی ماژول PARKING می باشد) به آن اضافه نمودیم (این فایل از نوع Verilog HDL File می باشد). در ادامه این فایل را compile کردیم و فرایند سنتز توسط خود این نرم افزار انجام گردید.

مدار طراحی شده توسط این نرم افزار، از منوی tools>netlist viewer قابل مشاهده می باشد. به علت بزرگ بودن این مدار ها و کم کیفیت بودن تصاویر، از قرار دادن تصویر این مدار ها در این گزارش صرف نظر می کنیم.

برای مشاهده بیشترین فرکانس از قسمت compilation report منوی TimeQuest Timing Analyzer را انتخاب می کنیم. در این منو، سه فایل به ازای مدل سازی های مختلف وجود دارد که در هر کدام بیشینه فرکانس برای سیگنال های car\_exited ،clk و car\_exited ،clk نوشته شده است. در ادامه تصویر خروجی این فایل ها را آورده ایم.

| Slow | Slow 900mV 100C Model Fmax Summary |                 |             |                                                               |  |
|------|------------------------------------|-----------------|-------------|---------------------------------------------------------------|--|
|      | Fmax                               | Restricted Fmax | Clock Name  | Note                                                          |  |
| 1    | 102.25 MHz                         | 102.25 MHz      | clk         |                                                               |  |
| 2    | 184.2 MHz                          | 184.2 MHz       | car_entered |                                                               |  |
| 3    | 344.47 MHz                         | 260.01 MHz      | car_exited  | limit due to minimum period restriction (max I/O toggle rate) |  |

| Slow | Slow 900mV -40C Model Fmax Summary |                 |             |                                                               |  |
|------|------------------------------------|-----------------|-------------|---------------------------------------------------------------|--|
|      | Fmax                               | Restricted Fmax | Clock Name  | Note                                                          |  |
| 1    | 108.44 MHz                         | 108.44 MHz      | clk         |                                                               |  |
| 2    | 192.64 MHz                         | 192.64 MHz      | car_entered |                                                               |  |
| 3    | 356.25 MHz                         | 260.01 MHz      | car_exited  | limit due to minimum period restriction (max I/O toggle rate) |  |

با مشاهده تصاویر بالا، به این نتیجه می رسیم که مسیر بحرانی برای مدار طراحی شده، مسیری است که منجر به فرکانس بیشترین (Slow 900mV 100C Model (در مدل سازی مربوط به Car\_entered شده است، چرا که این فرکانس بیشترین مقدار را در بین فرکانس های نمایش داده شده دارد. همچنین می توان دریافت که مسیری که ورودی car\_exited طی می کند دارای تاخیر بیشتری است (چرا که فرکانس آن کمتر می باشد).

دقت کنید که اگر فرکانس داده شده به مدار از فرکانس های مشخص شده بیشتر شود، در عملکرد مدار اختلال ایجاد خواهد شد. بهینه ترین حالت این است که فرکانس هر کدام از ورودی ها برابر با بیشینه فرکانس ممکن تنظیم شود تا علاوه بر افزایش سرعت و کارایی مدار (به دلیل کاهش تاخیر های موجود در مدار بویژه تاخیر مسیر بحرانی)، در عملکرد آن اختلالی ایجاد نشود.

در ادامه به بررسی setup time و مابطه آن ها با فرکانس ورودی می پردازیم. این بررسی ها برای مدل Slow 900mV 100C Model انجام شده اند.

درابتدا مقادیر setup time و hold time را مشاهده می کنید.

| Slow 900mV 100C Model Setup Summary |             |        |               |  |  |
|-------------------------------------|-------------|--------|---------------|--|--|
|                                     | Clock       | Slack  | End Point TNS |  |  |
| 1                                   | clk         | -8.780 | -394.518      |  |  |
| 2                                   | car_entered | -4.498 | -81.788       |  |  |
| 3                                   | car_exited  | -1.919 | -39.942       |  |  |

| Slow 900mV 100C Model Hold Summary |             |       |               |  |  |
|------------------------------------|-------------|-------|---------------|--|--|
|                                    | Clock       | Slack | End Point TNS |  |  |
| 1                                  | car_entered | 0.409 | 0.000         |  |  |
| 2                                  | car_exited  | 0.415 | 0.000         |  |  |
| 3                                  | clk         | 0.419 | 0.000         |  |  |

مقدار فرکانس ورودی ها را نیز مجددا در شکل زیر می آوریم.

| Slow | Słow 900mV 100C Model Fmax Summary |                 |             |                                                               |  |
|------|------------------------------------|-----------------|-------------|---------------------------------------------------------------|--|
|      | Fmax                               | Restricted Fmax | Clock Name  | Note                                                          |  |
| 1    | 102.25 MHz                         | 102.25 MHz      | clk         |                                                               |  |
| 2    | 184.2 MHz                          | 184.2 MHz       | car_entered |                                                               |  |
| 3    | 344.47 MHz                         | 260.01 MHz      | car_exited  | limit due to minimum period restriction (max I/O toggle rate) |  |

حال دقت کنید که می توان نوشت (جمع ها بدون در نظر گرفتن علامت انجام شده اند):

clk: Setup Time + Hold Time = 
$$8.780 + 0.409 = 9.189$$
 ns   
 $\Rightarrow \frac{1}{\text{Setup Time + Hold Time}} = \frac{1}{9.189} \times 10^9 = 108.82 \text{ MHz} > 102.25 \text{ Mhz}$ 

car\_entered: Setup Time + Hold Time = 
$$4.498 + 0.415 = 4.913$$
 ns   

$$\Rightarrow \frac{1}{\text{Setup Time + Hold Time}} = \frac{1}{4.913} \times 10^9 = 203.54 \text{ MHz} > 184.20 \text{ Mhz}$$

car\_exited: Setup Time + Hold Time = 
$$1.919 + 0.419 = 2.338$$
 ns   

$$\Rightarrow \frac{1}{\text{Setup Time + Hold Time}} = \frac{1}{2.338} \times 10^9 = 427.71 \text{ MHz} > 260.01 \text{ Mhz}$$

همانطور که مشاهده می شود، برای تمامی ورودی ها وارون مجموع setup time و hold time بیشتر از فرکانس به دست آمده می باشد.

همچنین برای ورودی clk (ورودی با کمترین فرکانس)، مجموع setup time و hold time بسیار نزدیک به فرکانس آن می باشد و این یعنی به آنچه که می خواستیم، رسیده ایم.