# export EXPERIMENT_NAME="E-ASPL"
# export MODEL_PATH="./stable-diffusion/stable-diffusion-2-1-base"
# export CLEAN_TRAIN_DIR="data/n000050/set_A" 
# export CLEAN_ADV_DIR="data/n000050/set_B"
# export OUTPUT_DIR="outputs/$EXPERIMENT_NAME/n000050_ADVERSARIAL"
# export CLASS_DIR="data/class-person"
# ------------------------- Train ASPL on set B -------------------------
# export EXPERIMENT_NAME="vangogh_ensemble_ASPL_style_loss_upscaling"
export EXPERIMENT_NAME="test_textual_inversion"

# diffusion model 2-1
# export MODEL_PATH="stabilityai/stable-diffusion-2-1-base"
#export MODEL_PATH="CompVis/stable-diffusion-v1-4"
# export MODEL_PATH="stabilityai/stable-diffusion-xl-base-1.0"
export MODEL_NAME="stable-diffusion-v1-5/stable-diffusion-v1-5"


export HUGGINGFACE_TOKEN=""
# export CLEAN_TRAIN_DIR="data/CelebA-HQ/$EXPERIMENT_NAME/set_A" 
# export CLEAN_ADV_DIR="data/CelebA-HQ/$EXPERIMENT_NAME/set_B"
# export OUTPUT_DIR="outputs/simac/CelebA-HQ/$EXPERIMENT_NAME"
# export CLASS_DIR="clean_class_image"
export CLEAN_TRAIN_DIR="/home/anonymous/AIGC/diffusers/image_van_gogh_small" 
export CLEAN_ADV_DIR="/home/anonymous/AIGC/diffusers/image_van_gogh_small"
export OUTPUT_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/outputs/style/wikiart/test_lora"
export CLASS_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/data/wikiart/reference"

# ------------------------- Train E-ASPL on set B -------------------------
# pretrained sd models
# sd14_path="./stable-diffusion/stable-diffusion-v1-4"
export sd14_path="CompVis/stable-diffusion-v1-4"

export su_upscale_path="stabilityai/stable-diffusion-x4-upscaler"
sd15_path="./stable-diffusion/stable-diffusion-v1-5"
# sd21_path="./stable-diffusion/stable-diffusion-2-1-base"
export sd21_path="stabilityai/stable-diffusion-2-1-base"
# ref_model_path="${sd14_path},${su_upscale_path}"
export ref_model_path="${sd21_path, su_upscale_path}"

#mkdir -p $OUTPUT_DIR
#cp -r $CLEAN_TRAIN_DIR $OUTPUT_DIR/image_clean
#cp -r $CLEAN_ADV_DIR $OUTPUT_DIR/image_before_addding_noise


# ------------------------- Train DreamBooth on perturbed examples -------------------------
export INSTANCE_DIR="$OUTPUT_DIR/noise-ckpt/50"
export DREAMBOOTH_OUTPUT_DIR="/media/ssd1/anonymous/dreambooth-outputs/anti-style/$EXPERIMENT_NAME/"

export MODEL_NAME="stable-diffusion-v1-5/stable-diffusion-v1-5"

# accelerate launch --gpu_ids="5,6" --num_processes=2 --config_file gpu_config.yaml --main_process_port=8888 /home/anonymous/AIGC/diffusers/StyleGuard/diffusers/examples/textual_inversion/textual_inversion.py \
#   --pretrained_model_name_or_path=$MODEL_NAME \
#   --train_data_dir=$INSTANCE_DIR \
#   --learnable_property="style" \
#   --placeholder_token="<sks-style>" \
#   --initializer_token="toy" \
#   --resolution=512 \
#   --train_batch_size=1 \
#   --gradient_accumulation_steps=4 \
#   --max_train_steps=3000 \
#   --learning_rate=5.0e-04 \
#   --scale_lr \
#   --lr_scheduler="constant" \
#   --lr_warmup_steps=0 \
#   --output_dir=$DREAMBOOTH_OUTPUT_DIR



# export INSTANCE_DIR="outputs/style/wikiart/$EXPERIMENT_NAME/noise-upscaling"
# python Noisy_Upscaling.py \
#   --input_folder="/home/anonymous/AIGC/diffusers/StyleGuard/outputs/style/wikiart/vangogh_ensemble_ASPL_style_loss_upscaling/image_before_addding_noise" \
#   --output_folder=$INSTANCE_DIR \
#   --upscaler="flux" \
#   --step=step


python /home/anonymous/AIGC/diffusers/StyleGuard/infer_textural_inversion.py \
    --model_path "stable-diffusion-v1-5/stable-diffusion-v1-5" \
    --embedding_path "/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/anti-style/test_textual_inversion" \
    --prompt " a <sks-style> paint of house" \
    --placeholder_token "<sks-style>" \
    --num_images 8 \
    --output_dir "/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/anti-style/test_textual_inversion/image"


# python infer_lora.py \
#     --model_path $MODEL_PATH \
#     --lora_path "$DREAMBOOTH_OUTPUT_DIR/pytorch_lora_weights.safetensors" \
#     --prompt "an sks painting including a house"
#     --v "sks" \
#     --img_num 8 \
#     --output_dir "evaluate/$EXPERIMENT_NAME"


python evaluate/eval_fid_new.py \
  --input_folder "/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/anti-style/test_textual_inversion/image" \
  --refer '/home/anonymous/AIGC/diffusers/StyleGuard/evaluate/clean-infer-fid-ref.npz'




export INPUT_FOLDER="/home/anonymous/AIGC/diffusers/Gogh_House/Gogh_House_SD1_5"

python evaluate/eval_precision_new.py \
  --reference_folder $INPUT_FOLDER \
  --gen_folder "/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/anti-style/test_textual_inversion/image/"

# python infer.py \
#   --model_path $MODEL_PATH \
#   --output_dir $DREAMBOOTH_OUTPUT_DIR/checkpoint-1000-test-infer \
#   --prompt "an sks painting, including a basket and some apples"

# # export DREAMBOOTH_OUTPUT_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/anti-style/vangogh_ensemble_ASPL_style_loss_upscaling/checkpoint-1000-test-infer"
# python infer.py \
#   --model_path /home/anonymous/AIGC/diffusers/model/saved_model_vangogh\
#   --output_dir $DREAMBOOTH_OUTPUT_DIR/checkpoint-1000-test-infer-normal \
#   --prompt "a sks painting, including a river and a house"
# python infer.py \
#   --model_path /home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/anti-style/vangogh_ensemble_ASPL_style_loss_upscaling \
#   --output_dir $DREAMBOOTH_OUTPUT_DIR/checkpoint-1000-test-infer \
#   --prompt "a sks painting, including a river and a house"


# step=50
# # export DREAMBOOTH_OUTPUT_DIR="dreambooth-outputs/anti-style/vangogh_ensemble_ASPL_style_loss_upscaling_step${step}/"
# # export INSTANCE_DIR="outputs/style/wikiart/$EXPERIMENT_NAME/noise-upscaling-step${step}"

# export DREAMBOOTH_OUTPUT_DIR="/media/ssd1/anonymous/dreambooth-outputs/anti-style/vangogh_ensemble_ASPL_style_loss_upscaling_x2/"
# export INSTANCE_DIR="outputs/style/wikiart/$EXPERIMENT_NAME/noise-upscaling-x2"


# python Noisy_Upscaling.py \
#   --input_folder="outputs/style/wikiart/$EXPERIMENT_NAME/noise-ckpt/50" \
#   --output_folder=$INSTANCE_DIR \
#   --upscaler="x2" \
#   --step=${step}

# accelerate launch train_dreambooth.py \
# accelerate launch --num_processes=2 --gpu_ids="0,1" --config_file gpu_config.yaml --main_process_port=8830 /home/anonymous/AIGC/diffusers/examples/dreambooth/train_dreambooth.py \
#   --pretrained_model_name_or_path=$MODEL_PATH  \
#   --enable_xformers_memory_efficient_attention \
#   --train_text_encoder \
#   --instance_data_dir=$INSTANCE_DIR \
#   --class_data_dir=$CLASS_DIR \
#   --output_dir=$DREAMBOOTH_OUTPUT_DIR \
#   --with_prior_preservation \
#   --prior_loss_weight=1.0 \
#   --instance_prompt="an sks painting" \
#   --class_prompt="a painting" \
#   --resolution=512 \
#   --train_batch_size=1 \
#   --gradient_accumulation_steps=1 \
#   --learning_rate=5e-6 \
#   --lr_scheduler="constant" \
#   --lr_warmup_steps=0 \
#   --num_class_images=100 \
#   --max_train_steps=500 \
#   --center_crop \
#   --mixed_precision=bf16 \
#   --prior_generation_precision=bf16 \
#   --sample_batch_size=8 \
#   --snr_gamma=1.5


# python infer.py \
#   --model_path $DREAMBOOTH_OUTPUT_DIR \
#   --output_dir $DREAMBOOTH_OUTPUT_DIR/checkpoint-1000-test-infer \
#   --prompt "an sks painting, including a basket and some apples"

# export INSTANCE_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/outputs/style/wikiart/vangogh_with_styleloss_SD14/image_clean_crop"
# export DREAMBOOTH_OUTPUT_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/anti-style/vangogh_clean"

# accelerate launch --num_processes=2 --gpu_ids="0,1,2,3,4,5,6,7" --config_file gpu_config.yaml --main_process_port=8830 /home/anonymous/AIGC/diffusers/examples/dreambooth/train_dreambooth.py \
#   --pretrained_model_name_or_path=$MODEL_PATH  \
#   --enable_xformers_memory_efficient_attention \
#   --train_text_encoder \
#   --instance_data_dir=$INSTANCE_DIR \
#   --class_data_dir=$CLASS_DIR \
#   --output_dir=$DREAMBOOTH_OUTPUT_DIR \
#   --with_prior_preservation \
#   --prior_loss_weight=1.0 \
#   --instance_prompt="a sks painting" \
#   --class_prompt="a painting" \
#   --resolution=512 \
#   --train_batch_size=1 \
#   --gradient_accumulation_steps=1 \
#   --learning_rate=5e-6 \
#   --lr_scheduler="constant" \
#   --lr_warmup_steps=0 \
#   --num_class_images=30 \
#   --max_train_steps=500 \
#   --checkpointing_steps=500 \
#   --center_crop \
#   --mixed_precision=bf16 \
#   --prior_generation_precision=bf16 \
#   --sample_batch_size=8 \
#   --snr_gamma=1.5


# python infer.py \
#   --model_path $DREAMBOOTH_OUTPUT_DIR \
#   --output_dir $DREAMBOOTH_OUTPUT_DIR/checkpoint-1000-test-infer \
#   --prompt "an sks painting, including a blue sky and mountains"

# python infer.py \
#   --model_path $DREAMBOOTH_OUTPUT_DIR \
#   --output_dir $DREAMBOOTH_OUTPUT_DIR/checkpoint-1000-test-infer \
#   --prompt "a painting, including a blue sky and mountains"

# python infer.py \
#   --model_path $DREAMBOOTH_OUTPUT_DIR \
#   --output_dir $DREAMBOOTH_OUTPUT_DIR/checkpoint-1000-test-infer \
#   --prompt "an sks painting, including river and house"

# python infer.py \
#   --model_path $DREAMBOOTH_OUTPUT_DIR \
#   --output_dir $DREAMBOOTH_OUTPUT_DIR/checkpoint-1000-test-infer \
#   --prompt "a painting, including river and house"


# export INPUT_FOLDER="/home/anonymous/AIGC/diffusers/Gogh_House/Gogh_House_SD1_5"
# export EXPERIMENT_NAME="vangogh_ensemble_ASPL_style_loss"

# experiment_name="vangogh_ensemble_ASPL_style_loss"
# python infer.py \
#   --model_path dreambooth-outputs/anti-style/${experiment_name} \
#   --output_dir evaluate/${experiment_name}-infer/ \
#   --prompt "an sks painting, inclusing a house" \
#   --img_num 20

# python evaluate/eval_fid_new.py \
#   --input_folder "evaluate/${experiment_name}-infer/an_sks_painting_inclusing_a_house" \
#   --refer '/home/anonymous/AIGC/diffusers/StyleGuard/evaluate/clean-infer-fid-ref.npz'

# python evaluate/eval_precision_new.py \
#   --reference_folder $INPUT_FOLDER \
#   --gen_folder "evaluate/${experiment_name}-infer/an_sks_painting_inclusing_a_house"