adc.txt 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. АЦП включается установкой бита ADEN (бит 7) в регистре управления АЦП -
  2. ADCSR (или ADCSRA)
  3. Режим непрерывных измерений активизируется установкой бита ADFR (бит 5)
  4. этого же регистра.
  5. В ряде моделей Mega (к ним относится ATmega8535) этот бит носит
  6. наименование ADATE, и управление режимом работы производится сложнее: там
  7. добавляются несколько режимов запуска через различные прерывания (в т. ч.
  8. прерывание от компаратора, при наступлении различных событий от таймера и
  9. т. п.), и выбирать их следует, задавая биты ADTS регистра SFIOR, а
  10. установка бита ADATE разрешает запуск АЦП по этим событиям. Так как нулевые
  11. значения всех битов ADTS (по умолчанию) означают режим непрерывного
  12. преобразования, то в случае, когда вы их значения не трогали, функции битов
  13. ADATE и ADFR в других моделях будут совпадать.
  14. Если выбран режим запуска не от внешнего источника, то преобразование
  15. запускается установкой бита adcs (бит 6 того же регистра adcsr/adcsra). При
  16. непрерывном режиме установка этого бита запустит первое преобразование,
  17. затем они будут автоматически повторяться. В режиме однократного
  18. преобразования, а также независимо от установленного режима при запуске
  19. через прерывания (в тех моделях, где это. возможно) установка бита adcs
  20. просто запускает одно преобразование. При наступлении прерывания,
  21. запускающего преобразование, бит adcs устанавливается аппаратно. Отметив,
  22. что преобразование начинается по фронту первого тактового импульса
  23. (тактового сигнала АЦП, а не самого контроллера!) после установки adcs.
  24. Само преобразование занимает 13 (или 14 для дифференциального входа)
  25. периодов тактового сигнала АЦП, кроме первого после включения АЦП
  26. преобразования, которое займет 25 тактов.
  27. По окончании одиночного преобразования бит adcs аппаратно сбрасывается.
  28. Кроме того, по окончании любого преобразования (и в одиночном, и в
  29. непрерывном режиме) устанавливается бит adif (бит 4, флаг прерывания).
  30. Разрешение прерывания АЦП осуществляется установкой бита adie (бит 3) все
  31. того же регистра adcsr/adcsra.
  32. Для работы с АЦП необходимо еще установить его тактовую частоту. Это
  33. делается тремя младшими битами регистра adcsr/adcsra под названием
  34. adps0..2. Коэффициент деления частоты тактового генератора МК
  35. устанавливается по степеням двойки, все нули в этих трех битах
  36. соответствуют коэффициенту 2, все единицы - 128. Напомним, что оптимальная
  37. частота преобразования лежит в диапазоне 50-200 кГц, так что, например,
  38. для тактовой частоты МК, равной 4 МГц, коэффициент может иметь значение
  39. только 32 (состояние битов adpso...2 = 101, частота 125 кГц) или 64
  40. (состояние битов adpso...2 = 110, частота 62,5 кГц). При тактовой частоте
  41. 16 МГц в допустимый диапазон укладывается только коэффициент 128.
  42. Выборка источника опорного напряжения производится битами REFS1..0 регистра
  43. ADMUX (старшие биты 7 и 6), причем их нулевое значение (по умолчанию)
  44. соответствует внешнему источнику. Напряжение этого внешнего источника может
  45. лежать в пределах от 2 В до напряжения питания аналоговой части AVCC (а
  46. оно, в свою очередь, не должно отличаться от питания цифровой части более
  47. чем на 0,3 В в большую или меньшую сторону). Можно выбрать в качестве
  48. опорного и питание самой аналоговой части, причем двояким способом: либо
  49. просто соединить выводы AREF и AVCC микросхемы, либо установить биты
  50. refs1..0 в состояние 01 (тогда соединение осуществляется внутренними
  51. схемами, но заметим, что внешний опорный источник при этом должен быть
  52. отключен). Предусмотрен и встроенный источник (задается refs1..0 в
  53. состоянии 11, при этом к выводу AREF рекомендуется подключать фильтрующий
  54. конденсатор), имеющий номинальное напряжение 2,56 В с большим разбросом от
  55. 2,4 до 2,7 В.
  56. Результат преобразования АЦП оказывается в регистрах adch:adcl. Поскольку
  57. результат 10-разрядный, то по умолчанию старшие 6 битов в регистре adch
  58. оказываются равными нулю. Чтение этих регистров производится, начиная с
  59. младшего adcl, после чего регистр adch блокируется, пока не будет прочитан.
  60. Следовательно, даже если момент между чтением регистров попал на фронт
  61. 14(15) такта АЦП, когда данные в них должны меняться, значения прочитанной
  62. пары будут соответствовать друг другу, пусть и результат этого
  63. преобразования пропадет. В противоположном порядке читать эти регистры не
  64. рекомендуется. Но бит adlar (бит 5 регистра admux) предоставляет интересную
  65. возможность: если его установить в 1, то результат преобразования в
  66. регистрах adch:adcl выравнивается влево: бит 9 результата окажется в
  67. старшем бите adch, а незначащими будут младшие 6 битов регистра adcl. В
  68. этом случае, если хватает 8-разрядного разрешения результата, можно
  69. прочесть только значение adch.
  70. Выбор каналов и режимов их взаимодействия в АЦП производится пятью битами
  71. MUX0..4 в регистре admux. В некоторых моделях (семейство Tiny) этих битов
  72. всего три (MUX0..2), а, например, в ATmega8 - четыре (MUX0..3), в
  73. зависимости от общего числа каналов, В любом случае их значения от 0 до
  74. максимального номера канала (которых в большинстве случаев 8, так что
  75. значения оказываются в пределах от 000 до 111, старшие биты, если они есть,
  76. равны 0) выбирают нужный канал в обычном (недифференциальном) режиме, когда
  77. измеряемое напряжение отсчиты- вается от "земли" (аналоговой). А последние
  78. два значения этих битов для семейства Mega (11110 и 11111 в большинстве
  79. моделей или 1110 и 1111 для ATmega8) выбирают режимы, когда вход АЦП
  80. подсоединяется к опорному источнику компаратора (1,22 В) или к "земле"
  81. соответственно, что может использоваться для автокалибровки устройства. В
  82. имеющих АЦП моделях Tiny (а также в "классическом" AT90S8535) такого режима
  83. нет.
  84. Наконец, остальные комбинации разрядов MUX предназначены для установки
  85. различных дифференциальных режимов - в тех моделях, где они присутствуют, в
  86. других случаях эти биты зарезервированы (как в моделях Atmega8, ATmegal63 и
  87. др.). В дифференциальном режиме АЦП измеряет напряжение между двумя
  88. выбранными выводами (например, между ADC0 и ADC1), причем не все выводы
  89. могут быть в таком режиме задействованы. В том числе дифференциальные входы
  90. АЦП можно подключать к одному и тому же входу для коррекции нуля. Дело в
  91. том, что в ряде моделей на входе АЦП имеется встроенный усилитель, с
  92. коэффициентом 1х, 20х и 100х (коэффициент выбирается теми же битами
  93. MUX0..4), и такой режим используется для его калибровки — в дальнейшем
  94. значение выхода при соединенных входах можно просто вычесть.
  95. Для недифференциального режима АЦП, когда напряжение отсчитывается от
  96. "земли", результат преобразования определяется формулой: Ка = 1024Uвх/Uref,
  97. где Ка — значение выходного кода АЦП, Uвх и Uref - входное и опорное
  98. напряжения. Дифференциальному измерению соответствует такая формула: Ка =
  99. 512(Upos - Uneg)/Vref, где Upos и Uneg - напряжения на положительном и
  100. отрицательном входах соответственно. Если напряжение на отрицательном входе
  101. больше, чем на положительном, то результат в дифференциальном режиме
  102. становится отрицательным и выражается в дополнительном коде от $200 (-512)
  103. до $3FF (-1). Реальная точность преобразования в дифференциальном режиме
  104. равна 8 разрядам.