嵌入式爱好者

查看: 25304|回复: 0

[评测] 【飞凌嵌入式 OK3399-C 开发板试用体验】(.NET CORE的跨平台使用)

[复制链接]

4

主题

4

帖子

49

积分

LS1043A\46A通行证RK3399通行证LS1028A通行证AM335x通行证i.MX RT通行证

扫一扫,手机访问本帖
发表于 2020-9-6 18:43:23 | 显示全部楼层 |阅读模式
本帖最后由 fcb5511 于 2020-9-9 13:59 编辑

在使用QT实现了三个自定义控件后,我又查找了QT环境下实现可视化图表的一些优秀开源方案,发现QCustomPlot是一个不错的开源库,移植后效果也还不错。后面会继续尝试把基本的自定义控件做完,整个界面的组态也会在后面继续做下去。
这一次本来是想尝试在OK3399-C上移植OpenVINO,刚好手里有一块Neural Compute Stick2可以做加速。奈何在开源版的OpenVINO移植过程中困难重重,各种依赖库缺乏,以及现有的软件版本冲突,反反复复的切换版本,配置环境,虽然最后编译和安装都成功了,但是在运行demo程序时,始终不能完成模型的下载。引用openvino库编写的python程序提示无法加载cv2模块,安装cv2提示找不到满足需求的版本,更难过的是NCS2的SDK在RK3399平台上也不支持,完全不能安装,真的是一次一次的打击信心,最终还是放弃了。
还是拥抱微软吧,做一个TCP Modbus通讯服务,服务程序通过json配置生成多线程模块,每路通讯的IO层,协议解析层,数据应用层分离达到去耦合的目的。应用层数据最终发送到RabbitMQ消息队列服务器,局域网内以及路由的下一层网络中的设备可通过连接MQ获取所有通讯数据。源代码是基于windows下的.NET CORE开发的。可以轻松移植到linux系统下。

安装.NET CORE3.0,从微软官方https://dotnet.microsoft.com/download/dotnet-core/3.0获取SDK和runtime。这里以sdk-3.0.103和runtime3.0.3为例
获取dotnet-sdk-3.0.103-linux-arm64.tar.gzwget https://download.visualstudio.microsoft.com/download/pr/eb4ffaf1-b0a9-466d-8440-0220dca8f806/48df585d8d978c5418fa514da6a2bd9b/dotnet-sdk-3.0.103-linux-arm64.tar.gz 1.png 获取dotnet-runtime-3.0.3-linux-arm64.tar.gzwget https://download.visualstudio.microsoft.com/download/pr/24687337-74b3-4897-89e4-eec2a743fb70/e12c8e9decba2cadc31e6358c2dad9da/dotnet-runtime-3.0.3-linux-arm64.tar.gz 2.png
在/root目录下创建dotnet-arm64目录
mkdir /root/dotnet-arm64
解压上面的两个包至dotnet-arm64目录
tar zxf dotnet-runtime-3.0.3-linux-arm64.tar.gz -C $HOME/dotnet-arm64
tar zxf dotnet-sdk-3.0.103-linux-arm64.tar.gz -C $HOME/dotnet-arm64


将.NET Core加入环境变量
export DOTNET_ROOT=$HOME/dotnet-arm64
export PATH=$PATH:$HOME/dotnet-arm64

执行dotnet --info命令查看环境变量添加情况,出现以下信息说明配置成功。
3.png

在windows环境下搭建好项目工程,并通过NuGet安装好程序所需要的package,该项目工程用到的package有RabbitMQ.Client,Newtonsoft.Json。整个工程项目的windows搭建我是在visual studio code完成。
10.png


整个代码结构按照IO层,协议层,应用层结构进行功能解耦合。各层间数据通过队列进行数据交互,应用层数据最终进到MQ服务器。所有单元模块根据json配置文件生成一个独立线程。
5.png

Json配置文件目录结构
6.png
其中ApplicationserverConfig用来定位应用层模块的json配置路径,IOserverConfig用来定位IO层模块json配置路径,ProtocolserverConfig用来定位协议层模块的json配置路径。

在保证程序能在windows下正常运行的情况下,将工程移入OK3399-C开发板。进入到工程目录,通过.NET CORE命令运行程序。

dotnet run

远端modbus slave服务器我是放到了本地计算机,开了四个端口,OK3399端服务的四个IO层创建四个TCPClient连接到远端服务器。实际使用中根据需要可增加数量,增加的越多,cpu的使用率,内存,网络带宽占用也就越高。
7.png

OK3399数据到发送到MQ端,任何设备通过MQ声明队列绑定到OK3399的upexchange即可获取到modbus数据。
8.png
通过top命令可查看protocol程序运行状态
9.png



1.png
4.png
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋| 飞凌嵌入式 ( 冀ICP备12004394号-1 )

GMT+8, 2024-12-23 00:07

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表