export PYTHONPATH=$PYTHONPATH:./

DATASET_NAME=$1
NFE=$2
GEN_SAMPLER=$3

if [[ $DATASET_NAME == "e2h" ]]; then
    SPLIT=train
    PREFIX=e2h_ema_0.9999_420000_adapted/sample_420000
    REF_PATH=assets/stats/edges2handbags_ref_64_data.npz
    # SAMPLE_NAME=samples_138567x64x64x3_nfe${NFE}.npz
    SAMPLE_NAME=samples_${num_samples}x64x64x3_nfe${NFE}.npz
elif [[ $DATASET_NAME == "diode" ]]; then
    # SPLIT=train  <-- 这个不再关键，因为我们直接读文件
    # PREFIX=...   <-- 也不再关键
    
    # ==============================================================================
    # 【核心修改】强制指向刚才 sample.py 在 sample_dir 下生成的两个对应文件
    # ==============================================================================
    
    # 1. 动态设置参考路径 (REF_PATH) 为刚才生成的 Ground Truth 文件
    # 文件名格式对应 sample.py 里的: gt_{num}x256x256x3_nfe{nfe}.npz
    REF_PATH="${sample_dir}/gt_${num_samples}x256x256x3_nfe${NFE}.npz"
    
    # 2. 设置生成样本的文件名 (SAMPLE_NAME)
    # 文件名格式对应 sample.py 里的: samples_{num}x256x256x3_nfe{nfe}.npz
    SAMPLE_NAME="samples_${num_samples}x256x256x3_nfe${NFE}.npz"
    
    # 3. (保险起见) 也可以直接构造绝对路径的 SAMPLE_PATH，防止脚本后面拼错目录
    SAMPLE_PATH="${sample_dir}/${SAMPLE_NAME}"

    echo ">>> [Auto-Config] Ref Path (GT): $REF_PATH"
    echo ">>> [Auto-Config] Sample Path:   $SAMPLE_PATH"
elif [[ $DATASET_NAME == "imagenet_inpaint_center" ]]; then
    SPLIT=test
    PREFIX=imagenet256_inpaint_ema_0.9999_100000/sample_100000
    DATA_DIR=assets/datasets/ImageNet
    SAMPLE_NAME=samples_${num_samples}x256x256x3_nfe${NFE}.npz
    LABEL_NAME=labels_${num_samples}_nfe${NFE}.npz
fi

if [[ $GEN_SAMPLER == "heun" ]]; then
    N=$(echo "$NFE" | awk '{print ($1 + 1) / 3}')
    N=$(printf "%.0f" "$N")
    SAMPLER="heun"
elif [[ $GEN_SAMPLER == "dbim" ]]; then
    N=$((NFE-1))
    ETA=$4
    SAMPLER="dbim_eta=${ETA}"
elif [[ $GEN_SAMPLER == "dbimt" ]]; then
    N=$((NFE-1))
    ETA=$4
    SAMPLER="dbimt_eta=${ETA}"
elif [[ $GEN_SAMPLER == "dbim_high_order" ]]; then
    N=$((NFE-1))
    ORDER=$4
    SAMPLER="dbim_order=${ORDER}"
fi

# For example:
# SAMPLE_PATH="workdir/e2h_ema_0.9999_420000_adapted/sample_420000/split=train/dbim_eta=0.0/steps=4/samples_138567x64x64x3_nfe5.npz"
# SAMPLE_PATH="workdir/diode_ema_0.9999_440000_adapted/sample_440000/split=train/dbim_eta=0.0/steps=4/samples_16502x256x256x3_nfe5.npz"
# SAMPLE_PATH="workdir/imagenet256_inpaint_ema_0.9999_400000/sample_400000/split=test/dbim_order=3/steps=9/samples_10000x256x256x3_nfe10.npz"

# SAMPLE_DIR=workdir/${PREFIX}/split=${SPLIT}/${SAMPLER}/steps=${N}
SAMPLE_DIR=$sample_dir
SAMPLE_PATH=${SAMPLE_DIR}/${SAMPLE_NAME}

if [[ $DATASET_NAME == "e2h" || $DATASET_NAME == "diode" ]]; then
    python evaluations/evaluator.py $REF_PATH $SAMPLE_PATH --metric fid
    python evaluations/evaluator.py $REF_PATH $SAMPLE_PATH --metric lpips
elif [[ $DATASET_NAME == "imagenet_inpaint_center" ]]; then
    LABEL_PATH=${SAMPLE_DIR}/${LABEL_NAME}
    python evaluation/compute_metrices_imagenet.py --ckpt $SAMPLE_PATH --label $LABEL_PATH --dataset-dir $DATA_DIR
    python evaluations/evaluator.py "" $SAMPLE_PATH --metric is
fi

echo "Removing sample file: $SAMPLE_PATH"
rm $SAMPLE_PATH