Библиотека для повышения разрешения измерений Arduino (оверсэмплинг)
- Повышение разрядности до +6 бит
- Ручной режим работы (любые данные)
- Автоматический режим работы (бортовой АЦП)
- Быстрые вычисления
Совместима со всеми Arduino платформами (используются Arduino-функции)
- Библиотеку можно найти по названию OVS и установить через менеджер библиотек в:
- Arduino IDE
- Arduino IDE v2
- PlatformIO
- Скачать библиотеку .zip архивом для ручной установки:
- Распаковать и положить в C:\Program Files (x86)\Arduino\libraries (Windows x64)
- Распаковать и положить в C:\Program Files\Arduino\libraries (Windows x32)
- Распаковать и положить в Документы/Arduino/libraries/
- (Arduino IDE) автоматическая установка из .zip: Скетч/Подключить библиотеку/Добавить .ZIP библиотеку… и указать скачанный архив
- Читай более подробную инструкцию по установке библиотек здесь
- Рекомендую всегда обновлять библиотеку: в новых версиях исправляются ошибки и баги, а также проводится оптимизация и добавляются новые фичи
- Через менеджер библиотек IDE: найти библиотеку как при установке и нажать "Обновить"
- Вручную: удалить папку со старой версией, а затем положить на её место новую. "Замену" делать нельзя: иногда в новых версиях удаляются файлы, которые останутся при замене и могут привести к ошибкам!
OVS<gain> ovs;
// gain - в <> указывается НА сколько бит нужно повысить разрешение. От 1 до 6 (включительно)
uint32_t read(uint8_t pin); // прочитать с аналогового пина и преобразовать
uint32_t get(); // получить значение (обновляется после read() и compute())
uint32_t getMax(uint16_t bits); // получить максимальное значение при начальном разрешении
uint16_t samples(); // получить количество измерений, которое нужно сделать
void reset(); // сбросить расчёт
void add(uint16_t val); // добавить измерение
void compute(); // преобразовать
Библиотеку можно использовать как для работы с бортовым АЦП, так и для обработки данных с других источников.
Достаточно вызвать read(аналоговый пин)
, которая вернёт преобразованный результат.
Также можно можно забирать предыдущее преобразованное значение из get()
.
В этом режиме можно скормить библиотеке значения с других источников:
- Перед новым измерением нужно вызвать
reset()
- Далее нужно передавать новые значения в
add(val)
в количестве, равномsamples()
- После передачи нужного количества значений вызвать
compute()
- Забираем преобразованное значение из
get()
Оверсэмплинг фактически усредняет N измерений (в библиотеке это количество можно получить из samples()
),
подгоняя новый диапазон под указанное увеличение разрешения Gain. Необходимое количество измерений
зависит от увеличения как N = 2^(2*Gain)
, то есть для увеличения разрешения на 6 бит понадобится 4096 измерений!
Gain | N |
---|---|
+1 | 4 |
+2 | 16 |
+3 | 64 |
+4 | 256 |
+5 | 1024 |
+6 | 4096 |
#include <OVS.h>
// увеличим разрядность на 2
// (AVR Arduino 10+2 = 12 бит)
OVS<2> ovs;
void setup() {
Serial.begin(9600);
}
void loop() {
// прочитать с аналогового пина и преобразовать
Serial.print(ovs.read(0));
Serial.print(',');
// после ovs.read() можно забирать последний результат из ovs.get()
// выводим макс. значение при начальном разрешении (У нас АЦП 10 бит)
Serial.println(ovs.getMax(10));
}
// оверсэмплинг, ручной режим
#include <OVS.h>
// увеличим разрядность на 2
// (AVR Arduino 10+2 = 12 бит)
OVS<2> ovs;
void setup() {
Serial.begin(9600);
}
void loop() {
// сбрасываем перед измерением
ovs.reset();
// добавляем новые значения в количестве ovs.samples()
for (int i = 0; i < ovs.samples(); i++) {
ovs.add(analogRead(0));
}
// преобразовываем
ovs.compute();
// выводим результат
Serial.print(ovs.get());
Serial.print(',');
// выводим макс. значение при начальном разрешении (У нас АЦП 10 бит)
Serial.println(ovs.getMax(10));
}
- v1.0
- v1.1 - read() возвращает результат
При нахождении багов создавайте Issue, а лучше сразу пишите на почту [email protected]
Библиотека открыта для доработки и ваших Pull Request'ов!
При сообщении о багах или некорректной работе библиотеки нужно обязательно указывать:
- Версия библиотеки
- Какой используется МК
- Версия SDK (для ESP)
- Версия Arduino IDE
- Корректно ли работают ли встроенные примеры, в которых используются функции и конструкции, приводящие к багу в вашем коде
- Какой код загружался, какая работа от него ожидалась и как он работает в реальности
- В идеале приложить минимальный код, в котором наблюдается баг. Не полотно из тысячи строк, а минимальный код