Создание сигнализации на датчике движения arduino. Бюджетная GSM сигнализация с мозгами из Arduino. Как это работает

Здравствуй, дорогой читатель! Сегодняшняя статья посвящена созданию простой домашней системы безопасности, при помощи доступных компонентов. Это маленькое и дешёвое устройство поможет тебе защитить ваше жилище от проникновения при помощи Arduino, датчика движения, дисплея и динамика. Питаться устройство сможет от батарейки или USB-порта компьютера.

Итак, начнём!

Как оно работает?

Тела теплокровных излучают в ИК-диапазоне, который невидим для человеческих глаз, однако может быть обнаружен при помощи датчиков. Такие датчики делаются из материала, который под воздействием тепла может спонтанно поляризоваться, благодаря чему это позволяет определить появления источников тепла в радиусе действия датчика.

Для более широкого радиуса действия используют линзы Френеля, которые собирают ИК-излучение с разных направлений и концентрируют его на самом датчике.

На рисунке видно, как линза искажает лучи, которые падают на неё.

Стоит отметить, что роботы без особо греющихся частей и хладнокровные излучают в ИК-диапазоне очень слабо, поэтому датчик может не сработать в случае, если тебя решат обнести сотрудники Boston Dynamics или рептилоиды.

Когда происходит изменение уровня ИК излучения в диапазоне действия, это будет обрабатываться на Arduino после чего на LCD дисплее будет выводится статус, светодиод будет мигать, а спикер пищать.

Что нам потребуется?

  1. (или любая другая плата ).
  2. (16 символов по две строки)
  3. Один разъём для подключения кроны к Arduino
  4. (хотя можно использовать и обычный динамик)
  5. USB-кабель - только для программирования (прим. пер.: с нашими Arduino он всегда идёт в комплекте!)
  6. Компьютер (опять же только для того, чтобы написать и загрузить программу).

Кстати, если не хочется покупать все эти детали по отдельности - рекомендуем обратить внимание на наши . К примеру, всё необходимое и даже больше есть в нашем стартовом наборе .

Подключаем!

Подключение датчика движения очень простое:

  1. Пин Vcc подключаем к 5V Ардуино.
  2. Пин Gnd подключаем к GND Ардуино.
  3. Пин OUT подключаем к цифровому пину №7 от Arduino

Теперь присоединим светодиод и спикер. Тут всё так же просто:

  1. Короткую ножку (минус) светодиода подключаем к земле
  2. Длинную ножку (плюс) светодиода подключаем к выходу №13 Arduino
  3. Красный провод спикера к выходу №10
  4. Чёрный провод – к земле

И теперь самое сложное – подключение LCD дисплея 1602 к Arduino. Дисплей у нас без I2C, поэтому потребуется много выходов Arduino, но результат будет того стоить. Схема представлена ниже:

Нам нужна только часть схемы (у нас не будет регулировки контраста потенциометром). Поэтому требуется сделать лишь следующие:

Теперь ты знаешь, как подключить дисплей 1602 к Arduino UNO R3 (ровно как и к любой версии Arduino от Mini до Mega).

Программируем

Пришло время перейти к программированию. Ниже представлен код, который надо лишь залить и, если вы собрали всё верно – устройство готово!

#include int ledPin = 13; // Пин светодиода int inputPin = 7; // Пин, к которому подключен Out датчика движения int pirState = LOW; // Текущее состояние (в начале ничего не обнаружено) int val = 0; // Переменная для чтения состояния цифровых входов int pinSpeaker = 10; // Пин, к которому подключен динамик. Требуется использовать пин с ШИМ (PWM) LiquidCrystal lcd(12, 11, 5, 4, 3, 2); // Инициалиация LCD дисплея void setup() { // Определение направления передачи данных на цифровых пинах pinMode(ledPin, OUTPUT); pinMode(inputPin, INPUT); pinMode(pinSpeaker, OUTPUT); // Запуск вывода отладочной информации через последовательный порт Serial.begin(9600); // Запуск вывода на LCD дисплей lcd.begin(16, 2); // Устанавливаем индекс на дисплеи, с которого начнём вывод // (2 символ, 0 строки) lcd.setCursor(2, 0); // Вывод на LCD дисплей lcd.print("P.I.R Motion"); // Снова перемещаем lcd.setCursor(5, 1); // Выводим lcd.print("Sensor"); // Пауза, чтобы успели прочитать, что вывели delay(5000); // Очистка lcd.clear(); // Аналогично lcd.setCursor(0, 0); lcd.print("Processing Data."); delay(3000); lcd.clear(); lcd.setCursor(3, 0); lcd.print("Waiting For"); lcd.setCursor(3, 1); lcd.print("Motion...."); } void loop() { // Считываем показание датчика val = digitalRead(inputPin); if (val == HIGH) { // Если есть движение, то зажигаем светодиод и включаем сирену digitalWrite(ledPin, HIGH); playTone(300, 300); delay(150); // Если движения до данного момента не было, то выводим сообщение // что оно обнаружено // Код ниже нужен для того, чтобы писать лишь смену состояния, а не каждый раз выводить значение if (pirState == LOW) { Serial.println("Motion detected!"); lcd.clear(); lcd.setCursor(0, 0); lcd.print("Motion Detected!"); pirState = HIGH; } } else { // Если движене закончилось digitalWrite(ledPin, LOW); playTone(0, 0); delay(300); if (pirState == HIGH){ // Сообщаем, что движение было, но уже закончилось Serial.println("Motion ended!"); lcd.clear(); lcd.setCursor(3, 0); lcd.print("Waiting For"); lcd.setCursor(3, 1); lcd.print("Motion...."); pirState = LOW; } } } // Функция воспроизведения звука. Duration (длительность)- в миллисекундах, Freq (частота) - в Гц void playTone(long duration, int freq) { duration *= 1000; int period = (1.0 / freq) * 100000; long elapsed_time = 0; while (elapsed_time < duration) { digitalWrite(pinSpeaker,HIGH); delayMicroseconds(period / 2); digitalWrite(pinSpeaker, LOW); delayMicroseconds(period / 2); elapsed_time += (period); } }

Весна, как известно, сопровождается всевозможными обострениями и вот главное «обострение» повылазило из своих нор на улицу, дабы присвоить себе то, что ему не принадлежит. А значит тема защиты своего имущества становится, как никогда, актуальной.
На сайте уже есть несколько обзоров на самодельные - . Они конечно функциональны, однако у всех имеется общая особенность - зависимость от розетки. Если с недвижимостью, где уже подведено электричество, это не проблема, то как быть с имуществом, где розетка далеко или окрестности вовсе обесточены? Я решил пойти другим путём - собрать долгоживущий, максимально простой и независимый от сетевого питания девайс, который будет всё время отсыпаться, а при проникновении грабителей, запускаться и отзваниваться хозяину на телефон, сигнализируя простым звонком о тревоге.

Предметы обзора

Покупные:
1. Макетная плата односторонняя 5x7 см: гетинакс - или стеклотекстолит
*- стеклотекстолит намного качественнее гетинакса.
2. Модуль Neoway M590 - , с антенной на текстолите -
3. Arduino Pro Mini «RobotDyn» ATmega168PA 8MHz 3.3V -
4. Плата контроля заряда-разряда лития -

Добытые на развалах цивилизации:
1. Стойки для платы, выпиленные из корпусов приборов - 6шт.
2. Аккумулятор литиевый плоский 1300mAh
3. Скобы, используемые для фиксации кабеля к стене
4. Ластик канцелярский
5. Медная проволока толщиной 1.5мм
6. Приборный корпус с местного радиорынка - 1.5$
7. Пара светодиодов разного цвета (взял с VHS-плеера)
8. Антенна и кнопка с колпачком (взял с Wi-Fi роутера)
9. 4-х контактный клеммник (взял со с диммера)
10. Разъём питания (взял со старого зарядника для 18650)
11. Разъём 6-пиновый (взял с DVD-привода)
12. Жестяная банка (из-под кофе например)

Arduino Pro Mini «RobotDyn» Atmega 168PA 3.3V 8MHz

Технические характеристики:
Микроконтроллер: ATmega168PA
Рабочее напряжение прямое: .8 - 5.5 В
Рабочее напряжение через стабилизатор LE33: 3.3 В или 5 В (в зависимости от модели)
Рабочая температура: -40°C… 105°C
Входное напряжение: 3.35-12 В (модель 3.3 В) или 5-12 В (модель 5 В)
Цифровые Входы/Выходы: 14 (6 из которых могут использоваться как выходы ШИМ: 3, 5, 6, 9, 10, и 11)
Аналоговые входы: 6
Таймеры-счётчики: два 8-битных и один 16-битный
Режимы энергосбережения: 6
Постоянный ток через вход/выход: 40 мА
Флеш-память: 16 Кб (2 используются для загрузчика)
ОЗУ: 1 Кб
EEPROM: 512 байт
Ресурс записи/стирания памяти: 10,000 Flash/100,000 EEPROM
Тактовая частота: 8 МГц (модель 3.3 В) или 16 МГц (модель 5 В)
SPI: 10 (SS), 11 (MOSI), 12 (MISO), 13 (SCK)
I2C: A4 (SDA) и A5 (SCL)
UART TTL: 0 (RX) и 1 (TX)
Даташит:

Выбор пал на данную атмегу совершенно случайно. на одном форуме, где обсуждались энергоэкономичные проекты, в комментариях попался совет использовать именно 168-ю атмегу.
Однако пришлось повозится, чтобы такую плату отыскать, поскольку сплошь и рядом все лоты были завалены 328-ми атмегами на частоте 16МГц, работающими от 5В. Для моего проекта такие характеристики были избыточны и неудобны уже изначально, поиски усложнились.
В итоге набрёл на 3.3-вольтовую версию Pro Mini на Atmega 168PA на eBay, причём не простую китайскую, а под брендом RobotDyn от российского разработчика. Да, у меня тоже сначала, как и у вас, возникло зерно сомнения. А зря. Когда проект уже был собран, а AliExpress ввёл обязательную платную доставку для дешёвых товаров (после которой посылки стали теряться гораздо чаще), тo позже заказал обычную Pro Mini Atmega168 (без PA) 3.3V 8MHz. Я немного экспериментировал с режимами энергосбережения c обеими платами, прошивая в каждую специальный скетч, погружающий микроконтроллер в максимальный режим энергосбережения и вот что вышло:
1) Arduino Pro Mini «RobotDyn»: ~250мкА
2) Arduino Pro Mini «NoName»: при подаче питания на стабилизатор напряжения (вывод RAW) и выпаянном светодиоде потребляемый ток составил ~3.92мА




- как вы поняли, разница в энергопотреблении почти в 16 раз, всё потому, что в NoName"мовской Pro Mini используется связка Atmega168+ , из которых сам МК ест всего 20мкА тока (это я проверил отдельно), всё остальное обжорство приходится на линейный преобразователь напряжения AMS1117 - даташит это только подтверждает:


В случае с платой от RobotDyn связка уже несколько иная - это Atmega168PA+ - здесь применён уже другой LDO-стабилизатор, чьи характеристики в плане энергосбережения оказались более приятными:


Выпаивать я его не стал, поэтому не могу сказать, сколько Atmega168PA потребляет тока в чистом виде. В данном случае мне хватило ~250мкА при питании от нокиевского литиевого аккумулятора. Однако если выпаять AMS1117 c NoName"мовской платы, то ATmega168-я обычная, в чистом виде, как я и сказал выше, потребляет 20мкА .
Светодиоды, стоящие по питанию можно сковырнуть чем-то острым. Это не проблема. Стабилизатор выпаивал феном. Однако не у каждого есть фен и навыки работы с ним, поэтому оба вышеприведённых варианта имеют право на существование.

Модуль Neoway M590E

Технические характеристики:
Частоты: EGSM900/DCS1800 Dual-band, or GSM850/1900 or Quad-band
Чувствительность: -107dBm
Максимальная мощность передачи: EGSM900 Class4(2W), DCS1800 Class1(1W)
Пиковый ток:
Рабочий ток: 210мА
Ток в спящем режиме: 2.5мА
Рабочая температура: -40°C… +85°C
Рабочее напряжение: 3.3V… 4.5V (рекомендуемое 3.9V)
Протоколы: GSM/GPRS Phase2/2+, TCP/IP, FTP, UDP etc.
Интернет: GPRS CLASS 10
Даташит:

Самый дешёвый GSM-модуль, что можно найти на рынке, как правило б/у, выпаянный не всегда ловкими китайскими руками с оборудования. Почему не всегда ловкими? Да всё из-за выпайки феном - нередко людям эти модули приходят с закороченным плюсом и минусом, что является одной из причин их неработоспособности. Поэтому первым делом необходимо прозванивать контакты питания на короткое замыкание.

Примечание. Отдельный немаловажный, на мой взгляд, момент хотелось бы отметить - эти модули могут приходить с круглым коаксиальным разъёмом под антенну, что позволяет отдельно заказать антеннку посерьёзнее и без плясок с бубном её к модулю подключить. А могут приходить и без этого разъёма. Это если говорить о самых дешёвых наборах. Если не хочется уповать на счастливую случайность, то есть наборы чуть подороже, где этот разъём присутствует + в комплекте идёт внешняя антенна на текстолитовой плате.

Этот модуль к тому же ещё и капризен до питания, поскольку в пике он потребляет до 2А тока, а диод, идущий в комплекте, вроде как задуман для понижения напряжения с 5В (почему и написано на самой плате 5В) до 4.2В, но судя по жалобам народа, он создаёт больше хлопот, чем пользы.
Допустим этот модуль у вас уже собран, а вместо диода впаяна перемычка, поскольку мы не собираемся подавать на него напряжение 5В, а будем питать его напрямую от литиевого аккумулятора, что укладывается в пределы допустимых напряжений 3.3-4.2В.
Надо будет его как-то ещё подключить к компьютеру, и проверить на работоспособность. Для этого случая лучше заранее прикупить себе - посредством него мы будем общаться с модулем и платами Arduino по последовательному интерфейсу UART (USART).
Подключение показано ниже на картинке (нарисовал, как умею):
TX модема >>> RX конвертера
RX модема <<< TX конвертера
Плюс аккумулятора - Плюс модема
Минус литиевого аккумулятора объединён с GND модема и GND конвертера
Для запуска модема вывод BOOT через резистор 4.7 кОм подать на GND


Тем временем, на компьютере запустить программу . Обратить внимание на настройки:
1) Выбрать COM-порт, к которому подключен TTL-конвертер, в моём случае это COM4, у вас может быть другой.
2) Выбрать скорость обмена данными. (Тут есть нюанс, ибо сами модули могут быть настроены под разные скорости, чаще всего 9600 бод или 115200 бод. Здесь нужно подбирать опытным путём, выбрав какую-то скорость, соединившись, и отправив команду АТ, если в ответ приходят крякозябры, то отключится, выбрать другую скорость и повторить команду. И так, пока не придёт в ответ ОК).
3) Выбрать длину пакета (в данном случае 8 бит), бит чётности отключен (none), стоп-бит (1).
4) Обязательно поставить галку +CR , и тогда к каждой посылаемой нами на модуль команде в конце будет автоматически добавляться символ переноса каретки - модуль понимает команды только с этим символом в конце.
5) Соединение, тут всё понятно, нажали и можем работать с модулем.

Если нажать на «Соединение» и после этого запустить модуль, подав BOOT через резистор 4.7К на землю, то сперва в терминале высветится надпись «MODEM:STARTUP», затем, через некоторое время надпись"+PBREADY", означающая, что была прочтена телефонная книга, несмотря на то, что она может быть пустой:

Под этим спойлером АТ-команды с примерами

Печатаем команду AT - в ответ модуль нам присылает нашу команду, поскольку включен режим эха, и OK:

Проверим статус модема командой AT+CPAS - в ответ опять наша команда, +CPAS: 0 и ОК.
0 - означает, что модуль готов к работе, но в зависимости от ситуации могут быть и другие цифры, например 3 – входящий звонок, 4 – в режиме соединения, 5 – спящий режим. По 1 и 2 информации не нашёл.

Изменение скорости передачи данных по UART происходит командой AT+IPR=9600 - это если нужна скорость 9600. Если какая-то другая, аналогично AT+IPR=19200 к примеру или AT+IPR=115200.

Проверим сигнал сети. AT+CSQ, в ответ приходит +CSQ: 22,1 - значение до запятой имеет диапазон 0… 31 (115… 52дБл) - это уровень сигнала, чем больше, тем лучше. Но 99 означает его отсутствие. Значение после запятой - качество сигнала 0… 7 - здесь уже наоборот, чем число меньше, тем лучше.

Отключим режим эха, отправив команду ATE0, чтобы дублирующие команды не мешались. Обратно этот режим включается командой ATE1.

Посмотреть версию прошивки AT+GETVERS



Эти и многие другие команды можно посмотреть

Совмещение плат

Если Pro Mini припаять к макетной плате труда не составляет, то с GSM-модулем дело обстоит несколько сложнее, т.к. контактная гребёнка у него расположена только лишь с одной стороны и если припаять только её, то другая сторона платы останется просто висеть в воздухе. Тогда, опять же на глаз пришлось сверлить дополнительные 3 отверстия возле трёх углов на плате. Затем области вокруг каждого из отверстий были зачищены от маски. Для удобства, на беспаечную макетную плату (белую) поместил разъединённые выводы от гребёнки и, установив на них плату GSM-модуля нормально запаял:

Позже пришлось делать ещё одно отверстие, в моём случае на букве «I», где написано «Мade In China», с краю платы.


Получилось так, что добавленный контакт, который по сути является GND, стал находится рядом c GND платы Pro Mini, и тем самым появилась возможность объединить землю GSM-модуля и Pro Mini каплей припоя (длинный вывод посередине и справа от него вывод Pro Mini) - стрелочками их отметил. Кривовато конечно вышло, зато надёжно теперь держится:



Между платами осталось некоторое пространство - в него я поместил плату контроля заряда разряда лития с предварительно выпаянным microUSB-разъёмом и припаянными проводами.

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



Стойки для платы

Чтобы надёжно закрепить плату внутри корпуса, пришлось потратить пару дней на раздумия, как это можно реализовать. Вариант с термоклеем не рассматривался по нескольким причинам - он может отвалиться, деформироваться и самое главное - конструкция получилась бы трудно разбираемой.
Пришёл к мысли, что самым простым и правильным вариантом здесь будет применить стойки, которых естественно у меня не было. Однако было пару нерабочих зарядников, откуда было выпилено по одной длинной стойке с резьбой под саморезы. Каждая стойка была распилена пополам допилена напильником до примерно 9.5мм - именно при такой высоте расположенный под платой аккумулятор имеет достаточный запас, примерно в 2мм - это сделано для того, чтобы паянные контакты платы своими остриями не касались него и чтобы была возможность вложить между ними кусочек поролона для фиксации.
Что касается прикрепления платы непосредственно к корпусу, то здесь нарезал четыре полоски из банки из-под кофе, на концах которых просверлил по отверстию, затем закрепил их на тех же саморезах, которые вкручены в стойки. Ниже на фото посмотрите, как это выглядит.
Следующий этап - прикрутить пару стоек с другой стороны платы, то есть сверху, чтобы при закрытом корпусе, крышка слегка упиралась в эти стойки, создавая дополнительную фиксацию. Чуть позже, под это дело мне в руки попался корпус из-под советского пропагандистского радио (если бы он нашёлся раньше - все стойки взял бы отсюда), где нашёл парочку более-менее подходящих по высоте, но сперва я их по центру рассверлил дрелью под саморезы. Потом спилил их и также допилил напильником, убрав излишки. Тут у меня вышла одна тонкость - на фото можно заметить, что одна белая стойка прикручена к гетинаксовой плате с краю, а другая белая - непосредственно к плате модуля, т.к. с одного края плата модема полностью закрывает собой плату нижнюю, а с противоположного края - наоборот - выглядывает уже нижняя. При этом в обеих платах пришлось дополнительно рассверливать отверстия, чтобы шляпки саморезов могли свободно пройти.
Ну и наконец, осталось сделать так, чтобы плата всегда была параллельна корпусу - под это дело замечательно подошли скобы, которые применяют для фиксации проводов и кабелей на стене, гвозди из них я предварительно извлёк. Скобы хорошо цепляются к плате вогнутой стороной без каких-либо дополнительных приспособлений, единственное - справа от SIM-карты, ширина скобы оказалась избыточной и пришлось её также отшлифовать.
Все детали подгонялись на глаз и опытным путём, ниже фото всего вышесказанного:



Разъёмы. Светодиоды. Кнопка.

Так как гребёнка у меня закончилась, пришлось с платы DVD-привода демонтировать 6-пиновый разъём, который припаял затем к Pro Mini, это для удобства перепрошивки платы. Рядом же припаял круглый разъём (нокиевский 3.5мм) для заряда лития.

Корпус 6-пинового разъёма немного допилил напильником, ибо его края немного выступали над корпусом. Гнездо зарядки идеально плотно упёрлось в стенку корпуса.

С другой стороны платы припаял кнопку для перезагрузки устройства и два светодиода для отладки прошивки - красный светодиод подключен к GSM-модулю, второй зелёный светодиод к 10-му выводу Pro Mini - по нему мне проще отлаживать программу.

Доработка аккумулятора

Плоский нокиевский аккумулятор от телефонов Nokia не менее распространённый элемент, чем 18650, однако многие попросту отказываются от его использования из-за неудобства подключения контактов, которые на самом аккумуляторе утоплены вглубь. Паять их нежелательно, поэтому решено было воспользоваться способом, предложенным этими , а именно сделать из канцелярского ластика и медной проволоки (толщиной 1.5мм) контактную колодку самому.
Сперва проткнул кусочек ластика двумя проволоками с предварительно зачищенными концами, и прикинул к контактам аккумулятора, чтобы расстояние между ними совпадало,
кончики загнул, залудил паяльником, а за длинные концы чуть вытащил назад, чтобы полученные контакты оказались утоплены в ластик.



Примерка на аккумуляторе:

Закрепить контактную колодку можно канцелярской резинкой или замотать синей изолентой, что я и сделал в итоге.

Сборка.

Основная часть работы сделана, осталось всё это собрать и зафиксировать.
Между аккумулятором и платой вложил кусочек поролона, чтобы тот не елозил потом внутри корпуса. На питание модуля я дополнительно припаял конденсатор на 2200 мкФ.

При подключенной зарядке:

Корпус. Внешний клеммник.

Корпус заимел на местном радиорынке примерно за 1.5$, если перевести в доллары, размером 95x60x25мм, практически с пачку сигарет. В нём я просверлил несколько отверстий. Сперва для 4-х контактного клеммника, взятого от неработающего диммера.
Два крайних контакта я полностью освободил от болтов с прокладками, просверлил отверстия под более длинные болты, на которых весь клеммник и будет держаться на корпусе. На самом же корпусе, понятно дело, два крайних отверстия будут большими, а два посередине поменьше - в них будут продеты контакты, один из которых подключен к VCC Pro Mini, а второй контакт к пину 2.

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

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

Плата в корпусе с подключенным шлейфом USB-TTL конвертера:

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

Ну и совсем в сборе с подключенной зарядкой выглядит так:

Тест. Как это работает:

Помимо тестов с антенками я проверял, как будет себя вести сигнализация на улице, в мороз -15. Для этого я просто поместил внутренности целиком в контейнер и оставлял на балконе на ночь, сигнализация при этом не стартовала, причина оказалась в общем-то очевидна - литий не любит мороз. Это подтвердилось другим тестом, где аккумулятор я оставлял дома, а плату через длинные провода выводил на улицу и оставлял так на сутки в тот же мороз - срабатывание, как ни в чём не бывало. С другой стороны было бы странно, если бы сигнализация не заработала т.к. в даташитах что на атмегу, что на модуль, что на кварц - допустимые температуры работы до -40 градусов.

Принцип работы организован по внешнему прерыванию, изначально пин 2 замкнут на VCC и тем самым на выводе поддерживается логический 1, а контроллер спит. Как только контакт нарушается и на пине 2 появляется 0, микроконтроллер просыпается, опускает 3-й пин (к которому через резистор подключен BOOT модема) к земле - запускается модуль, МК периодически опрашивает модуль на готовность, и как только он поймает сеть, сразу посылает вызов на указанный в коде номер телефона хозяина. После отклонения вызова, девайс отключается, не посылая больше бесконечных вызовов, чем грешат многие китайские сигнализации.

Дополнительная информация

#include #include // библиотека программного UART SoftwareSerial gsm(7, 6); // RX(7), TX(6) void wakeUp(){} // пустой обработчик прерывания /////////////////////////////////////////// void gsmOFF(){ // PORTD|=(1<<3); // ВЫКЛЮЧЕНИЕ МОДУЛЯ _delay_ms(10); // gsm.println("AT+CPWROFF"); // ПЕЧАТАЕМ КОМАНДУ OFF PORTB &=~ (1<<2); // выключить LED 10 } // //========================================= void gsmON(){ // PORTD|=(1<<6); // 6-му порту (TX) назначить 1 PORTD &= ~(1<<3); // ЗАПУСК МОДУЛЯ _delay_ms(10); // while(!gsm.find("+PBREADY")); // ждём прочтения тел. книги PORTB |= (1<<2); // включить LED 10 _delay_ms(100); // while(1){ // gsm.println("AT+CREG?"); // проверяем в сети ли модуль if (gsm.find("0,1")) break; // если сеть есть, выходим из цикла _delay_ms(400); // проверка раз в 0,4 сек } // } // /////////////////////////////////////////// // void sleepNow(){ // функция засыпания ADCSRA = 0x00; // отключить подсистему АЦП (экономия 140 мкА) PORTD&=~(1<<6); // в вывод TX поставить 0 _delay_ms(100); // set_sleep_mode(SLEEP_MODE_PWR_DOWN); // режим сна PWR_DOWN sleep_enable(); // включение сна attachInterrupt(0, wakeUp, LOW); // включить прерывания sleep_mode(); // sleep_disable(); // detachInterrupt(0); // отключить прерывания } void setup(){ gsm.begin(9600); // скорость работы UART DDRD = B01001000; // 3-й и 6-й выводы на выход DDRB |= (1<<2); // вывод 10 на выход gsmON(); // запуск модуля для теста gsmOFF(); // выключаем модуль } void loop(){ if (!(PIND&(1<<2))){ // если на 0-ом прерывании появился 0 gsmON(); gsm.println("ATD+79xxxxxxxxx;"); // отзваниваемся, в ответ приходит OK и CONNECT _delay_ms(100); if (gsm.find("OK")) while(1){ // ожидание сброса вызова gsm.println("AT+CPAS"); // при каждой итерации опрашиваем модуль if (gsm.find("0")) break; // если 0, то выходим из цикла while _delay_ms(100); // проверка раз в 0,1 сек } for (char i=0; i<14; i++){ PORTB|=(1<<2); // LED 10 ON _delay_ms(200); PORTB&=~(1<<2); // LED 10 OFF _delay_ms(200); } gsmOFF(); // выключить модуль _delay_ms(10); while(1); // блокируем программу } else { sleepNow(); // укладываем контроллер спать } }

Схема (без платы контроля заряда-разряда)



Выводы и мысли. Планы.

Сигнализация используется на даче, работой удовлетворён, однако с дальнейшим изучением AVR, приходит всё больше идей для дальнейшей ей модификации. Ардуино с его лже-языком Wiring меня сильно расстроила, т.к. обнаружился один неприятный момент в работе. Когда я использовал функции для работы с портами digitalWrite(); или pinMode(); - то GSM-модуль почему-то очень часто зависал. Но стоило заменить их на выкрутасы вроде DDRB|=(1<Только лишь операция прямого обращения к портам заставила заработать девайс, как и было задумано.

По энергосбережению...
Собранный девайс отработал четыре полных месяца без подзарядки и продолжает работать, хотя правильнее сказать «спать». Проверяется это простой перезагрузкой через белую кнопку. При энергопотреблении 250 мкА (через стабилизатор LE33) и аккумуляторе ~1430 mAh, хотя ладно, ввиду неновизны аккумулятора округлим до 1000mAh, получается, что девайс может отсыпаться около 5.5 месяцев без подзарядки. Если всё-таки выпаять стабилизатор, то время работы можно смело умножить в 10 раз. Но в моём случае в этом нет нужды, т.к всё равно нужно раз в три месяца тратить баланс с симки, заодно и девайс можно проверить и подзарядить.
Приведённый в обзоре пример энергосбережения - далеко не предел, т.к. судя по информации из даташита, можно понизить тактовую частоту микроконтроллера (а делается это установкой фьюзов) до 1МГц и, если подать 1.8В напряжения, то потребление опустится ниже планки 1мкА в активном режиме. Весьма недурно! Но если МК при этом будет тактироваться от внутреннего RC-генератора, то появится другая проблема - эфир UART окажется засорен мусором и ошибками, особенно если контроллер нагреть или охладить.

По доработке...
1) Обычная проволока, установленная на разрыв не совсем удобна, планирую поэкспериментировать с датчиком Холла и герконом, хотя про последний говорят, что не шибко надёжен, ибо контакты внутри него могут залипнуть.
2) Неплохо было бы добавить возможность смены «номера хозяина» без участия компьютера и перепрошивки. Это уже с EEPROM придётся поработать.
3) Попробовать прерывания от сторожевого таймера, но не просто любопытства ради, а чтобы микроконтроллер периодически просыпался сам, делал замеры напряжения аккумулятора и отправлял полученное значение по SMS, чтобы быть в курсе насколько аккумулятор разряжен.
4) Солнечная панель может и вовсе избавить от необходимости подзаряжать девайс, это будет актуально особенно для малоёмких аккумуляторов.
5) Ещё давно хотел прикупить LiFePo4 аккумуляторы, которые по отзывам нормально переносят мороз, да вот пока искал годный лот, весна уже незаметно наступила.
6) Поработать над эстетической составляющей

Какую Pro Mini купить?
Если фена нет, то Pro Mini «RobotDyn» Atmega168PA 3.3V, чем-то острым сковыриваете светодиод и имеете ~250мкА.
Если есть фен, то любую плату, выпаиваете стабилизатор и светодиод по питанию - получаете ~20мкА потребления тока.

На этом пока всё, надеюсь, обзор был интересен и полезен.

Планирую купить +174 Добавить в избранное Обзор понравился +143 +278

Всем привет, сегодня мы рассмотрим устройство под названием датчик движения. Многие из нас слышали об этой штуке, кто то даже имел дело с этим устройством. Что же такое датчик движения? Попробуем разобраться, итак:

Датчик движения, или датчик перемещения - устройство (прибор) обнаруживающий перемещение каких либо объектов. Очень часто эти устройства, используются в системах охраны, сигнализации и мониторинга. Форм факторов этих датчиков существует великое множество, но мы рассмотрим именно модуль датчика движения для подключения к платам Arduino, и именно от фирмы RobotDyn. Почему именно этой фирмы? Я не хочу заниматься рекламой этого магазина и его продукции, но именно продукция данного магазина была выбрана в качестве лабораторных образцов благодаря качественной подаче своих изделий для конечного потребителя. Итак, встречаем - датчик движения (PIR Sensor) от фирмы RobotDyn:


Эти датчики малы по габаритам, потребляют мало энергии и просты в использовании. Кроме того - датчики движения фирмы RobotDyn имеют еще и маркированные шелкографией контакты, это конечно мелочь, но очень приятная. Ну а тем кто использует такие же датчики, но только других фирм, не стоит беспокоиться - все они имеют одинаковый функционал, и даже если не промаркированы контакты, то цоколёвку таких датчиков легко найти в интернете.

Основные технические характеристики датчика движения(PIR Sensor):

Зона работы датчика: от 3 до 7 метров

Угол слежения: до 110 о

Рабочее напряжение: 4,5...6 Вольт

Потребляемый ток: до 50мкА

Примечание: Стандартный функционал датчика можно расширить, подключив на пины IN и GND датчик освещенности, и тогда датчик движения будет срабатывать только в темноте.

Инициализация устройства.

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

Угол и область обнаружения.

Угол обнаружения(слежения) составляет 110 градусов, диапазон расстояния обнаружения от 3 до 7 метров, иллюстрация ниже показывает всё это:

Регулировка чувствительности(дистанции обнаружения) и временной задержки.

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


Подключение датчика:

  • PIR Sensor - Arduino Nano
  • PIR Sensor - Arduino Nano
  • PIR Sensor - Arduino Nano
  • PIR Sensor - для датчика освещенности
  • PIR Sensor - для датчика освещенности

Типичная схема подключения дана на схеме ниже, в нашем случае датчик показан условно с тыльной стороны и подключен к плате Arduino Nano.

Скетч демонстрирующий работу датчика движения(используем программу ):

/* * PIR Sensor -> Arduino Nano * PIR Sensor -> Arduino Nano * PIR Sensor -> Arduino Nano */ void setup() { //Установить соединение с монитором порта Serial.begin(9600); } void loop() { //Считываем пороговое значение с порта А0 //обычно оно выше 500 если есть сигнал if(analogRead(A0) > 500) { //Сигнал с датчика движения Serial.println("Есть движение!!!"); } else { //Нет сигнала Serial.println("Всё тихо..."); } }

Скетч является обычной проверкой работы датчика движения, в нём есть много недостатков, таких как:

  1. Возможные ложные срабатывания, датчику необходима самоинициализация в течение одной минуты.
  2. Жесткая привязка к монитору порта, нет выходных исполнительных устройств(реле, сирена, светоиндикация)
  3. Слишком короткое время сигнала на выходе датчика, при обнаружении движения необходимо программно задержать сигнал на более долгий период времени.

Усложнив схему и расширив функционал датчика, можно избежать вышеописанных недостатков. Для этого потребуется дополнить схему модулем реле и подключить обычную лампу на 220 вольт через данный модуль. Сам же модуль реле будет подключен к пину 3 на плате Arduino Nano. Итак принципиальная схема:

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

/* * PIR Sensor -> Arduino Nano * PIR Sensor -> Arduino Nano * PIR Sensor -> Arduino Nano * Relay Module -> Arduino Nano */ //relout - пин(выходной сигнал) для модуля реле const int relout = 3; //prevMillis - переменная для хранения времени предидущего цикла сканирования программы //interval - временной интервал для отсчета секунд до выключения реле unsigned long prevMillis = 0; int interval = 1000; //DelayValue - период в течение которого реле удерживается во включенном состоянии int DelayValue = 10; //initSecond - Переменная итерации цикла инициализации int initSecond = 60; //countDelayOff - счетчик временных интервалов static int countDelayOff = 0; //trigger - флаг срабатывания датчика движения static bool trigger = false; void setup() { //Стандартная процедура инициализации порта на который подключен модуль реле //ВАЖНО!!! - чтобы модуль реле оставался в первоначально выключенном состоянии //и не срабатывал при инициализации, нужно записать в порт входа/выхода //значение HIGH, это позволит избежать ложных "перещелкиваний", и сохранит //состояние реле таким, каким оно было до включения всей схемы в работу pinMode(relout, OUTPUT); digitalWrite(relout, HIGH); //Здесь всё просто - ждем когда закончатся 60 циклов(переменная initSecond) //продолжительностью в 1 секунду, за это время датчик "самоинициализируется" for(int i = 0; i < initSecond; i ++) { delay(1000); } } void loop() { //Считать значение с аналогового порта А0 //Если значение выше 500 if(analogRead(A0) > 500) { //Установить флаг срабатывания датчика движения if(!trigger) { trigger = true; } } //Пока флаг срабатывания датчика движения установлен while(trigger) { //Выполнять следующие инструкции //Сохранить в переменной currMillis //значение миллисекунд прошедших с момента начала //выполнения программы unsigned long currMillis = millis(); //Сравниваем с предидущим значением миллисекунд //если разница больше заданного интервала, то: if(currMillis - prevMillis > interval) { //Сохранить текущее значение миллисекунд в переменную prevMillis prevMillis = currMillis; //Проверяем счетчик задержки сравнивая его со значением периода //в течение которого реле должно удерживаться во включенном //состоянии if(countDelayOff >= DelayValue) { //Если значение сравнялось, то: //сбросить флаг срабатывания датчика движения trigger = false; //Обнулить счетчик задержки countDelayOff = 0; //Выключить реле digitalWrite(relout, HIGH); //Прервать цикл break; } else { //Если значение всё еще меньше, то //Инкрементировать счетчик задержки на единицу countDelayOff ++; //Удерживать реле во включенном состоянии digitalWrite(relout, LOW); } } } }

В программе присутствует конструкция:

unsigned long prevMillis = 0;

int interval = 1000;

...

unsigned long currMillis = millis();

if(currMillis - prevMillis > interval)

{

prevMillis = currMillis;

....

// Наши операции заключенные в тело конструкции

....

}

Чтобы внести ясность, было решено отдельно прокомментировать эту конструкцию. Итак, данная конструкция позволяет выполнить как бы параллельную задачу в программе. Тело конструкции срабатывает примерно раз в секунду, этому способствует переменная interval . Сначала, переменной currMillis присваивается значение возвращаемое при вызове функции millis() . Функция millis() возвращает количество миллисекунд прошедших с начала программы. Если разница currMillis - prevMillis больше чем значение переменной interval то это означает, что уже прошло более секунды с начала выполнения программы, и нужно сохранить значение переменной currMillis в переменную prevMillis затем выполнить операции заключенные в теле конструкции. Если же разница currMillis - prevMillis меньше чем значение переменной interval , то между циклами сканирования программы еще не прошло секунды, и операции заключенные в теле конструкции пропускаются.

Ну и в завершение статьи видео от автора:

Пожалуйста, включите javascript для работы комментариев.

Её автор хотел выполнить самоделку, чтобы она была дешевой и беспроводной.
Эта самоделка использует PIR датчик движения, а передача информации происходит при помощи RF модуля.

Автор хотел воспользоваться инфракрасным модулем, но так как он имеет ограниченную дальность действия, и плюс может работать только на линии прямой видимости приемником, поэтому он выбрал RF модуль, при помощи которого можно добиться дальности приблизительно 100 метров.


Для того, чтобы посетителям было удобнее просматривать сборку сигнализации, я решил поделить статью на 5 этапов:
Этап 1: Создание передатчика.
Этап 2: Создание приемника.
Этап 3: Установка программного обеспечения.
Этап 4: Тестирование собранных модулей.
Этап 5: Сборка корпуса и установка в него модуля.

Все что понадобилось автору, это:
- 2 платы ARDUINO UNO/ARDUINO MINI/ARDUINO NANO для приёмника и передатчика;
- RF приёмопередающий модуль (433 MHZ);
- PIR датчик движения;
- 9В батарейки (2 штуки) и коннекторы к ним;
- Зуммер;
- Светодиод;
- Резистор с сопротивлением 220 Ом;
- Макетная плата;
- Джамперы/провода/перемычки;
- Монтажная плата;
- Межплатные штыревые соединители;
- Переключатели;
- Корпуса для приёмника и передатчика;
- Цветная бумага;
- Монтажный скотч;
- Наборной скальпель;
- Термоклеевой пистолет;
- Паяльник;
- Кусачки /инструмент для снятия изоляции;
- Ножницы по металлу.


Этап 1.
Начинаем создание передатчика.
Ниже предоставлена схема работы датчика движения.


Сам передатчик состоит из:
- Датчика движения;
- Платы Arduino;
- Модуль передатчика.


Сам датчик имеет три вывода:
- VCC;
- GND;
- OUT.

После чего, проверил работу датчика


Внимание!!!
Перед загрузкой прошивки, автор убеждается в том, что в настройках Arduino IDE верно установлена текущая плата и последовательный порт. После чего загрузил скетч:

Позже, как датчик движения зафиксирует движение перед собой, засветится светодиод, а также в мониторе вы сможете увидеть соответствующее сообщение.


По схеме чуть ниже.


Передатчик имеет 3 вывода (VCC, GND, и Data), соединяем их:
- VCC > 5В выводом на плате;
- GND > GND ;
- Data > 12 выводом на плате.

Этап 2.


Сам приёмник состоит из:
- Модуля RF приёмника;
- Платы Arduino
- Зуммера (динамика).

Схема Приемника:


Приемник, как и передатчик, имеет 3 вывода (VCC, GND, и Data), соединяем их:
- VCC > 5В выводом на плате;
- GND > GND ;
- Data > 12 выводом на плате.


Этап 3.
Основой всей прошивки автор выбрал файл-библиотеки. Скачал, который он , и поместил его в папку с библиотеками Arduino.

ПО для передатчика.
Перед тем, как загружать код прошивки в плату, автор выставил следующие параметры IDE:
- Board -> Arduino Nano (или та плата, которую вы используете);
- Serial Port ->


После установки параметров, автор скачал файл прошивки Wireless_tx и загрузил его на плату:

ПО для приемника
Автор повторяет те же действия и для принимающей платы:
- Board -> Arduino UNO (или та плата, которую вы используете);
- Serial Port -> COM XX (проверьте com порт, к которому подключено ваша плата).



После того как автор установил параметры, скачивает файл wireless_rx и загружает его в плату:


После, при помощи программы, которую можно скачать , автор сгенерировал звук для зуммера.

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


Этап 5.
Финальная сборка передатчика
Сначала автор срезал выступающие выводы с приемника, передатчика, плат arduino, и т. д.


После чего, соединил плату arduino с датчиком движения и RF передатчиком при помощи джамперов.


Далее автор начал делать корпус для передатчика.

Сначала он вырезал: отверстие для выключателя, а также круглое отверстие для датчика движения,после чего приклеил его к корпусу.




Потом автор свернул лист цветной бумаги, и приклеил на лицевую крышку образа, для того чтобы скрыть внутренние части самоделки.


После чего, автор начал вставлять электронную начинку внутрь корпуса, при помощи двухстороннего скотча.



Финальная сборка приемника
Автор решил соединить плату Arduino с монтажной платой резиновой лентой, а также установим RF приемник.


Далее автор вырезает на другом корпусе два отверстия, одно для зуммера, другое для выключателя.


И приклеивает.


После чего, автор устанавливает на все детали джамперы.




Потом автор вставляет готовую плату в корпус, и фиксирует ее двухсторонним клеем.

Являются специальными аппаратными платформами, на основе которых можно создавать различные электронные устройства, включая и . Устройства этого типа отличаются простой конструкцией и возможностью программирования алгоритмов их работы. Благодаря этому, созданная с помощью Arduino GSM сигнализация, может максимально настраиваться под объект, который она будет охранять.

Что собой представляет модуль Arduino?

Arduino реализуются в виде небольших плат, которые имеют собственный микропроцессор и память. На плате также располагается набор функциональных контактов, к которым можно подключать различные электрифицированные устройства, включая и датчики, используемые для охранных систем.

Процессор Arduino позволяет загружать в себя программу, написанную пользователем самостоятельно. Создавая собственный уникальный алгоритм, можно обеспечивать оптимальные режимы работы охранных сигнализаций для разных объектов и для разных условий использования и решаемых задач.

Сложно ли работать с Arduino?

Модули Arduino отличаются высокой популярностью среди многих пользователей. Это стало возможным благодаря своей простоте и доступности.

Программы для управления модулями пишутся с использованием обычного C++ и дополнений в виде простых функций управления процессами ввода/вывода на контактах модуля. Кроме этого, для программирования может применяться и бесплатная программная среда Arduino IDE, функционирующая под Windows, Linux или Mac OS.

С модулями Arduino существенно упрощена процедура сборки устройств. GSM сигнализация на Ардуино может создаваться без потребности в паяльнике – сборка происходит с использованием макетной доски, перемычек и проводов.

Как создать сигнализацию с помощью Arduino?

К основным требованиям, которым должна отвечать созданная gsm сигнализация на Ардуино своими руками относятся:

  • оповещать владельца объекта о взломе или проникновении;
  • поддержке внешних систем типа звуковая сирена, сигнальные фонари;
  • управление сигнализацией через СМС или звонок;
  • автономная работа без внешнего питания.

Для создания сигнализации потребуется:

  • модуль Arduino;
  • набор функциональных датчиков;
  • или модем;
  • источник автономного питания;
  • внешние исполнительные устройства.

Отличительной особенностью модулей Ардуино является использование специальных плат расширения. С их помощью осуществляется подключение всех дополнительных устройств к Arduino, которые требуются для сборки конфигурации охранной системы. Такие платы устанавливаются поверх модуля Ардуино в виде «бутерброда», а уже к самим платам подключаются соответствующие вспомогательные устройства.

Как это работает?

При срабатывании одного из подключенных датчиков происходит передача сигнала к процессору модуля Arduino. Используя загруженный пользовательский софт, микропроцессор производит его обработку по определенному алгоритму. В результате этого может формироваться команда на срабатывание внешнего исполнительного устройства, которая передается к нему через соответствующую плату расширения-сопряжения.

Чтобы обеспечить возможность оправки предупредительных сигналов владельцу дома или квартиры, которые охраняются, к модулю Arduino, через плату расширения, подключается специальный модуль GSM. В него устанавливается SIM-карта одного из провайдеров сотовой связи.

При отсутствии специального GSM-адаптера его роль может выполнять и обычный мобильный телефон. Кроме отправки СМС-сообщений с предупреждением о тревоге и дозвона, наличие сотовой связи позволит управлять GSM сигнализацией на Ардуино дистанционно, а также контролировать состояние объекта, отправляя специальные запросы.

«Обратите внимание!

Для связи с владельцем объекта, кроме GSM-модулей могут использоваться и обычные модемы, которые обеспечивают связь через интернет.»

В таком случае, когда срабатывает датчик, обработанный процессором сигнал, передается через модем на специальный портал или сайт. А уже из сайта осуществляется автоматическое генерирование предупредительной СМС или рассылки на привязанный e-mail.

Выводы

Использование модулей Arduino позволит пользователям самостоятельно проектировать GSM-сигнализации, которые могут работать с разно функциональными датчиками и управлять внешними устройствами. Благодаря возможности применения различных датчиков функции сигнализации можно существенно расширить и создать комплекс, который будет следить не только за безопасностью объекта, а и за его состоянием. Например, можно будет контролировать температуру на объекте, фиксировать утечку воды и газа, перекрывать их подачу в случае аварии и многое другое.