Project Icon

Parts2Whole

多参考框架实现可控人像生成

Parts2Whole提出新型框架,利用多个参考图像生成定制人像。该框架包含语义感知外观编码器和多图像条件生成的共享自注意力机制,能精确选择人体部位实现高度可控生成。项目开源全套代码、模型和数据集,为人像生成研究提供完整解决方案。

Parts2Whole

[Arxiv 2024] 从部分到整体:可控人像生成的统一参考框架

  • 推理代码和预训练模型
  • 评估代码
  • 训练代码
  • 训练数据
  • 基于Stable Diffusion 2-1的新模型

🔥 更新

[2024-06-21] 发布训练代码。参见训练
[2024-05-26] 数据集已在此处发布。参见数据集
[2024-05-06] 🔥🔥🔥 代码已发布。尽情享受人体部件组合吧!

🏠 项目主页 | 论文 | 模型

img:teaser

摘要:我们提出了Parts2Whole,这是一个新颖的框架,旨在从多个参考图像生成定制人像,包括姿势图像和人类外观的各个方面。首先,我们开发了一个语义感知外观编码器,以保留不同人体部位的细节,该编码器根据文本标签将每个图像处理为一系列多尺度特征图,而不是一个图像标记,从而保留了图像维度。其次,我们的框架通过在扩散过程中在参考和目标特征之间操作的共享自注意力机制支持多图像条件生成。我们通过结合参考人体图像的掩码信息来增强原始注意力机制,允许精确选择任何部位。

🔨 方法概述

img:pipeline

⚒️ 安装

克隆我们的仓库,并安装requirements.txt中的包。我们在80G A800 GPU上使用CUDA 11.8和PyTorch 2.0.1测试了我们的模型。但在较小的GPU上进行推理也是可能的。

conda create -n parts2whole
conda activate parts2whole
pip install -r requirements.txt

此处下载检查点到pretrained_weights/parts2whole目录。我们还提供了一个简单的下载脚本,使用:

python download_weights.py

🎨 推理

查看inference.py。根据需要修改检查点路径和输入,然后运行命令:

python inference.py

您可能需要在inference.py脚本中修改以下代码:

### 定义配置 ###
device = "cuda"
torch_dtype = torch.float16
seed = 42
model_dir = "pretrained_weights/parts2whole"  # 本地机器上的检查点路径
use_decoupled_cross_attn = True
decoupled_cross_attn_path = "pretrained_weights/parts2whole/decoupled_attn.pth" # 包含在model_dir中
### 定义输入数据 ###
height, width = 768, 512
prompt = "这个人穿着短袖衬衫。" # 输入提示
input_dict = {
    "appearance": {
        "face": "testset/face_man1.jpg",
        "whole body clothes": "testset/clothes_man1.jpg",
    },
    "mask": {
        "face": "testset/face_man1_mask.jpg",
        "whole body clothes": "testset/clothes_man1_mask.jpg",
    },
    "structure": {"densepose": "testset/densepose_man1.jpg"},
}

⭐️⭐️⭐️ 值得注意的是,input_dict应包含键appearancemaskstructure。前两个表示指定多个参考图像中部分的外观,structure表示姿势,如densepose。

⭐️⭐️⭐️ 这三个部分中的键也有解释。appearancemask中的键应该相同。选项包括"upper body clothes"、"lower body clothes"、"whole body clothes"、"hair or headwear"、"face"、"shoes"。structure的键应为"densepose"。(openpose模型尚未发布。)

🔨🔨🔨 为了方便获取每个参考图像的掩码,我们还提供了相应的工具,并在工具中解释了如何使用它们。首先,您可以使用Real-ESRGAN提高参考图像的分辨率,并使用segformer获取人体各个部位的掩码。

📊 数据集

data_sample

我们的数据集已在此处发布。我们在download_dataset.py中提供了下载和解压脚本,请使用以下命令:

python download_dataset.py

它将在data/DeepFashion-MultiModal-Parts2Whole文件夹中准备数据集,这样您就可以运行我们的配置来训练模型或运行我们的数据集文件parts2whole/data/ref_trg.py来检查我们的数据集。

确保数据集按如下方式组织:

DeepFashion-MultiModal-Parts2Whole
# 结构信号
|-- densepose
|-- openpose
# 外观条件
|-- face
|-- hair_headwear
|-- lower_body_clothes
|-- upper_body_clothes
|-- whole_body_clothes
|-- shoes
# 目标图像
|-- images
# 说明文件
|-- train.jsonl
`-- test.jsonl

这个人像数据集包含约41,500对参考-目标对。该数据集中的每对都包括多个参考图像,包括姿势图、人类外观的各个方面(如头发、脸部、衣服、鞋子),以及一张featuring相同个体(ID)的目标图像,还有文本说明。有关数据集的详细信息,请参阅我们的数据集仓库

我们的数据集是从DeepFashion-Multimodal数据集后处理而来的。

🏋️ 训练

如果在单个设备上训练我们的parts2whole,请使用以下命令:

python train.py --config configs/train-sd15.yaml

如果在 DDP 环境中训练(假设有 8 个设备),请运行以下命令:

accelerate launch \
--mixed_precision=fp16 \
--num_processes=$((8*$WORLD_SIZE)) \  # 8 是设备数量
--num_machines=$WORLD_SIZE \
--multi_gpu \
--machine_rank=$RANK \
train.py --config configs/train-sd15.yaml

在我们的配置文件中,每个设备的批量大小设置为 8(这是针对 80G 内存设备的推荐值)。如果你在内存较小的设备上训练,需要减小这个值。

😊 评估

进行评估之前,请先安装以下额外的包:

pip install git+https://github.com/openai/CLIP.git # 用于 clip
pip install dreamsim # 用于 dreamsim
pip install lpips # 用于 lpips

我们在 scripts/evals 文件夹中提供了易于使用的评估脚本。这些脚本接收统一格式的数据,以两个图像列表作为输入。根据需要修改加载图像的代码。更多细节请查看我们的脚本。

🔨 工具

Real-ESRGAN

要使用 Real-ESRGAN 来恢复图像,请先下载 RealESRGAN_x4plus.pth./pretrained_weights/Real-ESRGAN 目录。然后运行以下命令:

python -m scripts.real_esrgan -n RealESRGAN_x4plus -i /path/to/dir -o /path/to/dir --face_enhance

SegFormer

要使用 segformer 对人物图像进行分割并获取帽子、头发、面部、衣服等部分,请运行以下命令:

python scripts.segformer_b2_clothes.py --image-path /path/to/image --output-dir /path/to/dir

标签:0: "背景", 1: "帽子", 2: "头发", 3: "太阳镜", 4: "上衣", 5: "裙子", 6: "裤子", 7: "连衣裙", 8: "腰带", 9: "左鞋", 10: "右鞋", 11: "脸", 12: "左腿", 13: "右腿", 14: "左臂", 15: "右臂", 16: "包", 17: "围巾"

😭 局限性

目前,训练数据的泛化性一般,女性数量相对较多,因此模型的泛化能力需要改进,比如风格化等方面。我们正在努力提高模型的鲁棒性和能力,同时也期待并欢迎社区的贡献和拉取请求。

🤝 致谢

我们感谢以下项目的开源:

diffusersmagic-animateMoore-AnimateAnyoneDeepFashion-MultiModalReal-ESRGAN

📎 引用

如果您觉得这个仓库有用,请考虑引用:

@misc{huang2024parts2whole,
  title={From Parts to Whole: A Unified Reference Framework for Controllable Human Image Generation},
  author={Huang, Zehuan and Fan, Hongxing and Wang, Lipeng and Sheng, Lu},
  journal={arXiv preprint arXiv:2404.15267},
  year={2024}
}
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

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

Project Cover

AI写歌

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

Project Cover

白日梦AI

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

Project Cover

有言AI

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

Project Cover

Kimi

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

Project Cover

讯飞绘镜

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

Project Cover

讯飞文书

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

Project Cover

阿里绘蛙

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

Project Cover

AIWritePaper论文写作

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

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