[嵌入式AI从0开始到入土]16_ffmpeg_ascend编译安装及性能测试

[嵌入式AI从0开始到入土]嵌入式AI系列教程

注:等我摸完鱼再把链接补上
可以关注我的B站号工具人呵呵的个人空间,后期会考虑出视频教程,务必催更,以防我变身鸽王。

第1期 昇腾Altas 200 DK上手
第2期 下载昇腾案例并运行
第3期 官方模型适配工具使用
第4期 炼丹炉的搭建(基于Ubuntu23.04 Desktop)
第5期 炼丹炉的搭建(基于wsl2_Ubuntu22.04)
第6期 Ubuntu远程桌面配置
第7期 下载yolo源码及样例运行验证
第8期 在线Gpu环境训练(基于启智ai协作平台)
第9期 转化为昇腾支持的om离线模型
第10期 jupyter lab的使用
第11期 yolov5在昇腾上推理
第12期 yolov5在昇腾上应用
第13期_orangepi aipro开箱测评
第14期 orangepi_aipro小修补含yolov7多线程案例
第15期 orangepi_aipro欢迎界面、ATC bug修复、镜像导出备份
第16期 ffmpeg_ascend编译安装及性能测试
未完待续…


文章目录

  • [嵌入式AI从0开始到入土]嵌入式AI系列教程
  • 前言
  • 一、卸载ffmpeg
  • 二、前置依赖安装
    • 1、libx264编码器
    • 2、libx265编码器
    • 3、fdk-aac
    • 4、lame
    • 5、speex
  • 三、获取源码
  • 四、编译安装
    • 1、添加环境变量
    • 2、编译配置
    • 3、编译安装
    • 4、验证编码器是否可用
  • 五、性能测试
  • 六、问题
    • 1、安装x265时找不到numa
    • 2、找不到ascend相关的编码器
    • 3、fftools/ffmpeg_opt.c:23:10: fatal error: csignal: No such file or directory
    • 4、xxx.so no found
      • 1、添加环境变量
      • 2、配置动态链接库
  • 总结


前言

注:本文基于香橙派24.02.27日ubuntu_desktop镜像
镜像预装的ffmpeg是4.5.4版本,h265解码1080*1080的mp4视频帧数低至0.8帧。几乎处于不可用的状态。启用h265_ascend编解码器后,能够凭借libx265编解码器不到一半的cpu利用率实现超过20帧的成绩。
镜像预装ffmpeg情况如下,但是没有h265编码器。
在这里插入图片描述
本文测试视频信息如下,统一不处理音频数据。
在这里插入图片描述

ffmpeg -i test.mp4 -s 1920*1080 -c:v libx264 -an out.264

用时3分38秒,cpu利用率几乎全程100%

一、卸载ffmpeg

sudo apt --purge remove ffmpeg
ffmpeg -version	#如下图所示即为卸载成功

二、前置依赖安装

libx264和libx265可以不安装,这里是为了对性能做对比。

1、libx264编码器

没什么好说的,照抄

wget https://code.videolan.org/videolan/x264/-/archive/master/x264-master.tar.bz2
tar jxf x264-master.tar.bz2
cd x264-master
./configure --prefix=/usr --enable-shared --disable-asm

在这里插入图片描述

make -j4
sudo make install
x264 

出现如下提示表示安装成功
在这里插入图片描述

2、libx265编码器

这里我使用的是最新的版本,但是需要修改几个地方,否则配置的时候就会报错。

wget https://www.x265.org/files/x265_v3_3.tar.gz
tar -xf x265_3.3.tar.gz 
cd x265_3.3/build/linux

这里需要修改几个地方,否则配置的时候就会报错。

vim ../../source/CMakeLists.txt
#43行添加aarch64
set(ARM_ALIASES armv6l armv7l aarch64)

在这里插入图片描述
67-75行这里替换整段
在这里插入图片描述

elseif(ARMMATCH GREATER "-1")if("${SYSPROC}" STREQUAL "aarch64")message(STATUS "Detected aarch64 target processor")set(AARCH64 1)add_definitions(-DX265_ARCH_AARCH64=1)else()if(CROSS_COMPILE_ARM)message(STATUS "Cross compiling for ARM arch")else()set(CROSS_COMPILE_ARM 0)endif()message(STATUS "Detected ARM target processor")set(ARM 1)add_definitions(-DX265_ARCH_ARM=1 -DHAVE_ARMV6=1)endif()

接着安装两个包

sudo apt-get install libnuma-dev
sudo apt-get install nasm

接着是是两个包名的问题

vim ../../source/cmake/FindNasm.cmake
#23行
find_package_handle_standard_args(Nasm
vim ../../source/cmake/FindNuma.cmake

将21,26,32,37,41,43行的NUMA改为Numa,修改后如图所示。
在这里插入图片描述

再安装一个包,不然不会出现配置界面

sudo apt-get install cmake-curses-gui
./make-Makefiles.bash

如果上面配置正确,会弹出如下配置界面,请参考下图配置,OFF的选项看需求开启,ON的不要动,会导致编译失败。
在这里插入图片描述
这里使用方向键移动,空格开启/关闭选项,修改完成后,按c配置,确认输出信息如下
此处如果出现libnuma找不到的情况,看问题区第一条。
在这里插入图片描述
按e,g完成配置。
配置完成后,编译安装

make -j4
sudo make install
x265 #验证安装

在这里插入图片描述

3、fdk-aac

fdk-aac 是一个高效、高质量的开源音频编解码器,它实现了 MPEG 高级音频编解码器(AAC)的标准。

wget https://jaist.dl.sourceforge.net/project/opencore-amr/fdk-aac/fdk-aac-2.0.3.tar.gz
tar -zxf fdk-aac-2.0.3.tar.gz
cd fdk-aac-2.0.3
sudo apt-get install autoconf
sudo apt-get install libtool
./autogen.sh
./configure --enable-shared  CFLAGS=-fPIC

配置成功,你将看到如下提示信息
在这里插入图片描述

make -j4
sudo make install
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig/	#建议加到.bashrc里

4、lame

LAME 是一个开源的 MP3 编码器,它的名字最初是作为“LAME Ain’t an MP3 Encoder”的递归缩写。尽管名字中暗示它不是一个 MP3 编码器,但实际上 LAME 是一个非常流行和广泛使用的 MP3 编码库和程序。它允许用户将音频文件转换为 MP3 格式,并提供广泛的编码选项来调整压缩效率和音频质量。

wget https://zenlayer.dl.sourceforge.net/project/lame/lame/3.100/lame-3.100.tar.gz
tar -zxf lame-3.100.tar.gz
cd lame-3.100
./configure --enable-shared
make -j4
sudo make install

5、speex

Speex 是一个开源的音频编解码器,专门设计用于处理语音信号。Speex 非常适合实时通信应用,如VoIP和视频会议系统,因为它可以处理非常短的音频帧,减少传输延迟,Speex 包括噪声抑制、回声消除和增益控制等语音增强功能。

wget https://ftp.osuosl.org/pub/xiph/releases/speex/speex-1.2.1.tar.gz
tar -zxf speex-1.2.1.tar.gz
cd speex-1.2.1
./configure 
make -j4
sudo make install

三、获取源码

这里使用的是昇腾的官方仓库,除了版本有点老,是4.4.1,现在都6.1了。后期我试试移植过去。

git clone https://gitee.com/ascend/mindxsdk-referenceapps.git

四、编译安装

ASCEND_HOME_PATH这个是cann自带的,指向/usr/local/Ascend/ascend-toolkit/latest

1、添加环境变量

这一步能有效解决下面extra-cflagsextra-ldflags报错的问题。

source /usr/local/Ascend/ascend-toolkit/set_env.sh
export LD_LIBRARY_PATH=/usr/lib:/usr/local/Ascend/ascend-toolkit/latest/acllib/lib64:$LD_LIBRARY_PATH

2、编译配置

cd mindxsdk-referenceapps/mxVision/Ascendffmpeg
chmod +x ./configure
chmod +x ./ffbuild/*.sh
#除前5个配置外,其余看需求设置
./configure \--prefix=/usr \--enable-shared \--extra-cflags="-I${ASCEND_HOME_PATH}/acllib/include" \--extra-ldflags="-L${ASCEND_HOME_PATH}/aarch64-linux/lib64" \--extra-libs="-lacl_dvpp_mpi -lascendcl" \--enable-ascend \--enable-gpl \--enable-nonfree \--enable-ffplay \--enable-libfdk-aac \--enable-libmp3lame \--enable-libx264 \--enable-libx265 \--enable-filter=delogo \--enable-debug \--disable-optimizations \--enable-libspeex \--enable-shared \--enable-pthreads \--enable-version3

从这开始就是噩梦,你会发现日志中h264_ascendh265_ascend这俩编解码器都是enable,enable hwaccels中也有h264_ascend。但是编译后就是没有的情况,或者就是存在,但是疯狂报错。解决办法看问题区第2条

3、编译安装

make -j$(nproc)

不出意外的话又要出意外了
在这里插入图片描述
直接看问题区第3点

sudo make install

在这里插入图片描述
到这里安装算完成了,但很可能会有类似找不到libfdk-aac.so.2等的报错,看问题区第4点。

4、验证编码器是否可用

ffmpeg -encoders | grep ascend
ffmpeg -decoders | grep ascend
ffmpeg -hwaccels | grep ascend

确认出现图中的ascend编码器
在这里插入图片描述

五、性能测试

依旧是我们开头的test.mp4视频。

#h264编解码测试
ffmpeg -i test.mp4 -s 1920*1080 -c:v libx264 -an out1.264
ffmpeg -hwaccel ascend -i test.mp4 -s 1920*1080 -c:v h264_ascend -an out_ascend.264#h265编解码测试
ffmpeg -i test.mp4 -s 1920*1080 -c:v libx265 -an out.265
ffmpeg -hwaccel ascend -i test.mp4 -s 1920*1080 -c:v h265_ascend -an out_ascend.265

结果如下

编解码器用时
h2643分39秒
h264_ascend1分39秒
h26540分49秒
h265_ascend1分39秒

实测在h265编码环节,ascend硬件编解码有大约25倍的提升。
注意:这个数据还不是ascend硬件编解码器的极限,全程平均cpu在60%左右,而libx264或libx265几乎跑满了cpu。

六、问题

1、安装x265时找不到numa

这里有两种方案

  1. 检查x265_3.3/source/cmake/FindNuma.cmake这个文件中的NUMA是否被全部替换为了Numa,至少我上文提到的几行必须更改
  2. x265_3.3/build/linux目录下执行以下命令,指定Numa路径。
cmake -D Numa_INCLUDE_DIR=/usr/include/libnuma -D Numa_LIBRARY=/usr/lib/libnuma.so -D Numa_ROOT_DIR=/usr .

2、找不到ascend相关的编码器

这里我也是查了很久,甚至看了N长的编译日志(日志中没有出现ascend相关的信息),最后发现需要在./configure之前添加以下环境变量

export LD_LIBRARY_PATH=${ASCEND_HOME_PATH}/acllib/lib64/:$LD_LIBRARY_PATH	#建议使用下面的绝对路径
export LD_LIBRARY_PATH=/usr/local/Ascend/ascend-toolkit/latest/acllib/lib64/:$LD_LIBRARY_PATH

3、fftools/ffmpeg_opt.c:23:10: fatal error: csignal: No such file or directory

在这里插入图片描述
将这两个文件的报错的地方的csignal改为signal.h

sudo apt-get install build-essential
vim fftools/ffmpeg_opt.c
vim fftools/ffmpeg.c

4、xxx.so no found

这里以libfdk-aac.so.2为例

find / -name 'libfdk-aac.so.2'

我们查到这个文件在/usr/local/lib目录,接着就有两种方案了,推荐第二种,这样所有用户都可以使用。

1、添加环境变量

export LD_LIBRARY_PATH=/usr/lib/:$LD_LIBRARY_PATH
export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH

2、配置动态链接库

sudo vim /etc/ld.so.conf
#将我们搜索到的路径加入其中

在这里插入图片描述

sudo ldconfig

总结

以上就是ffmpeg启用ascend硬件编辑器的相关过程,当然,要想压榨极限性能,建议使用DVPP,不过就是没有这么方便罢了。

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

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

相关文章

前端精准测试调用链路分析

精准测试在评估需求的测试范围时,需要评估一下代码的影响范围,这个范围有两部分:一是需求直接修改的代码;二是修改代码影响到的功能模块。代码影响到的功能一般是通过调用链路分析来实现的,java和kotlin代码可以由java…

Linux/Ubuntu/Debian基本命令:命令行历史记录

一组与类 Unix 环境中的命令行(Terminal)历史记录和命令调用相关的键盘快捷键: Ctrl R: 启动对以前使用过的命令的反向搜索。 当你键入时,它将查找并显示与输入的字符匹配的最新命令。Ctrl G: 退出历史搜索模式,不运行命令。 如…

[CUDA] 使用thrust::sort()函数排序

一、简介 本文介绍了如何使用thrust::sort()函数对device_vector<int>容器&#xff0c;或者int*指针表示的内存&#xff08;显存&#xff09;处的数据进行排序。 二、示例代码 1. 排序 device_vector<int>中的数据 main.cu文件内容&#xff1a; #include <…

前端页面访问后台hiveserver2,阶段性报错

1、运行环境 Windows11下安装VMware&#xff0c;VMware下安装CentOS7 Linux系统&#xff0c;三台虚拟机集群部署hadoop&#xff0c;安装hive&#xff1b; 在Linux下安装Eclipse&#xff0c;创建maven工程&#xff0c;使用hive-jdbc-2.3.2访问hiveserver2 2、在windows11下&…

Python从0到100(四):Python中的运算符介绍

前言&#xff1a; 零基础学Python&#xff1a;Python从0到100最新最全教程。 想做这件事情很久了&#xff0c;这次我更新了自己所写过的所有博客&#xff0c;汇集成了Python从0到100&#xff0c;共一百节课&#xff0c;帮助大家一个月时间里从零基础到学习Python基础语法、Pyth…

就业班 2401--3.12 Linux Day16 PXE布置——自动化装系统

什么是PXE&#xff1f; PXE&#xff0c;全名Pre-boot Execution Environment&#xff0c;预启动执行环境&#xff1b;通过网络接口启动计算机&#xff0c;不依赖本地存储设备&#xff08;如硬盘&#xff09;或本地已安装的操作系统&#xff1b;由Intel和Systemsoft公司于1999年…

云游戏发行是什么?云游戏发行的演进历程

云游戏发行是一系列基于云游戏技术的游戏发行策略或行为&#xff0c;融合云试玩、云微端、可玩广告、跨端移植等技术&#xff0c;从而在传统游戏发行生态的基础上实现更为卓越的发行效果。 云游戏发行出现的原因 近年来&#xff0c;游戏市场出现负增长。其原因一方面在于游戏版…

一套plm系统大约多少钱?彩虹PLM系统

一套PLM&#xff08;产品生命周期管理&#xff09;系统的价格因多个因素而异&#xff0c;包括企业规模、需求复杂性、系统功能、技术支持和厂商选择等。一般来说&#xff0c;面向小型和微型企业的PLM产品&#xff0c;其价位在5万元~15万元左右&#xff1b;面向中型企业的中端PL…

【数据结构学习笔记】冒泡排序

【数据结构学习笔记】冒泡排序 参考电子书&#xff1a;排序算法精讲 算法原理 对未排序的元素进行多次遍历&#xff0c;每次遍历都将相邻的两个元素进行比较&#xff0c;如果它们的顺序错误就交换它们的位置。在每一轮遍历后&#xff0c;最大的元素会被冒泡到序列的末端。这…

【Docker】容器的生态系统

Docker提供了一整套技术支持&#xff0c;包括核心技术、平台技术、支持技术。 核心技术 容器核心技术是指能让Container&#xff08;容器&#xff09;在host&#xff08;集群、主机&#xff09;上运行起来的那些技术。 1&#xff09;容器规范&#xff1a;OCI&#xff08;runt…

【Java】读取手机文件名称

首先&#xff0c;确保你已经连接了你的手机并已启用 USB 调试模式。然后&#xff0c;你需要使用 Android Debug Bridge&#xff08;ADB&#xff09;工具来获取手机文件列表。以下是一个简单的 Java 代码片段&#xff0c;使用 ProcessBuilder 调用 ADB 命令来获取文件列表&#…

InnoDB和MyISAM存储引擎

InnoDB mysql默认存储引擎 支持事务&#xff0c;行级锁&#xff08;并发量大&#xff09;&#xff0c;外键约束&#xff0c;容量大&#xff0c;支持缓存&#xff0c;支撑主键自增&#xff0c; 全文检索&#xff0c;不存储表的总行数&#xff0c;需要sql逐行统计 MyISAM 不…

QString的参数传递

在 Qt 框架中,QString 是一个非常常用的类,用于处理字符串。当涉及到 QString 的参数传递时,通常需要考虑以下几点: 按值传递 (Pass by Value): 当你将一个 QString 对象作为参数传递给一个函数时,你可以直接传递它的值。这种情况下,函数会接收这个 QString 的一个副本。…

沙发3d模型制作过程---模大狮模型网

制作沙发的3D模型通常需要经历以下步骤&#xff1a; 概念设计&#xff1a; 首先&#xff0c;根据设计师或客户的需求&#xff0c;进行概念设计。这包括通过手绘草图或数字绘图软件创建初始设计概念。 建模&#xff1a; 使用专业的3D建模软件(例如Blender、Maya、3ds Max)进行建…

ATFX汇市:美国2月CPI数据来袭,高通胀问题或进一步缓解

ATFX汇市&#xff1a;今日20:30&#xff0c;美国劳工部将公布2月未季调核心CPI年率数据&#xff0c;前值为3.9%&#xff0c;预期值3.7%&#xff0c;预期将下降0.2个百分点。历史数据看&#xff0c;美国核心CPI年率处于快速下降状态&#xff0c;去年3月份数据仍高达5.6%&#xf…

CSS 用 flex 布局绘制骰子

<!DOCTYPE html> <html><head><meta charset"utf-8"><title></title><style>.box {height: 100px;width: 100px;border: 2px solid grey;border-radius: 10px;display: flex;justify-content: center; // 水平居中/* alig…

[论文笔记] ICLR 2022 | 减少跨语言表示差异,字节跳动AI Lab通过流形混合增强跨语言迁移

论文地址:https://openreview.net/pdf?id=OjPmfr9GkVv代码地址:https://github.com/yhy1117/X-Mixup 字节跳动人工智能实验室和加利福尼亚大学圣塔芭芭拉分校的研究者提出了 跨语言流形混合(X-Mixup)方法为目标语言提供 “折衷” 的表示,让模型自适应地校准表示差…

LLM(大语言模型)常用评测指标-MAP@R

MAPR (Mean Average Precision at R) 是一种用于评估信息检索系统或排序模型效果的评价指标。它特别适用于那些返回一组相关结果的情况&#xff0c;例如搜索引擎或推荐系统。这里的“R”代表返回的相关结果的数量。MAPR 考虑了结果的排名和相关性两个因素。 计算方法 计算平…

基础小白快速入门web前端开发技术------->hbuilder的下载安装以及简易的网页最开始制作

工欲善其事&#xff0c;必先利其器&#xff0c; 在我们学习开发网页设计&#xff0c;我们首先需要一个良好的开发工具 这里我比较推荐hbuilder这个 只需要进入官网傻瓜下载&#xff0c;傻瓜安装 https://dcloud.io/ 点击hbuilder选择版本进行下载安装即可 hbuilder的新建文件…

01 THU大模型之基础入门

1. NLP Basics Distributed Word Representation词表示 Word representation: a process that transform the symbols to the machine understandable meanings 1.1 How to represent the meaning so that the machine can understand Compute word similarity 计算词相似度 …