Леса на нашей планете являются ключевым элементом в сохранении природного баланса, предотвращении деструктивных изменений климата. Сохранение лесов является одной из важнейших задач, стоящих перед человечеством. Как известно, ежегодно огромный ущерб лесам наносят пожары, уничтожающие миллионы гектаров растительности. При этом чем раньше пожар удается обнаружить, тем, как правило, проще его потушить. Поэтому в данной статье мы рассмотрим создание системы обнаружения лесного пожара на основе платы Arduino и GSM модуле, которая будет передавать данные о состоянии леса на интернет сервис Thingspeak, который очень хорошо подходит для реализации различных проектов тематики интернета вещей (Internet of Things, IoT). На нашем сайте вы можете посмотреть все проекты с использованием сервиса Thingspeak.
Для связи с интернет сервисом Thingspeak в нашем проекте используется GSM/GPRS модуль, поскольку другие средства радиосвязи (например, радиочастотные модули), применимые в миниатюрной электронике, обычно не обеспечивают в лесу необходимой нам дальности связи.
Необходимые компоненты
- Плата Arduino Nano (купить на AliExpress).
- GSM/GPRS модуль SIM800L (купить на AliExpress).
- Литий-ионная батарейка 3.7V.
- Датчик огня (Flame sensor) (купить на AliExpress).
- Резисторы (купить на AliExpress).
- Перфорированная плата (Dot matrix Perf board).
GSM модуль SIM800L
SIM800L представляет собой компактный модуль, с помощью которого можно осуществлять передачу данных GPRS, передавать/принимать SMS и совершать голосовые звонки. Модуль SIM800L имеет две антенны, поставляемые в комплекте вместе с ним. Первая – это кольцевая антенна и она может быть непосредственно распаяна на плате модуля, а вторая является внешней антенной. Более подробно работу с данным модулем мы рассматривали в статье про автоответчик на основе платы Raspberry Pi.
Основные технические характеристики модуля:
- входное (питающее) напряжение: 3.4V - 4.2V;
- интерфейсы: UART (последовательный порт) и AT команды;
- поддерживаемые частотные диапазоны: 850 / 950 / 1800 /1900 MHz;
- слот для SIM карты: micro SIM;
- разъем антенны: IPX;
- диапазон рабочих температур: от -40 до + 85 ° C.
Структурная схема работы проекта
Ключевым элементом нашего проекта является датчик огня/датчик пламени (flame sensor) подключение которого к плате Arduino мы рассматривали в данной статье. Структурная схема проекта показана на следующем рисунке и включает в себя датчик огня, плату Arduino Nano и GSM/GPRS модуль SIM800L.
Огонь в лесу обнаруживается датчиком огня, который передает эту информацию по цифровому выходу на плату Arduino, которая, в свою очередь, передает эту информацию в сеть интернет (на сервис Thingspeak) с помощью модуля SIM800L.
Принципиальная схема проекта
Схема системы обнаружения лесного пожара на Arduino и GSM модуле представлена на следующем рисунке.
Как показано на схеме, датчик огня подключен к цифровому контакту платы Arduino Nano. Модуль SIM800L подключен к плате Arduino Nano с помощью делителя напряжения поскольку он работает с логическими уровнями 3.3v, а на выходе контактов платы Arduino уровни напряжения составляют 5 В. Модуль SIM800L запитывается отдельно от остальной схемы поскольку он работает от напряжения 3.4-4.2V DC, а питающее напряжение 5V DC с внешнего источника подается на плату Arduino Nano. Двух источников питания в данной схеме можно избежать если использовать преобразователь напряжения (Boost converter).
Настройка аккаунта Thingspeak
После сборки схемы проекта настало время настройки нашей платформы IoT, которая будет принимать наши данные в режиме реального времени. В нашем проекте сервис Thingspeak используется для хранения принимаемых данных и их последующего отображения в виде графиков в графическом интерфейсе пользователя (GUI). Для настройки аккаунта Thingspeak выполните следующую последовательность шагов.
Шаг 1. Регистрация на сервисе Thingspeak.
Перейдите по адресу https://thingspeak.com/ и создайте там себе бесплатный Mathworks account (если у вас его еще нет).
Шаг 2. Создание проекта на Thingspeak.
Войдите в свой аккаунт на Thingspeak и в нем нажмите на “New Channel” (новый канал). Заполните детали создаваемого проекта: имя, описание и необходимые поля. Затем нажмите на “Save channel” (сохранить канал).
Шаг 3. Сохранение необходимых данных.
Выберите в меню свой созданный канал и запишите с него (сохраните в файле) следующие данные, которые в дальнейшем нам пригодятся для разработки программы:
- Channel ID (идентификатор канала), находится вверху страницы канала;
- API key (API ключ), который находится на вкладке API Keys страницы канала.
Шаг 4. Добавление виджетов в графический интерфейс пользователя (GUI).
Нажмите на кнопку “Add Widgets” и добавьте 4 необходимых виджета: средства измерений, цифровые дисплеи и индикаторы. В нашем случае мы использовали индикатор для сигнала тревоги при обнаружении пожара (Fire Alert). Выберите соответствующие имена полей для каждого виджета:
Объяснение программы для Arduino
Полный код программы приведен в конце статьи, здесь же мы кратко рассмотрим его основные фрагменты.
Первым делом в программе нам необходимо подключить используемые библиотеки – в нашем случае это библиотеки “SoftwareSerial.h” и “String.h”.
1 2 |
#include <SoftwareSerial.h> #include <String.h> |
На следующем шаге с помощью библиотеки SoftwareSerial.h сделаем контакты 10 и 11, к которым подключен модуль SIM800L, контактами последовательного канала связи.
1 |
SoftwareSerial gprsSerial(10, 11); |
Далее в функции void setup() зададим режимы работы используемых контактов, режим работы последовательного порта, инициализируем его и модуль SIM800L.
1 2 3 4 5 6 7 8 |
void setup() { pinMode(12, OUTPUT); pinMode(9, INPUT); gprsSerial.begin(9600); // the GPRS baud rate Serial.begin(9600); // the GPRS baud rate Module_Init(); } |
Далее будем использовать AT команды для инициализации модуля SIM800L и определения его состояния. Доступные к использованию AT команды можно найти в даташите на модуль SIM800L. Особого внимания в приведенных ниже командах заслуживает команда “gprsSerial.println("AT+CSTT=\"www\"")”, в которой задается точка доступа к оператору. Убедитесь в том, что в данной команде имя точки доступа (Access point name) заменено на “www”.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
void Module_Init() { gprsSerial.println("AT"); delay(1000); gprsSerial.println("AT+CPIN?"); delay(1000); gprsSerial.println("AT+CREG?"); delay(1000); gprsSerial.println("AT+CGATT?"); delay(1000); gprsSerial.println("AT+CIPSHUT"); delay(1000); gprsSerial.println("AT+CIPSTATUS"); delay(2000); gprsSerial.println("AT+CIPMUX=0"); delay(2000); ShowSerialData(); gprsSerial.println("AT+CSTT=\"www\""); delay(1000); ShowSerialData(); gprsSerial.println("AT+CIICR"); delay(3000); ShowSerialData(); gprsSerial.println("AT+CIFSR"); delay(2000); ShowSerialData(); gprsSerial.println("AT+CIPSPRT=0"); delay(3000); ShowSerialData(); } |
Внутри функции loop() мы будем считывать состояние с контакта 12 платы и сохранять его в переменной fire.
1 |
int fire = digitalRead(12); |
Далее, если будет обнаружен огонь, мы будем передавать соответствующие сообщения на сервер Thingspeak. Команда AT+CIPSTART используется для соединения с сервером Thingspeak и начала соединения. Команда AT+CIPSEND используется для передачи данных на сервер. Но не забудьте в представленном фрагменте программы заменить в поле “Thingspeak write API Key” представленный API ключ на свой API ключ, который вы ранее записали.
1 2 3 4 5 6 7 8 9 |
gprsSerial.println("AT+CIPSTART=\"TCP\",\"api.thingspeak.com\",\"80\"");//start up the connection delay(6000); ShowSerialData(); gprsSerial.println("AT+CIPSEND");//begin send data to remote server delay(4000); ShowSerialData(); String str = "GET https://api.thingspeak.com/update?api_key=ER43PWXXXXXQF0I&field1=" + String(1); Serial.println(str); gprsSerial.println(str);//begin send data to remote server |
После завершения передачи данных команда AT+CIPSHUT используется для закрытия соединения.
1 2 |
gprsSerial.println("AT+CIPSHUT");//close the connection delay(100); |
Тестирование работы проекта
Перед началом работы проекта вставьте в модуль SIM800L SIM карту формата micro SIM как показано на рисунке ниже. Затем подайте питание на модуль и вы увидите как на нем начнет мигать светодиод. Если светодиод начнет мигать медленнее, чем при запуске модуля в работу, это будет означать что модуль обнаружил сеть и готов к соединению к сервером. После этого мы на сервере Thingspeak сможем смотреть состояние нашей системы.
Более подробно работу проекта вы можете посмотреть на видео, приведенном в конце статьи.
Исходный код программы (скетча)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 |
#include <SoftwareSerial.h> SoftwareSerial gprsSerial(10, 11); #include <String.h> int flag = 0; void setup() { pinMode(9, OUTPUT); pinMode(12, INPUT); gprsSerial.begin(9600); // скорость передачи данных с модулем GPRS Serial.begin(9600); // the GPRS baud rate Module_Init(); } void loop() { if (gprsSerial.available()) Serial.write(gprsSerial.read()); int fire = digitalRead(12); if (fire == 0) { digitalWrite(9, HIGH); gprsSerial.println("AT+CIPSTART=\"TCP\",\"api.thingspeak.com\",\"80\"");//start up the connection (начало соединения) delay(6000); ShowSerialData(); gprsSerial.println("AT+CIPSEND");//начинаем передачу данных на удаленный сервер delay(4000); ShowSerialData(); String str = "GET https://api.thingspeak.com/update?api_key=ER43PXXXXXHQF0I&field1=" + String(1); Serial.println(str); gprsSerial.println(str);// начинаем передачу данных на удаленный сервер delay(4000); ShowSerialData(); digitalWrite(9, LOW); gprsSerial.println((char)26);//sending delay(5000);//waitting for reply, important! the time is base on the condition of internet (ждем ответа, важно – время зависит от состояния связи) gprsSerial.println(); ShowSerialData(); gprsSerial.println("AT+CIPSHUT"); // закрываем соединение delay(100); ShowSerialData(); flag = 0; } else { digitalWrite(9, LOW); if (flag == 0) { flag = 1; gprsSerial.println("AT+CIPSTART=\"TCP\",\"api.thingspeak.com\",\"80\"");//начинаем соединение delay(6000); ShowSerialData(); gprsSerial.println("AT+CIPSEND");//начинаем передачу данных на удаленный сервер delay(4000); ShowSerialData(); String str = "GET https://api.thingspeak.com/update?api_key=ER43PWT91CGHQF0I&field1=" + String(0); Serial.println(str); gprsSerial.println(str);// начинаем передачу данных на удаленный сервер delay(4000); ShowSerialData(); digitalWrite(9, LOW); gprsSerial.println((char)26);//sending delay(5000);//waitting for reply, important! the time is base on the condition of internet (ждем ответа, важно – время зависит от состояния связи) gprsSerial.println(); ShowSerialData(); gprsSerial.println("AT+CIPSHUT");//закрываем соединение delay(100); ShowSerialData(); } } } void ShowSerialData() { while (gprsSerial.available() != 0) Serial.write(gprsSerial.read()); delay(5000); } void Module_Init() { gprsSerial.println("AT"); delay(1000); gprsSerial.println("AT+CPIN?"); delay(1000); gprsSerial.println("AT+CREG?"); delay(1000); gprsSerial.println("AT+CGATT?"); delay(1000); gprsSerial.println("AT+CIPSHUT"); delay(1000); gprsSerial.println("AT+CIPSTATUS"); delay(2000); gprsSerial.println("AT+CIPMUX=0"); delay(2000); ShowSerialData(); gprsSerial.println("AT+CSTT=\"www\""); delay(1000); ShowSerialData(); gprsSerial.println("AT+CIICR"); delay(3000); ShowSerialData(); gprsSerial.println("AT+CIFSR"); delay(2000); ShowSerialData(); gprsSerial.println("AT+CIPSPRT=0"); delay(3000); ShowSerialData(); } |