Project Icon

SLiMe

基于Stable Diffusion的单样本图像分割方法

SLiMe是一种基于Stable Diffusion的单样本图像分割方法,通过单个训练样本实现准确分割。项目提供PyTorch实现,包含训练、测试和数据处理指南。SLiMe在PASCAL-Part和CelebAMask-HQ数据集上表现优异,为图像分割研究提供新思路。项目开源代码,支持自定义数据集训练和测试。SLiMe采用图像分块处理技术,提高分割精度。研究者可基于此探索更多单样本学习应用场景。

SLiMe:像我一样分割

论文 | Colab笔记本

SLiMe方法

SLiMe:像我一样分割,一种基于Stable Diffusion的单样本图像分割方法的PyTorch实现。

Aliasghar Khani1, 2, Saeid Asgari Taghanaki1, 2, Aditya Sanghi2, Ali Mahdavi Amiri1, Ghassan Hamarneh1

1 西蒙弗雷泽大学 2 欧特克研究院

设置

要开始使用SLiMe,首先需要创建一个虚拟环境并使用以下命令安装依赖项:

python -m venv slime_venv
source slime_venv/bin/activate
pip install -r requirements.txt

*** 对于用于SLiMe训练、验证或测试的每对图像和掩码,它们的名称应该匹配。此外,图像应为PNG格式,而掩码应为NumPy格式。 ***

SLiMe训练

首先,创建一个新文件夹(例如,slime/data/train),并将训练图像和相应的掩码放入该文件夹(slime/data/train)。然后,将创建的训练数据文件夹路径(slime/data/train)作为参数提供给--train_data_dir。如果你有验证数据(仅用于检查点选择),对验证数据重复相同的过程(例如,将图像和掩码放在slime/data/val中),并将文件夹地址作为参数提供给--val_data_dir。但是,如果你没有验证数据,请使用训练数据文件夹的地址作为--val_data_dir的参数。

接下来,将测试图像放在单独的文件夹中(例如,slime/data/test),并使用--test_data_dir指定此文件夹的路径。此外,你应该为训练图像中分割的部分定义一个名称,以用于--parts_to_return参数,包括背景。例如,如果你已经分割了狗的身体和头部,你应该将--parts_to_return设置为"background body head"

最后,在slime文件夹(克隆后获得的主文件夹)中执行以下命令:

python -m src.main --dataset sample \
                   --part_names {PARTNAMES} \
                   --train_data_dir {TRAIN_DATA_DIR} \
                   --val_data_dir {TRAIN_DATA_DIR} \
                   --test_data_dir {TEST_DATA_DIR} \
                   --train \

如果你提供了测试图像及其相应的掩码,运行此命令将显示测试数据中每个分割部分的平均交并比(mIoU)。此外,它将在slime目录的slime/outputs/checkpoints文件夹中保存训练好的文本嵌入,并在slime/outputs/lightning_logs文件夹中保存日志文件。

使用训练好的文本嵌入进行测试

要使用训练好的文本嵌入进行测试,运行以下命令:

python -m src.main --dataset sample \
                   --checkpoint_dir {CHECKPOINT_DIR} \
                   --test_data_dir {TEST_DATA_DIR} \

在此命令中:

  • {CHECKPOINT_DIR}替换为存储训练好的文本嵌入的文件夹路径。确保此目录中只有相关的文本嵌入,因为代码将从指定文件夹加载所有文本嵌入。
  • 确保你已将测试图像(如果有掩码,用于计算mIoU)放在新文件夹中,并使用--test_data_dir参数提供此文件夹的路径。

伪装结果

在Colab笔记本上测试 在Colab中打开

你可以在Colab笔记本中测试训练好的文本嵌入。克隆代码后,请按照上述步骤操作并执行提供的命令。

图像分块

要配置验证和测试时的图像分块,你可以为--patch_size--num_patches_per_side参数指定不同的值。这些设置将用于将图像划分为一个块的网格,计算单个最终注意力图(称为WAS-attention图),聚合它们,并生成分割掩码预测。

以下是如何在命令中包含这些参数的示例:

python -m src.main --dataset sample \
                   --checkpoint_dir {CHECKPOINT_DIR} \
                   --test_data_dir {TEST_DATA_DIR} \
                   --patch_size {PATCH_SIZE} \
                   --num_patches_per_side {NUM_PATCHES_PER_SIDE}
  • {PATCH_SIZE}替换为每个块的所需大小。
  • {NUM_PATCHES_PER_SIDE}替换为你想要的图像每边的块数。 通过调整这些值,你可以控制验证和测试的分块过程,这对于在不同图像大小或特征上微调方法的性能很有用。

在数据集上进行1样本和10样本训练

PASCAL-Part 汽车

要在PASCAL-Part的汽车类上使用SLiMe的1样本设置进行训练和测试,请按以下步骤操作:

  1. 从此链接下载数据并解压。
  2. 导航到slime文件夹。
  3. 运行以下命令,将{path_to_data_folder}替换为你解压数据的文件夹路径(末尾不带反斜杠):
DATADIR={path_to_data_folder}
python3 -m src.main --dataset_name pascal \
                    --part_names background body light plate wheel window \
                    --train_data_dir $DATADIR/car/train_1 \
                    --val_data_dir $DATADIR/car/train_1 \
                    --test_data_dir $DATADIR/car/test \
                    --min_crop_ratio 0.6 \
                    --num_patchs_per_side 1 \
                    --patch_size 512 \
                    --train

对于10样本设置,你可以按如下方式修改命令:

DATADIR={path_to_data_folder}
python3 -m src.main --dataset_name pascal \
                    --part_names background body light plate wheel window \
                    --train_data_dir $DATADIR/car/train_10 \
                    --val_data_dir $DATADIR/car/val \
                    --test_data_dir $DATADIR/car/test \
                    --min_crop_ratio 0.6 \
                    --num_patchs_per_side 1 \
                    --patch_size 512 \
                    --train

在这种情况下,你应该为 --train_data_dir 指定 car/train_10,为 --val_data_dir 指定 car/val

PASCAL-Part 马类

要在 PASCAL-Part 的马类上使用 SLiMe 的 1 样本设置进行训练和测试,可以按以下步骤操作:

  1. 从此链接下载数据并解压。
  2. 进入 slime 文件夹。
  3. 运行以下命令,将 {path_to_data_folder} 替换为你解压数据的文件夹路径(末尾不加反斜杠):
DATADIR={path_to_data_folder}
python3 -m src.main --dataset_name pascal \
                    --part_names background head neck+torso leg tail \
                    --train_data_dir $DATADIR/horse/train_1 \
                    --val_data_dir $DATADIR/horse/train_1 \
                    --test_data_dir $DATADIR/horse/test \
                    --min_crop_ratio 0.8 \
                    --num_patchs_per_side 1 \
                    --patch_size 512 \
                    --train

对于 10 样本设置,你可以按如下方式修改命令:

DATADIR={path_to_data_folder}
python3 -m src.main --dataset_name pascal \
                    --part_names background head neck+torso leg tail \
                    --train_data_dir $DATADIR/horse/train_10 \
                    --val_data_dir $DATADIR/horse/val \
                    --test_data_dir $DATADIR/horse/test \
                    --min_crop_ratio 0.8 \
                    --num_patchs_per_side 1 \
                    --patch_size 512 \
                    --train

在这种情况下,你应该为 --train_data_dir 指定 horse/train_10,为 --val_data_dir 指定 horse/val

CelebAMask-HQ

要在 CelebAMask-HQ 上使用 SLiMe 的 1 样本设置进行训练和测试,可以按以下步骤操作:

  1. 从此链接下载数据并解压。
  2. 进入 slime 文件夹。
  3. 运行以下命令,将 {path_to_data_folder} 替换为你解压数据的文件夹路径(末尾不加反斜杠):
DATADIR={path_to_data_folder}
python3 -m src.main --dataset_name celeba \
                    --part_names background skin eye mouth nose brow ear neck cloth hair \
                    --train_data_dir $DATADIR/celeba/train_1 \
                    --val_data_dir $DATADIR/celeba/train_1 \
                    --test_data_dir $DATADIR/celeba/test \
                    --min_crop_ratio 0.6 \
                    --train

对于 10 样本设置,你可以按如下方式修改命令:

DATADIR={path_to_data_folder}
python3 -m src.main --dataset_name celeba \
                    --part_names background skin eye mouth nose brow ear neck cloth hair \
                    --train_data_dir $DATADIR/celeba/train_10 \
                    --val_data_dir $DATADIR/celeba/val \
                    --test_data_dir $DATADIR/celeba/test \
                    --min_crop_ratio 0.6 \
                    --train

在这种情况下,你应该为 --train_data_dir 指定 celeba/train_10,为 --val_data_dir 指定 celeba/val

训练好的文本嵌入

在这个链接,我们正在上传我们训练好的文本嵌入,包括我们为论文训练的文本嵌入。你可以下载这些文本嵌入,并使用使用训练好的文本嵌入进行测试部分的命令在你的数据上进行测试。

问题和故障

如果你有任何问题或遇到困难,请在这里创建一个问题。

引用

@article{khani2023slime,
  title={SLiMe: Segment Like Me},
  author={Khani, Aliasghar and Taghanaki, Saeid Asgari and Sanghi, Aditya and Amiri, Ali Mahdavi and Hamarneh, Ghassan},
  journal={arXiv preprint arXiv:2309.03179},
  year={2023}
}
项目侧边栏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号