|
Обработка данных 24-битной АЦП |
|
|
|
Nov 11 2009, 18:38
|
Участник

Группа: Участник
Сообщений: 24
Регистрация: 26-12-08
Пользователь №: 42 777

|
Доброго времени суток! Появилась возможность использовать для обработки данных 24-битный АЦП AD7714. При написании прошивки для МК встал вопрос как из этих 3 байт вытащить значение измеренного напряжения, т.е. расшифровать принимаемые данные? В даташите структура датарегистров не отображена. Возможно это стандартный вид передачи информации, но мы о нем не знаем
|
|
|
|
|
Nov 11 2009, 20:17
|

http://uschema.com
   
Группа: Свой
Сообщений: 708
Регистрация: 16-02-06
Из: UK(Ukrainian_Kingdom) Kharkov
Пользователь №: 14 394

|
Цитата(Kannikkiy @ Nov 11 2009, 21:38)  Доброго времени суток! Появилась возможность использовать для обработки данных 24-битный АЦП AD7714. При написании прошивки для МК встал вопрос как из этих 3 байт вытащить значение измеренного напряжения, т.е. расшифровать принимаемые данные? В даташите структура датарегистров не отображена. Возможно это стандартный вид передачи информации, но мы о нем не знаем  мне лет 5 назад приходилось иметь дело с AD7719, она тоже 16/24бита, и если я не запамятовал , то она похожа на вашу AD7714, только 2х канальная. посмотрите на ее даташит так вот там все тупо, несколько режимов - стробируете, и получаете данные, в соответствие с тем как сконфигурировали ее.. .
--------------------
|
|
|
|
|
Nov 11 2009, 21:14
|

Гуру
     
Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237

|
Цитата(Kannikkiy @ Nov 11 2009, 21:38)  При написании прошивки для МК встал вопрос как из этих 3 байт вытащить значение измеренного напряжения, т.е. расшифровать принимаемые данные? В даташите структура датарегистров не отображена. Возможно это стандартный вид передачи информации, но мы о нем не знаем. Это обычное число в двоичном формате. Обычно бывает достаточно приписать спереди еще один (старший) байт, содержащий нули, чтобы получилось типичное число типа unsigned long (32-битное беззнаковое целое). В тех случаях, когда АЦП работает в дифференциальном режиме, то выдаваемое им число может оказаться со знаком. Тогда приписываемый спереди байт заполнятеся нулями только в том случае, если старший бит данных является нулем, или заполняется полностью двоичными единичками, если старший бит является единичкой. Этот метод носит название "расширения знака", т.к. здесь старший бит данных распростаняется на всю приписываемую спереди часть. Последнее не есть какая-то специфика АЦП, а представляет собой типичный метод, которым более короткое знаковое число копируется в более длинное. Короче говоря, берете число типа long, зануляете его, запихиваете 24-битные данные от АЦП в его младшие 3 байта, а потом разбираетесь с тем, что получилось. Оно окажется либо пригодно сразу, либо потребует минимальную коррекцию: if (xlong >= 0x800000) xlong |= 0xFF000000;
|
|
|
|
|
Nov 12 2009, 01:18
|

Гуру
     
Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237

|
Цитата(vvs157 @ Nov 12 2009, 00:50)  В сигма-дельта вы эти 24 бита никогда не получите. Посмотрите DS на любой 24-битник и увидете, что там только 21 бит. А 24 - это то, что называется RMS - среднеквадратичная точность. Чисто маркетинговый ход, ибо, как изветно, "в попугаях-то больше" © Получите - не получите, но все эти 24 бита они выдают, как бы ни шумели младшие биты. Поэтому поднятый в теме вопрос о том, как преобразовать эти 24 бита в число, с которым можно работать, остается правомерным. А шум при желании можно фильтровать, если измерения поступают часто, а изменяемая величина малоподвижная, типа термопары.
|
|
|
|
|
Nov 12 2009, 14:01
|
Участник

Группа: Участник
Сообщений: 24
Регистрация: 26-12-08
Пользователь №: 42 777

|
Мы понимаем, что 24 бита это миф. И даташит читали много раз. И фильтровать будем. И знаем, что integer занимает 4 байта. НО! Это все очевидно и неважно. Проблема в следующем: из ацп приходит целое число. например 0x80123456. сколько это в вольтах? Мне кажется, что должна быть какая-то определённая формула пересчета. Цитата(sensor_ua @ Nov 12 2009, 16:48)  ... код соотвествует значениям от нуля до полной шкалы... это понятно, но сколько вольт полная шкала?
Сообщение отредактировал Kannikkiy - Nov 12 2009, 14:03
|
|
|
|
|
Nov 12 2009, 14:23
|

Гуру
     
Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237

|
Цитата(sensor_ua @ Nov 12 2009, 16:48)  В униполярном режиме код соотвествует значениям от нуля до полной шкалы. В биполярном режиме нет знакового бита, код от 0 до 0x7fffff соотвествует отрицательным значениям (0 соответствует наиболее отрицательному числу), 0x800000 - ноль шкалы, а все значения кода более 0x800000 и до максимума шкалы 0xffffff соотвествуют положительным значениям входного сигнала. В этом случае, после перемещения данных в переменную типа в long достаточно вычесть из нее 0x800000, чтобы получить стандартное представление, где нуль находится на нуле, а не на 0x800000. Цитата(Kannikkiy @ Nov 12 2009, 17:01)  это понятно, но сколько вольт полная шкала? Полная шкала для этого АЦП, кажется, равна удвоенному опорному (без учета Gain). Но в даташите это должно быть написано точно. Страница 11 даташита (ревизия C): Цитата The effective resolution of the device is defined as the ratio of the output rms noise to the input full scale (i.e., 2 х VREF/GAIN).
|
|
|
|
|
Nov 12 2009, 14:30
|
Профессионал
    
Группа: Свой
Сообщений: 1 266
Регистрация: 22-04-05
Из: Киев
Пользователь №: 4 387

|
Цитата это понятно, но сколько вольт полная шкала? RTFM AIN Differential Voltage Range 0 to +VREF/GAIN nom Unipolar Input Range (B/U Bit of Filter High Register = 1) ±VREF/GAIN nom Bipolar Input Range (B/U Bit of Filter High Register = 0) VREF = REF IN(+) – REF IN(–).
--------------------
aka Vit
|
|
|
|
|
Nov 12 2009, 14:34
|
Участник

Группа: Участник
Сообщений: 24
Регистрация: 26-12-08
Пользователь №: 42 777

|
Цитата(V_G @ Nov 12 2009, 17:28)  Полная шкала у АЦП обычно равна опоре. А какая опора - написано в даташите. Все в сад! Так и зделаем. Всем спасибо. Просто на варварском языке тяжеловато читать. не всегда находится то что надо.
Сообщение отредактировал Kannikkiy - Nov 12 2009, 14:38
|
|
|
|
|
Nov 12 2009, 14:46
|

Гуру
     
Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237

|
Цитата(V_G @ Nov 12 2009, 17:28)  Полная шкала у АЦП обычно равна опоре. А какая опора - написано в даташите. Удвоенному опорному! При Vref=2.5V в униполярном режиме полная шкала 5V. Однако так не для всех АЦП - те, что встроены в МК, действительно требуют опору, равную величине шкалы. Цитата(V_G @ Nov 12 2009, 17:28)  Все в сад! Прошу вас соблюдать на форуме правила приличия и не опускаться до унижения собеседников.
|
|
|
|
|
Nov 12 2009, 15:04
|
Участник

Группа: Участник
Сообщений: 24
Регистрация: 26-12-08
Пользователь №: 42 777

|
Цитата(sensor_ua @ Nov 12 2009, 17:30)  AIN Differential Voltage Range 0 to +VREF/GAIN nom Unipolar Input Range (B/U Bit of Filter High Register = 1) ±VREF/GAIN nom Bipolar Input Range (B/U Bit of Filter High Register = 0) VREF = REF IN(+) – REF IN(–). Цитата(Xenia) Удвоенному опорному! При Vref=2.5V в униполярном режиме полная шкала 5V. Ну и как теперь быть?
|
|
|
|
|
Nov 12 2009, 16:48
|

Гуру
     
Группа: Модераторы
Сообщений: 10 983
Регистрация: 23-11-05
Пользователь №: 11 287

|
Цитата(Kannikkiy @ Nov 12 2009, 16:34)  Так и зделаем. Всем спасибо.
Просто на варварском языке тяжеловато читать. не всегда находится то что надо. Это на варварском языке Вы, похоже, пишете. А datasheet написан нормальным английским. Цитата(Kannikkiy @ Nov 12 2009, 17:04)  Ну и как теперь быть? Очень просто: читать! Рекомендую страницу 19, там всё подробно разжёвано. Или отказаться от выпавшей возможности...
|
|
|
|
|
Nov 12 2009, 23:09
|
дятел
    
Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065

|
Цитата(vvs157 @ Nov 13 2009, 01:44)  На 24 битном S-D АЦП вы никогда не получите 24-битной точности - в DS на это прямо указано - реальная точность 21 бит. Если же вы получили путем усреднения такую точность (то есть устойчивый младший разряд) - то эта точность к разрядности АЦП прямого отношения не имеет Вы говорите об усреднении в софте или самим АЦП на встроенном цифровом фильтре ? Ну к примеру ADS1255 оцифровывает ВСЕ отсчеты на 30KSPS но выдавать резальты может с частотой от 30KSPS до 2,5SPS. Все что выдается на частоте ниже 30KSPS есть результат усреднения в ЦИФРЕ внутри самого АЦП. Дык о какой точности мы говорим ? При 2,5SPS опроса +-1LSB от этого АЦП получаем легко.
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|