Image-to-Image
Diffusers
English
InstantIR / README.md
JOY-Huang's picture
Update README.md
f793f9c verified
|
raw
history blame
5.32 kB
metadata
license: apache-2.0
language:
  - en
library_name: diffusers
pipeline_tag: image-to-image

InstantIR Model Card

InstantIR is a novel single-image restoration model designed to resurrect your damaged images, delivering extrem-quality yet realistic details. You can further boost InstantIR performance with additional text prompts, even achieve customized editing!

Usage

1. Clone the github repo

git clone https://github.com/JY-Joy/InstantIR.git
cd InstantIR

2. Download model weights

You can directly download InstantIR weights in this repository, or you can download them using python script:

from huggingface_hub import hf_hub_download
hf_hub_download(repo_id="InstantX/InstantIR", filename="models/adapter.pt", local_dir="./models")
hf_hub_download(repo_id="InstantX/InstantIR", filename="models/aggregator.pt", local_dir="./models")
hf_hub_download(repo_id="InstantX/InstantIR", filename="models/previewer_lora_weights.bin", local_dir="./models")

3. Load InstantIR with 🧨 diffusers

# !pip install opencv-python transformers accelerate
import torch
from PIL import Image

from diffusers import DDPMScheduler, StableDiffusionXLPipeline
from schedulers.lcm_single_step_scheduler import LCMSingleStepScheduler

from transformers import AutoImageProcessor, AutoModel

from module.ip_adapter.utils import init_adapter_in_unet
from module.ip_adapter.resampler import Resampler
from pipelines.sdxl_instantir import InstantIRPipeline

# prepare 'dinov2'
image_encoder = AutoModel.from_pretrained('facebook/dinov2-large')
image_processor = AutoImageProcessor.from_pretrained('facebook/dinov2-large')

# prepare models under ./checkpoints
dcp_adapter = f'./models/adapter.pt'
previewer_lora_path = f'./models'
instantir_path = f'./models/aggregator.pt'

# load SDXL
sdxl = StableDiffusionXLPipeline.from_pretrained('stabilityai/stable-diffusion-xl-base-1.0', torch_dtype=torch.float16)

# InstantIR pipeline
pipe = InstantIRPipeline(
    sdxl.vae, sdxl.text_encoder, sdxl.text_encoder_2, sdxl.tokenizer, sdxl.tokenizer_2,
    sdxl.unet, sdxl.scheduler, feature_extractor=image_processor, image_encoder=image_encoder,
)

# load adapter
image_proj_model = Resampler(
    embedding_dim=image_encoder.config.hidden_size,
    output_dim=sdxl.unet.config.cross_attention_dim,
)
init_adapter_in_unet(
    pipe.unet,
    image_proj_model,
    dcp_adapter,
)

# load previewer lora
pipe.prepare_previewers(previewer_lora_path)
pipe.scheduler = DDPMScheduler.from_pretrained('stabilityai/stable-diffusion-xl-base-1.0', subfolder="scheduler")
lcm_scheduler = LCMSingleStepScheduler.from_config(pipe.scheduler.config)
pipe.unet.to(dtype=torch.float16)
pipe.to('cuda')

# load aggregator weights
pretrained_state_dict = torch.load(instantir_path)
pipe.aggregator.load_state_dict(pretrained_state_dict)
pipe.aggregator.to(dtype=torch.float16, device=pipe.unet.device)

Then, you can restore your broken images with:

# load a broken image
image = Image.open('path/to/your-image').convert("RGB")

# InstantIR restoration
image = pipe(
    prompt='',
    image=image,
    ip_adapter_image=[image],
    negative_prompt='',
    guidance_scale=7.0,
    previewer_scheduler=lcm_scheduler,
    return_dict=False,
)[0]

For more details including text-guided enhancement/editing, please refer to our GitHub repository.

Examples

Disclaimer

This project is released under Apache License and aims to positively impact the field of AI-driven image generation. Users are granted the freedom to create images using this tool, but they are obligated to comply with local laws and utilize it responsibly. The developers will not assume any responsibility for potential misuse by users.

Citation

@article{huang2024instantir,
  title={InstantIR: Blind Image Restoration with Instant Generative Reference},
  author={Huang, Jen-Yuan and Wang, Haofan and Wang, Qixun and Bai, Xu and Ai, Hao and Xing, Peng and Huang, Jen-Tse},
  journal={arXiv preprint arXiv:2410.06551},
  year={2024}
}