
AFS_list=(False)
DATASET_list=("ms_coco")
NUM_STEPS_list=(5 7 9 11)
FREEZE_NET_list=(True)
TOTAL_KIMG_list=(5)
LR_LIST=(1e-5)
ITER_LIST=(160)
RANK_LIST=(64)
SCA_LIST=(1.0)
BEGIN_ID=346

for AFS in "${AFS_list[@]}"; do
    for DATASET in "${DATASET_list[@]}"; do
        for FREEZE_NET in "${FREEZE_NET_list[@]}"; do
            for LR in "${LR_LIST[@]}"; do
                for ITER in "${ITER_LIST[@]}"; do
                    for RANK in "${RANK_LIST[@]}"; do
                        for SCALE in "${SCA_LIST[@]}"; do
                            for NUM_STEPS in "${NUM_STEPS_list[@]}"; do
                               for TOTAL_KIMG in "${TOTAL_KIMG_list[@]}"; do
                                    if [[ " 1e-4 5e-4 " =~ " $LR " ]]; then
                                        LR_DECIMAL=$(python -c "print('%.4f' % float('$LR'))")
                                    elif [[ " 1e-5 5e-5 " =~ " $LR " ]]; then
                                        LR_DECIMAL=$(python -c "print('%.5f' % float('$LR'))")
                                    fi
                                    echo "AFS: $AFS, DATASET: $DATASET, FREEZE_NET: $FREEZE_NET, LR: $LR_DECIMAL, ITER: $ITER, RANK: $RANK, SCALE: $SCALE, TOTAL_KIMG: $TOTAL_KIMG, NUM_STEPS: $NUM_STEPS"
if [ $BEGIN_ID -lt 10 ]; then
    DIR_ID="0000${BEGIN_ID}"
elif [ $BEGIN_ID -lt 100 ]; then
    DIR_ID="000${BEGIN_ID}"
elif [ $BEGIN_ID -lt 1000 ]; then
    DIR_ID="00${BEGIN_ID}"
fi
BEGIN_ID=$((BEGIN_ID + 1))

SAMPLE_TEA="dpmpp"
PREDICT_X0=True
LOW_ORDER_FINAL=True

USE_STEP_CONDITION=False
IS_SECOND_STAGE=False

if [ "$AFS" = "True" ]; then
    NFE=$((NUM_STEPS - 2)) 
elif [ "$AFS" = "False" ]; then
    NFE=$((NUM_STEPS - 1)) 
fi

if [ "$DATASET" = "lsun_bedroom_ldm" ]; then
    BATCH_SIZE=8
    SCHEDULE_TYPE="discrete"
    SCHEDULE_RHO=1
elif [ "$DATASET" = "ms_coco" ]; then
    BATCH_SIZE=4
    SCHEDULE_TYPE="discrete"
    SCHEDULE_RHO=1
    MAX_ORDER=2
    M=2
    NFE=$((NFE * 2))
elif [ "$DATASET" = "imagenet64" ]; then
    SCHEDULE_TYPE="polynomial"
    SCHEDULE_RHO=7
    BATCH_SIZE=32
else
    SCHEDULE_TYPE="polynomial"
    SCHEDULE_RHO=7
    BATCH_SIZE=128
fi


if [ $TOTAL_KIMG -lt 10 ]; then
    USE_KIMG="00000${TOTAL_KIMG}"
elif [ $TOTAL_KIMG -lt 100 ]; then
    USE_KIMG="0000${TOTAL_KIMG}"
elif [ $TOTAL_KIMG -lt 1000 ]; then
    USE_KIMG="000${TOTAL_KIMG}"
fi

if [ "$AFS" = "True" ]; then
    if [ "$DATASET" = "lsun_bedroom_ldm" ] || [ "$DATASET" = "ms_coco" ]; then
        MODEL_PATH="./exps/${DIR_ID}-${DATASET}-${NUM_STEPS}-${NFE}-${SAMPLE_TEA}-${MAX_ORDER}-discrete1.0-${ITER}-${LR_DECIMAL}-${RANK}-${SCALE}-afs/network-${FREEZE_NET}-${TOTAL_KIMG}-snapshot-best.pkl"
        PLUGIN_PATH="./exps/${DIR_ID}-${DATASET}-${NUM_STEPS}-${NFE}-${SAMPLE_TEA}-${MAX_ORDER}-discrete1.0-${ITER}-${LR_DECIMAL}-${RANK}-${SCALE}-afs/plugin-${FREEZE_NET}-${TOTAL_KIMG}-snapshot-best.pkl"
    else
        MODEL_PATH="./exps/${DIR_ID}-${DATASET}-${NUM_STEPS}-${NFE}-${SAMPLE_TEA}-${MAX_ORDER}-poly7.0-${ITER}-${LR_DECIMAL}-${RANK}-${SCALE}-afs/network-${FREEZE_NET}-${TOTAL_KIMG}-snapshot-best.pkl"
        PLUGIN_PATH="./exps/${DIR_ID}-${DATASET}-${NUM_STEPS}-${NFE}-${SAMPLE_TEA}-${MAX_ORDER}-poly7.0-${ITER}-${LR_DECIMAL}-${RANK}-${SCALE}-afs/plugin-${FREEZE_NET}-${TOTAL_KIMG}-snapshot-best.pkl"
    fi
elif [ "$AFS" = "False" ]; then
    if [ "$DATASET" = "lsun_bedroom_ldm" ] || [ "$DATASET" = "ms_coco" ]; then
        MODEL_PATH="./exps/${DIR_ID}-${DATASET}-${NUM_STEPS}-${NFE}-${SAMPLE_TEA}-${MAX_ORDER}-discrete1.0-${ITER}-${LR_DECIMAL}-${RANK}-${SCALE}/network-${FREEZE_NET}-${TOTAL_KIMG}-snapshot-best.pkl"
        PLUGIN_PATH="./exps/${DIR_ID}-${DATASET}-${NUM_STEPS}-${NFE}-${SAMPLE_TEA}-${MAX_ORDER}-discrete1.0-${ITER}-${LR_DECIMAL}-${RANK}-${SCALE}/plugin-${FREEZE_NET}-${TOTAL_KIMG}-snapshot-best.pkl"
    else
        MODEL_PATH="./exps/${DIR_ID}-${DATASET}-${NUM_STEPS}-${NFE}-${SAMPLE_TEA}-${MAX_ORDER}-poly7.0-${ITER}-${LR_DECIMAL}-${RANK}-${SCALE}/network-${FREEZE_NET}-${TOTAL_KIMG}-snapshot-best.pkl"
        PLUGIN_PATH="./exps/${DIR_ID}-${DATASET}-${NUM_STEPS}-${NFE}-${SAMPLE_TEA}-${MAX_ORDER}-poly7.0-${ITER}-${LR_DECIMAL}-${RANK}-${SCALE}/plugin-${FREEZE_NET}-${TOTAL_KIMG}-snapshot-best.pkl"
    fi
fi

SOLVER_LIST=( 'euler' )
for SOLVER in "${SOLVER_LIST[@]}"; do
    if  [ "$DATASET" = "ms_coco" ]; then
        torchrun --standalone --nproc_per_node=1 --master_port=12345 sample.py \
        --dataset_name=${DATASET} --model_path=${MODEL_PATH} --plugin_path=${PLUGIN_PATH} --seeds='0-29999' --batch=${BATCH_SIZE} --solver=${SOLVER} 
    else
        torchrun --standalone --nproc_per_node=1 --master_port=12345 sample.py \
        --dataset_name=${DATASET} --model_path=${MODEL_PATH} --plugin_path=${PLUGIN_PATH} --seeds='50000-99999' --batch=${BATCH_SIZE} --solver=${SOLVER}
    fi
    # # ################# Evaluation #################
    if [ "$DATASET" = "cifar10" ]; then
        ref_path="./stats/cifar10-32x32.npz"
    elif [ "$DATASET" = "ffhq" ]; then
        ref_path="./stats/ffhq-64x64.npz"
    elif [ "$DATASET" = "imagenet64" ]; then
        ref_path="./stats/imagenet-64x64.npz"
    elif [ "$DATASET" = "lsun_bedroom_ldm" ]; then
        ref_path="./stats/lsun_bedroom-256x256.npz"
    elif [ "$DATASET" = "ms_coco" ]; then
        ref_path="./stats/ms_coco-512x512.npz"
    fi
    python fid.py calc --model_path=${MODEL_PATH} --images="./samples/${DATASET}/${SOLVER}_step${NUM_STEPS}_nfe${NFE}_best_${FREEZE_NET}" --ref=${ref_path}
done

done
done
done
done
done
done
done
done
done