## به نام خدا

## درس طراحی سیستمهای مبتنی بر ASIC / FPGA

دكتر مهدى شعباني

دانشکده مهندسی برق

دانشگاه صنعتی شریف

تمرین سری اوّل

نیمسال اوّل ۱۴۰۲ – ۱۴۰۱

## نکاتی در مورد انجام این تمرین:

- ۱- برای تحویل تمرین، تمامی فایلها از جمله ماژولها و تستبنچ ها به همراه گزارشی از نحوه ی انجام کار به همراه نتایج مربوطه را در سامانه آپلود کنید. برای تحویل کدها، فقط فایلهای مربوط به ماژولها و تستبنچها را در فولدرهای جداگانه قرار دهید(هر فولدر مربوط به هر سؤال و هر بخش نیز در فولدر جداگانه). برای سؤالات دارای فایلهای اضافی مثل فایل مموری یا txt آنها را نیز تحویل دهید. از ارسال کل پروژه پرهیز کنید!!!!!
- ۲- کد تحویل داده شده توسط شما باید قابل سنتز و شبیه سازی باشد و در صورت این که کد سنتز و شبیه سازی نشود، نمرهای به آن تعلق نمی گیرد.
- ۳- مشورت و کمک گرفتن از یکدیگر، جستجو در اینترنت و کتابها و.... کاملاً جایز میباشد ولی تمرین باید توسط خود شما انجام شود. در صورت مشاهده شباهت غیرعادی نمره سؤال برای همه افراد کاملاً صفر می شود.
- <sup>۴</sup>- سعی کنید در تمرین برنامهنویسی، هم از سطح رفتاری و هم سطح جریان داده استفاده کنید تا به هر دو سطح مسلط شوید.
- 4- در صورت وجود هر گونه ابهام یا سؤال در مورد تمرین، آن را با ایمیل <u>AmirMZeyghami@gmail.com</u> در میان بگذارید.
- <sup>9</sup>- این تمرین برای تمرین کدزنی و شبیه سازی شما در نظر گرفته شده است و صرفاً صورت سؤالات طولانی است و هدف اصلی افزایش تسلط شما در کدزنی می باشد؛ از انجام این تمرین نهایت لذت را ببریدا

۱– در این سؤال با ساختارهای مختلف یک FIRفیلتر آشنا میشوید و دو ساختار رایج آنها را پیادهسازی میکنید.

الف – در مورد ساختار کلی FIR تحقیق کنید و ساختار رایج آن را بکشید. سپس یک فیلتر FIR با ده tap پیاده سازی کنید. فرض کنید مقادیر ضرایب ۸ بیتی است و برای معین نمودن ضرایب، سه ورودی داریم :

شماره ضریب مورد نظر

مقدار ضریب

یک بیت جهت تغییر مقدار ضریب موردنظر با نام write\_en

در هر لبه کلاک، اگر write\_en یک باشد، مقدار ضریب مورد نظر در لبه ی کلاک بعدی تغییر می کند. این فیلتر یک ورودی ۸ بیتی به صورت stream دریافت می کند و خروجی نیز stream است؛ محاسبه کنید که با این ویژگیها، خروجی حداکثر چند بیتی است و همین مقدار بیت را برای آن در نظر بگیرید. جهت نمایش صحت عملکرد ساختار پیادهسازی شده testbench بنویسید و ورودی را فقط در یک لبه کلاک ۱ کنید و در بقیه ی لحظات صفر؛ خروجی باید مقادیر ضرایب باشد.

ساختار خواسته شده در نهایت به صورت زیر میباشد:



ب- در مورد symmetric بودن ضرایب و ساختار تغییر یافته برای فیلتر وقتی ضرایب symmetric هستند تحقیق کنید و ضمن ارائه ساختار خود برای یک فیلتر با ۹ ضریب، کد وریلاگ آن را نوشته و با تست ذکر شده در قسمت الف، شبیهسازی کنید.

ج- مزیت عمدهی ساختار پیشنهادی در قسمت ب با قسمت الف (با فرض symmetric بودن ضرایب) را بیان کنید.

د- فرض کنید که ضرایب فقط مقادیر ۱، ۰ و ۱- را به خود می گیرند. ساختار فیلتر طراحی شده در قسمت الف را بهینه کنید.

در این سؤال، استفاده از ضرایب یک فیلتر پایین گذر واقعی و استفاده از generate block برای پیاده سازی امتیازی است. لازم است که نحوه ی تعیین ضرایب به صورت کامل شرح داده شود. در صورت علاقه مندی، می توانید ما ژول نوشته شده در قسمت الف و ج را به صورت جداگانه سنتز کنید و منابع مصرف شده در آن دو را مقایسه کنید.

 $Y - c_0$  Embedded System میباشد؛ یکی از مشکلات این نوع کلیدها، bouncing آنها میباشد؛ یعنی بعد از فشار دادن کلید، اگر خروجی کلید را با استفاده از اسکوپ ببینیم، شکلی مانند زیر دارد.



اگر فرکانس تغییرات شکل موج حاصل شده از فشاردادن کلید از فرکانس کاری موردنظر کمتر باشد، همانطور که واضح است، فشار داده شدن کلید چندین بار اعمال می گردد؛ به این اثر، Bouncing گفته می شود که در اثر لرزش کلید فشاری(یا هر کلید دیگری) ایجاد می شود.

فرض کنید یک کلید فشاری به FPGA متصل شده است؛ مبنای این که کلید زده شده است، آن است که لبه ی بالارونده ببینیم. ماژولی طراحی کنید که با زده شدن کلید، تنها یکبار آن را اعمال کند؛ اصطلاحاً به این عمل Debouncing گفته می شود و کار آن این است که ورودی نویزی بگیرد و خروجی تمیز تولید کند. اگر ورودی این ماژول شکل قبل باشد، خروجی باید یک شکل موج مربعی باشد. فرکانس کاری را ۲۰ مگاهر تز در نظر بگیرید. با نوشتن testbench و اعمال یک ورودی نویزی، صحت عملکرد ماژول خود را نشان دهید. در طراحی ماژول، مدت زمانی که ورودی در اثر لرزش کلید می تواند نویزی باشد را دلخواه در نظر بگیرید و ماژول را برای این فرض خود طراحی کنید.

۳ – در این سؤال با نحوهی صحت سنجی ساختارهای پیادهسازی شده با استفاده از Matlab آشنا می شوید. توصیه می شود در مورد fixed point مطالعه کنید.

الف – با استفاده از نرمافزار Matlab، یک پریود کامل از یک موج سینوسی با طول ۱۰۲۴ در نظر بگیرید و آن را fixed – point کنید. (فیکس پوینت مورد نیاز: (1,16,14)). نتایج را باید در دو فایل با فرمت mem. بنویسید. حال کدی بنویسید که دو آرایه ۱۶ بیتی به عمق ۱۰۲۴ را با مقادیر سینوسی ساخته شده در متلب، مقداردهی اوّلیه کند(سینوس و کسینوس). برای این کار باید در بلوک initial، از تسک سیستمی freadmemb یا readmemb استفاده کنید. طرز کار این دو تسک به راحتی با سرچ از اینترنت به دست می آید. سپس ماژولی بنویسید که از این دو آرایه استفاده کند و خروجی سینوسی با فرکانس ۱، ۲، ۴، ۸ و... برابر فرکانس موج سینوسی ساخته شده را بسازد. برای مشخص کردن فرکانس خروجی یک ورودی ۳ بیتی در نظر بگیرید که فقط می تواند مقادیر ۱، ۲، ۳ و ۴ بگیرد که این مقادیر در واقع متناظر فرکانس اوّلیه و... است.

ب- برای تست ماژول نوشته شده در قسمت الف، تست بنچی بنویسید که خروجی ماژول در دوحالت دلخواه ورودی را روی یک فایل txt. بنویسد. هر یک از دو حالت را در متلب به فرم sin + i\*cos در آورده و با استفاده از دستور fft یا pwelch طیف آنها را رسم کنید. فرکانس نمونهبرداری را دلخواه در نظر بگیرید و فرکانسهای موجهای تولیدی توسط خود را صحتسنجی کنید.

ج- در مورد هستههای نرمافزاری و سخت افزاری تحقیق کنید و کاربرد آنها را شرح دهید و چند نمونه به عنوان مثال نام ببرید. در مورد DDS و کاربردهای آن با مطالعه ی دیتاشیت آن (مربوط به شرکت زایلینکس) توضیح دهید. سعی کنید ارتباط بخشهای مختلف این تمرین با DDS را توضیح دهید.

۴- در این تمرین با استفاده از شیفت رجیستر، یک Sequence Detector را پیادهسازی خواهید کرد.

فرض کنید در یک رشته بیت ورودی میخواهیم وجود ۱۰۱۱۱۰۱۰۰۰ را تشخیص دهیم. ماژولی بنویسید که در هر کلاک یک بیت ورودی دریافت کند و اگر رشته بیت مذکور مشاهده شد، خروجی به مدت یک کلاک، ۱ شود و در غیر این صورت صفر بماند.

 $\Delta - یک واحد ALU با دو ورودی ۴ بیتی و یک خروجی ۸ بیتی طراحی کنید که ۴ عمل جمع، ضرب، تفریق و تقسیم را انجام دهد. این واحد باید قابلیت پیاده سازی داشته باشد و طبیعتاً نمی توانید از عملگر تقسیم استفاده کنید. یک ورودی دو بیتی نیز برای کنترل در نظر بگیرید و با نوشتن تست بنچ این واحد را تست کنید. اطلاعات فیکس پوینت خروجی در هر ۴ عمل را مشحص کنید. فرض کنید ورودی ها اعداد صحیح هستند. ماکزیمم رزولوشن عمل تقسیم را چقدر است؟ راهنمایی : این رزولوشن بستگی به نحوه ی برخورد شما با تقسیم دارد.$ 

۶- در این سؤال با ساختار DSP48های موجود در تراشههای شرکت زایلینکس آشنا میشوید.

الف- ساختار كلى DSP48هاى شركت زايلينكس را مطالعه كنيد و با بيان ساختار كلى، آن را شرح دهيد.

yب یک ضرب کننده مختلط با ورودیهای ۱۸ بیتی و خروجیهای به طول مناسب طراحی کنید. ساختار پیادهسازی شده را سنتز کنید و تعداد DSPهای استفاده شده را گزارش کنید. ساختار داده شده باید دارای پایپ-لاین در مکانهای مورد نیاز باشد و تعداد DSPهای استفاده شده کمینه باشد. تعداد DSPهای موردنظر را با مقایسه با کد و قسمت الف توجیه کنید.

ج- حال یک ورودی را ۱۹ بیتی در نظر بگیرید و پس از سنتز تغییر در تعداد DSPهای گزارش شده را با توجه به قسمت الف توجیه کنید.

د- ساختار ب را شبیه سازی کنید و صحت عملکرد آن را بررسی کنید.

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

۷- یک شیفت رجیستر طراحی کنید که با استفاده از یک سیگنال کنترلی، شیفت به راست، شیفت به چپ، لچ یا مقدار ورودی را load کند. برای مطالعه ی نحوه عملکرد این شیفت رجیستر می توانید به ICهای با عملکرد یکسان مراجعه کنید. سپس این شیفت رجیستر را شبیه سازی کنید و صحت عملکرد آن را بررسی نمایید.

۸- در این سؤال با CRC آشنا میشوید و یک فرستنده و گیرندهی ساده را شبیهسازی میکنید.

الف- در مورد کاربرد CRC در شبکه تحقیق کنید و کاربردهای آن را شرح دهید.

ب- یک فرستنده طراحی کنید که با یک سیگنال کنترلی start ورودی ۸ بیتی دلخواه را دریافت، CRC-8 مربوطه را تولید می کند و در نهایت یک عدد ۱۶ بیتی ارسال می شود. این فرستنده را شبیه سازی کنید و صحت عملکرد آن را مطمئن شوید.

ج- یک گیرنده طراحی کنید که با سیگنال کنترلی valid، عدد ۱۶ بیتی را دریافت می کند و بررسی می کند که مقدار CRC درست محاسبه شده بود، عدد ۸ موردنظر روی خروجی قرار می گیرد و در غیر این صورت ورودی دور ریخته می شود. توجه کنید که خروجی نیز باید با سیگنال valid متناظر به خود نمایش داده شود. با نوشتن تست بنچ، صحت عملکرد این گیرنده را مطمئن شوید.

د- فرستنده و گیرنده را به هم متصل کنید. با شبیه سازی (نوشتن تست بنج جداگانه) یک عدد ۸ بیتی دلخواه را با استفاده از فرستنده ارسال کنید و بعد از چندین کلاک آن را روی خروجی گیرنده مشاهده کنید. (چون سیستم در شرایط ایدئال و بدون نویز کار می کند، CRC قطعاً درست است ولی ماژول شما باید یک بار بتواند CRC را تولید و بار دیگر در گیرنده چک کند.

ه-(امتیازی) یک سیگنال کنترلی به عنوان ورودی به فرستنده اضافه کنید با نام noise که اگر یک بود، بعد از محاسبهی CRC، یک بیت را تغییر دهد و سپس ارسال کند. قسمت د را تکرار کنید و نتیجه را گزارش کنید.

راهنمایی: برای تولید CRC، می توانید از کدهای موجود در اینترنت استفاده کنید. در صورت استفاده از این کدهای آماده، کدها را بخوانید و سعی کنید منطق موجود در کدها را درک کنید.

۹-(امتیازی) الف- در مورد primitiveها و attributeهای موجود در زبان برنامه نویسی سختافزار تحقیق کنید و کاربردهای آنها تشریح کنید. با هم چه تفاوتی دارند؟ ب- با استفاده از attributeهای موجود در زبان برنامهنویسی، ماژول نوشته شده در سؤال ۶ قسمت ب را به گونهای تغییر دهید که در مرحله سنتز از DSP برای ضرب استفاده نشود و ضرب و جمع شما با استفاده از LUT پیادهسازی شود. سپس ماژول نهایی را سنتز کنید و با استفاده از گزارش سنتز تأثیر استفاده از attribute مذکور را بررسی کنید.

یک وبسایت کاربردی جهت آشنایی بیشتر با کاربردهای FPGA و مشاهدهی پروژههای مختلف:

https://www.fpga4fun.com

موفق باشيد