六、ffmpeg编译(GPU版本)和使用教程

该教程详细介绍了如何在Linux环境中编译GPU版本的FFmpeg,包括安装依赖如NVIDIA驱动、CUDA、cuDNN,配置FFmpeg编译选项,以及使用GPU进行视频处理的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

六、ffmpeg编译(GPU版本)和使用教程

(1)需要安装nvidia-driver
没有安装的可以看我的这篇文章:一、安装nvidia-driver
(2)需要安装cuda
没有安装的可以看我的这篇文章:二、安装cuda
(3)需要安装cudnn
没有安装的可以看我的这篇文章:三、安装cudnn
(4)需要安装anaconda
没有安装的可以看我的这篇文章:四、安装anaconda

1、安装cuda硬解码

输入命令:

mkdir ~/nvidia/ && cd ~/nvidia/
git clone https://git.videolan.org/git/ffmpeg/nv-codec-headers.git
cd nv-codec-headers && sudo make install

成功截图:
在这里插入图片描述

2、下载ffmpeg

切换到 ~/nvidia/目录下,输入命令:

cd ~/nvidia/

网址:https://ffmpeg.org/download.html

截图(选择红框内的内容):
在这里插入图片描述

下载完成后,上传服务器:
在这里插入图片描述

3、解压文件

输入解压命令:

tar -jxvf ffmpeg-snapshot.tar.bz2

成功截图:
在这里插入图片描述

4、安装必须包(包括解析h264和h265)

输入命令:

sudo apt install build-essential yasm cmake libtool libc6 libc6-dev unzip wget libnuma1 libnuma-dev
sudo apt-get install libfdk-aac-dev libx264-dev libx265-dev

5、输入编译配置信息

输入命令:

cd ~/nvidia/ffmpeg/
./configure --enable-nonfree --enable-shared --enable-cuda-nvcc --enable-libnpp --extra-cflags=-I/usr/local/cuda/include --extra-ldflags=-L/usr/local/cuda/lib64 --enable-libx264 --enable-libx265 --enable-libfdk-aac --enable-ffplay --enable-gpl

成功截图:
在这里插入图片描述

6、编译

输入命令:

make -j $(nproc)

成功截图:
在这里插入图片描述

输入命令:

sudo make install

成功截图:
在这里插入图片描述

输入命令:

sudo ldconfig

7、验证成功

输入命令:

ls -l ffmpeg*

成功截图:
在这里插入图片描述

输入命令:

ffmpeg

成功截图:
在这里插入图片描述

输入命令:

ffmpeg -codecs | grep nv

成功截图:
在这里插入图片描述

8、使用方法

(1)cpu

输入命令(time是记录运行时间的):

time ffmpeg -c:v h264_cuvid -i input.mp4 -c:v h264_nvenc output1.mp4

成功截图:
在这里插入图片描述

(2)gpu

输入命令:

time ffmpeg -hwaccel cuda -c:v h264_cuvid -i input.mp4 -c:v h264_nvenc output1.mp4

成功截图:
在这里插入图片描述

(3)使用GPU读取视频流(h264)

输入命令:

ffmpeg -hwaccel cuda -c:v h264_cuvid -i "流地址" -c:v h264_nvenc  -f segment -segment_time 60 -segment_format_options movflags=+faststart out%03d.mp4

成功截图:
在这里插入图片描述

(4)查看编码方式

输入命令:

ffmpeg -codecs | grep h264

成功截图:
在这里插入图片描述

9、教程

参考:https://juejin.cn/post/7034411980316213256

在这里插入图片描述

python使用:

import threading
import os
import time
from datetime import datetime

def thread_func(num): 
 os.system('/root/ffmpeg/ffmpeg -hwaccel cuda -hwaccel_output_format cuda -video_size 1920x1080 -i /root/Samples/YUV/ml.mp4 -c:v h264_nvenc -b:v 5M /root/video_output/ml%s.mp4 >>/root/video_output.log 2>&1' % num)
 print('num=', num)

def many_thread(num):
 threads = []
 for i in range(num):
     t = threading.Thread(target=thread_func, args=(i,))
     threads.append(t)
 for t in threads:
     t.start()


if __name__ == '__main__':
 many_thread(40)
<think>嗯,用户想了解SQL中的IF语句的使用方法示例。首先,我需要回忆一下SQL中不同数据库系统对条件判断的支持情况。比如,MySQL有IF函数,SQL Server使用IIF,而Oracle可能在较新版本中用CASE代替IF。引用里的内容提到Oracle9i之后建议用CASE,所以需要区分不同数据库的语法。 用户可能需要知道基本语法结构,比如在MySQL中如何用IF函数,或者在存储过程中使用IF语句。示例很重要,比如查询中的简单条件判断,或者在存储过程中控制流程。还要注意区分IF函数CASE表达式,特别是当有多个条件时,CASE可能更合适。 用户可能还想了解实际应用场景,比如数据清洗、动态计算字段,或者在存储过程中的逻辑分支。需要给出不同场景的例子,并说明注意事项,比如性能问题或可读性。还要提到不同数据库的兼容性问题,比如SQL Server的IIFMySQL的IF的区别。 另外,引用中提到的案例,如处理折扣逻辑,可以作为一个示例来展示如何避免NULL或无效值。要确保示例代码正确,语法无误,并且有注释说明。可能还需要比较IFCASE的优缺点,帮助用户选择合适的方法。 最后,生成相关问题时,要考虑用户可能进一步的问题,比如性能优化、复杂条件处理、与CASE的比较,以及在不同数据库中的写法差异。这些能帮助用户深入理解应用IF语句。</think>### SQL中IF语句的用法详解 #### 一、基本语法结构 在SQL中,`IF`语句主要用于**条件判断**,但在不同数据库系统中的实现方式不同: 1. **MySQL**:支持`IF()`函数存储过程中的`IF-THEN`语句 2. **SQL Server**:使用`IIF()`函数`IF`控制流语句 3. **Oracle**:推荐使用`CASE`表达式替代`IF`(Oracle 9i之后)[^1] #### 二、具体用法示例 **1. MySQL中的IF函数** ```sql -- 简单条件判断 SELECT order_id, IF(discount > 0, '有折扣', '无折扣') AS discount_status FROM orders; -- 处理NULL值(示例引用[3]改进) SELECT order_amount, IF(discount IS NULL OR discount > order_amount*0.5, 0, discount) AS valid_discount FROM sales; ``` **2. SQL Server中的IIF函数** ```sql -- 三目运算形式 SELECT product_name, IIF(stock > 0, '可售', '缺货') AS stock_status FROM products; -- 嵌套使用 SELECT IIF(score >= 90, 'A', IIF(score >= 80, 'B', IIF(score >= 70, 'C', 'D'))) AS grade FROM exams; ``` **3. 存储过程中的IF语句(通用写法)** ```sql -- MySQL存储过程示例 DELIMITER $$ CREATE PROCEDURE CheckInventory(IN product_id INT) BEGIN DECLARE stock INT; SELECT quantity INTO stock FROM inventory WHERE id = product_id; IF stock < 10 THEN UPDATE orders SET priority = 'high' WHERE product = product_id; ELSEIF stock < 50 THEN UPDATE orders SET priority = 'medium'; ELSE UPDATE orders SET priority = 'low'; END IF; END$$ DELIMITER ; ``` #### 三、应用场景 1. **数据清洗**:处理空值或异常值 ```sql UPDATE users SET age = IF(age < 0 OR age > 120, NULL, age) ``` 2. **动态计算字段** ```sql SELECT price * IF(member_level = 'VIP', 0.8, 1) AS final_price FROM transactions ``` 3. **条件聚合** ```sql SELECT COUNT(IF(status = 'completed', 1, NULL)) AS completed_orders, COUNT(IF(status = 'canceled', 1, NULL)) AS canceled_orders FROM orders ``` #### 四、注意事项 1. **性能优化**:复杂条件判断可能影响查询性能,建议配合索引使用 2. **可读性**:多层嵌套时建议改用`CASE`表达式[^3] 3. **兼容性**:不同数据库系统语法差异较大,需注意移植问题
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值