Project Icon

LVM

大规模视觉模型的创新顺序建模方法

LVM是一种创新视觉预训练模型,将多种视觉数据转化为视觉句子,并进行自回归式标记预测。该模型采用顺序建模方法,无需语言数据即可学习大规模视觉模型。通过设计视觉提示,LVM可解决多种视觉任务。兼容GPU和TPU,为大规模视觉模型学习提供新方法。

LVM:顺序建模实现大规模视觉模型的可扩展学习

LVM是一种视觉预训练模型,它将各种视觉数据转换为视觉句子,并自回归地执行下一个标记预测。它兼容GPU和TPU。

LVM建立在OpenLLaMA(一个自回归模型)和OpenMuse(一个将图像转换为视觉标记的VQGAN)之上。

这项工作是与HuggingFace合作完成的。感谢Victor Sanh在这个项目中的支持。

摘要:

我们提出了一种新颖的顺序建模方法,使得在不使用任何语言数据的情况下学习大规模视觉模型(LVM)成为可能。 为此,我们定义了一种通用格式"视觉句子",可以在不需要像素之外的任何元知识的情况下,将原始图像和视频以及语义分割和深度重建等带注释的数据源表示出来。一旦这种多样化的视觉数据(包含4200亿个标记)被表示为序列,模型就可以通过最小化下一个标记预测的交叉熵损失来进行训练。通过在不同规模的模型架构和数据多样性上进行训练,我们提供了经验证据,证明我们的模型可以有效扩展。通过在测试时设计合适的视觉提示,可以解决许多不同的视觉任务。

视觉句子

与原始论文版本的主要区别

  1. 我们目前发布的是7B模型(之前是3B)。其他模型规模的变体将在稍后提供。
  2. 对LAION数据集进行了深度过滤(包括质量过滤、去重和已知CSAM内容移除),将数据集规模从15亿张图像减少到12亿张。
  3. 改进了分词器以获得更好的性能。

许可证

LVM采用Apache 2.0许可证。

安装

git clone https://github.com/ytongbai/LVM
cd LVM
export PYTHONPATH="${PWD}:$PYTHONPATH"

环境设置

conda env create -f scripts/gpu_environment.yml
conda activate LVM

数据集准备

请参阅DATASET.md获取准备数据集的详细说明。

准备好数据集后,你将得到一个预分词文件dataset.jsonl

训练脚本

我们提供了一个7B模型的示例训练脚本,关于分布式训练设置的更多细节,请参考EasyLM

对于其他模型大小,我们在'./EasyLM/models/llama/llama_model.py'中提供了从100M、300M、600M、1B、3B、7B、13B、20B到30B的模型定义。

python -u -m EasyLM.models.llama.llama_train \
    --jax_distributed.initialize_jax_distributed=True \
    --jax_distributed.coordinator_address='$MASTER_ADDR:$MASTER_PORT' \
    --jax_distributed.local_device_ids='0,1,2,3,4,5,6,7' \
    --mesh_dim='$SLURM_NNODES,-1,1' \
    --dtype='bf16' \
    --total_steps=400000 \ # 根据数据数量进行调整
    --log_freq=10 \
    --save_model_freq=1000 \
    --save_milestone_freq=2000 \
    --load_llama_config='vqlm_7b' \
    --optimizer.type='adamw' \
    --optimizer.adamw_optimizer.weight_decay=0.1 \
    --optimizer.adamw_optimizer.lr=1.5e-4 \
    --optimizer.adamw_optimizer.end_lr=3e-5 \
    --optimizer.adamw_optimizer.lr_warmup_steps=8000 \
    --optimizer.adamw_optimizer.lr_decay_steps=288000 \
    --optimizer.accumulate_gradient_steps=4 \
    --train_dataset.type='json' \
    --train_dataset.text_processor.fields=',{tokens},' \
    --train_dataset.json_dataset.path='/path/to/dataset.jsonl' \
    --train_dataset.json_dataset.seq_length=4096 \
    --train_dataset.json_dataset.batch_size=32 \
    --train_dataset.json_dataset.tokenizer_processes=16 \
    --checkpointer.save_optimizer_state=True \
    --logger.online=True \
    --logger.output_dir='/path/to/checkpoint/$RUN_NAME' \
    --logger.wandb_dir='/path/to/wandb' \
    --logger.notes='' \
    --logger.experiment_id=$EXPERIMENT_ID

转换为Huggingface检查点

python -m EasyLM.models.llama.convert_easylm_to_hf --load_checkpoint='trainstate_params::/path/to/checkpoint/streaming_train_state' --model_size='vqlm_7b' --output_dir='/path/to/output/checkpoint/'

演示和推理

下载少样本示例数据集

主要有两种视觉提示方式:顺序提示和类比提示。

类比提示:

用少样本示例描述任务,这些示例是(x, y)输入对,其中x是输入图像,y是"注释"图像。最后添加一个查询图像。我们在此链接提供了更多少样本示例,你可以简单地更改最后的查询图像进行测试。

顺序提示:

输入一系列连续帧,让模型生成下一帧。

查看我们在HuggingFace Spaces上的演示和额外推理代码:LVM演示

评估

查看evaluation/EVAL.md

模型

微调

LVM是一个预训练模型,没有指令调整或其他类型的后训练。如果你想要一个特定任务,我们建议将数据组织成视觉句子格式,然后使用我们提供的训练脚本,以较小的学习率进行微调。

引用

如果你在研究或应用中发现LVM有用,请使用以下BibTeX引用我们的工作:

@article{bai2023sequential,
  title={Sequential modeling enables scalable learning for large vision models},
  author={Bai, Yutong and Geng, Xinyang and Mangalam, Karttikeya and Bar, Amir and Yuille, Alan and Darrell, Trevor and Malik, Jitendra and Efros, Alexei A},
  journal={arXiv preprint arXiv:2312.00785},
  year={2023}
}
项目侧边栏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号