logo
0
0
WeChat Login
Changlin-Lee<clibt@connect.ust.hk>
update readme

English

混元视频特征提取工具

本项目提供了一个高效的工具,用于从视频中提取潜在特征,为后续的视频生成和处理任务做准备。

功能特点

  • 支持各种视频格式和分辨率
  • 多GPU并行处理,提高效率
  • 支持多种宽高比
  • 高性能VAE模型用于特征提取
  • 自动跳过已处理的视频,支持断点续传功能

使用方法

1. 配置文件

输入数据集格式

输入的视频元数据文件(meta_file.list)应为JSON文件路径的列表,每个JSON文件包含以下字段:

meta_file.list的格式(例如,./assets/demo/i2v_lora/train_dataset/meta_file.list)如下:

/path/to/0.json /path/to/1.json /path/to/2.json ...

重要: 确保每个视频的名字是唯一的!!!

/path/to/0.json的格式(例如,./assets/demo/i2v_lora/train_dataset/meta_data.json)如下:

{ "video_path": "/path/to/video.mp4", "raw_caption": { "long caption": "视频的详细描述文本" } }

hyvideo/hyvae_extract/vae.yaml中配置参数:

vae_path: "./ckpts/hunyuan-video-i2v-720p/vae" # VAE模型路径 video_url_files: "/path/to/meta_file.list" # 视频元数据文件列表 output_base_dir: "/path/to/output/directory" # 输出目录 sample_n_frames: 129 # 采样帧数 target_size: # 目标尺寸 - bucket_size - bucket_size enable_multi_aspect_ratio: True # 启用多种宽高比 use_stride: True # 使用步长采样

分辨率桶大小参考

target_size参数定义了分辨率桶大小。以下是不同质量级别的推荐值:

质量桶大小典型分辨率
720p9601280×720或类似
540p720960×540或类似
360p480640×360或类似

enable_multi_aspect_ratio设置为True时,系统将使用这些桶大小作为基础来生成多种宽高比的桶。为了获得最佳性能,请根据您的硬件能力选择平衡质量和内存使用的桶大小。

2. 运行提取

# 设置环境变量 export HOST_GPU_NUM=8 # 设置要使用的GPU数量 # 运行提取脚本 cd HunyuanVideo-I2V bash hyvideo/hyvae_extract/start.sh

3. 单GPU运行

cd HunyuanVideo-I2V export PYTHONPATH=${PYTHONPATH}:`pwd` export HOST_GPU_NUM=1 CUDA_VISIBLE_DEVICES=0 python3 -u hyvideo/hyvae_extract/run.py --local_rank 0 --config 'hyvideo/hyvae_extract/vae.yaml'

输出文件

程序在指定的输出目录中生成以下文件:

  1. {video_id}.npy - 视频的潜在特征数组
  2. json_path/{video_id}.json - 包含视频元数据的JSON文件,包括:
    • video_id: 视频ID
    • latent_shape: 潜在特征的形状
    • video_path: 原始视频路径
    • prompt: 视频描述/提示
    • npy_save_path: 保存潜在特征的路径
output_base_dir/ │ ├── {video_id_1}.npy # 视频1的潜在特征数组 ├── {video_id_2}.npy # 视频2的潜在特征数组 ├── {video_id_3}.npy # 视频3的潜在特征数组 │ ... ├── {video_id_n}.npy # 视频n的潜在特征数组 │ └── json_path/ # 包含元数据JSON文件的目录 ├── {video_id_1}.json # 视频1的元数据 ├── {video_id_2}.json # 视频2的元数据 ├── {video_id_3}.json # 视频3的元数据 │ ... └── {video_id_n}.json # 视频n的元数据

高级配置

多宽高比处理

enable_multi_aspect_ratio设置为True时,系统会选择最接近视频原始宽高比的目标尺寸,而不是强制将其裁剪为固定尺寸。这有助于保持视频内容的完整性。

步长采样

use_stride设置为True时,系统会根据视频的帧率自动调整采样步长:

  • 当帧率 >= 50fps时,步长为2
  • 当帧率 < 50fps时,步长为1