Project Icon

clip-video-encode

视频帧CLIP嵌入向量计算工具

clip-video-encode是一个Python工具,用于计算视频帧的CLIP嵌入向量。它可处理本地MP4文件、YouTube链接或包含多个视频源的文本文件。工具提供帧采样、多进程处理和自定义CLIP模型等配置选项。clip-video-encode支持大规模数据集处理,曾用于压缩Kinetics700和WebVid等大型视频数据集。这个工具为视频分析和机器学习任务提供了预处理解决方案。

clip-video-encode

pypi 在Colab中打开 在gitpod上试用

轻松计算视频帧的clip嵌入。

安装

使用pip:

pip install clip-video-encode

或从源代码构建:

python setup.py install

使用方法

名称
    clip-video-encode - 使用CLIP图像编码器对帧进行编码

概要
    clip-video-encode SRC <标志>

描述
    输入:
      src:
        str: mp4文件路径
        str: YouTube链接
        str: 包含多个mp4或YouTube链接的txt文件路径
        list: 包含多个mp4或YouTube链接的列表
      dest:
        str: 保存嵌入的目录
        None: dest = src + .npy
      output_format:
        str: "files"或"webdataset"
      take_every_nth:
        int: 仅取每第n帧
      frame_workers:
        int: 分配视频读取的进程数。
      frame_memory_size:
        int: FrameReader的内存大小(GB)。
      metadata_columns:
        str: 在src中查找的元数据列名的逗号分隔列表
      use_dst_name:
        bool: 使用video2numpy建议的保存名称
      distribute:
        str: 分发策略,目前可选slurm或none
      oc_model_name:
        str: open_clip模型名称,用于选择CLIP架构
      pretrained:
        str: open_clip预训练权重名称

位置参数
    SRC

标志
    --dest=DEST
        默认值: ''
    --output_format=OUTPUT_FORMAT
        默认值: 'files'
    --take_every_nth=TAKE_EVERY_NTH
        默认值: 1
    --frame_workers=FRAME_WORKERS
        默认值: 1
    --frame_memory_size=FRAME_MEMORY_SIZE
        默认值: 4
    --metadata_columns=METADATA_COLUMNS
        默认值: ''
    --use_dst_name=USE_DST_NAME
        默认值: False
    --distribute=DISTRIBUTE
        默认值: 'none'
    --oc_model_name=OC_MODEL_NAME
        默认值: 'ViT-B-32'
    --pretrained=PRETRAINED
        默认值: 'laion2b_s34b_b79k'

API

该模块公开了一个名为clip_video_encode的函数,它接受与命令行工具相同的参数:

import glob
from clip_video_encode import clip_video_encode

VIDS = glob.glob("some/path/my_videos/*.mp4")
EMBEDDING_DIR = "some/path/my_embeddings"
take_every_5 = 5

clip_video_encode(VIDS, EMBEDDING_DIR, take_every_5)

谁在使用clip-video-encode?

  • CLIP-Kinetics700 - 使用clip-video-encode以1 FPS的速度将Kinetics700数据集(700GB)压缩到约8GB
  • CLIP-WebVid - 以1 FPS的速度将WebVid数据集(1000万个视频)编码为CLIP ViT-B/32嵌入。

示例

查看一些很酷的clip-video-encode示例:

  • 物体检测器 - 使用clip-video-encode生成的嵌入在视频中查找物体。
  • 大型数据集处理 - 如果您想将大型数据集(如WebVid)处理成CLIP嵌入,请查看链接的README.md底部的示例。

设置虚拟环境:

python3 -m venv .env
source .env/bin/activate
pip install -e .

运行测试:

pip install -r requirements-test.txt

然后

make lint
make test

您可以使用make black重新格式化代码

python -m pytest -x -s -v tests -k "dummy"运行特定测试

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号