# ------------------------- Train ASPL on set B -------------------------
export EXPERIMENT_NAME="face"
# diffusion model 2-1
# export MODEL_PATH="stabilityai/stable-diffusion-2-1-base"
export MODEL_PATH="CompVis/stable-diffusion-v1-4"

# 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/StyleGuard/CelebA-HQ/103/all" 
export CLEAN_ADV_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/CelebA-HQ/103/all"
export OUTPUT_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/outputs/style/celeba/$EXPERIMENT_NAME"
export CLASS_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/clean_class_image"
# export CUDA_VISIBLE_DEVICES=0,1,2,3
export DEVICE="0,1,2,3,4"
export TARGET_PAINTING_DIR="data/wikiart/2"
# export TARGET_PAINTING_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/CelebA-HQ/5/set_A"
mkdir -p $OUTPUT_DIR
cp -r $CLEAN_TRAIN_DIR $OUTPUT_DIR/image_clean
cp -r $CLEAN_ADV_DIR $OUTPUT_DIR/image_before_addding_noise


export INSTANCE_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/CelebA-HQ/103/all"
# export DREAMBOOTH_OUTPUT_DIR="dreambooth-outputs/simac/CelebA-HQ/$EXPERIMENT_NAME"
export DREAMBOOTH_OUTPUT_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/clean/$EXPERIMENT_NAME"

# diffusion 1-4
export MODEL_PATH="CompVis/stable-diffusion-v1-4"
# export OUTPUT_DIR="model/saved_model_vangogh_addnoise"
export HUGGINGFACE_TOKEN=""

# accelerate launch --num_processes=4 --gpu_ids=$DEVICE --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  \
#   --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 person of sks" \
#   --class_prompt="a person" \
#   --resolution=512 \
#   --train_batch_size=1 \
#   --gradient_accumulation_steps=2 \
#   --gradient_checkpointing \
#   --use_8bit_adam \
#   --learning_rate=5e-6 \
#   --lr_scheduler="constant" \
#   --lr_warmup_steps=0 \
#   --num_class_images=50 \
#   --max_train_steps=500 \
#   --snr_gamma=1.5

# python infer.py \
#   --model_path $DREAMBOOTH_OUTPUT_DIR \
#   --output_dir $OUTPUT_DIR/checkpoint-1000-test-infer \
#   --prompt "a person of sks, wearing a sunglass"

# python infer.py \
#   --model_path $DREAMBOOTH_OUTPUT_DIR \
#   --output_dir $OUTPUT_DIR/checkpoint-1000-test-infer \
#   --prompt "a person, wearing a sunglass"

# accelerate  launch --main_process_port 0 attacks/time_feature.py \
# CUDA_VISIBLE_DEVICES=0 python attacks/time_feature.py \
# accelerate  launch attacks/time_feature_style.py \
# #CUDA_VISIBLE_DEVICES=1,2,3,4 python attacks/time_feature_style.py \
# accelerate launch --num_processes=4 --mixed_precision="fp16" --gpu_ids=$DEVICE --config_file gpu_config.yaml  --main_process_port=8889 attacks/time_feature_style.py \
#   --target_image_dir=$TARGET_PAINTING_DIR \
#   --pretrained_model_name_or_path=$MODEL_PATH \
#   --enable_xformers_memory_efficient_attention \
#   --instance_data_dir_for_train=$CLEAN_TRAIN_DIR \
#   --instance_data_dir_for_adversarial=$CLEAN_ADV_DIR \
#   --instance_prompt="an sks painting" \
#   --num_class_images=16 \
#   --output_dir=$OUTPUT_DIR \
#   --center_crop \
#   --prior_loss_weight=1.0 \
#   --resolution=512 \
#   --train_text_encoder \
#   --train_batch_size=1 \
#   --max_train_steps=50 \
#   --max_f_train_steps=3 \
#   --max_adv_train_steps=6 \
#   --checkpointing_iterations=50 \
#   --learning_rate=5e-6 \
#   --pgd_alpha=0.005 \
#   --pgd_eps=32 \
#   --seed=0 \
#   --class_data_dir=$CLASS_DIR \
#   --with_prior_preservation \
#   --class_prompt="a painting" \
#   --style_loss_weight=1 \
#   --noise_pred_loss_weight=1


# export INSTANCE_DIR="$OUTPUT_DIR/noise-ckpt/50"
# # export DREAMBOOTH_OUTPUT_DIR="dreambooth-outputs/simac/CelebA-HQ/$EXPERIMENT_NAME"
# export DREAMBOOTH_OUTPUT_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/anti-style/$EXPERIMENT_NAME"

# # diffusion 1-4
export MODEL_PATH="CompVis/stable-diffusion-v1-4"
# # export OUTPUT_DIR="model/saved_model_vangogh_addnoise"
# export HUGGINGFACE_TOKEN=""
export INSTANCE_DIR="$OUTPUT_DIR/noise-upscale"
export DREAMBOOTH_OUTPUT_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/face_upscale"

accelerate launch --num_processes=4 --gpu_ids=$DEVICE --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  \
  --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=2 \
  --gradient_checkpointing \
  --use_8bit_adam \
  --learning_rate=5e-6 \
  --lr_scheduler="constant" \
  --lr_warmup_steps=0 \
  --num_class_images=50 \
  --max_train_steps=500 \
  --snr_gamma=1.5

python infer.py \
  --model_path $DREAMBOOTH_OUTPUT_DIR \
  --output_dir $OUTPUT_DIR/upscale_checkpoint-1000-test-infer \
  --prompt "an person of sks, wearing a sunglass"

python infer.py \
  --model_path $DREAMBOOTH_OUTPUT_DIR \
  --output_dir $OUTPUT_DIR/upscale_checkpoint-1000-test-infer \
  --prompt "a person, wearing a sunglass"

# python Noisy_Upscaling.py \
#   --input_folder $INSTANCE_DIR \
#   --output_folder "$OUTPUT_DIR/noise-upscale"

# export EXPERIMENT_NAME="face_upscale"

# export DREAMBOOTH_OUTPUT_DIR="/home/anonymous/AIGC/diffusers/StyleGuard/dreambooth-outputs/anti-style/$EXPERIMENT_NAME"

# accelerate launch --num_processes=4 --gpu_ids=$DEVICE --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  \
#   --instance_data_dir="$OUTPUT_DIR/noise-upscale" \
#   --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=2 \
#   --gradient_checkpointing \
#   --use_8bit_adam \
#   --learning_rate=5e-6 \
#   --lr_scheduler="constant" \
#   --lr_warmup_steps=0 \
#   --num_class_images=50 \
#   --max_train_steps=500 \
#   --snr_gamma=1.5


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

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