上位机图像处理和嵌入式模块部署(树莓派4b的提高版)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】

        目前人工智能非常火,但是人工智能需要极高的算力和海量的数据,因此相关的关联公司非常吃香,nvidia就是提供算力的一家公司。大家都知道,nvidia的游戏显卡非常厉害,但是大家不了解的是,nvidia的嵌入式开发板jetson系列也非常不错。至少从性能上说,jetson系列的开发板还是非常不错的,n个大核arm cpu,还有不少的gpu资源。

        不过要说jetson开发板的缺点,无非就是这么三个,第一,发热比较大;第二,价格比较贵;第三,产品供应存在风险。客户如果追求性能,并且是小批量使用,对成本不太敏感的话,个人还是非常推荐jetson系列开发板。和树莓派4b相比,nvidia的gpu资源就是最大的杀手锏。这次,我们以jetson Xavier nx做一个介绍。

1、价格

        一般来说,nano的价格会比较便宜一点,其他类型的板子,一般都在几千元上下。目前手上的这个nx开发板,当时的购买价格应该是5000左右。这还不是最贵的,如果是orin系列的开发板,价格甚至会到上万元。所以,这方面大家根据自己的经济能力灵活进行选择。

2、系统镜像

        从电商网站上面购买到的jetson开发板,一般系统镜像都是安装好的。此外还会额外带一个ssd存储,所以系统软件这方面,不需要我们担心。

3、创建用户、配置静态ip

        拿到板子之后,插好电源、插好键盘和鼠标、接好hdmi、上电之后,第一步要做的事情,就是创建第一个用户。比如说,我们第一个创建的用户是lidar,密码也是lidar。

        此外,对于我个人而言,不太习惯用屏幕进行系统操作,所以这个时候还会配置一个静态ip。一般的做法,就是直接找到eth0,通过鼠标选择manual设置ip的方式,把ip设置为192.168.0.97即可。后期,我们如果需要访问jetson,直接和它配置在同一个网段,用网线和pc直连,用ssh登录就可以访问。       

        默认jetson里面的系统软件,已经开启了ssh服务。

4、下载软件

        本身nx是同时支持wifi和有线网口的。这边为了方便,就直接通过有线网口直接插入到路由器端口了。当然也需要把路由器配置在192.168.0.*网段。我们的pc也连到这个路由器上面,后续通过ssh登录到jetson,用apt install就可以下载需要的软件了。

         当然,喜欢使用wifi的朋友,可以用nmcli配置一下,也是可以的,

sudo nmcli dev wifi list
sudo nmcli dev wifi connect NETGEAR86 password "88888888" ifname wlan0
sudo nmcli dev dis wlan0

5、默认安装的软件

        jetson本质上已经和一台pc没什么区别了,里面默认安装了gcc、g++、make和gdb等工具,我们要做的就是使用好这些工具。

6、资料的上传和下载

        在jetson系统里面,sftp服务已经开启了。这个时候我们只需要找一个支持sftp协议的客户端就可以实现资料的上传、下达了。比如说,mobaxterm就支持sftp协议。

7、支持opencv

        前面我们已经配置好了网络环境,所以如果需要进行opencv开发,比较简单,直接输入下面这行命令就可以了,

sudo apt-get install libopencv-dev

8、安装pcl库

        pcl,全称point cloud library,也就是点云库。本身安装pcl库依赖于几百个第三方库,如果pcl都可以安装了,那代表整个系统、软件库和编译环境就基本ok了。安装方法和opencv差不多,直接输入下面这个命令就可以了,

sudo apt-get install libpcl-dev

9、网站开发

        个人写网站比较喜欢用python去处理,框架使用webpy。所以,直接输入这个命令即可,

sudo apt-get install python3-webpy

10、pyqt5开发

        有的时候,我们需要开发qt界面程序。这种情况下,用c++来开发又显得有点笨重。所以,为了偷懒,我们可以通过pyqt5来完成对应界面的开发。因为之前安装libpcl-dev的时候,pyqt5已经安装好了,所以可以编写一个demo.py,用python3.6 demo.py执行一下即可。在mobaxterm上面,对应的窗口是可以显示的。

11、docker安装

        开机启动后,我们通过ifconfig看到了docker0的ip信息,这说明docker已经安装好了。

lidar@lidar-desktop:~/Desktop$ ifconfig
docker0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500inet 172.17.0.1  netmask 255.255.0.0  broadcast 172.17.255.255ether 02:42:51:c1:79:b5  txqueuelen 0  (Ethernet)RX packets 0  bytes 0 (0.0 B)RX errors 0  dropped 0  overruns 0  frame 0TX packets 0  bytes 0 (0.0 B)TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

        既然有了docker,那么可以验证和测试一下相关功能,比如运行hello-world、或者运行ubuntu,

sudo docker run hello-world
sudo docker run -it ubuntu bash

12、安装ros1

        安装ros1的方法,目前我们是利用docker来完成的,这主要也是为了防止不同ubuntu版本之间的差异。因为,现在ros版本和ubuntu的版本都是一一对应的。所以,这里可以找一个kinetic版本测试验证一下,如果没有问题的话,就可以进行ros1的开发了。

sudo docker pull ros:kinetic-robot
sudo docker run -it  --rm ros:kinetic-robot /bin/bash

13、编写驱动代码hello.ko

        首先,我们准备hello.c文件,

#include <linux/init.h>
#include <linux/sched.h>
#include <linux/module.h>MODULE_LICENSE("GPL");
MODULE_AUTHOR("feixiaoxing");
MODULE_DESCRIPTION("This is just a hello module!\n");static int __init hello_init(void)
{printk(KERN_EMERG "hello, init\n");return 0;
}static void __exit hello_exit(void)
{printk(KERN_EMERG "hello, exit\n");
}module_init(hello_init);
module_exit(hello_exit);

        接着我们准备Makefile文件,

ifneq ($(KERNELRELEASE),)
obj-m := hello.oelse
PWD  := $(shell pwd)
KVER := $(shell uname -r)
KDIR := /lib/modules/$(KVER)/build
all:$(MAKE) -C $(KDIR) M=$(PWD) modules
clean:rm -rf .*.cmd *.o *.mod.c *.ko .tmp_versions
endif

        直接输入make,不出意外的话,可以生成ko文件。接着就可以通过sudo insmod hello.ko和sudo rmmod hello的方法分别添加和删除驱动。为了验证驱动是否添加、删除成功,可以通过sudo dmesg的方法进行确认。

14、总结    

        因为写这篇文章的原因,发现现在jetson系列性能又更强了。不过算力要求不是特别严苛的话,个人觉得nano版本就够了,价格在2500上下,算力20t,这还是可以接受的。比纯硬件能力更重要的,是通过软件把开发板的性能发挥出来,这比什么都重要。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/701119.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据结构与算法学习笔记十---链队列的表示和实现(C语言)

目录 前言 1.什么是链队 2.链队的表示和实现 1.定义 2.初始化 3.销毁 4.清空 5.空队列 6.队列长度 7.获取队头 8.入队 9.出队 10.遍历队列 11.完整代码 前言 本篇博客介绍链栈队列的表示和实现。 1.什么是链队 链队是采用链式存储结构实现的队列。通常链队使用单…

nginx 发布静态资源

一. nginx 发布静态资源 在nginx中nginx.conf配置文件中添加内容如下&#xff1a; server {listen 90;server_name localhost;# 配置静态资源文件&#xff0c;就可以访问了location / {root /home/fooie-shop;index index.html;}# 配置音频和图片资源location /imoo…

用大于meilisearch-java-0.7.0.jar的报错的解决

Elasticsearch 做为老牌搜索引擎&#xff0c;功能基本满足&#xff0c;但复杂&#xff0c;重量级&#xff0c;适合大数据量。 MeiliSearch 设计目标针对数据在 500GB 左右的搜索需求&#xff0c;极快&#xff0c;单文件&#xff0c;超轻量。 所以&#xff0c;对于中小型项目来说…

Ceph集群扩容及数据再均衡原理分析

用户文件在Ceph RADOS中存储、定位过程大概包括&#xff1a;用户文件切割成对象、对象映射到PG、PG分组PGP、PG映射到OSD。这些过程中&#xff0c;可能涉及了大量概念和变量&#xff0c;而其实它们大部分是通过HASH、CRUSH等算法计算出来的&#xff0c;初始参数可能也就只有这么…

Day28

回溯算法part02 LC组合总和II 终止条件&#xff0c;sumn且mid.size()k加入result。其他终止条件sum>n或者mid.size()>k也结束一样可以引入剪枝操作进行优化&#xff0c;其实sum>n也可以算是剪枝操作的一部分 LC17电话号码的字母组合&#xff08;超时5min&#xff…

Ubuntu 安装chrome和chromedriver

1.安装包下载 百度网盘地址 2.更新软件包 sudo apt-get update 3.安装chrome sudo apt install ./google-chrome-stable_current_amd64.deb 4.检查是否安装成功 google-chrome --version 5.安装chrome-driver驱动&#xff0c;解压zip文件 unzip chromedriver_linux64.z…

如何使用AI总结超长PDF文件?NoteGPT做到了!

NoteGPT&#xff08;PDF Summary with AI - NoteGPT&#xff09;是我在做一个产品&#xff0c;其中一个功能就是如题&#xff0c;总结超长的PDF文件。 这篇文章从业务和技术的角度&#xff0c;来给大家分享下&#xff0c;我是如何实现的。 为什么要做总结总结超长PDF文件&…

【生信技能树】GEO数据挖掘全流程

R包的安装&#xff0c;每次做分析的时候先运行这段代码把R包都安装好了&#xff0c;这段代码不需要任何改动&#xff0c;每次分析直接运行。 options("repos""https://mirrors.ustc.edu.cn/CRAN/") if(!require("BiocManager")) install.packag…

RS422一主多从MAX3490

RS422一主多从MAX3490 最近项目用到了RS422一主多从&#xff0c;一个主机4个从机。芯片用的MAX3490&#xff0c;几经折腾&#xff0c;最终只能从一拖4改为一拖2。 主机发送端&#xff0c;从机4个接收端都是正常的&#xff0c;没有问题。波形非常完美&#xff0c;没有太大变形 …

超级漂亮的 Ai 官网源码

超级漂亮的 AI 官网源码 效果图部分源码领取源码下期更新预报 效果图 部分源码 <script lang"js">function project3D(x, y, z, vars) {var p, dx - vars.camXy - vars.camY - 8z - vars.camZp Math.atan2(x, z)d Math.sqrt(x * x z * z)x Math.sin(p - v…

揭秘奇葩环境问题:IDEA与Maven版本兼容性解析

1.问题描述 最近在实现通过Java爬虫获取网页源码&#xff0c;然后紧接着将源码转换为图片上传到OSS服务器&#xff0c;其中探索了很多办法&#xff0c;但是在实现过程中遇到一个奇葩问题&#xff0c;就是我无论下载任何Maven依赖&#xff0c;都无法正常下载&#xff0c;简直是…