Проект GSM/GPRS сигнализации на Arduino ч.2

Проект GSM/GPRS сигнализации на Arduino ч.2 Сигнализация, Arduino, Sim800l, Gsm, Gprs, Смс-рассылка, Длиннопост

Приветствую моих читателей. В первой части https://pikabu.ru/story/proekt_gsmgprs_signalizatsii_na_ardu... я рассказал вам, как сделать простую GPRS сигнализацию на Ардуино. Проект продолжает развиваться. Сигнализация эксплуатируется около месяца, и уже можно подводить некоторые итоги. За это время не было ни одного случая отказа или зависания, как модуля SIM800L, так и самой Ардуины. Напомню, в моём проекте микроконтроллер питается напрямую от аккумулятора пониженным напряжением 4 В. К каким-то отказам, как опасались многие читатели, это не приводит. Мною был проведён эксперимент, чтобы узнать, как поведёт себя сигнализация при постепенном разряде батареи.

Так как Ардуина разряжала аккумуляторы очень медленно, я подключил её вместе с модемом к лабораторному источнику питания, выставил ограничение по току 2А, и проверил работу на различных значениях напряжения.

Что удалось выяснить. При 3,5 В и выше SIM800L работает штатно. С питанием 3,4 В иногда начинаются перезагрузки при входящих звонках. При снижении напряжения ниже 3,4 В отваливается сеть, могут начаться перезагрузки, но на AT команды модуль продолжает отвечать. Так он работает в плоть до 3В, после чего выключается.

Ардуина работает даже при напряжении 2,7 В, ниже которых отключается. Никаких сбоев отмечено не было.

Но этого нам не достаточно. Нужно было проверить работу при длительной разрядке аккумулятора. Так сказать в условиях, близких к боевым. Я отключил режим сна Ардуины, подключил дополнительную нагрузку к аккумулятору, включил Serial монитор, и отслеживал поведение сигнализации, периодически проверяя её работоспособность. Эксперимент продолжался более суток. Аккумулятор разрядился до 3,6 В. Сбоев замечено не было. Схема полностью работоспособна.  Ставьте ёмкий аккумулятор и не о чём не думайте.

Для справки. Номинальное напряжение питания чипа зависит от частоты его работы. Если программно понизить частоту до 10МГц или ниже, то питание напряжением от 2,7 до 5,5В для Atmega328p будет стандартным. Если кого-то не убедили результаты эксперимента, то они могут  поиграться с настройками частоты.


С этим разобрались, теперь поговорим о доработках проекта.


За прошедшие две недели проект претерпел некоторые изменения. Геркон теперь подтянут через резистор не к +5В, а к +4,2В батареи (см. фото). Что позволит сохранить на пине высокий уровень при отключении внешнего питания без программной подтяжки. Мне кажется это более надёжным решением. Резисторы можно использовать любого номинала, начиная с 2,2 кОм и выше.


Остальные доработки касаются программной части. Файл настроек settings.h получил новые опции. https://github.com/wisenheimer/Arduino/blob/master/libraries...


По рекомендации читателей, в проект был добавлен watchdog (WTD), который перезагрузит Ардуину в случае её зависания. Включен по умолчанию следующим дефайном:

Проект GSM/GPRS сигнализации на Arduino ч.2 Сигнализация, Arduino, Sim800l, Gsm, Gprs, Смс-рассылка, Длиннопост

Т. к. стандартный загрузчик Ардуино Нано не поддерживает watchdog, и в случае его срабатывания уходит в бесконечную перезагрузку, для его работы нужно либо сменить загрузчик на другой, либо поступить проще. Прошить Ардуину через программатор. В этом случае на Ардуине больше не будет загрузчика. И watchdog будет работать. Но вы уже не сможете прошивать Ардуину по USB. Если вас это не устраивает, не используйте watchdog.


В качестве программатора я применил Ардуино УНО с прошивкой ArduinoISP из примеров.


Следующее изменение касается способа доставки отчётов. Теперь сигнализация поддерживает SMS отправку сообщений. Ранее мы отправляли ответы сигнализации на e-mail при помощи GPRS. Теперь можно выбирать способ отправки. Для этого добавлен следующий дефайн:

Проект GSM/GPRS сигнализации на Arduino ч.2 Сигнализация, Arduino, Sim800l, Gsm, Gprs, Смс-рассылка, Длиннопост

По умолчанию включены оба варианта.


SET_FLAG_ONE(GPRS_ENABLE) разрешает отправку e-mail по GPRS.

SET_FLAG_ONE(SMS_ENABLE) разрешает отправку отчётов по SMS.


GPRS имеет более высокий приоритет. Если сигнализации не удалось установить GPRS соединение, и SMS режим разрешён, то сообщения будут отправлены по SMS, флаг GPRS_ENABLE  выключен, и в дальнейшем будет задействована только SMS отправка. Включить или выключить оба режима можно так же в ручную DTMF командой.

Если мы хотим всегда использовать один режим, то дефайн нужно отредактировать, удалив лишнее.


Следующим нововведением стало изменение списка DTMF команд:

Проект GSM/GPRS сигнализации на Arduino ч.2 Сигнализация, Arduino, Sim800l, Gsm, Gprs, Смс-рассылка, Длиннопост

Команды, не вошедшие в список, будут подставлены в USSD запрос и отправлены сотовому оператору. Так что можете в режиме DTMF напирать любые USSD команды. Например запрос баланса. В случае успеха ответ оператора вернётся в виде отчёта.


Админ так же может управлять модемом SIM800L при помощи АТ команд из его даташита http://www.mt-system.ru/sites/default/files/documents/sim800... .


Например, добавлять и удалять номера из телефонной книги. Для этого достаточно с телефона Админа отправить сигнализации SMS с текстом АТ команды.


Дальше хочу подробно рассказать, как добавлять в проект датчики.


Для начала необходимо определиться с количеством пинов, требуемых для ваших датчиков. Датчики у нас подключаются, начиная с 4 пина. Первым желательно выбрать геркон, т.к. он будет будить Ардуину, если она войдёт в режим энергосбережения при отключении внешнего питания.

Проект GSM/GPRS сигнализации на Arduino ч.2 Сигнализация, Arduino, Sim800l, Gsm, Gprs, Смс-рассылка, Длиннопост

В файле https://github.com/wisenheimer/Arduino/blob/master/libraries... описан класс Sensor и следующие типы датчиков:

Проект GSM/GPRS сигнализации на Arduino ч.2 Сигнализация, Arduino, Sim800l, Gsm, Gprs, Смс-рассылка, Длиннопост

DIGITAL_SENSOR - любой датчик с одним цифровым выходом, на котором может быть только два состояния, 0 или 1.

CHECK_DIGITAL_SENSOR - тоже самое, только с проверкой от ложного срабатывания. Если через 10 секунд датчик сбросил своё значение, то срабатывание считается ложным.  Применяется для тех датчиков, которые удерживают логическое значение на выходном пине при сохранении внешнего воздействия. Например датчик пламени.

ANALOG_SENSOR - любой датчик с аналоговым выходом. Например датчик газа MQ-2.

DHT11, DHT21, DHT22 - датчики температуры и влажности.


Конструктор класса имеет следующий вид:

Проект GSM/GPRS сигнализации на Arduino ч.2 Сигнализация, Arduino, Sim800l, Gsm, Gprs, Смс-рассылка, Длиннопост

В нашем файле настроек имеется целый массив таких классов для каждого датчика:

Проект GSM/GPRS сигнализации на Arduino ч.2 Сигнализация, Arduino, Sim800l, Gsm, Gprs, Смс-рассылка, Длиннопост

Очень важно указать точный размер массива, иначе проект не соберётся. В данном случае у меня имеется 6 датчиков, конструктор для каждого описан отдельно.


Например:

Sensor(DOOR_PIN, DIGITAL_SENSOR, "DOOR", HIGH, 0)

означает, что для датчика двери (геркона) задействован пин Ардуино DOOR_PIN (задан в том же в файле), тип датчика DIGITAL_SENSOR, название датчика, которое будет выводиться в отчётах - "DOOR" (можно заменить на любое другое слово), обычное состояние пина  HIGH (DOOR_PIN у нас подтянут к 4,2В), время подготовки датчика при включении питания в секундах, через которое он начнёт показывать правильные значения - 0 секунд.


Для аналогового датчика газа MQ-2:

Sensor(A0, ANALOG_SENSOR, "GAS", LOW, 120)

пин A0, тип датчика ANALOG_SENSOR, имя  "GAS", значение на пине LOW, на прогрев датчика и выход на номинальный режим работы отводится 120 секунд. До истечения этого времени после включения датчик не опрашивается, что бы не получать неверные значения.


Для датчика температуры DHT11

Sensor(DHT_PIN, DHT11, "DHT", LOW, 10, 35)

в конце появилась цифра 35, которая означает уровень в градусах, при превышении которого считается, что датчик сработал. В помещении стало слишком жарко.


Внимательный читатель уже заметил, что для разных датчиков описано разное количество параметров. Дело в том, что в языке С++ можно не писать все параметры функции, если в заголовке функции указаны их значения по умолчанию. Мы пишем только то, что не имеет значения по умолчанию, или мы хотим задать другое значение. Однако никто не запрещает указать все параметры конструктора класса.


Вы можете подключать к сигнализации любые датчики, не требующие отдельной библиотеки, лишь заполнив конструктор класса, и добавив его в массив Sensor sensors[]. И это будет работать. Если для датчика требуется отдельная библиотека, то её можно добавить точно так же, как в проект была добавлена библиотека stDHT.h для датчика DHT11, который имеет свой протокол для обмена данными. Или напишите мне, я добавлю.


На этом всё, спасибо за внимание.


Скачать проект можно как всегда по ссылке: https://github.com/wisenheimer/Arduino

Arduino & Pi

1.4K постов20.6K подписчик

Добавить пост

Правила сообщества

В нашем сообществе запрещается:

• Добавлять посты не относящиеся к тематике сообщества, либо не несущие какой-либо полезной нагрузки (флуд)

• Задавать очевидные вопросы в виде постов, не воспользовавшись перед этим поиском

• Выкладывать код прямо в посте - используйте для этого сервисы ideone.com, gist.github.com или схожие ресурсы (pastebin запрещен)

• Рассуждать на темы политики

• Нарушать установленные правила Пикабу

Вы смотрите срез комментариев. Показать все
4
Автор поста оценил этот комментарий
Ардуина работает даже при напряжении 2,7 В

ниже 3,7В такие аккумуляторы разряжать не рекомендуется. Многие контроллеры блокируют на 3,4В и возобновляют работу только при зарядке в обход - напрямую.

Я когда планировал что то подобное собрать (руки недошли) нашел такую статейку https://habr.com/post/390967/

там же в комментариях есть еще более удобное решение https://ru.aliexpress.com/popular/ads1115.html

на ютубе есть куча видео по его пользованию

тут с примером и использования и скетч на экране https://www.youtube.com/watch?v=9kBeDhEIiSI

раскрыть ветку (13)
4
Автор поста оценил этот комментарий

Дело в том, что ниже 3 В аккумулятор всё равно не разрядится. Sim800l выключится. Ардуина уйдёт в глубокий сон. Я использую старые ноутбучные банки, их не жалко. Даже от них сигнализация без внешнего питания продержится несколько недель. Свет на столько не пропадает. Без режима сна за 15 часов 4 аккумулятора разрядились только до 4В.

раскрыть ветку (2)
1
Автор поста оценил этот комментарий

Так чтобы информирование было - что система "того", скоро может стать нерабочей из-за питания. У каждого свои "хотелки")) но так то да... без включенных всяких экранов - можно днями не беспокоится.

раскрыть ветку (1)
Автор поста оценил этот комментарий

В режиме энергосбережения Ардуина находится в глубоком сне. Чтобы информировать, её нужно периодически пробуждать. Есть способ проще, позвонить на неё, и набрать DTMF команду 11# (BAT_CHARGE). Она всё измерит, пришлёт ответ и снова уснёт. 

2
Автор поста оценил этот комментарий
3.7 вольт это 50-60% емкости литиевого аккумулятора. Практически все банки 18650 по даташитам разрешается разряжать до 2.5-2.7 вольт. А сони vtc 5/6 так и до двух.
раскрыть ветку (2)
Автор поста оценил этот комментарий

новые - да, но в б/у банках при малом заряде аккумулятора падение напряжения идет очень быстро. Даже в новых там "неудобная" кривая разряда, что уж говорить про б/у. У самого же валяются такие емкости.

http://www.kit-e.ru/assets/images/1211/119_pic5.jpg

раскрыть ветку (1)
Автор поста оценил этот комментарий

Насколько БУ? С внутренним сопротивлением в 400-500 миллиом? :D

И что это за сферический график в вакууме? Это какие аккумуляторы? Ничего что у разной химии совершенно разная дельта может быть?

И в любом случае, разряжать банки не ниже 3.7 глупо, а если после этой границы аккумулятор ненормально проваливается, то может стоит его поменять хотя бы для безопасности?

3
Автор поста оценил этот комментарий

Кем не рекомендуется? домашними спецами? 3.6-3.7 номинальное напряжение для этих акб, он боится полного разряда и перезаряда, в пределах заявленными производителем параметров, его можно гонять, даже нужно ибо заряжая его раньше времени, вы сами себе на яйца наступаете, акб прослужит по количеству заряд-разряд +- так же, вот только количество отданного объема будет в разы меньше...

раскрыть ветку (3)
1
Автор поста оценил этот комментарий
Кем не рекомендуется? домашними спецами?

ок, а ты кривую разряда дальше можешь предсказать на уровне заряда в 3,6В? Давай-ка ты не будешь задвигать чушь про "домашних спецов". Вот график, на котором все видно. Все это нормальные люди или уже давным-давно видели или сам к этому дошли. Сколько раз я уже видел когда идет 3,6 падает до 3,5-3,4 более-менее линейно и резкий провал с последствиями в виде отключения контроллера аккумулятора и блокировкой.


вы сами себе на яйца наступаете, акб прослужит по количеству заряд-разряд +-

у лития есть три фактора старения - самоустаревание, хоть 10 раз его заряди малыми токами, но через 5 лет он в любом случае потеряет в емкости. Количество циклов заряда-разряда. И использование верхних и нижних пределов уровня заряда. Что верхний "потолок" что нижний уровень - чем ближе к предельным значениям экссплуатировать - тем быстрее сдохнет. Да и условия могут внести свои коррективы - зарядил аккумулятор ночью/под утро на полную, а днем на солнце он может выйти из строя из-за нагрева итого что заряжен полностью. А с нижним порогом еще веселее - падение на графике на низком уровне заряда. Например было все хорошо, напряжение себе тихо-спокойно опускалось до 3,2В и тут внезапно понадобилось включится серьезному потребителю в виде экрана и модуля Sim. При б/у аккумуляторе провал с 3-3,2В может быть вообще быстрым.

Иллюстрация к комментарию
раскрыть ветку (1)
Автор поста оценил этот комментарий

СПАСИБО за дельные данные.

Автор поста оценил этот комментарий
Не совсем так. Полностью зарядить и разрядить желательно только первые несколько раз. И то не обязательно, а желательно.
Если при обычном использовании полностью не разряжать, то работать будет дольше. Современные смартфоны просят зарядить их при 20%, и это не просто так.
После количества циклов на картинке аккумулятор не выходит из строя, а теряет часть ёмкости. Примерно половину.
Иллюстрация к комментарию
1
Автор поста оценил этот комментарий

Измерение заряда аккумулятора уже реализовано средствами SIM800L. Описано в DTMF командах. Оказалось, что она измеряет довольно точно. Только что вы хотите с этим сделать, я не очень понимаю.

DELETED
Автор поста оценил этот комментарий
ниже 3,7В такие аккумуляторы разряжать не рекомендуется.

Только не ниже 3.7, а ниже 2.7, а в остальном вы правы.

раскрыть ветку (1)
Автор поста оценил этот комментарий

рекомендации на то и рекомендации, что их можно и до 2,5В эксплуатировать, но чем "уже" диапазон напряжений одной банки - тем дольше он живет. Поэтому китайцы свои аккумуляторы раньше тоже давали разряжаться и 3-3,2В, верхний порог не помню. А брендовые только сейчас начали использовать нижнюю планку в районе 3,4В. У самого такой вот китаец "Нокла" был на руках, веселый аппарат.

Вы смотрите срез комментариев. Чтобы написать комментарий, перейдите к общему списку