Wio LTE的宠物物流安全卫士设计案例

描述

 

今天小编给大家带来的是来自墨西哥的Maker Victor Altamirano为了解决宠物寄送过程中可能遇到的安全问题,而制作的“Follow My Paws”项目,该项目可以在远程实时向用户发送宠物航空仓的各种信息。

材料清单

硬件:

Seeed Studio Wio LTE

物联网SIM卡

适用于英特尔 Edison 的 Seeed Studio Grove 入门套件 plus

DHT11温湿度传感器

软件:

arduino IDE

SORACOM Funnel

Amazon Web Services AWS IoT

Amazon Web Services AWS Lambda

Amazon Web Services AWS SNS

Amazon Web Services AWS S3

背景

Follow My Paws:

有时我们需要通过包裹服务发送宠物。我们怎么能确保他们出现意外时即使处理呢?。因此,主要问题是:宠物在物流寄送服务中运输时会出现意外情况。但是通常又不得不使用该服务,我们怎么能确保他们在任何时候都没事呢?

解决方案

 

我将制作一个完整的物联网解决方案来监控宠物的环境,以确保它们在整个旅程中的健康。所有这些都与云平台集成,该平台除了实时显示包裹的状态外,还以固定的频率发送通知。

目前的监控解决方案仅限于无生命的包装,这使得对宠物的连续监控成为一种新奇事物。它很有用,因为多亏了这个系统,宠物主人可以 100% 确定他们的宠物会很好,并且可以在整个旅程中监控和跟踪它们。

硬件介绍

要将传感器连接到 WIO,传感器必须具有 Grove 型输入,如以下链接中所示的输入。

https://www.seeedstudio.com/catalogsearch/result/index/?cat=890&q=Grove

对于这个项目,我已经有了“Grove Starter Kit Plus”包,如下图所示。   

 

内容:

DHT11

建立的连接如下:   

DHT11

Grove 软件包中包含的加速度计在连接到 WIO 时没有问题,因为它已经有了它的 Grove 适配器,我不得不破解它是 DHT,因为我们没有 Grove 的 DHT。

加速度计 Grove 版本:

DHT11

DHT No-Grove 版本:   

DHT11

以下是将模块连接到 grove 电缆的方法:   

DHT11

Wio设置

我们将通过将SIM卡连接到适当的插槽中来准备WIO LTE。

DHT11

找到SIM卡的插槽后,将SIM卡插入插槽(是的,保护您的IMEI和其他数据)。   

DHT11

一旦卡完全插入,就会看到这一点。

DHT11

由于我们在WIO LTE中安装了SIM卡,因此我们将天线连接到下图所示的插槽。   

DHT11

完成此操作后,我们将准备好将模块与Arduino IDE一起使用。

Wio Arduino设置:

这是在Arduino IDE上安装WIO LTE的官方指南。非常清晰简洁,强烈建议试用它。

https://github.com/Seeed-Studio/Wio_LTE_Arduino_Library

Arduino软件在Github上。

Soracom平台设置:

检查您的SIM卡是否已经连接到一个组非常重要,就我而言,我称之为Harvest Group。   

DHT11

如果我们没有创建组,我们将创建一个组,如下图所示,如果我们不这样做,我们将无法执行 AWS IoT 配置。

DHT11

自从创建了小组以来,就我而言,我们通过按“Harvest Group”进入小组菜单,一旦进入,我们将看到以下内容。   

DHT11

在组菜单中,我们将输入选项“SORACOM Funnel”,此选项将允许我们访问与AWS服务的连接,所有凭证将在稍后的AWS配置中获得,因此请勿关闭此选项卡(请遵循)。

DHT11

AWS IoT 设置

要与 AWS IoT 通信,我们需要在 IAM 控制台中创建一个角色,以便授权 Soracom 访问我们的控制台。   

第一步是创建一个允许我们与 AWS 通信的角色。

DHT11

在角色配置中,我们需要授予对 AWS IoT 的访问权限。   

DHT11

在这里,我们可以看到可以与此角色一起使用的服务,在本例中,此策略只是一个示例。注意:如果您不确定要获取角色的策略,请选择策略 (AWSIoTFullAccess)。   

DHT11

我们给新角色起了个名字。

DHT11

我们进入 AWS IoT 控制台并转到“设置”部分。   

DHT11

进入“设置”部分后,我们将复制“端点”,这将在 Soracom 控制台选项卡中使用。

下一步是在 AWS IoT 和其他 AWS 服务(如 Lambda、SNS 和 DynamoDB)之间创建连接。因此,为此,我们必须创建一个“规则”,该规则将用于在此服务和上述服务之间建立桥梁。

DHT11

一旦我们有了规则,我们将如图所示对其进行配置。   

DHT11

在此选项卡中,我们将配置数据到达后要激活的 lambda(在完成配置其他服务之前不要关闭)    

DHT11

AWS Lambda 设置

我们创建一个 Lambda,如屏幕上所示(它非常直观,应该没有问题)。   

DHT11

lambda 应该以这种方式看待,使用 lambda 的原因是因为我们需要处理从模块获取的数据,以通过消息和我们的 Web 平台给出响应(执行此过程 2 次,因为我们将配置 2 个 lambda 以连接到 SNS 和 DynamoDB 的服务)    

DHT11

第一个 Lambda SNS 服务:

这是向 SNS 发送通知的代码,稍后将在 SNS 配置中获取 TopicARN。

 

console.log('Loading function'); // Load the AWS SDK var AWS = require("aws-sdk"); // Set up the code to call when the Lambda function is invoked exports.handler = (event, context, callback) => { // Load the message passed into the Lambda function into a JSON object var eventText = JSON.parse(JSON.stringify(event, null, 2)); // Log a message to the console; you can view this text in the Monitoring tab in the Lambda console or in the CloudWatch Logs console // Create a string, extracting the click type and serial number from the message sent by the AWS IoT button // Write the string to the console var temp=parseInt(eventText.temperature) var acc=parseInt(eventText.accelerometer) var moi=parseInt(eventText.moisture) var air=parseInt(eventText.air) var id=eventText.ID var myarray=[0,0,0,0] if(temp<15) { myarray[0]=4 } else if(temp >= 15 && temp < 18) { myarray[0]=3 } else if(temp >= 18 && temp < 19) { myarray[0]=2 } else if(temp >= 21 && temp < 24) { myarray[0]=1 } else if(temp >= 24 && temp < 26) { myarray[0]=2 } else if(temp >= 26 && temp < 28) { myarray[0]=3 } else if(temp >= 28) { myarray[0]=4 } temp=temp*1.8+32 if(acc<3) { myarray[1]=1 } else if(acc >= 3 && acc < 6) { myarray[1]=2 } else if(acc >= 6 && acc < 10) { myarray[1]=3 } else if(acc >= 10) { myarray[1]=4 } if(moi<20) { myarray[3]=4 } else if(moi >= 20 && moi < 30) { myarray[3]=3 } else if(moi >= 30 && moi < 40) { myarray[3]=2 } else if(moi >= 40 && moi < 50) { myarray[3]=1 } else if(moi >= 50 && moi < 65) { myarray[3]=2 } else if(moi >= 65 && moi < 80) { myarray[3]=3 } else if(moi >= 80) { myarray[3]=4 } air=0.5 * (temp + 61.0 + ((temp-68.0)*1.2) + (moi*0.094)) if(air<90) { myarray[2]=1 } else if(air >= 90 && air < 102) { myarray[2]=2 } else if(air >= 102 && air < 122) { myarray[2]=3 } else if(air >= 122) { myarray[2]=4 } var mess=""; if(myarray[3]==1 || myarray[2]==1 || myarray[1]==1 || myarray[0]==1) { mess="Your dog goes in perfect travel conditions" } if(myarray[3]==2 || myarray[2]==2 || myarray[1]==2 || myarray[0]==2) { mess="Your dog is in good condition" } if(myarray[3]==3 || myarray[2]==3 || myarray[1]==3 || myarray[0]==3) { mess="Your dog is fine but the travel conditions are not the best." } if(myarray[3]==4 || myarray[2]==4 || myarray[1]==4 || myarray[0]==4) { mess="Your dog is fine but travel conditions should improve" } // Create an SNS object var sns = new AWS.SNS(); console.log("Received event:",JSON.stringify(myarray, null, 2),air); var params = { Message: mess, TopicArn: "YOURSNSENDPOINT" }; sns.publish(params, context.done); };

 

第二个 Lambda DynamoDB 服务:

这是将数据发送到 DynamoDB 的代码。

 

console.log('Loading function'); var AWS = require("aws-sdk"); exports.handler = (event, context, callback) => { var eventText = JSON.parse(JSON.stringify(event, null, 2)); var temp=parseInt(eventText.temperature) var acc=parseInt(eventText.accelerometer) var moi=parseInt(eventText.moisture) var air=0 var id=eventText.ID var myarray=[0,0,0,0] if(temp<15) { myarray[0]=4 } else if(temp >= 15 && temp < 18) { myarray[0]=3 } else if(temp >= 18 && temp < 19) { myarray[0]=2 } else if(temp >= 21 && temp < 24) { myarray[0]=1 } else if(temp >= 24 && temp < 26) { myarray[0]=2 } else if(temp >= 26 && temp < 28) { myarray[0]=3 } else if(temp >= 28) { myarray[0]=4 } temp=temp*1.8+32 if(acc<3) { myarray[1]=1 } else if(acc >= 3 && acc < 6) { myarray[1]=2 } else if(acc >= 6 && acc < 10) { myarray[1]=3 } else if(acc >= 10) { myarray[1]=4 } if(moi<20) { myarray[3]=4 } else if(moi >= 20 && moi < 30) { myarray[3]=3 } else if(moi >= 30 && moi < 40) { myarray[3]=2 } else if(moi >= 40 && moi < 50) { myarray[3]=1 } else if(moi >= 50 && moi < 65) { myarray[3]=2 } else if(moi >= 65 && moi < 80) { myarray[3]=3 } else if(moi >= 80) { myarray[3]=4 } air=0.5 * (temp + 61.0 + ((temp-68.0)*1.2) + (moi*0.094)) if(air<90) { myarray[2]=1 } else if(air >= 90 && air < 102) { myarray[2]=2 } else if(air >= 102 && air < 122) { myarray[2]=3 } else if(air >= 122) { myarray[2]=4 } // Set the region AWS.config.update({region: 'ap-northeast-1'}); // Create the DynamoDB service object var ddb = new AWS.DynamoDB({apiVersion: '2012-08-10'}); var params = { TableName: 'FMPtemp', Item: { 'ID' : {S: id}, 'Array' : {S: JSON.stringify(myarray, null, 2)} } }; // Call DynamoDB to add the item to the table ddb.putItem(params, function(err, data) {if (err) {} else {}}); };

 

AWS SNS设置

在SNS服务中,我们创建了一个主题    

DHT11

在 SNS 服务中,我们创建了一个主题。

DHT11

由于我们创建了主题,因此我们可以在希望通知到达的位置创建订阅。

DHT11

这是我们可以发送通知的所有方面的一个示例。   

DHT11

为您的第一个 Lambda 保存此 ARN:

DHT11

AWS DynamoDB 设置:

对于这个项目和我们的 WEB 实现,我们需要在 DynamoDB 中创建 2 个表,因为一个表将用作数据存储,另一个表将用于可以在 WEB 平台中使用的临时变量。   

对于此步骤,仅创建了两个表,如图所示:

DHT11

WEB 界面设置

Web 平台可能看起来很简单,但它在与 AWS 交互的方式上有一个非常有趣的实现。

使用网页时最大的问题之一是具有临时变量,因为每次更新页面时,我们都会丢失变量存储的所有信息,但是在我的实现中,我直接从 DynamoDB 中提取数据,这要归功于提供 AWS 的 javascript 开发工具包,因此我可以将信息存储在数据库中, 如上图所示,在名为“FMP”的数据库中,并保存临时变量和快速访问,以便部署和更新网页“FMPtemp”。

在显示网页时,调用FMPtemp数据库实时获取宠物的状态,并根据我们的算法确定宠物的一般状态,将通过颜色通知,如下图所示。   

DHT11

每图标代表以下内容:

温度:环境温度

加速度:最大加速度

空气Q:空气质量

湿润:空气湿气

颜色范围:

DHT11

空气质量是使用以下公式计算的,使用简化版本来计算空气的露点,根据书籍,它必须小于 90:

空气 Q=0.5 * (温度 + 61.0 + ((温度-68.0)1.2) + (湿润 0.094))    

最终产品

我们将温度传感器组装在外壳中。

DHT11

   

DHT11

DHT11

        

DHT11

   

DHT11

   

DHT11

---end---

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分