## Train Implicit Textual Extractor

### Prepare Environment 

```sh
conda create -n implicit_textual python=3.8
conda activate implicit_textual
pip install -r requirements.txt
```

### Train Mapper

```sh
accelerate launch --config_file option/1_gpu.json --main_process_port 25656 \
  	Implicit_Textual_Guidance/train/mapper.py \
  	--pretrained_stable_diffusion_path="sd2.1_path" \
  	--pretrained_clip_model_path="clip-vit-large-patch14_path" 
  	--num_words=30 \
	--train_data_dir="FFHQ_dataset_path" \
    --placeholder_token="S" --resolution=512 --train_batch_size=4 --gradient_accumulation_steps=4 \
    --max_train_steps=17500 --learning_rate=1e-06 --scale_lr --lr_scheduler="constant" --lr_warmup_steps=0 \
    --output_dir="./experiments/mapper" \
    --save_steps=50
```

### Train Remover

```sh
accelerate launch --config_file option/1_gpu.json --main_process_port 25656 \
    Implicit_Textual_Guidance/train/remover.py \
    --pretrained_stable_diffusion_path="sd2.1_path" \
  	--pretrained_clip_model_path="clip-vit-large-patch14_path" 
  	--num_words=30 \
	--train_data_dir="FFHQ_dataset_path" \
    --placeholder_token="S" --resolution=512 --train_batch_size=4 --gradient_accumulation_steps=4 \
    --max_train_steps=17500 --learning_rate=1e-06 --scale_lr --lr_scheduler="constant" --lr_warmup_steps=0 \
    --output_dir="./experiments/remover" \
    --mapper_path="mapper_path" \
    --save_steps=50
```

### Generate reference Image

```sh
python inference/generate_remover_output.py \
    --pretrained_stable_diffusion_path="sd2.1_path" \
    --pretrained_clip_model_path="clip-vit-large-patch14_path" \
    --inference_data_dir="LQ_dir" \
    --output_dir="./outputs" \
    --num_words=30 --template="a photo of a S" \
    --mapper_path="mapper_path" \
    --remover_path="remover_path" 
```