#!/bin/bash

# 1. Clone the repository and enter the directory
echo "Cloning EDM2 repository..."
git clone https://github.com/NVlabs/edm2.git
cd edm2 || { echo "Failed to enter edm2 directory"; exit 1; }

# 2. Patch generate_images.py
echo "Patching generate_images.py..."
sed -i 's/gnet(x, t)/gnet(x, t, labels)/g' generate_images.py

# 3. Download snapshot files using rclone
echo "Downloading edm2-img512-xs-uncond..."
rclone copy --progress --http-url https://nvlabs-fi-cdn.nvidia.com/edm2 :http:raw-snapshots/edm2-img512-xs/ raw-snapshots/edm2-img512-xs-uncond/

echo "Downloading edm2-img512-s..."
rclone copy --progress --http-url https://nvlabs-fi-cdn.nvidia.com/edm2 :http:raw-snapshots/edm2-img512-s/ raw-snapshots/edm2-img512-s/

# 4. Reconstruct images
echo "Reconstructing img512-xs-uncond (std=0.025)..."
python reconstruct_phema.py --indir=raw-snapshots/edm2-img512-xs-uncond --outdir=recon/phema --outprefix=img512-xs-uncond --outkimg=134217 --outstd=0.025

echo "Reconstructing img512-s (std=0.070)..."
python reconstruct_phema.py --indir=raw-snapshots/edm2-img512-s --outdir=recon/phema --outprefix=img512-s --outkimg=2147483 --outstd=0.070

# 5. Copy evaluation script
echo "Copying eval_edm2.py..."
cp ../eval_edm2.py . || { echo "Failed to copy 'eval_edm2.py'"; exit 1; }
cp ../generate_images_custom.py . || { echo "Failed to copy 'generate_images_custom.py'"; exit 1; }

# 6. Run evaluation
echo "Starting evaluation..."

guidances=(1.7)
gammas=(0.3)
beta1s=(0.9)
beta2s=(0.9)
pred_types=('reg')
num_gpus=4

base_dir="eval"
mkdir -p "$base_dir"

########## TODO ##########
imagenet_dir="" 
########## TODO ##########

nets=("recon/phema/img512-s-2147483-0.070.pkl")
gnets=("recon/phema/img512-xs-uncond-0134217-0.025.pkl")

for net in "${nets[@]}"; do
    for gnet in "${gnets[@]}"; do
        for guidance in "${guidances[@]}"; do
            for gamma in "${gammas[@]}"; do
                for beta1 in "${beta1s[@]}"; do
                    for beta2 in "${beta2s[@]}"; do
                        for pred_type in "${pred_types[@]}"; do

                            net_name="$(basename "$net" .pkl)"
                            gnet_name="$(basename "$gnet" .pkl)"
                            net_name="${net_name##*-}"
                            gnet_name="${gnet_name##*-}"

                            save_dir="$base_dir/${pred_type}_${net_name}_${gnet_name}_gui${guidance}_gam${gamma}_beta1${beta1}_beta2${beta2}"
                            log_file="$save_dir.log"

                            echo ">>> Starting run: $log_file" | tee -a "$log_file"
                            torchrun --standalone --nproc_per_node=$num_gpus eval_edm2.py \
                                --pred_type "$pred_type" \
                                --net "$model_root/$net" \
                                --gnet "$model_root/$gnet" \
                                --guidance "$guidance" \
                                --gamma "$gamma" \
                                --beta_1 "$beta1" \
                                --beta_2 "$beta2" \
                                --outdir "$save_dir" \
                                --seeds=0-49999 \
                                --gpu 0 \
                                --prc \
                                --input1 $save_dir \
                                --input2 $imagenet_dir \
                                --samples-resize-and-crop 512 \
                                --logwandb \
                                >> "$log_file" 2>&1

                        done
                    done
                done
            done
        done
    done
done

echo "All tasks completed."
