Jetson 学习笔记(十一):jetson agx xavier 源码编译ffmpeg(3.4.1)和opencv(3.4.0)

简介: 本文是关于在Jetson AGX Xavier上编译FFmpeg(3.4.1)和OpenCV(3.4.0)的详细教程,包括编译需求、步骤、测试和可能遇到的问题及其解决方案。还提供了Jetson AGX Xavier编译CUDA版本的OpenCV 4.5.0的相关信息。

编译需求

  • gcc -----------------------------7.5.0
  • g++ ---------------------------- 7.5.0
  • ubuntu ----------------------- 18.04
  • python ------------------------ 3.6.9
  • ffmpeg ------------------------ 3.4.1
  • opencv ------------------------ 3.4.0

编译ffmpeg

下载网址:http://www.ffmpeg.org/releases/

  • 安装依赖
sudo apt-get install -y nasm yasm cmake mercurial
sudo apt-get install -y libxcb-xfixes0-dev pkg-config texinfo wget zlib1g-dev
sudo apt-get install -y libtool libva-dev libvdpau-dev libvorbis-dev libxcb1-dev libxcb-shm0-dev
sudo apt-get install -y libfreetype6-dev libsdl2-dev libtheora-dev
sudo apt-get install -y autoconf automake build-essential git libass-dev
sudo apt-get install libx264-dev libx265-dev libnuma-dev libgtk-3-dev
  • 安装ffmpeg
cd ffmpeg-4.3

sudo -s
# 安装了yasm和nasm 就不需要加–disable-yasm
./configure --enable-shared   --enable-libx264  --enable-gpl  --prefix=/usr/local/ffmpeg

make && make install

如果要make有缓存 通过make clean即可

  • 配置环境ffmpeg变量
sudo gedit /etc/profile
export LD_LIBRARY_PATH=$/usr/local/ffmpeg/lib:$LD_LIBRARY_PATH
source /etc/profile
  • 建立软链接
cd /usr/bin
sudo ln -s /home/lqs/Downloads/ffmpeg-3.4.1/ffprobe ffprobe 
sudo ln -s /home/lqs/Downloads/ffmpeg-3.4.1/ffmpeg ffmpeg 
sudo ln -s /home/lqs/Downloads/ffmpeg-3.4.1/ffplay ffplay
  • 查看ffmpeg
ffmpeg
  • 如果要通过自己编译后的ffmpeg文件来反编译opencv
1.未编译前的源代码复制到aarch64-linux-gnu文件夹下(共9个文件)
cp -r libavcodec libavfilter libavresample libpostproc libswscale libavdevice libavformat libavutil libswresample /usr/include/x86_64-linux-gnu

在这里插入图片描述

2.将编译后的头文件全部复制到aarch64-linux-gnu文件夹下(共8个文件)
sudo cp -r /usr/local/ffmpeg/include/*   /usr/include/x86_64-linux-gnu
  • 卸载ffmpeg
sudo make uninstall
sudo apt-get --purge remove ffmpeg
ffmpeg -version

复制完了我们可以开始编译opencv了

编译opencv

  • 下载好了opencv的源代码之后,我们进行解压,在配置依赖环境
sudo apt-get install libopencv-dev build-essential cmake git libprotobuf-dev 
sudo apt-get install libgtk2.0-dev pkg-config python-dev python-numpy
sudo apt-get install libsnappy-dev gtk+-3.0 yasm Doxygen 
sudo apt-get install libdc1394-22 libopenblas-dev liblmdb-dev 
sudo apt-get install libdc1394-22-dev libjpeg-dev libpng12-dev libtiff4-dev 
sudo apt-get install libjasper-dev libhdf5-serial-dev 
sudo apt-get install libavcodec-dev libavformat-dev libswscale-dev libxine-dev 
sudo apt-get install libgstreamer0.10-dev libgflags-dev
sudo apt-get install libgstreamer-plugins-base0.10-dev libv4l-dev libtbb-dev 
sudo apt-get install libqt4-dev libfaac-dev libgoogle-glog-dev
sudo apt-get install libmp3lame-dev libopencore-amrnb-dev libopencore-amrwb-dev 
sudo apt-get install libtheora-dev libvorbis-dev protobuf-compiler liblapack-dev
sudo apt-get install libxvidcore-dev x264 v4l-utils unzip liblapacke-dev 
sudo apt-get install libavresample-dev libgphoto2-dev libavutil-dev
sudo apt-get install --no-install-recommends libboost-all-dev ccache libatlas-base-dev
  • cmake

jetson

cmake -D WITH_IPP=OFF -D BUILD_opencv_python3=YES -D INSTALL_PYTHON_EXAMPLES=OFF -D BUILD_EXAMPLES=OFF -D BUILD_opencv_python3=ON -D BUILD_opencv_python2=OFF -D BUILD_opencv_java=OFF -D PYTHON3_EXECUTABLE=/usr/bin/python3.6 -D PYTHON3_INCLUDE_DIR=/usr/include/python3.6 -D PYTHON3_INCLUDE_PATH=/usr/include/python3.6 -D PYTHON3_LIBRARY=/usr/lib/aarch64-linux-gnu/libpython3.6m.so.1.0 -D HAVE_opencv_python3=ON -D PYTHON3_NUMPY_INCLUDE_DIRS=/usr/local/lib/python3.6/dist-packages/numpy/core/include -D PYTHON3_PACKAGES_PATH=/usr/local/lib/python3.6/dist-packages -D HAVE_opencv_python3=ON -D OPENCV_ENABLE_MEMORY_SANITIZER=ON -D WITH_QT=OFF -D ENABLE_CXX11=ON -D WITH_CUDA=OFF -D FFMPEG_INCLUDE_DIR=/usr/local/ffmpeg/include -D FFMPEG_LIB_DIR=/usr/local/ffmpeg/lib -D ENABLE_PRECOMPILED_HEADERS=OFF ..

ubuntu

cmake -D WITH_IPP=OFF -D BUILD_opencv_python3=YES -D INSTALL_PYTHON_EXAMPLES=OFF -D BUILD_EXAMPLES=OFF -D BUILD_opencv_python3=ON -D BUILD_opencv_python2=OFF -D BUILD_opencv_java=OFF -D PYTHON3_EXECUTABLE=/usr/bin/python3.6 -D PYTHON3_INCLUDE_DIR=/usr/include/python3.6 -D PYTHON3_INCLUDE_PATH=/usr/include/python3.6 -D PYTHON3_LIBRARY=/usr/lib/x86_64-linux-gnu/libpython3.6m.so.1.0 -D HAVE_opencv_python3=ON -D PYTHON3_NUMPY_INCLUDE_DIRS=/usr/lib/python3/dist-packages/numpy/core/include -D PYTHON3_PACKAGES_PATH=/usr/lib/python3/dist-packages -D HAVE_opencv_python3=ON -D OPENCV_ENABLE_MEMORY_SANITIZER=ON -D WITH_QT=OFF -D ENABLE_CXX11=ON -D WITH_CUDA=OFF -D FFMPEG_INCLUDE_DIR=/usr/local/ffmpeg/include -D FFMPEG_LIB_DIR=/usr/local/ffmpeg/lib -D ENABLE_PRECOMPILED_HEADERS=OFF ..
  • make
sudo make -j8 #这里的8表示线程的数量
cp /home/lqs/Downloads/opencv-3.4.0/build/lib/python3/* /home/lqs/anaconda3/lib/python3.7/site-packages/
  • install
make install
  • check
python
import cv2
cv2.__version__
  • 添加环境变量
#在/etc/ld.so.conf.d/opencv.conf添加安装opencv的路径:
sudo gedit /etc/ld.so.conf.d/opencv.conf 
/usr/local/lib
sudo ldconfig       # 使配置生效
#在/etc/bash.bashrc中添加pkgconfig路径:
sudo gedit /etc/bash.bashrc
"""
PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/local/lib/pkgconfig  
export PKG_CONFIG_PATH 
"""
source /etc/bash.bashrc      # 使配置生效
sudo updatedb
  • 至此,安装成功,可以使用命令pkg-config --modversion opencv3查看是否安装成功以及版本号
  • 卸载opencv
    sudo apt-get purge libopencv* 卸载板子上的opencv

卸载编译安装的opencv

cd /home/lqs/Downloads/opencv-3.4.0/build/
sudo make uninstall  && cd .. && rm -rf build
cd /usr && find . -name "*opencv*" | xargs sudo rm -rf
pkg-config --modversion opencv

测试

打开rtsp摄像头

import cv2
cap = cv2.VideoCapture("rtsp://admin:a12345678@10.16.55.150:555/Streaming/Channels/1")
ret, frame = cap.read()
while ret:
    ret, frame = cap.read()
    cv2.imshow("frame",frame)
    if cv2.waitKey(1) & 0xFF == ord('q'):
        break
cv2.destroyAllWindows()
cap.release()

打开rtsp摄像头并获取ntp时间戳

import cv2

video = r'/home/lqs/Documents/face_detect_yolov4_yolov4tiny_ssd-master/action_detection/BalanceBeam.avi'
cap = cv2.VideoCapture("rtsp://admin:a12345678@10.16.55.150:555/Streaming/Channels/1")
while cap.isOpened():
    frame_exists, curr_frame = cap.read()
    # if frame_exists:
    k = cap.getRTPTimeStampSeconds()
    l = cap.getRTPTimeStampFraction()
    time_shift = 0x100000000
    #because in the getRTPTimeStampSeconds() 
    #function, seconds was multiplied by 0x10000000 
    seconds = time_shift * k
    m = (time_shift * k) + l
    print("Imagetimestamp: %i" % m)
    cv2.imshow('1',curr_frame)
    keyCode = cv2.waitKey(1) & 0xFF         
    if keyCode == 27:# ESC键退出
        break
cap.release()
cv2.destroyAllWindows()

编译问题

  • 问题1 libavcodec/libx264.c:282:9: error: ‘x264_bit_depth’ undeclared (first use in this function); did you mean ‘x264_picture_t’?
    解决办法:打开libx264.c,找到相应的代码行,将“x264_bit_depth”改成“X264_BIT_DEPTH”即可
  • 问题2 ffbuild/common.mak:60: recipe for target ‘libavdevice/v4l2.o’ failed
    解决办法:链接
  • 问题3 /usr/include/aarch64-linux-gnu/sys/videoio.h:45:10: fatal error: opencv2/core/core_c.h: No such file or directory
    解决办法:链接
  • 问题4:target ‘libavutil/libavutil.so.55’ failed make: *** [libavutil/libavutil.so.55] Error 1
    解决办法:编译后的源代码不干净,需要重新修改源代码来进行编译
  • 问题5: Package ‘gtk±3.0’ not found
    解决办法:sudo apt-get install build-essential libgtk-3-dev
  • 问题6: Package ‘gtk±2.0’ not found
    解决办法: apt-get install libgtk2.0-dev
  • 问题7:fatal error: sys/videoio.h No such file or directory
  • 解决办法:如果编译ffmpeg出现这个错,直接注释掉c4l2…h文件下video.h和types.h的头函数
    sudo cp /usr/include/opencv2/videoio/videoio_c.h /usr/include/x86_64-linux-gnu/sys
    sudo ln -s /usr/include/x86_64-linux-gnu/sys/videoio_c.h /usr/include/x86_64-linux-gnu/sys/videoio.h

附录

目录
相关文章
|
2天前
|
编解码 Java 程序员
写代码还有专业的编程显示器?
写代码已经十个年头了, 一直都是习惯直接用一台Mac电脑写代码 偶尔接一个显示器, 但是可能因为公司配的显示器不怎么样, 还要接转接头 搞得桌面杂乱无章,分辨率也低,感觉屏幕还是Mac自带的看着舒服
|
4天前
|
存储 缓存 关系型数据库
MySQL事务日志-Redo Log工作原理分析
事务的隔离性和原子性分别通过锁和事务日志实现,而持久性则依赖于事务日志中的`Redo Log`。在MySQL中,`Redo Log`确保已提交事务的数据能持久保存,即使系统崩溃也能通过重做日志恢复数据。其工作原理是记录数据在内存中的更改,待事务提交时写入磁盘。此外,`Redo Log`采用简单的物理日志格式和高效的顺序IO,确保快速提交。通过不同的落盘策略,可在性能和安全性之间做出权衡。
1540 5
|
1月前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
7天前
|
人工智能 Rust Java
10月更文挑战赛火热启动,坚持热爱坚持创作!
开发者社区10月更文挑战,寻找热爱技术内容创作的你,欢迎来创作!
581 22
|
4天前
|
存储 SQL 关系型数据库
彻底搞懂InnoDB的MVCC多版本并发控制
本文详细介绍了InnoDB存储引擎中的两种并发控制方法:MVCC(多版本并发控制)和LBCC(基于锁的并发控制)。MVCC通过记录版本信息和使用快照读取机制,实现了高并发下的读写操作,而LBCC则通过加锁机制控制并发访问。文章深入探讨了MVCC的工作原理,包括插入、删除、修改流程及查询过程中的快照读取机制。通过多个案例演示了不同隔离级别下MVCC的具体表现,并解释了事务ID的分配和管理方式。最后,对比了四种隔离级别的性能特点,帮助读者理解如何根据具体需求选择合适的隔离级别以优化数据库性能。
201 3
|
10天前
|
JSON 自然语言处理 数据管理
阿里云百炼产品月刊【2024年9月】
阿里云百炼产品月刊【2024年9月】,涵盖本月产品和功能发布、活动,应用实践等内容,帮助您快速了解阿里云百炼产品的最新动态。
阿里云百炼产品月刊【2024年9月】
|
11天前
|
Linux 虚拟化 开发者
一键将CentOs的yum源更换为国内阿里yum源
一键将CentOs的yum源更换为国内阿里yum源
580 5
|
23天前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。
|
7天前
|
XML 安全 Java
【Maven】依赖管理,Maven仓库,Maven核心功能
【Maven】依赖管理,Maven仓库,Maven核心功能
233 3
|
9天前
|
存储 人工智能 搜索推荐
数据治理,是时候打破刻板印象了
瓴羊智能数据建设与治理产品Datapin全面升级,可演进扩展的数据架构体系为企业数据治理预留发展空间,推出敏捷版用以解决企业数据量不大但需构建数据的场景问题,基于大模型打造的DataAgent更是为企业用好数据资产提供了便利。
327 2