#!/bin/bash


BASE_CKPT="/scratch/physics_diffusion_exp/experiments_iclr/DiffusionPDE_data"
OUTDIR="/scratch/physics_diffusion_exp/experiments_iclr/eval_results_final_2"
BASE_DATA="/projects/ml4science/physics_diffusion/datasets/DiffusionPDE/testing"
BATCH=32

BASE_EVAL="python evaluate_checkpoints.py --batch=$BATCH --kimg_intervals=$KIMG_INTERVALS --offset=0 --num=1000 --test_mode=full"
BASE_EVAL="python evaluate_checkpoints.py --batch=$BATCH --kimg_intervals=$KIMG_INTERVALS --offset=0 --num=1000 --steps=20 --test_mode=full"
NOISE_EVAL="python evaluate_checkpoints.py --batch=$BATCH --kimg_intervals=$KIMG_INTERVALS --offset=0 --num=1000 --steps=20 --test_mode=noisy --sparsity_ratio=$NOISE_RATIO --mask_filling_mode=additive_noise --noise_magnitude=1.0"
SPARSE_EVAL="python evaluate_checkpoints.py --batch=$BATCH --kimg_intervals=$KIMG_INTERVALS --offset=0 --num=1000 --steps=20 --test_mode=sparse --sparsity_ratio=0.97 --mask_filling_mode=zero"

run_eval() {
    local eqn=$1
    local direction=$2
    local model=$3
    local config=$4
    local ckpt_id=$5
    local kimg=$6

    # $BASE_EVAL \
    #   --save_predictions=true \
    #   --kimg_intervals=$kimg \
    #   --checkpoint_dir="$BASE_CKPT/$eqn/$direction/$model/$config/$ckpt_id" \
    #   --data="$BASE_DATA/$eqn.mat" \
    #   --outdir="$OUTDIR/$eqn/$direction/$model/$config/$ckpt_id"

    $SPARSE_EVAL \
      --save_predictions=true \
      --kimg_intervals=$kimg \
      --checkpoint_dir="$BASE_CKPT/$eqn/$direction/$model/$config/$ckpt_id" \
      --data="$BASE_DATA/$eqn.mat"\
      --outdir="$OUTDIR/$eqn/$direction/$model/$config/$ckpt_id"

    # $NOISE_EVAL \
    #   --save_predictions=true \
    #   --kimg_intervals=$kimg \
    #   --checkpoint_dir="$BASE_CKPT/$eqn/$direction/$model/$config/$ckpt_id" \
    #   --data="$BASE_DATA/$eqn.mat" \
    #   --outdir="$OUTDIR/$eqn/$direction/$model/$config/$ckpt_id"
}


run_eval_full() {
    local eqn=$1
    local direction=$2
    local model=$3
    local config=$4
    local ckpt_id=$5
    local kimg=$6
    local steps=$7
    local samples=$8

    $BASE_EVAL \
      --save_predictions=true \
      --kimg_intervals=$kimg \
      --checkpoint_dir="$BASE_CKPT/$eqn/$direction/$model/$config/$ckpt_id" \
      --data="$BASE_DATA/$eqn.mat" \
      --test_direction=$direction --steps=$steps --num=$samples \
      --outdir="$OUTDIR/$eqn/$direction/$model/$config/$ckpt_id"
}

###############################
STEPS_ARRAY=(20)
SAMPLES_ARRAY=(1000)
##########################################
######## FORWARD
EQUATION="darcy"
MODEL="SongUNOResidual"
CONFIG="dar_128_guided_unified_freq_comp_scalar_full_sparse_for"
CKPT="00000-DiffusionPDEDarcyDataset-cond-ddpmpp-SongUNOResidual-edm-gpus3-batch126-fp32"
KIMG="20000"

for STEPS in "${STEPS_ARRAY[@]}"; do
    # Loop through different sample counts
    for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
        # Loop through directions
        for DIRECTION in "forward"; do
            echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
            run_eval_full $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
        done
    done
done
########## INVERSE
EQUATION="darcy"
MODEL="SongUNOResidual"
CONFIG="dar_128_guided_unified_freq_comp_scalar_full_sparse_inv"
CKPT="00000-DiffusionPDEDarcyDataset-cond-ddpmpp-SongUNOResidual-edm-gpus3-batch126-fp32"
KIMG="18000"

for STEPS in "${STEPS_ARRAY[@]}"; do
    # Loop through different sample counts
    for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
        # Loop through directions
        for DIRECTION in "inverse"; do
            echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
            run_eval_full $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
        done
    done
done

###################################

##########################################
# ######### FORWARD
# EQUATION="helmholtz"
# MODEL="SongUNOResidual"
# CONFIG="helm_128_guided_unified_freq_comp_scalar_full_sparse_for"
# CKPT="00002-DiffusionPDEHelmholtzDataset-cond-ddpmpp-SongUNOResidual-edm-gpus3-batch126-fp32"
# KIMG="18600"

# for STEPS in "${STEPS_ARRAY[@]}"; do
#     # Loop through different sample counts
#     for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
#         # Loop through directions
#         for DIRECTION in "forward"; do
#             echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
#             run_eval_full $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
#         done
#     done
# done
# ############ INVERSE
# EQUATION="helmholtz"
# MODEL="SongUNOResidual"
# CONFIG="helm_128_guided_unified_freq_comp_scalar_full_sparse_inv"
# CKPT="00000-DiffusionPDEHelmholtzDataset-cond-ddpmpp-SongUNOResidual-edm-gpus2-batch180-fp32"
# KIMG="20000"

# for STEPS in "${STEPS_ARRAY[@]}"; do
#     # Loop through different sample counts
#     for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
#         # Loop through directions
#         for DIRECTION in "inverse"; do
#             echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
#             run_eval_full $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
#         done
#     done
# done

# # ###################################

# ##########################################
######## FORWARD
# EQUATION="poisson"
# MODEL="SongUNOResidual"
# CONFIG="pois_128_guided_unified_freq_comp_scalar_full_sparse_for"
# CKPT="00001-DiffusionPDEPoissonDataset-cond-ddpmpp-SongUNOResidual-edm-gpus3-batch126-fp32"
# KIMG="20000"

# for STEPS in "${STEPS_ARRAY[@]}"; do
#     # Loop through different sample counts
#     for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
#         # Loop through directions
#         for DIRECTION in "forward"; do
#             echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
#             run_eval_full $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
#         done
#     done
# done
# # ############ INVERSE
# EQUATION="poisson"
# MODEL="SongUNOResidual"
# CONFIG="pois_128_guided_unified_freq_comp_scalar_full_sparse_inv"
# CKPT="00000-DiffusionPDEPoissonDataset-cond-ddpmpp-SongUNOResidual-edm-gpus3-batch126-fp32"
# KIMG="20000"

# for STEPS in "${STEPS_ARRAY[@]}"; do
#     # Loop through different sample counts
#     for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
#         # Loop through directions
#         for DIRECTION in "inverse"; do
#             echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
#             run_eval_full $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
#         done
#     done
done
##################################


# ##########################################
# ######### FORWARD
# EQUATION="ns_nonbounded"
# MODEL="SongUNOResidual"
# CONFIG="nsnb_128_guided_unified_freq_comp_scalar_full_sparse_for"
# CKPT="00000-DiffusionPDENavierStokesNBDataset-cond-ddpmpp-SongUNOResidual-edm-gpus3-batch126-fp32"
# KIMG="20000"

# for STEPS in "${STEPS_ARRAY[@]}"; do
#     # Loop through different sample counts
#     for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
#         # Loop through directions
#         for DIRECTION in "forward"; do
#             echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
#             run_eval_full $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
#         done
#     done
# done
# ############ INVERSE
# EQUATION="ns_nonbounded"
# MODEL="SongUNOResidual"
# CONFIG="nsnb_128_guided_unified_freq_comp_scalar_full_sparse_inv"
# CKPT="00001-DiffusionPDENavierStokesNBDataset-cond-ddpmpp-SongUNOResidual-edm-gpus3-batch180-fp32"
# KIMG="20000"

# for STEPS in "${STEPS_ARRAY[@]}"; do
#     # Loop through different sample counts
#     for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
#         # Loop through directions
#         for DIRECTION in "inverse"; do
#             echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
#             run_eval_full $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
#         done
#     done
# done
###################################

##########################################

BATCH=2
SAMPLES_ARRAY=(2)
BASE_EVAL="python evaluate_checkpoints.py --batch=$BATCH --kimg_intervals=$KIMG_INTERVALS --offset=0 --num=1000 --test_mode=full"

run_eval_full_nsb() {
    local eqn=$1
    local direction=$2
    local model=$3
    local config=$4
    local ckpt_id=$5
    local kimg=$6
    local steps=$7
    local samples=$8

    $BASE_EVAL \
      --save_predictions=true \
      --kimg_intervals=$kimg \
      --checkpoint_dir="$BASE_CKPT/$eqn/$direction/$model/$config/$ckpt_id" \
      --data="$BASE_DATA/$eqn/" \
      --test_direction=$direction --steps=$steps --num=$samples \
      --outdir="$OUTDIR/$eqn/$direction/$model/$config/$ckpt_id"
}


######### FORWARD
EQUATION="ns_bounded"
MODEL="SongUNOResidual"
CONFIG="nsb_128_guided_unified_freq_comp_scalar_full_sparse_for"
CKPT="00000-DiffusionPDENavierStokesBDataset-cond-ddpmpp-SongUNOResidual-edm-gpus3-batch126-fp32"
KIMG="20000"

for STEPS in "${STEPS_ARRAY[@]}"; do
    # Loop through different sample counts
    for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
        # Loop through directions
        for DIRECTION in "forward"; do
            echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
            run_eval_full_nsb $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
        done
    done
done
############ INVERSE
EQUATION="ns_bounded"
MODEL="SongUNOResidual"
CONFIG="nsb_128_guided_unified_freq_comp_scalar_full_sparse_inv"
CKPT="00000-DiffusionPDENavierStokesBDataset-cond-ddpmpp-SongUNOResidual-edm-gpus3-batch126-fp32"
KIMG="20000"

for STEPS in "${STEPS_ARRAY[@]}"; do
    # Loop through different sample counts
    for SAMPLES in "${SAMPLES_ARRAY[@]}"; do
        # Loop through directions
        for DIRECTION in "inverse"; do
            echo "Running evaluation with direction=$DIRECTION, steps=$STEPS, samples=$SAMPLES"
            run_eval_full_nsb $EQUATION $DIRECTION $MODEL $CONFIG $CKPT $KIMG $STEPS $SAMPLES
        done
    done
done
###################################