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月前
|
机器学习/深度学习 IDE 开发工具
基于OpenCV的车牌识别系统源码分享
基于OpenCV的车牌识别系统主要利用图像边缘和车牌颜色定位车牌,再利用OpenCV的SVM识别具体字符,从而达到车牌识别的效果。
114 4
基于OpenCV的车牌识别系统源码分享
|
3月前
|
Ubuntu 开发工具 git
Ubuntu编译ffmpeg解决错误:ERROR: avisynth/avisynth_c.h not found
通过本文的详细指导,您可以顺利地在Ubuntu系统上配置和编译FFmpeg,并解决Avisynth头文件缺失的问题。
149 27
|
3月前
|
Ubuntu 计算机视觉 C++
Ubuntu系统下编译OpenCV4.8源码
通过上述步骤,你可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使你能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
94 43
|
3月前
|
Ubuntu 计算机视觉 C++
Ubuntu系统下编译OpenCV4.8源码
通过上述步骤,你可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使你能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
95 30
|
3月前
|
Ubuntu 计算机视觉 C++
Ubuntu系统下编译OpenCV4.8源码
通过上述步骤,你可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使你能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
45 12
|
6月前
|
Ubuntu 编译器 计算机视觉
Ubuntu系统编译OpenCV4.8源码
【10月更文挑战第17天】只要三步即可搞定,第一步是下载指定版本的源码包;第二步是安装OpenCV4.8编译需要的编译器与第三方库支持;第三步就是编译OpenCV源码包生成安装文件并安装。
|
6月前
|
Linux API 开发工具
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
ijkplayer是由B站研发的移动端播放器,基于FFmpeg 3.4,支持Android和iOS。其源码托管于GitHub,截至2024年9月15日,获得了3.24万星标和0.81万分支,尽管已停止更新6年。本文档介绍了如何在Linux环境下编译ijkplayer的so库,以便在较新的开发环境中使用。首先需安装编译工具并调整/tmp分区大小,接着下载并安装Android SDK和NDK,最后下载ijkplayer源码并编译。详细步骤包括环境准备、工具安装及库编译等。更多FFmpeg开发知识可参考相关书籍。
184 0
FFmpeg开发笔记(五十九)Linux编译ijkplayer的Android平台so库
|
6月前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
1554 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
7月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
93 4
|
7月前
|
存储 计算机视觉
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
本文介绍了使用OpenCV进行图像读取、显示和存储的基本操作,以及如何绘制直线、圆形、矩形和文本等几何图形的方法。
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等