sana-zero / scripts /infer_metric_run_inference_metric_geneval.sh
gen6scp's picture
Patched codes for ZeroGPU
d643072
#!/bin/bash
export LOGLEVEL=INFO
output_dir=output
# ============ 0. start of custom code block ============
#### Infer Hyper
default_step=20 # inference step for diffusion model
default_sample_nums=533 # inference first $sample_nums sample in list(json.keys())
default_sampling_algo="flow_dpm-solver"
default_add_label=''
default_log_geneval=false
# 👇No need to change the code below
if [ -n "$1" ]; then
config_file=$1
fi
if [ -n "$2" ]; then
model_paths_file=$2
fi
for arg in "$@"
do
case $arg in
--step=*)
step="${arg#*=}"
shift
;;
--sample_nums=*)
sample_nums="${arg#*=}"
shift
;;
--sampling_algo=*)
sampling_algo="${arg#*=}"
shift
;;
--exist_time_prefix=*)
exist_time_prefix="${arg#*=}"
shift
;;
--cfg_scale=*)
cfg_scale="${arg#*=}"
shift
;;
--suffix_label=*)
suffix_label="${arg#*=}"
shift
;;
--add_label=*)
add_label="${arg#*=}"
shift
;;
--log_geneval=*)
log_geneval="${arg#*=}"
shift
;;
--inference=*)
inference="${arg#*=}"
shift
;;
--geneval=*)
geneval="${arg#*=}"
shift
;;
--output_dir=*)
output_dir="${arg#*=}"
shift
;;
--auto_ckpt=*)
auto_ckpt="${arg#*=}"
shift
;;
--auto_ckpt_interval=*)
auto_ckpt_interval="${arg#*=}"
shift
;;
--tracker_pattern=*)
tracker_pattern="${arg#*=}"
shift
;;
--ablation_key=*)
ablation_key="${arg#*=}"
shift
;;
--ablation_selections=*)
ablation_selections="${arg#*=}"
shift
;;
*)
;;
esac
done
inference=${inference:-true}
geneval=${geneval:-true}
step=${step:-$default_step}
cfg_scale=${cfg_scale:-4.5}
sample_nums=${sample_nums:-$default_sample_nums}
sampling_algo=${sampling_algo:-$default_sampling_algo}
exist_time_prefix=${exist_time_prefix:-$default_exist_time_prefix}
add_label=${add_label:-$default_add_label}
ablation_key=${ablation_key:-''}
ablation_selections=${ablation_selections:-''}
suffix_label=${suffix_label:-$default_suffix_label}
tracker_pattern=${tracker_pattern:-"epoch_step"}
auto_ckpt=${auto_ckpt:-false}
auto_ckpt_interval=${auto_ckpt_interval:-0}
log_geneval=${log_geneval:-$default_log_geneval}
job_name=$(basename $(dirname $(dirname "$model_paths_file")))
metric_dir=$output_dir/$job_name/metrics
if [ ! -d "$metric_dir" ]; then
echo "Creating directory: $metric_dir"
mkdir -p "$metric_dir"
fi
# select all the last step ckpts of one epoch to inference
if [ "$auto_ckpt" = true ]; then
bash scripts/collect_pth_path.sh $output_dir/$job_name/checkpoints $auto_ckpt_interval
fi
# ============ 1. start of inference block ===========
cache_file_path=$model_paths_file
if [ ! -e "$model_paths_file" ]; then
cache_file_path=$output_dir/$job_name/metrics/cached_img_paths_geneval.txt
echo "$model_paths_file not exists, use default image path: $cache_file_path"
fi
if [ "$inference" = true ]; then
cache_file_path=$output_dir/$job_name/metrics/cached_img_paths_geneval.txt
rm $metric_dir/tmp_geneval_* || true
read -r -d '' cmd <<EOF
bash scripts/infer_run_inference_geneval.sh $config_file $model_paths_file \
--step=$step --sample_nums=$sample_nums --add_label=$add_label \
--cfg_scale=$cfg_scale \
--exist_time_prefix=$exist_time_prefix --if_save_dirname=true --sampling_algo=$sampling_algo \
--ablation_key=$ablation_key --ablation_selections="$ablation_selections"
EOF
echo $cmd
bash -c "${cmd}"
> "$cache_file_path" # clean file
# add all tmp_geneval_*.txt file into $cache_file_path
for file in $metric_dir/tmp_geneval_*.txt; do
if [ -f "$file" ]; then
cat "$file" >> "$cache_file_path"
echo "" >> "$cache_file_path" # add new line
fi
done
rm -r $metric_dir/tmp_geneval_* || true
fi
img_path=${output_dir}/${job_name}/vis
exp_paths_file=${cache_file_path}
# ============ 2. start of geneval compute block =================
if [ "$geneval" = true ]; then
read -r -d '' cmd <<EOF
bash tools/metrics/compute_geneval.sh $img_path $exp_paths_file \
--sample_nums=$sample_nums --suffix_label=$suffix_label \
--log_geneval=$log_geneval --tracker_pattern=$tracker_pattern
EOF
echo $cmd
bash -c "${cmd}"
fi