×

使用AI预测太阳能电池板电压输出

消耗积分:0 | 格式:zip | 大小:0.00 MB | 2023-06-27

王越建

分享资料个

描述

伟大的思想协同工作,为人类创造了这一重要资产。从家庭使用到工业活动,电力的发展和发电极大地改变了人们的生活。

尽管它在日常生活中非常重要,但可能很少有人会停下来思考没有电的生活会是什么样子。就像空气和水一样,人们倾向于将电视为理所当然。

不可再生资源和可再生资源用于发电,但不可再生资源在燃烧发电时不能被替代并释放二氧化碳和其他温室气体。

世界各国都在通过采用太阳能、风能和地热能来推动低碳未来。这是一个好兆头,但我们可以通过为家庭和办公室提供一个简单的系统来改善这一点。

目标/目的

太阳能在世界范围内使用并且是可再生的。近 74% 的能源需求由煤炭和天然气供应。可再生能源在确保低排放的可持续能源方面发挥着至关重要的作用。

光伏(PV)和光热发电是两种主要的太阳能发电技术。光伏转换直接从光伏电池中的阳光发电。

在这个项目中,我将使用 SensiML 软件来预测和分析给定光伏 (PV) 模块在特定太阳辐射水平下的电压输出。

QuickFeather 板将由可充电电池 - 锂离子电池供电。

硬件设置

QuickLogic QuickFeather 开发套件

pYYBAGNxJXiAZfg4AArfD_fHiHk388.jpg
 

QuickFeather开发套件是一个小型系统,非常适合支持下一代低功耗机器学习 (ML) 的物联网设备。与其他基于专有硬件和软件工具的开发套件不同,QuickFeather 基于开源硬件,与 Adafruit Feather 外形兼容,并且围绕 100% 开源软件(包括 Symbiflow FPGA 工具)构建。

QuickFeather 由 QuickLogic 的 EOS™ S3 提供支持,这是首款完全支持 Zephyr RTOS 且支持 FPGA 的 Arm Cortex®-M4F MCU

6V 3.5W 太阳能电池板

我将在这个项目中使用 6V 3.5W 太阳能电池板。为防止损坏 QuickFeather 开发套件的 IO 端口,将使用分压器。

光敏电阻

LDR 将用于测量光照水平,并假设光照水平与太阳辐照度水平成正比。

分压器

pYYBAGNxJaSATdZ7AAP2r98VsAw312.jpg
 

代码

对于这个项目,我们需要来自qorc-sdk github 存储库的 qf_ssi_app 自述文件中提供了使用此存储库的说明。

您需要按照 qf_ssi_app 的自述文件中提供的说明来了解如何添加新传感器。您不需要添加传感器,但您必须读取 IO 端口的模拟输入,然后使用模拟读数测量特定辐照度水平下的电压。

Eclipse IDE

我将使用 Eclipse IDE 来构建和调试这个项目。

为了设置 Eclipse IDE 环境,需要以下软件工具和插件。

安装到文件夹 C:\GnuWin32\

笔记:

请确保 PATH 包含“C:\GnuWin32\bin”作为第一个“make 实用程序”。

其他版本的 Make 可能与提供的 Makefile 一起“不起作用”。

为 QORC SDK 推荐的 Eclipse 是用于嵌入式 C/C++ 开发人员的 Eclipse IDE。

打开 Eclipse IDE,在主菜单上选择 Window -> Preferences

在“首选项”对话框中,导航到 MCU ->“全局构建工具路径”

在安装过程中按照上面的设置输入 Build tools 文件夹位置为“C:\GnuWin32\bin”。

构建设置:

在 Eclipse IDE 中,选择要构建的项目

在 Eclipse IDE 的主菜单中:

  • 选择项目 -> 属性
  • 从“ 的属性>”对话框的左窗格中选择 C/C++ Build。

在“构建器设置”选项卡上

  • 取消选择“使用默认构建命令”
  • 在构建命令框中输入以下内容:
make -C ${workspace_loc:/${ProjName}}/../

点击“C/C++ Build”下的子选项“Settings”

选择“工具链”选项卡和下拉名称选项并选择

“用于 ARM 嵌入式处理器的 GNU 工具 (arm-none-eabi-gcc)”

  • 从 C/C++ 构建中选择环境
  • 双击PATH环境变量
  • 将文件夹 C:\GnuWin32\bin 添加到 PATH 环境变量
  • 将安装 ARM GCC 工具链的文件夹添加到 PATH 环境变量中(例如,C:\Program Files (x86)\GNU Tools ARM Embedded\7 2017-q4-major\bin)
  • 选择项目->“构建项目”
  • 将 GCC_project/output/bin 文件夹中的 3 个输出文件添加到虚拟文件夹 GCC_project/output/bin 中(否则您将无法在下一步中选择项目)

将现有 Makefile GCC_Project 转换为 Eclipse 项目

所有 QORC SDK 应用程序都支持 Makefile,并且application_dir/GCC_Project/包含必要的 Makefile。

要将其转换为 Eclipse 项目,可以执行以下步骤:

  • 在应用eclipse_make_project程序的GCC_Project dir.
  • 在应用程序eclipse_custom_build_command.shGCC_Project dir.

将以下内容复制到文件中:

#!/usr/bin/env bash

cd $1
echo $INSTALL_DIR
export PATH="$INSTALL_DIR/quicklogic-arch-defs/bin:$INSTALL_DIR/quicklogic-arch-defs/bin/python:$PATH"
source "$INSTALL_DIR/conda/etc/profile.d/conda.sh"
conda activate
make $2

保存文件,并将其标记为可执行文件chmod +x eclipse_custom_build_command.sh

  • 打开 Eclipse 并选择首选工作区。
  • 对话框中选择,下面选择,然后单击下一步。File -> New -> Project
    New ProjectMakefile project with existing codeC++
  • 在文本框中指定项目名称(“使用您的首选名称”)。在Project Name文本框中指定eclipse_make_project在步骤 [1] 中创建的路径Existing Code Location同时保留CC++选中选项中的选择单击完成Languages
    ARM Cross GCCToolchain for Indexer Settings
  • 将文件和文件夹添加到 Eclipse 虚拟文件系统

从 QORC SDK repo 目录中选择以下目录:File Explorer

  • BSP
  • 哈尔
  • 自由实时操作系统
  • 图书馆
  • 任务

将选定的目录拖放到 Eclipse IDE 中新创建的项目中。

放下后,File and Folder Operation会弹出一个对话框。

选择Link to files and recreate folder structure with virtual folders选项。

确保Check the Create link locations relative to PROJECT_LOC选中该选项。

单击确定。

任何其他 QORC SDK 目录都可以以相同的方式添加到 eclipse 项目中。

  • 创建名为“App”的虚拟文件夹。

确保在 Eclipse IDE 中选择了新创建的项目

选择File -> New -> Folder

指定文件夹名称为App

单击Advanced选项卡并确保选择选项Folder is not located in the file system (Virtual Folder)

点击Finish

从应用程序目录中选择以下File Explorer目录:

  • GCC_项目
  • 源代码
  • 公司

将选定的目录拖放到AppEclipse IDE 中的新虚拟文件夹中。

现在,项目结构已准备就绪。

在头文件 sensor_ssss.h 中定义的宏文件中设置传感器采样率和通道数。

更新 sensor_ssss.cpp 中 json_string_sensor_config 的字符串值定义。

重复相同的过程以获得光敏电阻的读数。

为了读取您的数据,请编辑 qf_ssi_ai_app 目录中 dcl_import.ssf 文件中的配置。

为项目设置构建配置

  • 确保在 Eclipse IDE 中选择了新创建的项目
  • 选择Project -> Properties

- 从左侧窗格中选择 C/C++ Build

选择Builder Settings选项卡

取消选择Use default build command

在文本框中输入以下内容:Build command

${workspace_loc:/${ProjName}}/../eclipse_custom_build_command.sh ${workspace_loc:/${ProjName}}/../

- 选择Settings下的子选项C/C++ Build

选择Toolchains选项卡和下拉Name选项并选择GNU Tools for ARM Embedded Processors (arm-none-eabi-gcc)

- 选择Environment下的子选项C/C++ Build

单击选项Add,输入NameasINSTALL_DIRValueas "Path to the FPGA Toolchain Installation Directory"(与常规设置相同)

点击选项Add,输入NameasPATHValueas"Path to the ARM GCC Toolchain Directory":"$INSTALL_DIR/install/bin:$INSTALL_DIR/install/bin/python:$PATH

点击Apply and Close_Project Properties

  • 右键单击 中的项目Project Explorer,选择Clean Project

您应该能够看到项目已成功清理。

CDT Build Console输出看起来应该与从命令行执行时看到的相同。make clean

  • 右键单击 中的项目Project Explorer,选择您应该能够看到项目构建成功。输出应该与您从命令行执行时看到的相同。Build Project
    CDT Build Consolemake
  • 从应用程序的 GCC_Project/output/ 目录中选择 File Explorer 中的 bin 目录。将所选目录拖放到 Eclipse IDE 中的 App/GCC_Project/output/ 虚拟文件夹中

闪烁 Quickfeather 固件

1. 刷机的初始设置

确保您的系统上安装了 Python。建议安装 Python 3.6 或更新版本。

您将需要 QuickLogic 的 TinyFPGA Programmer 来刷新您的设备。设置计算机以刷新 QuickFeather 板的说明位于 qorc-sdk README 的实用程序部分。

当您下载 TinyFPGA Programmer 时,您需要使用git从 github 克隆 repo。下载 repo 的 zip 版本可能会导致意外结果

2. QuickFeather 按钮

QuickFeather 有两个按钮,USR(用户)和 RST(重置)。它们用于闪烁。在下图中,RST 以橙色突出显示,USR 按钮以紫色突出显示。

poYBAGNxJaiAXvqyAAJ2hSSptNI373.png
 

3. 刷新文件

  • 使用 USB 转 Micro-USB 电缆将 QuickFeather 板连接到计算机。
  • 按下 QuickFeather 板上的“重置”按钮。LED 将呈蓝色闪烁五秒钟。在 LED 仍闪烁蓝色时按下“用户”按钮。按下“用户”按钮后,LED 将开始闪烁绿色。这意味着设备现在处于上传模式。如果 LED 没有闪烁绿色,请重复此步骤
  • 当 LED 闪烁绿色时,通过运行以下命令将数据收集二进制程序编程到 QuickFeather 中:
python /Your-directory-path-to-TinyFPGA-Programmer/tinyfpga-programmer-gui.py --port COMX --m4app /Your-directory-path-to-binary/your-binary-file.bin --mode m4
# Replace COMX with your own device COM port number.
# Replace /Your-directory-path-to-TinyFPGA-Programmer/ and /Your-directory-path-to-binary/ with your computer's file path locations.
# Replace your-binary-file.bin with the name of the file you are flashing.
  • 编程完成后,按下“重置”按钮 LED 应呈蓝色闪烁 5 秒钟并加载选定的应用程序。应用程序加载完成后,LED 将关闭。重置开发板以开始运行 qf_ssi_app 应用程序。

QuickFeather 简单流式传输

串口设置

默认情况下,QuickFeather 固件的 Simple Streaming 版本使用硬件 UART。这意味着必须使用 USB 转 TTL 串行适配器(或另一个 Feather/Wing 进行通信)

为了使用 qf_ssi_ai_app 固件查看数据收集和识别输出,必须对适配器进行相应接线。该适配器将 RXD 插入到引脚 2(白线,橙色框),将 TXD 插入到 J3 上的引脚 3(绿线,紫色框)。

poYBAGNxJauAMfMbAAG-opzbvYU975.png
 

然后您可以在 460800 的 Tera Term、PuTTy 或其他串口程序中打开该端口来测试连接。我已经在讨论区寻求帮助。

未来更新

  • 由于斯里兰卡目前的封锁,我无法购买 Adafruit Huzzah32 - ESP32 Feather 板。

未来,我想:

  • 将此板与 QuickFeather 开发套件一起使用,并将此 POC 转变为 IoT POC。
  • 在各种情况下测试机器学习模型,并将可变数据输入机器学习模型以提高其准确性。
  • 用更高的采样频率试验我的机器学习模型。
  • 通过显示太阳能电池板电压输出来改进我的项目。
  • 添加一个系统来存储和利用太阳能而不是市电。
  • 找到一种自动为为 QuickFeather 开发板供电的锂离子电池充电的方法。

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

评论(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:'使用AI预测太阳能电池板电压输出',//标题 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);