# #!/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-xxl..."
rclone copy --progress --http-url https://nvlabs-fi-cdn.nvidia.com/edm2 :http:raw-snapshots/edm2-img512-xxl/ raw-snapshots/edm2-img512-xxl/
 
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
 
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=2147483 --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.025
 
echo "Reconstructing img512-xs-uncond (std=0.015)..."
python reconstruct_phema.py --indir=raw-snapshots/edm2-img512-xs-uncond --outdir=recon/phema --outprefix=img512-xs-uncond --outkimg=2147483 --outstd=0.015
 
echo "Reconstructing img512-xxl (std=0.075)..."
python reconstruct_phema.py --indir=raw-snapshots/edm2-img512-xxl --outdir=recon/phema --outprefix=img512-xxl --outkimg=0939524 --outstd=0.075
 
 
# 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.4)
gammas=(0.4)
beta1s=(0.9)
beta2s=(0.9)
pred_types=('reg')
num_gpus=4
 
base_dir="eval"
mkdir -p "$base_dir"
model_root=$(pwd)
########## TODO ##########
coco_dir="val2017/"
imagenet_dir="imgnet_val/"
########## TODO ##########
#EDM2-XXL
nets=("recon/phema/img512-xxl-0939524-0.075.pkl")
gnets=("recon/phema/img512-xs-uncond-2147483-0.015.pkl")
# # #EDM2-S
# nets=("recon/phema/img512-s-2147483-0.025.pkl")
# gnets=("recon/phema/img512-xs-uncond-2147483-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 4 \
                                --prc \
                                --input1 $save_dir\
                                --input2 $imagenet_dir \
                                --samples-resize-and-crop 512\
                                >> "$log_file" 2>&1
 
                        done
                    done
                done
            done
        done
    done
done
 
echo "All tasks completed."
# --logwandb \
 
GitHub - NVlabs/edm2: EDM2 and Autoguidance -- Official PyTorch implementation
EDM2 and Autoguidance -- Official PyTorch implementation - NVlabs/edm2
 