×

基于Arduino 33 BLE的智慧教室

消耗积分:0 | 格式:rar | 大小:9.54 MB | 2022-12-14

香香技术员

分享资料个

方案介绍

介绍
我们都遇到了到达公共图书馆或共享学习空间的问题,准备学习和工作,却发现没有可用空间。在我们的项目中,我们旨在通过引入一个跟踪座位占用情况的应用程序来解决这个问题,并提前通知您可用空间。

描述
我们的项目由两个主要部分组成,椅子和一个 Android 应用程序。

椅子上牢固地连接着一个 Arduino Nano 33 BLE,它通过人工智能增强程序跟踪椅子的占用情况,该程序已经学习并在我们的坐姿习惯上进行了测试。

蓝牙和 Arduino

对于该项目,我们使用了 Arduino 33 BLE,因为它包含一个蓝牙模块和一个加速度计,这两者都使编写程序更容易,因为外部变量和潜在问题更少。

我们使用预定义的 ArduinoBLE 库初始化 Arduino 的蓝牙连接,然后我们使用示例蓝牙程序的某些部分来帮助我们开始。

我们必须注册一个新的 BLE 服务,通过该服务,数据将以“1”或“0”的字符串形式发送和接收,指示椅子是否被占用。

设置本地名称后,我们只发送电池状态并查看 Arduino 是否连接到手机来测试 BLE 连接。幸运的是它做到了,所以我们进入了项目的下一部分,即机器学习算法。

机器学习细节
为了提供占用检测,我们对用户坐下或站立时产生的特定振动模式实施了边缘机器学习分析。这是使用 Edge Impulse 库完成的。为了提供训练神经网络的良好数据集,我们记录了大约五分钟的标记记录以及测试/验证数据。

在进行神经分析之前,数据被分成两秒的块并使用频谱分析进行参数化。这会产生一个包含 207 个特征的向量,然后将其传递到具有 207 个神经元的输入层。使用具有 96、56 和 30 个神经元的三个隐藏层,最后使用一个具有 3 个神经元的输出层,代表三个分类标签:坐下、站立和空闲。在我们标记的测试数据上,准确率达到了 93%。

然后将分类模型导出为 Arduino 库并与我们的设备固件集成,该固件分析神经网络生成的标签

首先,我们从 Edge Impulse 网站下载了 .zip 库,并打开了一个名为 nano_33ble_sense_accelerometer_continuous 的示例程序。程序持续跟踪椅子的占用情况,并每秒通过串行连接传输状态。我们在实际应用中测试了该程序的准确性,并对结果感到满意,因为它始终检测到正确的条件。

为了接收和显示数据,我们使用了一个 MIT 应用程序发明者开发的安卓应用程序。它是快速原型和开发相当复杂的应用程序的有用工具。

该应用程序有 3 个主要屏幕和功能:

在主屏幕上,您连接到 arduino 的 BT 模块,并可以显示椅子的占用数据。在顶部,您可以选择要检查占用率的库(现在您只选择库并没有真正发生,因为我们还没有实现全局数据库或服务器,您可以将数据保存到其中)访问其他两个屏幕在主页上有两个按钮。

每个页面都有自己的scratch代码,但只是为了了解一下,这里是主屏幕的部分代码,但最后你也可以找到mit app发明者的文件,在那里你可以进一步探索细节的代码。并确定占用状态:空闲或占用。为了提供直接的视觉反馈,控制 RGB LED 以反映占用情况 - 绿色表示空闲,红色表示占用。

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

评论(0)
发评论

下载排行榜

全部0条评论

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

'+ '

'+ '

'+ ''+ '
'+ ''+ ''+ '
'+ ''+ '' ); $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code ==5){ $(pop_this).attr('href',"/login/index.html"); return false } if(data.code == 2){ //跳转到VIP升级页面 window.location.href="//m.obk20.com/vip/index?aid=" + webid return false } //是会员 if (data.code > 0) { $('body').append(htmlSetNormalDownload); var getWidth=$("#poplayer").width(); $("#poplayer").css("margin-left","-"+getWidth/2+"px"); $('#tips').html(data.msg) $('.download_confirm').click(function(){ $('#dialog').remove(); }) } else { var down_url = $('#vipdownload').attr('data-url'); isBindAnalysisForm(pop_this, down_url, 1) } }); }); //是否开通VIP $.get('/article/vipdownload/aid/'+webid,function(data){ if(data.code == 2 || data.code ==5){ //跳转到VIP升级页面 $('#vipdownload>span').text("开通VIP 免费下载") return false }else{ // 待续费 if(data.code == 3) { vipExpiredInfo.ifVipExpired = true vipExpiredInfo.vipExpiredDate = data.data.endoftime } $('#vipdownload .icon-vip-tips').remove() $('#vipdownload>span').text("VIP免积分下载") } }); }).on("click",".download_cancel",function(){ $('#dialog').remove(); }) var setWeixinShare={};//定义默认的微信分享信息,页面如果要自定义分享,直接更改此变量即可 if(window.navigator.userAgent.toLowerCase().match(/MicroMessenger/i) == 'micromessenger'){ var d={ title:'基于Arduino 33 BLE的智慧教室',//标题 desc:$('[name=description]').attr("content"), //描述 imgUrl:'https://'+location.host+'/static/images/ele-logo.png',// 分享图标,默认是logo link:'',//链接 type:'',// 分享类型,music、video或link,不填默认为link dataUrl:'',//如果type是music或video,则要提供数据链接,默认为空 success:'', // 用户确认分享后执行的回调函数 cancel:''// 用户取消分享后执行的回调函数 } setWeixinShare=$.extend(d,setWeixinShare); $.ajax({ url:"//www.obk20.com/app/wechat/index.php?s=Home/ShareConfig/index", data:"share_url="+encodeURIComponent(location.href)+"&format=jsonp&domain=m", type:'get', dataType:'jsonp', success:function(res){ if(res.status!="successed"){ return false; } $.getScript('https://res.wx.qq.com/open/js/jweixin-1.0.0.js',function(result,status){ if(status!="success"){ return false; } var getWxCfg=res.data; wx.config({ //debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId:getWxCfg.appId, // 必填,公众号的唯一标识 timestamp:getWxCfg.timestamp, // 必填,生成签名的时间戳 nonceStr:getWxCfg.nonceStr, // 必填,生成签名的随机串 signature:getWxCfg.signature,// 必填,签名,见附录1 jsApiList:['onMenuShareTimeline','onMenuShareAppMessage','onMenuShareQQ','onMenuShareWeibo','onMenuShareQZone'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2 }); wx.ready(function(){ //获取“分享到朋友圈”按钮点击状态及自定义分享内容接口 wx.onMenuShareTimeline({ title: setWeixinShare.title, // 分享标题 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享给朋友”按钮点击状态及自定义分享内容接口 wx.onMenuShareAppMessage({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 type: setWeixinShare.type, // 分享类型,music、video或link,不填默认为link dataUrl: setWeixinShare.dataUrl, // 如果type是music或video,则要提供数据链接,默认为空 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ”按钮点击状态及自定义分享内容接口 wx.onMenuShareQQ({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到腾讯微博”按钮点击状态及自定义分享内容接口 wx.onMenuShareWeibo({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); //获取“分享到QQ空间”按钮点击状态及自定义分享内容接口 wx.onMenuShareQZone({ title: setWeixinShare.title, // 分享标题 desc: setWeixinShare.desc, // 分享描述 link: setWeixinShare.link, // 分享链接 imgUrl: setWeixinShare.imgUrl, // 分享图标 success: function () { setWeixinShare.success; // 用户确认分享后执行的回调函数 }, cancel: function () { setWeixinShare.cancel; // 用户取消分享后执行的回调函数 } }); }); }); } }); } function openX_ad(posterid, htmlid, width, height) { if ($(htmlid).length > 0) { var randomnumber = Math.random(); var now_url = encodeURIComponent(window.location.href); var ga = document.createElement('iframe'); ga.src = 'https://www1.elecfans.com/www/delivery/myafr.php?target=_blank&cb=' + randomnumber + '&zoneid=' + posterid+'&prefer='+now_url; ga.width = width; ga.height = height; ga.frameBorder = 0; ga.scrolling = 'no'; var s = $(htmlid).append(ga); } } openX_ad(828, '#berry-300', 300, 250);