



# مبدل آنالوگ به دیجیتال

در میکروکنترل های AVR

## فهرست مطالب

---

مطالبی که در این فصل با آنها آشنا خواهیم شد:  
• مبدل آنالوگ به دیجیتال

# مبدل آنالوگ به رقمنی

- مبدل آنالوگ به رقمنی به منظور تبدیل یک سیگنال آنالوگ به معادل رقمنی آن بکار می‌رود.
- مشخصات
- دقت ۱۰ بیتی در تبدیل سیگنال از آنالوگ به رقمنی
- غیرخطی بودن به میزان ۵.۰ بیت LSB
- زمان تبدیل ۶۵ الی ۲۶۰ میکروثانیه
- حداکثر سرعت نمونهبرداری ۱۵ کیلو نمونه در ثانیه
- هشت کanal ورودی تکانتها (غیرتفاضلی) تسهیم شده

# مبدل آنالوگ به رقمنی

## مشخصات (ادامه)

- هفت کanal ورودی تفاضلی
- دو کanal ورودی تفاضلی با بهره قابل انتخاب  $10x$  و  $200x$
- امکان از چپ خواندن بیت‌های نتیجه تبدیل
- قابلیت تغییر محدوده ولتاژ ورودی به ADC از  $0$  تا ولتاژ  $V_{CC}$
- دارای ولتاژ مرجع قابل انتخاب  $2.56$  ولتی
- دارای حالت تک تبدیل و حالت تبدیل free running
- آغاز تبدیل ADC با تحریک خودکار ناشی از منابع وقفه
- رخداد وقفه بعد از کامل شدن هر تبدیل ADC
- حذف کننده نویز در حالت خواب

# مبدل آنالوگ به رقمنی

- میکروکنترلر ATmega16 از روش تقریب‌های متوالی در ۱۰ بیت برای انجام عملیات ADC استفاده می‌کند.
- مبدل ADC به یک تسهیم‌کننده آنالوگ ۸ کاناله متصل می‌باشد که امکان دریافت یکی از ۸ ورودی تک‌انتهای متصل به یکی از پایه‌های درگاه A را فراهم می‌سازد. ولتاژ این ورودی‌ها نسبت به ولتاژ مرجع زمین (GND) سنجیده می‌شوند.

# مبدل آنالوگ به رقمنی

- این مبدل می‌تواند ۱۶ ترکیب ورودی با ولتاژ تفاضلی را بپذیرد. هر دو ورودی با هم به عنوان یک سیگنال تفاضلی به ADC داده می‌شود.
- دو عدد از این ورودی‌های تفاضلی شامل (ADC0 با ADC1) و (ADC2 با ADC3) به یک تقویت‌کننده با بهره قابل برنامه‌ریزی مجهز شده‌اند که ولتاژ تفاضلی ورودی را پیش از تبدیل از آنالوگ به رقمنی به میزان ۰ دسیبل (1x)، ۲۰ دسیبل (20x) و ۴۶ دسیبل (200x) تقویت می‌کند.
- هفت کanal ورودی آنالوگ از یک ترمینال منفی مشترک (ADC1) استفاده می‌کند، در حالی که هر ورودی ADC دیگر می‌تواند به عنوان ترمینال ورودی مثبت در نظر گرفته شود. اگر از بهره 1x یا 10x استفاده شود، ADC دارای دقت ۸ بیت و در صورت استفاده از بهره 200x، دارای دقت ۷ بیت می‌باشد.

## مبدل آنالوگ به رقمنی

- مبدل ADC دارای یک مدار نمونهبردار و نگهدارنده می‌باشد که تضمین می‌کند ولتاژ ADC در حین تبدیل در یک سطح ثابت نگه داشته شود.
- مبدل ADC یک پایه جداگانه برای تغذیه آنالوگ دارد که AVCC نام دارد. پایه AVCC نباید اختلاف ولتاژ بیشتر از  $3.0 \pm 0.3$  ولت با  $V_{CC}$  داشته باشد.
- یک منبع ولتاژ مرجع داخلی با ولتاژ نامی ۲.۵۶ ولت در درون خود تراشه فراهم شده است. ولتاژ اعمالی به پایه AVCC نیز می‌تواند در درون میکروکنترلر به عنوان ولتاژ مرجع استفاده شود.
- قرار دادن یک خازن در پایه AREF (که عملاً موازی با ولتاژ مرجع قرار می‌گیرد) موجب بهبود کارایی مبدل ADC از نقطه نظر کاهش نویز می‌گردد.

# نمودار بلوکی کلی مبدل آنالوگ به رقی

## انتخاب کانال ورودی و انتخاب بهره



# عملکرد مبدل آنالوگ به رقمی

- مبدل ADC، ولتاژ ورودی آنالوگ را با تقریب‌های متوالی به یک عدد ۱۰ بیتی رقمی تبدیل می‌کند.
- کمترین مقدار نتیجه تبدیل، نشان‌دهنده GND و بیشترین مقدار، نشان‌دهنده ولتاژ پایه AREF منهای ۱ بیت کم‌ارزش است.
- هریک از ولتاژ‌های AVCC و یا ولتاژ مرجع ۲.۵۶ ولت می‌توانند با تغییر بیت ADMUX در ثبات REFSn به پایه AREF اعمال شوند.
- با قرار دادن یک خازن در پایه AREF، می‌توان مصونیت نسبت به نویز را افزایش داد.

## عملکرد مبدل آنالوگ به رقی

- انتخاب کanal ورودی آنالوگ و انتخاب میزان بهره تفاضلی با نوشتن مقادیر مناسب در بیت‌های MUX در ثبات ADMUX انجام می‌شود.
- هر یک از پایه‌های ورودی ADC، GND و یک ولتاژ مرجع Bandgap ثابت، می‌توانند به عنوان ورودی تک‌انتهای به ADC انتخاب شوند.
- هر یک از پایه‌های ورودی ADC می‌توانند به عنوان ورودی‌های مثبت و منفی به تقویت کننده بهره تقاضلی انتخاب شوند.
- چنانچه کanal‌های تفاضلی انتخاب شوند، طبقه بهره تفاضلی تفاضل ولتاژ بین زوج ورودی‌های انتخاب شده را با توجه به فاکتور بهره انتخاب شده تقویت می‌نماید و آنگاه ولتاژ تقویت شده به مبدل ADC داده می‌شود.
- در صورت استفاده از کanal‌های تک‌انتهای، ولتاژ ورودی ADC تقویت نمی‌شود.

# عملکرد مبدل آنالوگ به رقمی

- با یک کردن بیت ADEN در ثبات ADCSRA، مبدل ADC فعال می‌شود و بدین ترتیب امکان استفاده از ولتاژ مرجع و کanal ورودی انتخاب شده فراهم می‌شود.
- هنگامی که ADEN صفر است، مبدل توان الکتریکی مصرف نمی‌کند. بنابراین بهتر است که قبل از استفاده از حالت‌های صرفه‌جویی توان، مبدل را خاموش کرد.
- مبدل ADC بعد از تبدیل یک نمونه از آنالوگ به فرم رقمی، یک مقدار ۱۰ بیتی تولید می‌کند که در ثبات‌های داده ADCL و ADCH یعنی ADC ذخیره می‌شود.
- بطور پیش‌فرض، داده به صورت راستچین ظاهر می‌شود ولی با تغییر بیت ADMUX در ثبات می‌توان آنرا به صورت چپ‌چین در آورد.

# عملکرد مبدل آنالوگ به رقمی

- اگر نتیجه به صورت چپ چین باشد و دقت بیشتر از ۸ بیت مورد نیاز نباشد، کافی است که تنها ADCH خوانده شود.
- در غیر این صورت برای اطمینان از این که محتوای ثبات داده مربوط به همان تبدیل است، ابتدا باید ADCL و سپس ADCH را خواند. به محض خواندن ADCL، دسترسی ADC به ثبات داده قطع می‌شود.
- این بدین معناست که اگر ADCL خوانده شود و قبل از خواندن ADCH یک تبدیل جدید کامل شود، نتیجه تبدیل جدید در ثبات داده گذاشته نمی‌شود و از دست می‌رود.
- با خواندن ADCH، دسترسی مجدد ADC به هر دو ثبات ADCL و ADCH برقرار می‌شود.

## عملکرد مبدل آنالوگ به رقمی

- مبدل ADC وقفه مخصوص به خود را دارد و هر بار که یک تبدیل کامل می‌شود، این وقفه تحریک می‌شود.
- در حین خواندن داده‌های ناشی از تبدیل قبلی از ثبات‌های ADCL و ADCH، حتی اگر داده حاصل از تبدیل جدید از دست برود، وقفه ناشی از تبدیل جدید تحریک خواهد شد.

## شروع یک تبدیل

- با نوشتن مقدار **1** در بیت شروع تبدیل (بیت ADSC)، یک تک تبدیل (تبدیل واحد) آغاز می‌شود.
- این بیت در تمام مدتی که تبدیل در حال انجام است، یک باقی می‌ماند و با تمام شدن تبدیل، توسط سخت افزار صفر می‌شود.
- اگر در حال انجام تبدیل، یک کانال دیگر انتخاب شود، ADC عمل تبدیل جاری را قبل از تعویض کانال به پایان می‌رساند.

**single convert**

# شروع یک تبدیل

- منابع مختلفی می‌توانند موجب تحریک یک تبدیل شوند.

با یک کردن بیت فعال‌ساز تحریک ADCSRA در ثبات ADATE، تحریک خودکار فعال می‌شود. منبع تحریک با تنظیم بیت‌های ADTS2:0 در ثبات SFIOR انتخاب می‌شود.

## انتخاب منبع تحریک خودکار ADC

- با رخ دادن یک لبه مثبت روی سیگنال تحریک انتخاب شده، پیش مقیاس‌گذار مبدل ADC بازنشانی شده و یک تبدیل آغاز می‌شود.

این روش موجب می‌شود که تبدیل در بازه‌هایی با فواصل زمانی مساوی انجام شود. اگر با کامل شدن تبدیل، همچنان سیگنال تحریک یک باشد، تبدیل جدید صورت نمی‌گیرد.

## شروع یک تبدیل

- اگر در حین تبدیل، یک لبه مثبت دیگر روی سیگنال تحریک رخ دهد، این لبه نادیده گرفته خواهد شد.
- توجه داشته باشید که پرچم وقفه حتی اگر آن وقفه غیرفعال باشد و یا بیت فعالسازی وقفه‌ها در ثبات SREG صفر شده باشد، یک می‌شود.
- لیکن برای تحریک یک تبدیل جدید در رخداد وقفه بعدی، پرچم وقفه باید صفر شود.

# واحد تحریک خودکار ADC



پیش مقیاس گذار و زمانبندی تبدیل  
فاکتور تقسیم بین فرکانس XTAL و ساعت ورودی ADC  
انتخاب منبع تحریک خودکار ADC

# شروع یک تبدیل

- استفاده از پرچم وقفه ADC یعنی ADIF به عنوان یک منبع تحریک موجب می‌شود که به محض آنکه تبدیل جاری تمام شد یک تبدیل جدید شروع شود.
- مبدل ADC سپس در حالت free running کار می‌کند و بطور ممتد عمل نمونه‌برداری را انجام و ثبات داده را به روز می‌نماید.
- اولین تبدیل باید با نوشتن یک منطقی در بیت ADSC از ثبات ADCSRA شروع می‌شود. در این مود، مبدل ADC تبدیل‌های متوالی را مستقل از اینکه پرچم وقفه یعنی ADIF صفر باشد یا خیر انجام می‌دهد.

## شروع یک تبدیل

اگر حالت تحریک خودکار فعال شود، تبدیل‌های تکی می‌تواند با یک کردن بیت ADSC در ثبات ADCSRA شروع شود.

ADSC همچنین می‌تواند برای تعیین اینکه یک تبدیل در حال پیشرفت است یا خیر استفاده شود.

بیت ADSC در طی یک تبدیل، مستقل از اینکه تبدیل چگونه آغاز شده است، یک خوانده می‌شود.

# پیش مقیاس گذار و زمانبندی تبدیل



پیش مقیاس گذار مبدل ADC  
بازگشت

## پیش مقیاس گذار و زمانبندی تبدیل

- بطور پیش فرض مدار تقریب متوالی برای انجام عمل تبدیل سیگنال آنالوگ به رقمی، یک فرکانس ساعت بین  $5\text{ کیلوهرتز}$  و  $200\text{ کیلوهرتز}$  برای دستیابی به دقت بالا در تبدیل نیاز دارد.
- اگر یک دقت کمتر از  $10$  بیت لازم باشد، فرکانس ساعت ورودی به مبدل ADC می‌تواند برای دستیابی به یک نرخ نمونه‌برداری بالاتر، بیشتر از  $200\text{ کیلوهرتز}$  نیز باشد.

# پیش مقیاس‌گذار و زمانبندی تبدیل

- مازول ADC شامل یک پیش مقیاس‌گذار می‌باشد که هر فرکانس CPU بالاتر از ۱۰۰ کیلوهرتز را به یک فرکانس ساعت قابل قبول برای خود تبدیل می‌کند.
- پیش مقیاس‌گذار توسط بیت‌های **ADCSRA** در ثبات **ADPS** تنظیم می‌شود. از لحظه‌ای که با یک کردن بیت **ADEN** در **ADCSRA** مبدل ADC روشن می‌شود، پیش مقیاس‌گذار شروع به شمارش می‌کند.
- پیش مقیاس‌گذار تا زمانی که بیت **ADEN** یک شود به کار خود ادامه می‌دهد و هنگامی که **ADEN** صفر است در حالت بازنشانی باقی می‌ماند.

## پیش مقیاس گذار و زمانبندی تبدیل

- هنگامی که با یک کردن بیت ADSC در ADCSRA، تبدیل یک سیگنال تکانتها پایه گذاری می شود، در لبه بالارونده بعدی سیکل ساعت ADC، تبدیل آغاز می شود.  
یک تبدیل عادی ۱۳ پالس ساعت ADC بطول می انجامد.
- اولین تبدیل بعد از روشن شدن ADC (با یک شدن بیت ADEN در ADCSRA)، به ۲۵ سیکل ساعت ADC برای آماده سازی مدار آنالوگ درون مازول ADC نیاز دارد.

## پیش مقیاس گذار و زمانبندی تبدیل

- نمونه بردار و نگهدار عملاً به ۱.۵ سیکل ساعت بعد از شروع یک تبدیل عادی و ۱۳.۵ سیکل ساعت بعد از شروع اولین تبدیل نیاز دارد.
- هنگامی که یک تبدیل کامل می‌شود، نتیجه در ثبات‌های داده ADC نوشته می‌شود و بیت ADIF یک می‌شود.
- در حالت تک‌تبدیل، ADSC بطور همزمان صفر می‌شود. نرم‌افزار ممکن است سپس ADSC را یک کند. با اینکار یک تبدیل جدید بر روی اولین لبه بالارونده ساعت ADC پایه‌گذاری می‌شود.

## پیش مقیاس گذار و زمانبندی تبدیل

- هنگامی که تحریکسازی خودکار مدنظر باشد، پیش مقیاس گذار هنگامی که رویداد تحریک رخ می‌دهد، بازنشانی می‌شود. این کار یک تاخیر ثابت (از لحظه رویداد تحریک تا لحظه شروع تبدیل) را تضمین می‌کند.
- در این مود، نمونه‌برداری و نگهداری به تعداد ۲ سیکل ساعت بعد از لبه بالارونده سیگنال منبع تحریک انجام می‌شود. سه سیکل ساعت CPU اضافی برای فرآیند همگام‌سازی استفاده می‌شود.

## پیش مقیاس گذار و زمانبندی تبدیل

- هنگامی که از حالت تفاضلی استفاده شود، در زمان تحریک شدن خودکار توسط عاملی غیر از کامل شدن تبدیل ADC، هر تبدیل به ۲۵ پالس ساعت نیاز دارد.
- این بدان دلیل است که ADC باید غیر فعال شود و بعد از هر تبدیل مجدداً فعال شود. در حالت free running، در صورت یک بودن ADSC، یک تبدیل جدید بلافاصله بعد از کامل شدن تبدیل شروع می‌شود.

# نمودار زمانبندی ADC، اولین تبدیل (مود تکتبدیل)



# نمودار زمانبندی ADC، تک تبدیل



# نمودار زمانبندی ADC، تبدیل با تحریک خودکار



# نمودار زمانبندی ADC، تبدیل free running



| <b>Condition</b>                 | <b>Sample &amp; Hold<br/>(Cycles from Start of<br/>Conversion)</b> | <b>Conversion<br/>Time (Cycles)</b> |
|----------------------------------|--------------------------------------------------------------------|-------------------------------------|
| First conversion                 | 13.5                                                               | 25                                  |
| Normal conversions, single ended | 1.5                                                                | 13                                  |
| Auto Triggered conversions       | 2                                                                  | 13.5                                |
| Normal conversions, differential | 1.5/2.5                                                            | 13/14                               |

## کانال‌های بهره تفاضلی

- هنگامی که کانال‌های بهره تفاضلی استفاده شوند، بعضی جنبه‌های تبدیل باید مورد توجه قرار گیرند. تبدیل‌های تفاضلی با ساعت داخلی  $CK_{ADC2}$  که نصف ساعت است همگام می‌شوند.
- این همگام سازی بطور خودکار توسط واسط ADC بطریقی که عمل نمونه‌برداری و نگهداری در یک فاز خاص از  $CK_{ADC2}$  رخ دهد انجام می‌شود.

## تغییر کانال‌ها یا انتخاب ولتاژ مرجع

- بیت‌های MUXn و REFS1:0 در ثبات ADMUX از طریق یک ثبات موقتی که CPU بدان دسترسی دارد بافر شده‌اند.
- این تضمین می‌کند که انتخاب کانال‌ها و انتخاب ولتاژ مرجع در زمان مناسبی انجام شود و انتخاب کانال و ولتاژ مرجع بتواند تا شروع یک تبدیل دائماً تغییر کند.
- هنگامی که تبدیل شروع شود، انتخاب کانال و ولتاژ مرجع قفل می‌شود تا فراهم بودن یک زمان نمونه‌برداری کافی برای ADC تضمین شود.
- به روز رسانی می‌تواند در آخرین سیکل ساعت ADC قبل از کامل شدن تبدیل (سیت شدن بیت ADIF در ADCSRA) از سر گرفته می‌شود.

## تغییر کانال‌ها یا انتخاب ولتاژ مرجع

- اگر حالت تحریک خودکار استفاده شود، زمان دقیق رویداد تحریک برای کاربر معلوم نیست.
- به منظور کنترل اینکه چه تبدیلی توسط تنظیمات جدید متاثر خواهد شد توجه مخصوص باشد هنگام به روز رسانی ثبات ADMUX صورت گیرد.
- اگر در هر دوی ADATE و ADEN مقدار یک نوشته شود، یک رویداد وقفه در هر زمان می‌تواند رخ دهد.
- باشید که بعد از نوشتن در ADSC، تبدیل در لبه بالارونده بعدی ساعت ADC، شروع می‌شود.
- بنابران به کاربر توصیه می‌شود که تا یک سیکل ساعت بعد از نوشتن در ADSC، مقادیر جدید انتخاب کانال یا ولتاژ مرجع، در ADMUX نوشته نشوند.

## تغییر کانال‌ها یا انتخاب ولتاژ مرجع

- بر اساس تنظیمات قبلی انجام شده یا تنظیمات جدید، ثبات ADMUX می‌تواند بطور مطمئنی در شرایط زیر به روز رسانی شود:
  - هنگامی که ADEN یا ADATE صفر شود.
  - در طی تبدیل، حداقل یک سیکل ساعت ADC بعد از رویداد تحریک
  - بعد از یک تبدیل، قبل از اینکه پرچم وقفه‌ای که به عنوان منبع تحریک بکار رفته صفر شود

## تغییر کانال‌ها یا انتخاب ولتاژ مرجع

- هنگام به روز رسانی ADMUX در یکی از شرایط فوق، تنظیمات جدید، تبدیل ADC بعدی را متأثر می‌کنند. موازنی ویژه‌ای باید هنگام تعویض کانال‌های تفاضلی صورت گیرد.
- هنگامی که یک کانال تفاضلی انتخاب شود، طبقه بهره ممکن است به زمانی به میزان ۱۲۵ میکروثانیه برای ثبیت یک مقدار جدید فرصت نیاز داشته باشد.
- بنابراین تبدیل‌ها نباید در فاصله ۱۲۵ میکروثانیه اول بعد از انتخاب یک کانال تفاضلی جدید شروع شوند. بعلاوه نتایج تبدیل بدست آمده در این فاصله زمانی باید دور انداخته شود.
- همین زمان تنظیم باید بعد از تبدیل ولتاژ مرجع ADC (با تغییر بیت‌های REFS1:0 در ثبات ADMUX) برای اولین تبدیل تفاضلی در نظر گرفته شود.

# کانال‌های ورودی ADC

- هنگام تغییر کانال‌ها، کاربر باید نکات راهنمای زیر را برای اطمینان از انتخاب کانال صحیح بکار برد:
- در حالت تک‌تبدیل، همیشه کانال را قبل از شروع تبدیل انتخاب کنید. انتخاب کانال می‌تواند یک سیکل ساعت قبل از نوشتن در ADSC انجام شود. اما ساده‌ترین کار آن است که قبل از انتخاب کانال صبر کنیم تا تبدیل تمام شود.
- در حالت free running، همیشه قبل از شروع تبدیل کانال را انتخاب کنید. انتخاب کانال ممکن است یک سیکل ساعت بعد از نوشتن مقدار 1 در بیت ADSC انجام شود. اما ساده‌ترین کار آن است که صبر کنیم تا اولین تبدیل تمام شود و سپس انتخاب کانال را عوض کنیم. از آنجا که تبدیل بعدی قبل از خودکار شروع شده است، نتیجه بعدی، انتخاب قبلی کانال را منعکس می‌کند و تبدیل‌های بعدی، انتخاب جدید کانال را منعکس خواهند کرد.
- هنگام سوئیچ کردن به یک کانال بهره متفاوت، نتیجه اولین تبدیل ممکن است به دلیل زمان لازم برای تنظیم مدار حذف خودکار افست، دقیق کمی داشته باشد. لذا بهتر است که کاربر اولین تبدیل را دور بیندازد.

# منبع ولتاژ مرجع ADC

- ولتاژ مرجع برای ADC ( $V_{REF}$ ), محدوده تبدیل را برای ADC مشخص می‌کند.
- سیگنال ورودی به کانال‌های تک‌انتهایی از  $V_{REF}$  بیشتر شوند منجر به نتیجه تبدیل نزدیک به 0x3FF می‌شود. ولتاژ مرجع  $V_{REF}$  می‌تواند با انتخاب AVCC، ولتاژ مرجع 2.56V یا توسط پایه خارجی AREF مشخص شود.
- AVCC از طریق یک سوئیچ پسیو به ADC متصل شده است. ولتاژ 2.56V داخلی توسط یک ولتاژ مرجع bandgap ( $V_{BG}$ ) و به کمک یک تقویت کننده داخلی تولید می‌شود.
- در هر صورت، پایه AREF خارجی مستقیماً به ADC متصل است و ولتاژ مرجع می‌تواند با اتصال یک خازن بین پایه AREF و زمین نسبت به نویز مصون‌تر شود.
- توجه داشته باشید که یک منبع امپدانس بالاست و در یک سیستم، تنها یک بار خازنی باید بدان متصل شود.

# منبع ولتاژ مرجع ADC

- اگر کاربر یک منبع ولتاژ با ولتاژ ثابت معین که به پایه AREF متصل شده است را در اختیار داشته باشد، بهتر است که او از سایر انتخاب‌ها به عنوان ولتاژ مرجع در یک کاربرد استفاده ننماید، چرا که در اینصورت منابع ولتاژ مرجع داخلی به ولتاژ مرجع خارجی متصل شده و باعث بروز مشکلاتی خواهد شد.
- اگر هیچ ولتاژ خارجی به پایه AREF متصل نشود، کاربر ممکن است که یکی از دو ولتاژ مرجع 2.56 ولت یا AVCC را به عنوان منبع ولتاژ مرجع انتخاب نماید.
- اولین نتیجه تبدیل ADC بعد از انتخاب منبع ولتاژ مرجع معتبر نخواهد بود و به کاربر توصیه می‌شود آنرا استفاده ننماید.

# حذف کننده نویز ADC

- مبدل ADC دارای یک حذف کننده نویز است که موجب کاهش نویز القاء شده توسط هسته CPU و سایر ماظولهای موجود در میکروکنترلر در حین تبدیل در طی حالت خواب می‌شود. حذف کننده نویز می‌تواند همراه با حالت خواب کاهش نویز ADC و حالت بیکار استفاده شود.
- اطمینان حاصل کنید که ADC فعال است و مشغول عمل تبدیل نیست. حالت تک تبدیل را انتخاب و صبر کنید تا وقفه کامل شدن تبدیل فعال شود.
- وارد حالت کاهش نویز ADC شوید (یا حالت بیکار). مبدل ADC هر بار که CPU به حالت ایست می‌رود یک تبدیل را شروع می‌کند.

# حذف کنند نویز ADC

- اگر هیچ نوع وقفه دیگری قبل از کامل شدن تبدیل ADC رخ ندهد، وقفه ADC موجب بیدار شدن CPU شده و روتین وقفه کامل شدن تبدیل ADC را اجرا می‌کند.
- اگر وقفه دیگری CPU را قبل از کامل شدن تبدیل بیدار نماید، آن وقفه اجرا خواهد شد و یک تقاضای وقفه کامل شدن تبدیل هنگامی که تبدیل کامل شود تولید خواهد شد.
- CPU تا زمان اجرای یک دستور خواب جدید در حالت فعال باقی می‌ماند.

# حذف کنند نویز ADC

- اگر ADC در یکی از حالت‌های خواب غیر از حالت بیکار و حالت کاهش نویز ADC فعال باشد، بطور خودکار خاموش نخواهد شد.
- به کاربر توصیه می‌شود که بیت ADEN قبل از ورود به اینگونه حالت‌ها صفر شود تا بدین طریق از مصرف توان اضافی اجتناب شود.
- اگر ADC در اینگونه حالت‌های خواب شود و کاربر بخواهد تبدیل روی ورودی‌های تقاضلی صورت دهد، به کاربر توصیه می‌شود که برای دریافت یک نتیجه تبدیل توسعه یافته معتبر، ADC را بعد از بیدار شدن از خواب، خاموش و سپس روشن کند.

# روش‌های حذف نویز آنالوگ

- چنانچه دقت تبدیل از آنالوگ به رقمی مهم باشد، سطح نویز با استفاده از روش‌های زیر می‌تواند کاهش یابد.
  - مسیرهای سیگنال آنالوگ را حتی‌امکان کوتاه انتخاب کنید و آنها را از مسیرهای عبور سیگنال‌های رقمی با سرعت تغییرات بالا دور نگه دارید.
  - پایه AVCC را از طریق یک مدار LC به تغذیه VCC متصل کنید.
  - از قابلیت کاهش نویز ADC برای کاهش نویز القاء شده توسط CPU استفاده کنید.
  - چنانچه هر یک از پایه‌های درگاه ADC به عنوان خروجی رقمی استفاده شده باشد، ضروری است که آن پایه در طی عمل تبدیل توسط ADC، تغییر نکند.

# اتصالات تغذیه ADC



# نتیجه تبدیل ADC

- بعد از کامل شدن تبدیل (بیت ADIF یک است)، نتیجه تبدیل را باید در ثبات‌های ADCH و ADCL یافت. برای یک تبدیل روی ورودهای تک‌انتهای، نتیجه تبدیل بصورت زیر است:

$$ADC = \frac{V_{IN} \cdot 1024}{V_{REF}}$$

- که  $V_{IN}$  ولتاژ روی پایه ورودی انتخاب شده و  $V_{REF}$  ولتاژ مرجع انتخاب شده است. خروجی 0x000 بیانگر زمین و 0x3FF بیانگر ولتاژ مرجع انتخاب شده منهای یک بیت LSB است.

# نتیجه تبدیل ADC

- اگر از کانال‌های تفاضلی استفاده شود، نتیجه تبدیل بصورت زیر خواهد بود:

$$ADC = \frac{(V_{POS} - V_{NEG}) \cdot GAIN \cdot 512}{V_{REF}}$$

- ولتاژ  $V_{POS}$  ولتاژ روی پایه ورودی مثبت،  $V_{NEG}$  ولتاژ روی پایه ورودی منفی،  $V_{REF}$  ولتاژ مرجع انتخابی است.
- نتیجه بصورت مکمل ۲ ارائه می‌شود و مقداری خواهد بود بین ۰x200 (مقدار ۵۱۱ دهدی) تا ۰x1FF (مقدار ۵۱۱ + دهدی). توجه داشته باشید که چنانچه کاربر بخواهد از مثبت یا منفی بودن نتیجه مطلع شود کافی است که بیت MSB نتیجه (بیت ADC9 در ثبات ADCH) را بخواند. اگر این بیت ۱ بود، نتیجه منفی و گرنه مثبت است.

# محدوده اندازه‌گیری تفاضلی



# ثبات انتخاب تسهیم کننده ADC :ADMUX

| Bit           | 7     | 6     | 5     | 4    | 3    | 2    | 1    | 0    | ADMUX |
|---------------|-------|-------|-------|------|------|------|------|------|-------|
|               | REFS1 | REFS0 | ADLAR | MUX4 | MUX3 | MUX2 | MUX1 | MUX0 |       |
| ReadWrite     | R/W   | R/W   | R/W   | R/W  | R/W  | R/W  | R/W  | R/W  |       |
| Initial Value | 0     | 0     | 0     | 0    | 0    | 0    | 0    | 0    |       |

## بیت‌های ۶ الی ۷ یا **REFS1:0**: بیت‌های انتخاب ولتاژ مرجع

- این بیت‌ها منبع ولتاژ مرجع را برای ADC تعیین می‌کنند. اگر این بیت‌ها در طول تبدیل تغییر کنند، این تغییر تا پایان کامل شدن تبدیل اثری نخواهد گذاشت (بیت ADCSRA در ثبات ADIF یک شده است).
- گزینه انتخاب منبع ولتاژ مرجع داخلی در حالتی که ولتاژ مرجع خارجی به پایه AREF وصل شده باشد، امکان پذیر نیست.
- چنانچه یک ولتاژ مرجع به پایه AREF متصل باشد، انتخاب‌های ولتاژ مرجع داخلی صورت نمی‌گیرد.

# انتخاب ولتاژ مرجع برای مبدل ADC

بازگشت

| REFS1 | REFS0 | انتخاب ولتاژ مرجع                                        |
|-------|-------|----------------------------------------------------------|
| 0     | 0     | AREF، ولتاژ مرجع داخلی خاموش                             |
| 0     | 1     | AVCC با خازن خارجی بر روی پایه AREF                      |
| 1     | 0     | رزو شده                                                  |
| 1     | 1     | ولتاژ مرجع ۲.۵۶ ولت داخلی با خازن خارجی بر روی پایه AREF |

## بیت ۵ یا بیت ADLAR: نتیجه تنظیم به چپ ADC

- بیت ADLAR شیوه نمایش نتیجه تبدیل ADC در ثبات داده ADC را تعیین می کند.
- نوشتن مقدار یک در ADLAR موجب چپ چین شدن نتیجه می شود. در غیراین صورت، نتیجه راست چین خواهد بود.
- تغییر دادن بیت ADLAR، صرفنظر از تبدیل در حال انجام، بلا فاصله بر روی ثبات های داده ADC تاثیر می گذارد.

# بیت‌های ۰ الی ۴ یا بیت‌های انتخاب کانال آنالوگ و انتخاب بهره

- مقدار این بیت‌ها نشان می‌دهد که چه ترکیبی از ورودی‌های آنالوگ به پایه‌های ADC متصل شده‌اند.
- این بیت‌ها میزان بهره را برای کانال‌های تفاضلی تعیین می‌کنند
- اگر این بیت‌ها در طول یک تبدیل تغییر پیدا کنند، این تغییر تا پایان تبدیل (یک شدن بیت ADIF در ثبات ADCSRA) بی‌اثر خواهد بود.

# انتخاب کانال ورودی و انتخاب بهره

بازگشت

| MUX 4..0 | ورودی غیرتفاضلی     | ورودی تفاضلی مثبت | ورودی تفاضلی منفی | بهره |
|----------|---------------------|-------------------|-------------------|------|
| 00000    | ADC0                |                   |                   |      |
| 00001    | ADC1                |                   |                   |      |
| 00010    | ADC2                |                   |                   |      |
| 00011    | ADC3                |                   |                   |      |
| 00100    | ADC4                |                   |                   | N/A  |
| 00101    | ADC5                |                   |                   |      |
| 00110    | ADC6                |                   |                   |      |
| 00111    | ADC7                |                   |                   |      |
| 01000    |                     | ADC0              | ADC0              | 10x  |
| 01001    |                     | ADC1              | ADC0              | 10x  |
| 01010    |                     | ADC0              | ADC0              | 200x |
| 01011    |                     | ADC1              | ADC0              | 200x |
| 01100    |                     | ADC2              | ADC2              | 10x  |
| 01101    |                     | ADC3              | ADC2              | 10x  |
| 01110    |                     | ADC2              | ADC2              | 200x |
| 01111    |                     | ADC3              | ADC2              | 200x |
| 10000    |                     | ADC0              | ADC1              | 1x   |
| 10001    |                     | ADC1              | ADC1              | 1x   |
| 10010    |                     | ADC2              | ADC1              | 1x   |
| 10011    |                     | ADC3              | ADC1              | 1x   |
| 10100    |                     | ADC4              | ADC1              | 1x   |
| 10101    |                     | ADC5              | ADC1              | 1x   |
| 10110    |                     | ADC6              | ADC1              | 1x   |
| 10111    |                     | ADC7              | ADC1              | 1x   |
| 11000    |                     | ADC0              | ADC2              | 1x   |
| 11001    |                     | ADC1              | ADC2              | 1x   |
| 11010    |                     | ADC2              | ADC2              | 1x   |
| 11011    |                     | ADC3              | ADC2              | 1x   |
| 11100    |                     | ADC4              | ADC2              | 1x   |
| 11101    |                     | ADC5              | ADC2              | 1x   |
| 11110    | 1.22 V ( $V_{BG}$ ) |                   | N/A               |      |
| 11111    | 0 V (GND)           |                   |                   |      |

# ثبتات کنترل و وضعیت ADC :ADCSRA

| Bit           | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |        |
|---------------|-----|-----|-----|-----|-----|-----|-----|-----|--------|
| ReadWrite     | R/W | ADCSRA |
| Initial Value | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |        |

## بیت ۷ یا بیت **ADC**: فعال‌سازی

- با نوشتن یک در این بیت، **ADC** فعال می‌شود و با نوشتن صفر در این بیت، خاموش خواهد شد. خاموش کردن **ADC** در حالی که یک تبدیل در حال انجام باشد، باعث خاتمه یافتن آن تبدیل می‌شود.

## بیت ۶ یا بیت ADSC: بیت شروع تبدیل

- در حالت تک تبدیل، برای شروع هر تبدیل باید مقدار یک در بیت ADSC نوشته باشد.
- در حالت free Running، با نوشتن یک در این بیت، اولین تبدیل انجام خواهد شد.
- اولین تبدیل بعد از یک کردن ADSC به دنبال فعال کردن ADC (یا یک کردن ADSC)، همزمان با فعال کردن ADC، ۲۵ سیکل ساعت به جای ۱۳ سیکل ساعت معمول طول خواهد کشید.
- این تبدیل اول عملیات آماده‌سازی ADC را انجام می‌دهد. بیت ADSC تا زمانی که تبدیل در حال انجام است، یک و وقتی که تبدیل کامل شد، صفر خوانده می‌شود.
- نوشتن صفر در این بیت هیچ تاثیری ندارد.

## بیت ۵ یا بیت ADATE: فعالساز تحریک خودکار ADC

- فعالسازی حالت تحریک خودکار با یک کردن این بیت انجام می‌شود.
- مبدل ADC تبدیل را در لبه بالارونده سیگنال تحریک انتخاب شده شروع خواهد کرد.
- منبع تحریک توسط بیت‌های انتخاب تحریک ADC انتخاب می‌شود (بیت‌های ADTS در ثبات SFIOR).

## بیت ۴ یا بیت ADC: پرچم وقفه ADIF

- این بیت هنگامی که یک تبدیل به پایان می‌رسد و ثبات‌های داده بروزرسانی می‌شوند، یک می‌شود.
- وقفهٔ کامل شدن تبدیل ADC اگر بیت ADIE و همچنین بیت I در ثبات SREG یک باشند، اجرا خواهد شد.
- بیت ADIF هنگام اجرای روتین وقفهٔ مربوطهٔ توسط سخت افزار صفر خواهد شد. نوشتن یک در این پرچم نیز موجب صفر شدن آن می‌شود.
- 
- با انجام یک خواندن-تغییر-نوشتنِ محتوای ADCSRA، یا با اجرای دستورالعمل‌های SBI و CBI، یک وقفهٔ معطل می‌تواند غیر فعال شود.

## بیت‌های ۲:۰ یا بیت‌های ADPS2:0: بیت‌های انتخاب پیش مقیاس‌گذار ADC

- این بیت‌ها فاکتور تقسیم بین فرکانس XTAL و ورودی ساعت ADC را تعیین می‌کنند.

# فاکتور تقسیم بین فرکانس XTAL و ساعت ورودی ADC

## بازگشت

| ADPS2 | ADPS1 | ADPS0 | فاکتور تقسیم |
|-------|-------|-------|--------------|
| 0     | 0     | 0     | 2            |
| 0     | 0     | 1     | 2            |
| 0     | 1     | 0     | 4            |
| 0     | 1     | 1     | 8            |
| 1     | 0     | 0     | 16           |
| 1     | 0     | 1     | 32           |
| 1     | 1     | 0     | 64           |
| 1     | 1     | 1     | 128          |

# ثبات داده ADC شامل ADCL و ADCH

| Bit           | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | ADCH |
|---------------|------|------|------|------|------|------|------|------|------|
|               | -    | -    | -    | -    | -    | -    | ADC9 | ADC8 | ADCL |
|               | ADC7 | ADC6 | ADC5 | ADC4 | ADC3 | ADC2 | ADC1 | ADC0 |      |
|               | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |      |
| Read/Write    | R    | R    | R    | R    | R    | R    | R    | R    |      |
|               | R    | R    | R    | R    | R    | R    | R    | R    |      |
| Initial Value | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |
|               | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |

| Bit           | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | ADCH |
|---------------|------|------|------|------|------|------|------|------|------|
|               | ADC9 | ADC8 | ADC7 | ADC6 | ADC5 | ADC4 | ADC3 | ADC2 | ADCL |
|               | ADC1 | ADC0 | -    | -    | -    | -    | -    | -    | ADCL |
|               | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |      |
| Read/Write    | R    | R    | R    | R    | R    | R    | R    | R    |      |
|               | R    | R    | R    | R    | R    | R    | R    | R    |      |
| Initial Value | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |
|               | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      |

## ثبت داده ADCL و ADCH شامل ADC

- وقتی یک تبدیل ADC تمام می‌شود، نتیجه در دو ثبات ADCL و ADCH ذخیره می‌شود.
- اگر کانال‌های تفاضلی استفاده شده باشند، حاصل به صورت مکمل ۲ نشان داده خواهد شد. هنگامی که ADCL خوانده شود، تا خوانده شده ثبات ADCH، ثبات داده ADC تغییر نمی‌کند.
- اگر نتیجه چپ‌چین باشد و دقت بیش از ۸ بیت نیاز نباشد، کافی است فقط ثبات ADCH را بخوانیم. در غیر این صورت، ابتدا باید حتماً ثبات ADCL و سپس ثبات ADCH خوانده شود.
- بیت ADLAR در ثبات ADMUX و بیت‌های MUXn در ثبات ADMUX شیوه خوانده شدن نتیجه تبدیل از ثبات‌ها را تعیین می‌کنند. اگر بیت ADLAR یک باشد، نتیجه چپ‌چین خواهد بود و اگر ADLAR صفر باشد (که حالت پیش فرض است)، نتیجه راست چین است.
- این بیت‌ها حاصل تبدیل را نمایش می‌دهند.

## ثبتات I/O با کارکرد ویژه - ثبات SFIOR

| Bit           | 7     | 6     | 5     | 4 | 3    | 2   | 1    | 0     | SFIOR |
|---------------|-------|-------|-------|---|------|-----|------|-------|-------|
|               | ADTS2 | ADTS1 | ADTS0 | - | ACME | PUD | PSR2 | PSR10 |       |
| ReadWrite     | R/W   | R/W   | R/W   | R | R/W  | R/W | R/W  | R/W   |       |
| Initial Value | 0     | 0     | 0     | 0 | 0    | 0   | 0    | 0     |       |

## بیت‌های ۵ الی ۷ یا بیت‌های ADC: منبع تحریک خودکار

- اگر بیت ADATE در ثبات ADCSRA یک شود، مقادیر بیت‌های ADTS2:0 منبعی که تبدیل ADC را تحریک خواهد کرد را مشخص می‌کنند.
- اگر بیت ADATE صفر باشد، مقدار بیت‌های ADTS2:0 هیچ تاثیری نخواهد داشت. یک تبدیل توسط لبه بالا رونده پرچم وقفه تحریک خواهد شد.
- با سوئیچ کردن از منبع تحریکی که بیت انتخاب آن صفر می‌باشد به منبع تحریک دیگری که بیت انتخاب آن یک است، یک لبه بالا رونده ایجاد می‌شود که اگر در ADCSRA یک باشد، یک تبدیل آغاز می‌شود.
- تغییر حالت به free Running (ADTS[2:0]=0) هیچ تحریکی ایجاد نخواهد کرد، حتی اگر پرچم وقفه ADC یک باشد.

# انتخاب منبع تحریک خودکار ADC

| ADTS2 | ADTS1 | ADTS0 | Trigger Source                 |
|-------|-------|-------|--------------------------------|
| 0     | 0     | 0     | Free Running mode              |
| 0     | 0     | 1     | Analog Comparator              |
| 0     | 1     | 0     | External Interrupt Request 0   |
| 0     | 1     | 1     | Timer/Counter0 Compare Match   |
| 1     | 0     | 0     | Timer/Counter0 Overflow        |
| 1     | 0     | 1     | Timer/Counter1 Compare Match B |
| 1     | 1     | 0     | Timer/Counter1 Overflow        |
| 1     | 1     | 1     | Timer/Counter1 Capture Event   |

بازگشت  
شروع یک تبدیل

## بیت ۴ یا بیت RES: بیت رزرو شده

- این بیت برای استفاده‌های آتی رزرو شده است. برای تضمین سازگاری با دستگاه‌های آینده، این بیت باید هنگامی که چیزی در SFIOR نوشته می‌شود، صفر نوشته شود.