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

参考链接

相关推荐
mit6.824几秒前
从 Vibe Coding 到 Agentic Engineering
人工智能
kay_5455 分钟前
YOLO26改进| 主干网络 | 提升长距离特征建模与全局上下文理解能力【CVPR】
人工智能·目标检测·计算机视觉·目标跟踪·论文·yolo26·yolo26改进
ting94520008 分钟前
Huddle01 VMs 支持 AI 助手一键部署,MCP 协议重塑云基础设施管理
人工智能
地理探险家9 分钟前
我整理了一份动物数据集合集,做深度学习的直接省掉80%时间(附使用建议)
人工智能·深度学习·数据集·图像·动物
硅谷秋水15 分钟前
语言智体的Harness工程:Harness层作为控制、智体和运行时
人工智能·深度学习·机器学习·语言模型
老黄编程17 分钟前
大型工地实时数据处理与三维重构系统方案(极简中心化部署版)
人工智能·数码相机·计算机视觉·大数据处理·入侵检测·三维重构
狙击主力投资工具25 分钟前
26年5月4日本周复盘总结,好票机会,下周大盘方向,热门板块方向,操作建议,实用干货
人工智能·区块链
生物信息与育种33 分钟前
黄三文院士领衔植物星球计划(PLANeT)发表Cell
人工智能·深度学习·算法·面试·transformer
Data-Miner40 分钟前
10个最佳表格Agent工具深度评测:让数据处理效率翻倍的智能助手
人工智能