# Painter ## 论文 `Images Speak in Images: A Generalist Painter for In-Context Visual Learning` - https://arxiv.org/abs/2212.02499 ## 模型结构 整个模型基于VIT系列的骨干,VIT的backbone由encoder、decoder两部分组成, 编码器是由VIT的骨干block堆积而成,解码器其实是卷积层构成的。
## 算法原理 通用视觉模型Painter, 将“以视觉为中心”作为建模核心思想,将图像作为输入和输出,从而获得上下文视觉信息,完成不同的视觉任务。将视觉任务的连续输出空间离散化, 并使用语言或专门设计的离散标记作为任务提示, 将视觉问题转化为NLP问题。
## 环境配置 Tips: timm==0.3.2 版本存在[cannot import name 'container_abcs' from 'torch._six'](https://github.com/huggingface/pytorch-image-models/issues/420#issuecomment-776459842)问题, 需要将 `timm/models/layers/helpers.py` 中`from torch._six import container_abcs`修改为 ```bash import torch TORCH_MAJOR=int(torch.__version__.split('.')[0]) TORCH_MINOR=int(torch.__version__.split('.')[1]) if TORCH_MAJOR == 1 and TORCH_MINOR < 8: from torch._six import container_abcs else: import collections.abc as container_abcs ``` ### Docker(方法一) -v 路径、docker_name和imageID根据实际情况修改 ```bash docker pull image.sourcefind.cn:5000/dcu/admin/base/pytorch:2.1.0-centos7.6-dtk24.04-py310 docker run -it -v /path/your_code_data/:/path/your_code_data/ --shm-size=32G --privileged=true --device=/dev/kfd --device=/dev/dri/ --group-add video --name docker_name imageID bash cd /your_code_path/painter_pytorch pip install -r requirements.txt # 安装detectron2 git clone https://github.com/facebookresearch/detectron2 python -m pip install -e detectron2 ``` ### Dockerfile(方法二) -v 路径、docker_name和imageID根据实际情况修改 ```bash cd ./docker docker build --no-cache -t painter:latest . docker run -it -v /path/your_code_data/:/path/your_code_data/ --shm-size=32G --privileged=true --device=/dev/kfd --device=/dev/dri/ --group-add video --name docker_name imageID bash cd /your_code_path/painter_pytorch pip install -r requirements.txt # 安装detectron2 git clone https://github.com/facebookresearch/detectron2 python -m pip install -e detectron2 ``` ### Anaconda(方法三) 1、关于本项目DCU显卡所需的特殊深度学习库可从光合开发者社区下载安装:https://developer.hpccube.com/tool/ ``` DTK软件栈:dtk24.04 python:python3.10 torch:2.1.0 torchvision:0.16.0 ``` Tips:以上dtk软件栈、python、torch等DCU相关工具版本需要严格一一对应 2、其他非特殊库直接按照requirements.txt安装 ```bash pip install -r requirements.txt # 安装detectron2 git clone https://github.com/facebookresearch/detectron2 python -m pip install -e detectron2 ``` ## 数据集 本项目所需数据集较多, 可以使用提供的[toy_datasets](http://113.200.138.88:18080/aimodels/baai/Painter/-/blob/main/toy_datasets.tar)数据集来验证部分功能, 数据集由每个类别中各10个类别组成. 将数据集放置于`$Painter_ROOT/toy_datasets`路径下, 并设置`$Painter_ROOT/train_painter_vit_large.sh`中`DATA_PATH=toy_datasets`即可, 其他参数请参考训练章节的介绍。 如需完整数据集, 请参考[data instructions](./docs/DATA.md)。完整数据集的目录结构如下: ``` ├── nyu_depth_v2/ │ ├── sync/ │ ├── official_splits/ │ ├── nyu_depth_v2_labeled.mat │ ├── nyuv2_sync_image_depth.json # 生成 │ ├── nyuv2_test_image_depth.json # 生成 ├── ade20k/ │ ├── images/ │ ├── annotations/ │ ├── annotations_detectron2/ # 生成 │ ├── annotations_with_color/ # 生成 │ ├── ade20k_training_image_semantic.json # 生成 │ ├── ade20k_validation_image_semantic.json # 生成 ├── ADEChallengeData2016/ # sim-link to $Painter_ROOT/datasets/ade20k ├── coco/ │ ├── train2017/ │ ├── val2017/ │ ├── annotations/ │ ├── instances_train2017.json │ ├── instances_val2017.json │ ├── person_keypoints_val2017.json │ ├── panoptic_train2017.json │ ├── panoptic_val2017.json │ ├── panoptic_train2017/ │ ├── panoptic_val2017/ │ ├── panoptic_semseg_val2017/ # 生成 │ ├── panoptic_val2017/ # sim-link to $Painter_ROOT/datasets/coco/annotations/panoptic_val2017 │ ├── pano_sem_seg/ # 生成 │ ├── panoptic_segm_train2017_with_color │ ├── panoptic_segm_val2017_with_color │ ├── coco_train2017_image_panoptic_sem_seg.json │ ├── coco_val2017_image_panoptic_sem_seg.json │ ├── pano_ca_inst/ # 生成 │ ├── train_aug0/ │ ├── train_aug1/ │ ├── ... │ ├── train_aug29/ │ ├── train_org/ │ ├── train_flip/ │ ├── val_org/ │ ├── coco_train_image_panoptic_inst.json │ ├── coco_val_image_panoptic_inst.json ├── coco_pose/ │ ├── person_detection_results/ │ ├── COCO_val2017_detections_AP_H_56_person.json │ ├── data_pair/ # 生成 │ ├── train_256x192_aug0/ │ ├── train_256x192_aug1/ │ ├── ... │ ├── train_256x192_aug19/ │ ├── val_256x192/ │ ├── test_256x192/ │ ├── test_256x192_flip/ │ ├── coco_pose_256x192_train.json # 生成 │ ├── coco_pose_256x192_val.json # 生成 ├── derain/ │ ├── train/ │ ├── input/ │ ├── target/ │ ├── test/ │ ├── Rain100H/ │ ├── Rain100L/ │ ├── Test100/ │ ├── Test1200/ │ ├── Test2800/ │ ├── derain_train.json │ ├── derain_test_rain100h.json ├── denoise/ │ ├── SIDD_Medium_Srgb/ │ ├── train/ │ ├── val/ │ ├── denoise_ssid_train.json # 生成 │ ├── denoise_ssid_val.json # 生成 ├── light_enhance/ │ ├── our485/ │ ├── low/ │ ├── high/ │ ├── eval15/ │ ├── low/ │ ├── high/ │ ├── enhance_lol_train.json # 生成 │ ├── enhance_lol_val.json # 生成 ``` ## 训练 下载预训练模型[MAE ViT-Large model](https://dl.fbaipublicfiles.com/mae/pretrain/mae_pretrain_vit_large.pth), 修改`$Painter_ROOT/train.sh`或`$Painter_ROOT/single_process.sh`中finetune参数地址。 ### 单机多卡 本项目默认参数是单机4卡(total_bsz=1x4x32=128), 如需使用其他的卡数, 请修改`train.sh`中对应参数. ```bash bash train.sh ``` ### 多机多卡 Tips: 作者使用8个节点, 每个节点8张卡 (total_bsz=8x8x32=2048) 进行的训练; 使用多节点的情况下,需要将使用节点写入hostfile文件, 多节点每个节点一行, 例如: c1xxxxxx slots=8, 8代表当前节点8张卡 ```bash bash run_train_multi.sh ``` ## 推理 1. 下载推理模型[painter_vit_large.pth](http://113.200.138.88:18080/aimodels/baai/Painter), 或者准备好自己的待测试模型; 2. 部分测试无法使用toy_datasets进行验证,如果使用toy_datasets数据集进行推理, 需确认默认图片是否存在, 如不存在请修改对应参数`PROMPT`; 3. 各个数据集推理方法如下: ### NYU Depth V2 设置[eval/nyuv2_depth/eval.sh](./eval/nyuv2_depth/eval.sh)文件里的`JOB_NAME`、`PROMPT`、`CKPT_FILE`和`DATA_DIR`参数,执行: ```bash bash eval/nyuv2_depth/eval.sh ``` ### ADE20k Semantic Segmentation 1. **当前数据集无法使用 toy_datasets 进行验证**; 2. 设置 [eval/ade20k_semantic/eval.sh](./eval/ade20k_semantic/eval.sh)文件里的`JOB_NAME`、`PROMPT`参数, 执行下面的命令: ```bash bash eval/ade20k_semantic/eval.sh ``` ### COCO Panoptic Segmentation 1. **当前数据集无法使用 toy_datasets 进行验证**; 2. 设置[eval/coco_panoptic/eval.sh](./eval/coco_panoptic/eval.sh)文件里的`JOB_NAME`、`PROMPT`参数, 然后执行下面的命令: ```bash bash eval/coco_panoptic/eval.sh ``` ### COCO Human Pose Estimation 1. **当前数据集无法使用 toy_datasets 进行验证**; 2. 生成验证所需的图像: ```bash python -m torch.distributed.launch --nproc_per_node=4 --master_port=29500 --use_env eval/mmpose_custom/painter_inference_pose.py --ckpt_path models/painter_vit_large/painter_vit_large.pth python -m torch.distributed.launch --nproc_per_node=4 --master_port=29500 --use_env eval/mmpose_custom/painter_inference_pose.py --ckpt_path models/painter_vit_large/painter_vit_large.pth --flip_test ``` 3. 修改 `$Painter_ROOT/eval/mmpose_custom/configs/coco_256x192_test_offline.py` 文件中的 `job_name`、`data_root`、`bbox_file` 和 `ckpt_file` 参数, 执行: ```bash cd $Painter_ROOT/eval/mmpose_custom ./tools/dist_test.sh configs/coco_256x192_test_offline.py none 1 --eval mAP ``` ### Low-Light Image Enhancement ```bash python eval/lol/painter_inference_lol.py --ckpt_path models/path/of/painter_vit_large.pth --data_dir path/of/datasets ``` Example: ``` python eval/lol/painter_inference_lol.py --ckpt_path models/painter_vit_large.pth --data_dir datasets ``` ## result 三张图从左到右分别为: 原始图像, 低分辨率图像, 经模型超分处理后的图像。
### 精度 基于项目提供的测试数据, 得到单卡测试结果如下: | device | task | datasets | PSNR | SSIM | | :------: | :------: | :------: | :------: | :------: | | Z100L | enhance | LOL | 22.34 | 0.8716 | | paper | enhance | LOL | 22.34 | 0.872 | ## 应用场景 ### 算法类别 图像超分,图像分割 ### 热点应用行业 交通,医疗,政府,制造 ## 源码仓库及问题反馈 http://developer.hpccube.com/codes/modelzoo/painter_pytorch.git ## 参考资料 https://github.com/baaivision/Painter/tree/main/Painter