Project Icon

SEED-Story

多模态长篇故事生成系统

SEED-Story是一种基于大型语言模型的多模态故事生成系统。该系统能够根据初始图像和文本,生成包含连贯叙事和风格一致图像的长篇故事,最多可达25个多模态序列。研究团队同时发布了StoryStream数据集,用于多模态故事生成模型的训练和评估。SEED-Story在图像风格一致性、故事吸引力和文图一致性方面表现优异,为多模态AI创作提供了新的可能性。

SEED-Story

arXiv Static Badge Static Badge

我们推出了SEED-Story,这是一个基于SEED-X的多模态大语言模型,能够生成多模态长篇故事,包含丰富连贯的叙事文本和角色及风格一致的图像。 我们还发布了StoryStream,这是一个专门为训练和评估多模态故事生成而设计的大规模数据集。

Teaser image

待办事项

  • 发布StoryStream数据集。
  • 发布推理代码和模型检查点。
  • 发布指令微调的训练代码。

简介

SEED-Story是一个由多模态大语言模型驱动的系统,能够基于用户提供的图像和文本作为故事开头,生成多模态长篇故事。生成的故事包含丰富连贯的叙事文本,以及角色和风格一致的图像。尽管我们在训练时最多使用10个序列,但生成的故事可以延伸至25个多模态序列。

Teaser image

给定相同的初始图像但不同的开场文本,SEED-Story可以生成不同的多模态故事。上面的分支以提及"戴黄帽子的男人"的文本开始,导致生成的图像包含该角色。下面的分支开始时没有提到这个男人,结果生成的故事与第一个故事不同,不包括他。

Teaser image

方法

第一阶段,我们预训练了一个基于SD-XL的解码器,通过输入预训练ViT的特征来重建图像。

第二阶段,我们采样一个随机长度的交错图像-文本序列,通过执行下一个词预测和可学习查询的输出隐藏状态与目标图像ViT特征之间的图像特征回归来训练多模态大语言模型。

第三阶段,将多模态大语言模型回归得到的图像特征输入解码器,以微调SD-XL,增强生成图像中角色和风格的一致性。

Pipeline image

视频演示

Thumbnail

这是SEED-Story的视频演示。点击可跳转到YouTube!在这个演示中,我们使用图像到视频模型来为生成的图像添加动画,并使用AI语音来叙述配套的故事文本。我们由衷感谢Meixi Chen制作了这个演示。

使用方法

依赖

安装

克隆仓库并安装依赖包

git clone 
cd SEED-Story
pip install -r requirements.txt

数据准备

我们发布了StoryStream数据集,用于训练和测试多模态故事生成。从StoryStream下载图像和故事文本文件。

StoryStream数据集包含3个子集:Curious George、Rabbids Invasion和The Land Before Time。我们以George子集为例。

jsonl文件包含所有数据。每行包含一个由30张图像和相应故事文本组成的故事。"image"组件是30张图像路径的列表。"captions"组件是30个相应故事文本的列表。

为了提高训练效率,您可以像我们一样将故事分成长度为10的块。分块脚本在./StoryStream/chunk_data.py中。

模型权重

我们发布了预训练的编码器、预训练的解码器、预训练的基础模型SEED-X-pretrained、 StoryStream指令微调的多模态大语言模型SEED-Story-George和StoryStream微调的解码器Detokenizer-George,它们都在SEED-Story Hugging Face中。

请下载检查点并将它们保存在./pretrained文件夹下。

您还需要下载stable-diffusion-xl-base-1.0Llama-2-7b-hfQwen-VL-Chat,并将它们保存在./pretrained文件夹下。请使用以下脚本提取Qwen-VL-Chat中视觉编码器的权重。

python3 src/tools/reload_qwen_vit.py

推理

使用SEED-Story进行推理

# 多模态故事生成
python3 src/inference/gen_george.py
# 使用多模态注意力汇聚进行故事可视化
python3 src/inference/vis_george_sink.py

评估

我们使用GPT4 API评估多模态生成结果。脚本位于./src/eval文件夹下。我们通过给定验证集的开头来评估生成结果。评估从3个方面进行:图像风格一致性、故事吸引力和文本-图像一致性。

风格吸引力一致性
GPT4评估8.616.278.24
比较评估结果如下所示。
流程图

指令微调

阶段1:视觉分词与反分词

视觉分词与反分词请参考 SEED-X

阶段2:指令微调

  1. 准备预训练模型(参见模型权重)。
  2. 准备指令微调数据。例如,使用"build_long_story_datapipe"数据加载器进行StoryStream时,每个文件夹存储多个jsonl文件,每个jsonl文件最多包含1万条内容,内容示例如下:
{"id": 102, "images": ["000258/000258_keyframe_0-19-49-688.jpg", "000258/000258_keyframe_0-19-52-608.jpg", "000258/000258_keyframe_0-19-54-443.jpg", "000258/000258_keyframe_0-19-56-945.jpg", "000258/000258_keyframe_0-20-0-866.jpg", "000258/000258_keyframe_0-20-2-242.jpg", "000258/000258_keyframe_0-20-4-328.jpg", "000258/000258_keyframe_0-20-10-250.jpg", "000258/000258_keyframe_0-20-16-673.jpg", "000258/000258_keyframe_0-20-19-676.jpg"], "captions": ["从前,在一个充满五彩缤纷建筑的小镇里,一个名叫蒂米的小男孩站在人行道上。他穿着一件浅绿色的T恤,上面印有建筑图案,还戴着配套的手套,看起来对即将到来的一天充满期待。", "不久,蒂米加入了聚集在公园里的一群人。其中有一个戴黄帽子、系绿领带的男子,一位穿粉色裙子、手持包包和喷雾瓶的女士,还有两个穿白衣服、拿着包的孩子。他们都准备好开始今天的活动了。", "蒂米站在那个戴黄帽子的男子旁边,那人还戴着黄手套,衣服上印有城市景观图案。蒂米穿着一件带有回收标志的绿色T恤,手里拿着一个装满可回收物的透明塑料袋和一张纸。他们准备开始他们的城市清洁任务。", "蒂米脸上依然挂着笑容,开始沿着带有银色栏杆的人行道行走,兴奋地准备帮助清洁他心爱的城市,他的热情感染了周围的人。", "这群人聚集在公园里,为清洁活动做准备。戴黄帽子的男子手持剪贴板,附近一个孩子戴着手套,拿着垃圾夹。每个人都迫不及待地想要开始。", "突然,一只棕色的猴子乔治出现了。他站在两个人之间,开心地拿着一个带有城堡图案的蓝色保龄球瓶。乔治总是准备好加入有趣的活动并伸出援手。", "小组成员之一戴着手套,拿着垃圾袋和剪贴板。他们都准备好开始清洁工作,而乔治也急切地想要帮忙。", "当他们开始清洁时,其中一个孩子把一幅画递给了一位成年人。这幅画上是花朵,象征着他们试图在城市中保护的美丽。", "这群人手牵手,提着袋子,沿着人行道走着。他们是一个团队,一起努力使他们的城市变得更干净、更美丽。", "他们走着,经过了一个穿白衣服的幼儿和一个推婴儿车的成年人。城市充满了生机,每个人都在为保持城市清洁尽自己的一份力。"], "orders": [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]}
  1. 运行指令微调脚本。
bash scripts/sft_storystream.sh

阶段3:反分词器适应

  1. 使用以下脚本获取"pytorch_model.bin"。
cd train_output/seed_story/checkpoint-xxxx
python3 zero_to_fp32.py . pytorch_model.bin
  1. 在"configs/clm_models/agent_7b_seed_story.yaml"中将"pretrained_model_path"更改为新的检查点。例如,
pretrained_model_path: train_output/seed_story/checkpoint-6000/pytorch_model.bin
  1. 运行反分词器适应脚本。
bash scripts/adapt_storystream.sh

引用

如果您觉得这项工作有帮助,请考虑引用:

@article{yang2024seedstory,
      title={SEED-Story: Multimodal Long Story Generation with Large Language Model}, 
      author={Shuai Yang and Yuying Ge and Yang Li and Yukang Chen and Yixiao Ge and Ying Shan and Yingcong Chen},
      year={2024},
      journal={arXiv preprint arXiv:2407.08683},
      url={https://arxiv.org/abs/2407.08683}, 
}

许可证

SEED-Story 在 Apache 许可证 2.0 版下授权,除了 License 中列出的第三方组件。

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

豆包MarsCode

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

Project Cover

AI写歌

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

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

Kimi

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

Project Cover

有言AI

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

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

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

Project Cover

AIWritePaper论文写作

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

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