Введение
Эта пожарная сигнализация входит в серию упражнений с образцами кода Intel для Интернета вещей. Здесь используется Intel® IoT Developer Kit, платформа разработки Intel® Edison, облачные платформы, API и другие технологии.
Выполнив это упражнение, разработчики научатся:
- подключать платформу разработки Intel® Edison, предназначенную для создания прототипов и носимых компьютерных устройств и решений Интернета вещей;
- подключаться к интерфейсу ввода-вывода платформы Intel® Edison и хранилищу датчиков с помощью MRAA и UPM из пакета Intel® IoT Developer Kit, представляющего собой полный набор аппаратных и программных компонентов, помогающих разработчикам изучать возможности Интернета вещей и создавать современные проекты;
- запускать этот образец кода в интегрированной среде разработки Intel® XDK IoT Edition, предназначенной для создания приложений, взаимодействующих с датчиками и приводами, и помогающей быстро приступить к разработке программного обеспечения для платы Intel® Edison и Intel® Galileo;
- настраивать сервер веб-приложения для размещения данных пожарной сигнализации с помощью Azure Redis Cache* в Microsoft* Azure*, настраивать облачные решения Интернета вещей, включая решения для анализа данных, машинного обучения и различных рабочих инструментов, чтобы упростить процесс подключения датчиков к облаку и помочь быстрее запустить проект Интернета вещей;
- вызывать службы API Twilio* для отправки СМС-сообщений.
Что это такое
В этом проекте, используя плату Intel® Edison, можно создать пожарную сигнализацию, обладающую следующими возможностями:
- Непрерывное отслеживание температуры воздуха.
- Вывод звукового сигнала при срабатывании.
- Вывод визуального уведомления при срабатывании.
- Отслеживание событий срабатывания сигнализации с помощью облачного хранилища данных.
- Отправка СМС-сообщений для оповещения получателей о возможном возгорании.
Как это работает
Эта пожарная сигнализация отслеживает температуру воздуха с помощью датчика температуры Grove*.
Если температура превышает заданный порог (в данном примере это 28 градусов по Цельсию), то сигнализация срабатывает, включается звуковой сигнал, а на ЖК-экран выводится оповещение.
Кроме того, сигнализация может отправить СМС-сообщение на указанный номер телефона с помощью Twilio*, чтобы предупредить получателя о возможной опасности.
Кроме того, система может записывать события срабатывания сигнализации с помощью хранилища IoT Examples и учетной записи Microsoft* Azure*.
Требования к оборудованию
Комплект Grove* Starter Kit Plus.
- Плата Intel® Edison с коммутационной платой Arduino*
- Датчик температуры Grove*
- Пищалка Grove*
- Цветной ЖК-экран Grove*
Требования к программному обеспечению
- Intel® XDK IoT Edition
- Учетная запись Microsoft* Azure*
- Учетная запись Twilio*
Инструкции по настройке
Чтобы приступить к работе, скопируйте хранилище How-To Intel IoT Code Samplesс помощью Git* на компьютер следующим образом:
$
git
clone
https://
github.
com/
intel-
iot-
devkit/
how-
to-
code-
samples.
git
Нужно загрузить ZIP-файл? В веб-браузере перейдите по адресу https://github.com/intel-iot-devkit/how-to-code-samplesи нажмите кнопку Download ZIPв правой нижней части экрана. После загрузки ZIP-файла распакуйте его и используйте файлы в папке этого примера.
Добавление программы в Intel® XDK IoT Edition
В Intel® XDK IoT Edition выберите Import Your Node.js Project.
Затем перейдите в папку примера проекта и выберите его.
Нужно подключить плату Intel® Edison к компьютеру, чтобы отправлять на нее код.
Щелкните меню IoT Deviceв левой нижней части экрана. Если плата Intel® Edison автоматически распознана, выберите ее.
В противном случае выберите Add Manual Connection. В поле Addressвведите 192.168.2.15
. В поле Portвведите 58888
. Щелкните Connect, чтобы сохранить подключение.
Установка программы вручную на плату Intel® Edison
Можно установить код на плату Intel® Edison вручную.
Скопируйте хранилище How-To Intel IoT Code Samplesна плату Intel® Edison после установки SSH-подключения к этой плате:
$ git clone https://github.com/intel-iot-devkit/how-to-code-samples.git
Затем перейдите в папку с примером.
Чтобы установить Git* на плату Intel® Edison, если это еще не сделано, установите SSH-подключение к плате и выполните следующую команду:
$
opkg
install
git
Подключение датчиков Grove*
Нужно подключить плату Grove* Shield к коммутационной плате, совместимой с Arduino*, и подключить все устройства Grove* к плате Grove* Shield. Убедитесь, что маленький переключатель VCC на плате Grove* Shield установлен в положение 5V.
Подключите один конец кабеля Grove* к датчику температуры Grove*, а другой — к порту A0 на плате Grove* Shield.
Подключите один конец кабеля Grove* к пищалке Grove*, а другой — к порту D5 на плате Grove* Shield.
Подключите один конец кабеля Grove* к цветному ЖК-экрану Grove*, а другой — к любому порту I2C на плате Grove* Shield.
Ручная настройка платы Intel® Edison
При запуске этого кода на плате Intel® Edison вручную необходимо установить зависимые компоненты.
Для получения модулей Node.js*, необходимых для запуска этого примера программы на плате Intel® Edison, выполните следующую команду:
npm install
Ключ API Twilio*
Для отправки СМС-сообщений необходимо зарегистрировать учетную запись и получить ключ API на веб-сайте Twilio*:
Для отправки СМС-сообщений нужно сначала получить ключ API Twilio*. Этот пример программы будет работать и без ключа, но в этом случае не будет СМС-сообщений.
Передайте ключ API Twilio* и маркер проверки подлинности в пример программы, изменив параметры TWILIO_ACCT_SID
и TWILIO_AUTH_TOKEN
в файле config.json
следующим образом:
{"TWILIO_ACCT_SID": "YOURAPIKEY","TWILIO_AUTH_TOKEN": "YOURTOKEN"
}
Настройка сервера Microsoft* Azure*
При желании можно хранить данные, созданные этим образцом программы, во внутренней базе данных, развернутой с помощью Microsoft* Azure*, Node.js* и хранилища данных Redis*.
Сведения о настройке собственного облачного сервера данных см. по адресу
https://github.com/intel-iot-devkit/intel-iot-examples-datastore
Настройка примера программы
Чтобы настроить этот пример для отправки СМС-сообщений, получите ключ API на веб-сайте Twilio*, как описано выше, и измените параметры TWILIO_ACCT_SID
и TWILIO_AUTH_TOKEN
в файле config.json
следующим образом:
{"TWILIO_ACCT_SID": "YOURAPIKEY","TWILIO_AUTH_TOKEN": "YOURTOKEN"
}
Чтобы настроить этот пример для использования хранилища данных Microsoft* Azure*, измените параметры SERVER
и AUTH_TOKEN
в файле config.json
следующим образом:
{"SERVER": "http://intel-examples.azurewebsites.net/logger/fire-alarm","AUTH_TOKEN": "s3cr3t"
}
Чтобы настроить этот пример для использования одновременно и СМС-сообщений, и хранилища данных Microsoft* Azure*, измените параметры TWILIO_ACCT_SID
, TWILIO_AUTH_TOKEN
, SERVER
и AUTH_TOKEN
в файле config.json
следующим образом:
{"TWILIO_ACCT_SID": "YOURAPIKEY","TWILIO_AUTH_TOKEN": "YOURTOKEN","SERVER": "http://intel-examples.azurewebsites.net/logger/fire-alarm","AUTH_TOKEN": "s3cr3t"
}
Запуск программы с помощью Intel® XDK IoT Edition
Перед запуском сохраните все файлы.
Щелкните значок Upload, чтобы отправить файлы на плату Intel® Edison.
Щелкните значок Runв нижней части окна Intel® XDK IoT Edition. В этом случае код будет запущен на плате Intel® Edison.
Если вы внесли изменения в код, щелкните Upload and Run. В этом случае на плате Intel® Edison будет запущена последняя версия кода со всеми изменениями.
При запущенной программе на экране появится текст, аналогичный показанному выше.
Запуск программы вручную
Чтобы запустить пример программы на плате Intel® Edison вручную, установите SSH-подключение к этой плате и выполните следующую команду:
node
index.
js
Определение IP-адреса платы Intel® Edison
Определить IP-адрес подключенной платы Intel® Edison можно с помощью следующей команды:
ip
addr
show |
grep
wlan
На экране появится приблизительно следующий текст:
3: wlan0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000 inet 192.168.1.13/24 brd 192.168.1.255 scope global wlan0
IP-адрес показан после слова inet
. В приведенном выше примере используется IP-адрес 192.168.1.13
.
Полный список образцов кода Intel для Интернета вещей см. на сайте Intel® Developer Zone.
Дополнительные сведения об этом образце кода см. в GitHub*.
Дополнительные сведения об оптимизации компиляторов см. в уведомлении об оптимизации.