英特尔物联网代码示例入门: 工厂照明系统

简介

这款工厂自动照明系统应用是一系列英特尔物联网代码示例入门实践(使用英特尔® 物联网开发人员套件、英特尔® Edison 开发平台、API 和其他技术)的一部分。

从该实践中,开发人员可以学习到如何:

  • 连接英特尔® Edison 开发平台;该平台是一个旨在创建原型,生产物联网和可穿戴计算产品的计算平台。
  • 使用英特尔® 物联网开发人员套件中的 MRAA 和 UPM 与英特尔® Edison 平台 IO 和传感器库交互;该套件是一款完整的软硬件解决方案,可帮助开发人员探索物联网和实施创新项目。
  • 在英特尔® XDK 物联网版中运行该代码示例;该工具是一个 IDE,可创建与传感器和制动器交互的应用,支持立即开发面向英特尔® Edison 或英特尔® Galileo 开发板的软件。
  • 使用 Microsoft* Azure* 的 Azure Redis Cache*、连接物联网解决方案(包括数据分析和机器学习)的云服务以及多种简化将传感器连接到云,支持物联网项目快速正常运行的效率提高工具,设置 Web 应用服务器以保存照明系统数据。
  • 调用 Twilio* API 服务以发送文本讯息。

它是什么

使用英特尔® Edison 开发板,该项目支持您创建具备下列功能的自动工厂照明监测器系统:

  • 使用灯光传感器根据可配置时间表检查各自动照明系统的启闭情况;
  • 支持使用手机通过内置 Web 界面访问以设置照明时间;
  • 另外使用连接的湿度传感器监测水位;
  • 使用基于云的数据存储记录照明系统的事件;
  • 如果系统未如预期一样工作,向警报接收者发送文本讯息。

工作原理

该系统支持您使用手机,通过直接由英特尔® Edison 显示的网页设置照明时间表。

如果到了开灯的时间,灯光传感器没有检测到灯光,应用将通过 Twilio*向特定号码发送文本告警。

它还定期自动检查并记录湿度传感器数据。

此外,它还可使用在 Microsoft* Azure* 账户中运行的英特尔物联网示例数据存储 (Intel IoT Examples Datastore) 保存系统事件。

硬件要求

Grove* 室内环境套件,包括:

  1. 带有 Arduino* breakout 开发板的英特尔® Edison
  2. Grove* 湿度传感器
  3. Grove* 灯光传感器
  4. Grove* RGB LCD

软件要求

  1. 英特尔® XDK 物联网版
  2. Microsoft* Azure* 账户
  3. Twilio* 账户

如何设置

首先,使用电脑上的 Git*(如下) 复制英特尔物联网代码示例入门库:

$ git clone https://github.com/intel-iot-devkit/how-to-code-samples.git

想要下载 .zip 文件? 在您的 Web 浏览器中,访问 https://github.com/intel-iot-devkit/how-to-code-samples,并点击右下方的 Download ZIP 按钮。 下载 .zip 文件后,对其进行解压,然后使用目录中的文件(对本例而言)。

将该程序添加至英特尔® XDK 物联网版

在英特尔® XDK 物联网版中,选择 Import Your Node.js Project

然后,导航至该示例项目所在的目录,并选择它:

您需要将电脑连接至您的英特尔® Edison 开发板以向其发送代码。

点击左下角的 IoT Device 菜单。 如果您的英特尔® Edison 被自动识别,选择它。

否则,选择 Add Manual Connection。 在 Address 字段,键入 192.168.2.15。 在 Port 字段,键入 58888。 点击 Connect 以保存连接。

在英特尔® Edison 上手动安装该程序

或者,您可以在英特尔® Edison 开发板上手动设置代码。

与您的英特尔® Edison 开发板建立 SSH 连接,然后将英特尔物联网代码示例入门库复制到该开发板中,如下:

$ git clone https://github.com/intel-iot-devkit/how-to-code-samples.git

然后,导航至该目录(对本例而言)。

如欲在英特尔® Edison 上安装 Git*(若没有),请与该开发板建立 SSH 连接,并运行下列命令:

$ opkg install git

连接 Grove* 传感器

您需要具有连接至兼容 Arduino* 的 breakout 开发板的 Grove* Shield,以便将所有 Grove* 设备插入 Grove* Shield。 确保 Grove* Shield 上的微型 VCC 开关设置为 5V

  1. 将 Grove* 线缆的一端插入 Grove* 灯光传感器,并将其另一端连接至 Grove* Shield 的 A0 端口上。

  2. 将 Grove* 线缆的一端插入 Grove* 湿度传感器,并将其另一端连接至 Grove* Shield 的 A1 端口上。

  3. 将 Grove* 线缆的一端插入 Grove* RGB LCD,并将其另一端连接至 Grove* Shield 的任意 I2C 端口上。

英特尔® Edison 手动设置

如果您在英特尔® Edison 上手动运行该代码,您需要安装一些关联组件。

如欲获得在英特尔® Edison 上执行该示例所需的 Node.js* 模块,请运行下列命令:

npm install

Twilio* API 密钥

如欲选择发送文本讯息,您需要注册一个账户,并从 Twilio* 网站中获取 API 密钥:

https://www.twilio.com/

若未事先获取 Twilio* API 密钥,您无法发送文本讯息, 不过仍然可以运行该示例。

将您的 Twilio* API 密钥和身份验证令牌传送至示例程序,具体方式是修改 TWILIO_ACCT_SIDTWILIO_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

配置该示例

如欲配置示例以选择发送文本讯息,请按照上述说明从 Twilio* 网站中获取 API 密钥,然后修改 TWILIO_ACCT_SIDTWILIO_AUTH_TOKEN 密钥(在 config.json 文件中),如下:

{ "TWILIO_ACCT_SID": "YOURAPIKEY", "TWILIO_AUTH_TOKEN": "YOURTOKEN" }

如欲配置该示例以使用可选的 Microsoft* Azure* 数据存储,请修改 SERVERAUTH_TOKEN 密钥(在 config.json 文件中,如下:

{ "SERVER": "http://intel-examples.azurewebsites.net/logger/lighting-system", "AUTH_TOKEN": "s3cr3t" }

如欲配置该示例以同时使用文本讯息和 Microsoft* Azure* 数据存储,请修改 TWILIO_ACCT_SIDTWILIO_AUTH_TOKENSERVERAUTH_TOKEN 密钥(在 config.json 文件中),如下:

{ "TWILIO_ACCT_SID": "YOURAPIKEY", "TWILIO_AUTH_TOKEN": "YOURTOKEN", "SERVER": "http://intel-examples.azurewebsites.net/logger/lighting-system", "AUTH_TOKEN": "s3cr3t" }

使用英特尔® XDK 物联网版运行该程序

准备好运行该示例时,确保保存了所有文件。

点击 Upload 图标,将文件上传至英特尔® Edison 开发板。

点击英特尔® XDK 物联网版底部的 Run 图标, 在英特尔® Edison 上运行该代码。

如果您修改了该代码,请点击 Upload and Run, 在英特尔® Edison 上运行包含您所做修改的最新代码。

当该程序在运行时,您会看到与上述内容类似的输出信息。

手动运行该程序

如欲在英特尔® Edison 上手动运行该程序,请与该开发板建立 SSH 连接,并执行下列命令:

node index.js

设置照明时间表

使用该示例程序运行时英特尔® Edison 显示的单页 Web 界面设置照明系统的时间表。

该 Web 服务器运行在端口 3000 上,因此,如果英特尔® Edison 连接至 192.168.1.13 上的Wi-Fi*,您在同一网络上时浏览的地址是 http://192.168.1.13:3000

确定英特尔® Edison 的 IP 地址

您可以通过运行下列命令确定英特尔® Edison 所连接的 IP 地址:

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

如欲查看英特尔物联网代码示例入门的完整列表,请访问英特尔开发人员专区

有关该代码示例的更多详情,请访问 GitHub*

 

有关编译器优化的更完整信息,请参阅优化通知