香橙派AIpro快速上线——纯小白体验版本!!!

2024-05-29 19:04

本文主要是介绍香橙派AIpro快速上线——纯小白体验版本!!!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

前言

一、快速上线

官网的样例测试

​编辑解决模型转换问题的步骤

如果系统卡死

二、usb摄像头测试

三、总结

模型转换

小结


前言

香橙派AIpro+ubuntu系统+32G sd卡

香橙派AIpro开发板采用昇腾AI技术路线,接口丰富且具有强大的可扩展性,提供8/20TOPS澎湃算力,可广泛使用于AI边缘计算、深度视觉学习及视频流AI分析、视频图像分析、自然语言处理等AI领域。通过昇腾CANN软件栈的AI编程接口,可满足大多数AI算法原型验证、推理应用开发的需求。

AscendCL(Ascend Computing Language,昇腾计算语言)是昇腾计算开放编程框架,是对底层昇腾计算服务接口的封装,提供Device管理、Context管理、Stream管理、内存管理、模型加载与执行、算子加载与执行、媒体数据处理等API,支持C&C++、Python编程语言,能够实现深度学习推理计算、图形图像预处理、单算子加速计算等能力。

掌握了AscendCL的编程方法,就意味着可以在香橙派AIpro开发板上充分利用昇腾的算力资源,能够基于深度学习算法开发图片分类、目标检测等一系列深度学习推理计算程序。

一、快速上线

wifi或者网线连接网络

官网的样例测试

在服务器任意目录下获取sample仓代码(以/home目录为例)

apt-get install gitgit config --global http.sslVerify "false"git clone https://gitee.com/ascend/samples.git

进入“样例目录”,下文中的“样例目录”均指“samples/cplusplus/level2_simple_inference/1_classification/resnet50_imagenet_classification”目录

cd samples/cplusplus/level2_simple_inference/1_classification/resnet50_imagenet_classification

获取ResNet-50原始模型

pip3 install Pillowmkdir -p caffe_model

将获取的模型文件和权重文件上传至创建的“caffe_model”目录

在“样例目录”下执行如下命令,将ResNet-50原始模型转换为适配昇腾AI处理器的离线模型(*.om文件)

atc --model=caffe_model/resnet50.prototxt --weight=caffe_model/resnet50.caffemodel --framework=0 --output=model/resnet50 --soc_version=Ascend310P3 --input_format=NCHW --input_fp16_nodes=data --output_type=FP32 --out_nodes=prob:0

解决模型转换问题的步骤

使用的是香橙派AI Pro开发板,运行的是Ubuntu 22.04.3 LTS操作系统,并且正在尝试使用昇腾AI技术和CANN(Compute Architecture for Neural Networks)软件栈进行模型转换。

模型转换过程中系统卡死可能有多种原因。以下是一些解决问题的方法:

1. 检查系统资源:
   
   - 确保系统有足够的资源(CPU、内存、存储)来处理转换过程。显示我的系统有7.4 GiB的内存,通常应该足够,但可能存在有其他占用资源较多的进程在同时运行。

2. ATC命令参数:
   
   - 确认提供给`atc`命令的所有参数是否正确并适合您的硬件和模型。
   - 例如,确保`--soc_version=Ascend310P3`适用于自己的设备。如果不适用,请根据实际情况进行调整。

3. CANN和Ascend工具包安装:
   
   - 确保正确安装了CANN和Ascend工具包,并正确设置了所有环境变量。
   - 检查安装的软件版本,确保兼容性。

4. 模型文件:
   
   - 验证`resnet50.prototxt`和`resnet50.caffemodel`文件的完整性和兼容性。
   - 确保这些文件正确放置在`caffe_model`目录中,并且转换工具可以访问这些文件。

5. 日志和调试:
   
   - 查看ATC工具生成的日志(如果有),以识别具体的错误或警告。
   - 可以通过在`atc`命令中添加`--log=debug`来启用详细日志记录,以获取更详细的输出。

6. 依赖项:
   
   - 确保所有必要的依赖项已安装并且是最新的。这包括Python包如Pillow以及ATC工具所需的系统库。

如果系统卡死

- 监控资源使用情况:使用系统监控工具在转换过程中检查CPU和内存的使用情况。
- 在Screen/Tmux会话中运行:如果系统容易卡死,可以在分离会话中运行命令,这样即使主终端无响应,也可以监控日志。

在“样例目录/data”目录下准备样例图片,如果data目录不存在,可在“样例目录”下执行mkdir -p data命令创建。

cd datawget https://obs-9be7.obs.cn-east-2.myhuaweicloud.com/models/aclsample/dog1_1024_683.jpg --no-check-certificatewget https://obs-9be7.obs.cn-east-2.myhuaweicloud.com/models/aclsample/dog2_1024_683.jpg --no-check-certificate

执行下列代码,将jpg转换成bin文件

python3 ../script/transferPic.py

在“样例目录”下执行如下命令配置环境变量

export DDK_PATH=/usr/local/Ascend/ascend-toolkit/latestexport NPU_HOST_LIB=$DDK_PATH/runtime/lib64/stub

在“样例目录”下执行如下命令编译可执行文件。

mkdir -p build/intermediates/hostcd build/intermediates/hostcmake ../../../src -DCMAKE_CXX_COMPILER=g++ -DCMAKE_SKIP_RPATH=TRUEmake

/out目录下,执行如下命令运行编译的文件

./main

模型转换失败的话,就会出现上图所示情况!!!

成功的话就是这样的!!!这部分是在

二、usb摄像头测试

gitclone源码

git clone https://gitee.com/ascend/EdgeAndRobotics.git

安装FFmpeg。

sudo apt-get install ffmpeg libavcodec-dev libswscale-dev libavdevice-dev

装OpenCV。

sudo apt-get install libopencv-dev

进入样例目录

/home/HwHiAiUser/EdgeAndRobotics/Peripherals/Camera/USBCamera/

编译样例源码。 执行编译命令

注意!!!需要将main.cpp文件中摄像头的具体参数改成你的实际的摄像头参数!!不然无法正常采集数据!原始的分辨率是1280*720,我的是640*480

g++ main.cpp -o main -lavutil -lavformat -lavcodec -lavdevice

编译命令执行成功后,在USBCamera样例目录下生成可执行文件main。

运行样例,从Camera获取图像。

 运行可执行文件,其中/dev/video0表示Camera设备,需根据实际情况填写:

./main /dev/video0

 运行成功后,在USBCamera样例目录下生成yuyv422格式、640*480分辨率的out.yuv文件。

当把一个摄像头插入开发板后,执行ls /dev/vi*命令可看到摄像头的vedio节点。这里出现了两个设备节点:/dev/video0、/dev/video1,是因为一个是图像/视频采集,一个是metadata采集,因此本样例中在运行可执行文件时,选择图像/视频采集的设备节点/dev/video0。

检查从Camera获取的图像。

执行如下命令,使用FFmpeg软件查看图像:

ffplay -pix_fmt yuyv422 -video_size 640*480 out.yuv

​图片看上去不太清晰是因为我的摄像头的问题

三、总结

模型转换

昇腾张量编译器(Ascend Tensor Compiler,简称 ATC)是昇腾 CANN 架构体系下的模型转换工具
ATC工具可将开源框架的网络模型(如TensorFlow等)转换为昇腾Al处理器支持的离线模型。支持原始框架类型为Caffe、TensorFlow、MindSpore、ONNX的模型转换,其中ONNX可以看做是一个中间模型,如果其他模型可以转换为ONNX模型那么也可以在使用ATC进行模型转换,例如pytorch模型转换为ONNX模型,ONNX模型再转换为.om文件。
这个部分是我本人特别喜欢的功能!

小结

因为本人基本上属于完全小白,之前只玩过X3板卡,所以本次我也只测试了两张板卡的相同的功能部分!进入系统界面后,空白处滑动鼠标滚轮可以实现切屏,非常丝滑。我目前就试了两个基本的功能,模型转换因为整体系统完全卡死了无法成功转换后续也没有再去跟进了,不过我有把大致的问题解决思路列出来,大家有兴趣的可以看看。usb相机的测试拍摄图片完全ok,不过这种基础功能的实现基本上都差不多。关于散热,相比于X3板卡,加上官网的散热器的香橙派的散热性能更佳!
 

有个小问题,关于USB接口,一共两个,接上鼠标键盘后,其实再接一个usb相机真的不方便!大家如果要试的话,还是蓝牙连接鼠标or键盘会方便些。

这篇关于香橙派AIpro快速上线——纯小白体验版本!!!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1014376

相关文章

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

hdu 4565 推倒公式+矩阵快速幂

题意 求下式的值: Sn=⌈ (a+b√)n⌉%m S_n = \lceil\ (a + \sqrt{b}) ^ n \rceil\% m 其中: 0<a,m<215 0< a, m < 2^{15} 0<b,n<231 0 < b, n < 2^{31} (a−1)2<b<a2 (a-1)^2< b < a^2 解析 令: An=(a+b√)n A_n = (a +

v0.dev快速开发

探索v0.dev:次世代开发者之利器 今之技艺日新月异,开发者之工具亦随之进步不辍。v0.dev者,新兴之开发者利器也,迅速引起众多开发者之瞩目。本文将引汝探究v0.dev之基本功能与优势,助汝速速上手,提升开发之效率。 何谓v0.dev? v0.dev者,现代化之开发者工具也,旨在简化并加速软件开发之过程。其集多种功能于一体,助开发者高效编写、测试及部署代码。无论汝为前端开发者、后端开发者

利用Django框架快速构建Web应用:从零到上线

随着互联网的发展,Web应用的需求日益增长,而Django作为一个高级的Python Web框架,以其强大的功能和灵活的架构,成为了众多开发者的选择。本文将指导你如何从零开始使用Django框架构建一个简单的Web应用,并将其部署到线上,让世界看到你的作品。 Django简介 Django是由Adrian Holovaty和Simon Willison于2005年开发的一个开源框架,旨在简

CentOs7上Mysql快速迁移脚本

因公司业务需要,对原来在/usr/local/mysql/data目录下的数据迁移到/data/local/mysql/mysqlData。 原因是系统盘太小,只有20G,几下就快满了。 参考过几篇文章,基于大神们的思路,我封装成了.sh脚本。 步骤如下: 1) 先修改好/etc/my.cnf,        ##[mysqld]       ##datadir=/data/loc

SAM2POINT:以zero-shot且快速的方式将任何 3D 视频分割为视频

摘要 我们介绍 SAM2POINT,这是一种采用 Segment Anything Model 2 (SAM 2) 进行零样本和快速 3D 分割的初步探索。 SAM2POINT 将任何 3D 数据解释为一系列多向视频,并利用 SAM 2 进行 3D 空间分割,无需进一步训练或 2D-3D 投影。 我们的框架支持各种提示类型,包括 3D 点、框和掩模,并且可以泛化到不同的场景,例如 3D 对象、室

PostgreSQL中的多版本并发控制(MVCC)深入解析

引言 PostgreSQL作为一款强大的开源关系数据库管理系统,以其高性能、高可靠性和丰富的功能特性而广受欢迎。在并发控制方面,PostgreSQL采用了多版本并发控制(MVCC)机制,该机制为数据库提供了高效的数据访问和更新能力,同时保证了数据的一致性和隔离性。本文将深入解析PostgreSQL中的MVCC功能,探讨其工作原理、使用场景,并通过具体SQL示例来展示其在实际应用中的表现。 一、

UE5 半透明阴影 快速解决方案

Step 1: 打开该选项 Step 2: 将半透明材质给到模型后,设置光照的Shadow Resolution Scale,越大,阴影的效果越好

快速排序(java代码实现)

简介: 1.采用“分治”的思想,对于一组数据,选择一个基准元素,这里选择中间元素mid 2.通过第一轮扫描,比mid小的元素都在mid左边,比mid大的元素都在mid右边 3.然后使用递归排序这两部分,直到序列中所有数据均有序为止。 public class csdnTest {public static void main(String[] args){int[] arr = {3,