torchcodec is not available问题

TorchCodec 环境配置指南

本文档记录了在 GR00T N1.5 项目中配置 TorchCodec 视频解码器遇到的问题及解决方案。


问题描述

运行训练脚本时出现以下错误:

复制代码
ImportError: torchcodec is not available.

或者:

复制代码
RuntimeError: Could not load libtorchcodec. Likely causes:
    1. FFmpeg is not properly installed in your environment.
    2. The PyTorch version is not compatible with this version of TorchCodec.

问题分析

1. TorchCodec 版本与 PyTorch 版本不兼容

TorchCodec 对 PyTorch 版本有严格的兼容性要求。不同版本的 TorchCodec 需要对应版本的 PyTorch:

TorchCodec 版本 兼容的 PyTorch 版本
0.8.x 2.9.x
0.9.x 2.10.x (部分)
0.4.x 2.5.x - 2.6.x

2. FFmpeg 库依赖问题

TorchCodec 需要 FFmpeg 库(版本 4、5、6 或 7)。如果系统没有安装或路径不正确,会导致加载失败。

3. 动态库路径问题

TorchCodec 的核心库依赖 PyTorch 的动态库(libtorch.solibc10.so 等),如果 LD_LIBRARY_PATH 设置不正确,会导致符号未定义错误。


解决方案

步骤 1:激活 conda 环境

bash 复制代码
conda activate gr00t

步骤 2:安装 FFmpeg

使用 conda 安装 FFmpeg(推荐版本 7):

bash 复制代码
conda install -y ffmpeg -c conda-forge

验证安装:

bash 复制代码
ffmpeg -version
# 应显示 ffmpeg version 7.x

步骤 3:安装兼容的 PyTorch 版本

关键:必须安装与 TorchCodec 兼容的 PyTorch 版本。

对于 TorchCodec 0.8.0,安装 PyTorch 2.9.1:

bash 复制代码
# 先卸载现有的 PyTorch
pip uninstall torch torchvision torchaudio -y

# 安装兼容版本(CUDA 13.0)
pip install torch==2.9.1 torchvision==0.24.1 torchaudio==2.9.1 --index-url https://download.pytorch.org/whl/cu130

步骤 4:安装 TorchCodec

bash 复制代码
pip install torchcodec==0.8.0

步骤 5:验证安装

运行以下 Python 代码验证 TorchCodec 是否正常工作:

python 复制代码
import torch
print('torch version:', torch.__version__)

import torchcodec
print('torchcodec version:', torchcodec.__version__)

# 测试解码视频
from torchcodec.decoders import VideoDecoder
video_path = '/path/to/your/video.mp4'
decoder = VideoDecoder(video_path)
print('Video duration:', decoder.metadata.duration_seconds, 'seconds')
print('Number of frames:', decoder.metadata.num_frames)
print('FPS:', decoder.metadata.average_fps)

# 解码第一帧
frame = decoder[0]
print('First frame shape:', frame.shape)
print('torchcodec 工作正常!')

预期输出:

复制代码
torch version: 2.9.1+cu130
torchcodec version: 0.8.0
Video duration: 20.8 seconds
Number of frames: 416
FPS: 20.0
First frame shape: torch.Size([3, 256, 256])
torchcodec 工作正常!

常见问题排查

问题 1:undefined symbol: _ZN3c1013MessageLoggerC1EPKcii

原因: PyTorch 版本与 TorchCodec 不兼容(ABI 不匹配)。

解决: 降级或升级 PyTorch 到兼容版本。

问题 2:libtorch.so => not found

原因: 动态库路径未设置。

解决: 在脚本中添加:

bash 复制代码
export LD_LIBRARY_PATH=/path/to/conda/envs/gr00t/lib:/path/to/conda/envs/gr00t/lib/python3.10/site-packages/torch/lib:$LD_LIBRARY_PATH

问题 3:FFmpeg 版本不支持

原因: 安装的 FFmpeg 版本过高(如 8.x)或过低。

解决: 使用 conda 安装 FFmpeg 7.x:

bash 复制代码
conda install -y ffmpeg=7.1 -c conda-forge

最终验证的环境配置

组件 版本
Python 3.10
PyTorch 2.9.1+cu130
TorchVision 0.24.1+cu130
TorchAudio 2.9.1+cu130
TorchCodec 0.8.0
FFmpeg 7.1
CUDA 13.0

参考链接

相关推荐
墩墩冰3 分钟前
计算机图形学 实现直线段的反走样
人工智能·机器学习
Pyeako8 分钟前
深度学习--卷积神经网络(下)
人工智能·python·深度学习·卷积神经网络·数据增强·保存最优模型·数据预处理dataset
OPEN-Source10 分钟前
大模型实战:搭建一张“看得懂”的大模型应用可观测看板
人工智能·python·langchain·rag·deepseek
zzz的学习笔记本13 分钟前
AI智能体时代的记忆 笔记(由大模型生成)
人工智能·智能体
AGI-四顾20 分钟前
文生图模型选型速览
人工智能·ai
大尚来也20 分钟前
一篇搞懂AI通识:用大白话讲清人工智能的核心逻辑
人工智能
Coder_Boy_21 分钟前
Deeplearning4j+ Spring Boot 电商用户复购预测案例
java·人工智能·spring boot·后端·spring
风指引着方向25 分钟前
动态形状算子支持:CANN ops-nn 的灵活推理方案
人工智能·深度学习·神经网络
weixin_3954489128 分钟前
cursor日志
人工智能·python·机器学习
凤希AI伴侣31 分钟前
你觉得,AI能让你“一人成军”吗?我的工具流与真实体验
人工智能·凤希ai伴侣