

## سوالات هوم ورک سوّم درس سیستم های تحمل پذیر اشکال

## نام مدرس: جناب آقای دکتر حسینی منزه دستیار آموزشی مرتبط: اثنی عشری

مهلت تحویل (بدون کسر نمره): 1 آبان ساعت ۹:۰۹،۰۹

با سلام و وقت بخير

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

- ۱- فرض کنید ۱۰۰ دانشجو داریم که هر کدام ۱۵ درس دارند و نمرات ایشان در سه فایل متنی با هدف افزایش قابلیت اطمینان ذخیر ه شده است. یک برنامه داریم که نمرات این دانشجویان را از این سه فایل میخواند (رأی گیری می کند) و معدل آن ها را حساب کرده و سپس بر اساس معدل، دانشجویان را مرتب می کند. میخواهیم برنامه نیز کاملاً به شکل TMR عمل کند. یعنی هر نوع محاسبه باید سه بار انجام شده و رأی گیری گردد. برای اینکه محاسبات سه گانه سرعت اجرای نرم افزار را کم نکند از Narrow Value بودن داده ها استفاده می کنیم. به این معنی که هر نمره فقط ۵ بیت را اشغال می کند و بنابراین در یک ثبات ۳۲ بیتی از یک کامپیوتر می توان به راحتی سه کپی از هرنمره را در کنار هم ذخیره نمود و آنها را به صورت موازی مورد پردازش قرار داد. حتی وقتی نمره جمع زده شود ۹ بیت برای مجموع کافی است و باز هم می توان سه کپی از مجموع نمرات در یک ثبات ۳۲ بیتی داشت. قطعه کد ۲ مربوط به این برنامه را بنو یسید.
- ۲- برای یک برنامه دلخواه که بر روی یک برد Arduino اجرا می شود مکانیسم کشف خطا Watchdog Timer را پیاده سازی کنید. نشان دهید
  که چگونه ایجاد یک خطای عمدی موجب فعال شدن مکانیسم کشف خطا می شود.
- $^{-}$  یک روش تحمل پذیری اشکال به این شکل عمل می کند که در ابتدای کار با N واحد که همه آنها روشن و فعال هستند کار را شروع می کند و طبعاً بافرض اینکه همه در ابتدای کار سالم هستند خروجی همه مشابه خواهد بود و خروجی کل سامانه نیز برابر با حاصل همین اجماع است. در ادامه کار به محض اینکه یکی از واحدها، خروجی متفاوت با خروجی جمع ارائه نماید خاموش می شود و از جمع کنار می رود که به این ترتیب تعداد واحدها به N-1 کاهش می یابد. این روند آنقدر ادامه می یابد تا در نهایت دو سامانه باقی بماند که در آن حالت با خرابی یک واحد دیگر کل سامانه خراب محسوب می شود. این روش را می توان بر هر پیمانه سخت افزاری اعمال نمود. فرض کنید توصیف زبان Verilog یک جمع کننده N بیتی را داریم. با فرض اینکه N باشد کد N باشد کد N باشد که به همین شکل جمع کننده مذکور را تحمل پذیر اشکال نموده است. در N اصامانه شما در مقابل آن اشکال عمل می کند.

لطفا نكات تكميلي تمارين را ملاحظه و رعايت فرماييد.

موفق باشيد.