## توضيحات آزمايش سوم

در هنگام نوشتن کد، حتماً نام متغیرهای ورودی و خروجی باید مشابه توضیحات زیر باشد و تنها نام سیگنالهای میانی میتواند متفاوت باشد.

برای طراحی فلیپ فلاپها و ماشینهای حالت از process که حساس به کلاک و سیگنالهای کنترلی مانند reset است استفاده کنید. در بدنه Process از دستورات ترتیبی مانند for ،when case ،۱۶ و یا wait

1- یک فلیپفلاپ از نوع D(DFF) حساس به لبه بالارنده پالس ساعت با سیگنال Reset ناهمگام (asynchronous) در منطق منفی (active low) طراحی کنید. نام فایلها و Entityها و پورتهای ورودی و خروجی را مانند شکلهای زیر انتخاب کنید. ورودیها و خروجیها از نوع std\_logic باشند.

برای وضعیت کلاک میتوان از توابع زیر که در بسته IEEE std\_logic\_1164 تعریف شده است استفاده کرد.

- rising\_edge(clk) برای بررسی وضعیت لبه بالارونده سیگنال کلاک
- falling\_edge(clk) براي بررسي وضعيت لبه بالارونده سيگنال كلاک
- clk'event and clk='1' (or '0') براي بررسي وضعيت سطح '1' (و يا '0' ) سيگنال كلاک



شكل ۱ : فليپ فلاپ نوع D با سيگنال reset غيرهمگام و منطق D شكل ۱ : فليپ فلاپ نوع

**Y**- یک فلیپفلاپ از نوع T(TFF) حساس به لبه پایین رونده پالس ساعت و سیگنال Reset ناهمگام (asynchronous) در منطق منفی و حس (active low) طراحی کنید. در شکل زیر میتوانید پورتهای ورودی و خروجی و نام Entity و فایل را مشاهده کنید. ورودیها و خروجیها از نوع std\_logic باشند.



شكل ٢ : فليپ فلاپ نوع T با سيگنال reset غيرهمگام و منطق T با سيگنال

۳- یک Ripple Counter ۴ بیتی که نمونهای از شمارندههای ناهمگام میباشد را با استفاده از TFF ساخته شده در (۲) طراحی کنید. ورودیها از نوع std\_logic و خروجی از نوع STD\_logic\_vector باشند.



شکل ۳: ماژول شمارنده carry ripple چهار بیتی

۴ – مدار یک Sequence detector برای رشته " 1101 " با قابلیت همپوشانی را ابتدا به صورت Mealy و سپس Moore طراحی کرده و آن را با استفاده از زبان VHDL طراحی کنید. ابتدا ماشین حالت Mealy و Moore و جدول صحت را برای شناسایی رشته std\_logic بیتی ۱۱۰۱ را طراحی کرده و سپس مدار آن را به صورت ماژولهای زیر طراحی کنید. ورودیها و خروجیهای مدار از نوع باشند.



شکل ۴: ماژولها و پورتهای ورودی و خورجی secuence detector و mealy و moore و Moore برای تست این دو ماژول از یک فایل testbench استفاده کنید. برای این کار سیگنالهای ورودی یکسان را به هر دو ماژول داده و سیگنال خروجی را با هم مقایسه کنید.



شکل ۵: ماژول تست sequence detector ماشین حالت میلی و مور به صورت همزمان

 $\Delta$ - مداری طراحی کنید که رخداد هر یک از دو رشته " 0110 " و " 0101 " را با قابلیت همپوشانی در ورودی تشخیص دهد (به kealy یا Moore و یا Mealy طراحی کنید). ورودیها و خروجیهای مدار از نوع std\_logic باشند. ماشین حالت mealy و یا moore و جدول صحت را برای شناسایی رشته بیتی طراحی کنید.



شکل ۶: ماژول و پورتهای ورودی و خروجی sequence detector