# RoboFace: Face Restoration Made Robust via Implicit and Explicit Textual Guidance

## Requirements

To install requirements:

```setup
conda create -n roboface python=3.8
conda activate roboface
pip install -r requirements.txt
```

## Training

To train the model(s) in the paper, run this command:

- Stage1: Training Implicit Text Extractor Module, see file ImpliccitTextExtractor
- Stage2: Training RoboFace model

```train stage2
CUDA_VISIBLE_DEVICES=0,1,2,3 accelerate launch train_roboface.py
```

## Inference

#### step 1: Download the pretrained models

- Download the pretrained SD-2.1 models from [HuggingFace](https://huggingface.co/stabilityai/stable-diffusion-2-1)
- Download the [LLaVA](https://huggingface.co/liuhaotian/llava-v1.5-13b/tree/main)
- Download the [GFPGAN-v1.4](https://github.com/TencentARC/GFPGAN)
- Download the [CLIP](https://huggingface.co/openai/clip-vit-large-patch14)
- Download the RoboFace model

you can put the models into `preset/models`

#### step 2: Prepare testing data

you can put the testing images in `preset/test_imgs/`

### step 3: Prepare prompt

run implicit text extractor inference in `ImplicitTextExtractor/inference/generate_ref.py` to generate output img and use llava in `llava/llm_agent` to generate prompt

#### step4: Runing the following command to generate the restored images:

```eval
python inference.py \
--roboface_model_path preset/models/spider \
--image_encoder_without_proj_path preset/models/clip \
--pretrained_sd2_1_path preset/models/sd_2_1 \
--mapper_model_path preset/models/mapper \
--remvoer_model_path preset/models/remover \
--llava_model_path preset/models/llava \
--gfpgan_path preset/gfpgan/
--image_path preset/test_imgs/
--output_dir output/
```
