n_gpus=1
task_name="retnlu"
dataset_name="multiwoz21"
speaker="user"
context_window_size=0
ratio=$1
dial_ids_order=$2
retrieval_topk=$3
data_dir="data/${task_name}/${dataset_name}_${ratio}_order${dial_ids_order}/${speaker}/context_${context_window_size}/in_context_False/topk_${retrieval_topk}"
output_dir="output/${task_name}/${dataset_name}_${ratio}_order${dial_ids_order}/${speaker}/context_${context_window_size}/in_context_False/topk_${retrieval_topk}"
cache_dir="../cache"
logging_dir="${output_dir}/runs"
train_file="${data_dir}/train.json"
validation_file="${data_dir}/validation.json"
test_file="${data_dir}/test.json"
metric_name_or_path="nlu_metric.py"
metric_for_best_model="overall_f1"
source_column="context"
target_column="dialogue_acts_seq"
truncation_side="left"
max_source_length=512
max_target_length=512
model_name_or_path="t5-small"
per_device_train_batch_size=128
per_device_eval_batch_size=64
gradient_accumulation_steps=2
lr=1e-3
num_train_epochs=100

# python ../create_data.py -t ${task_name} -d ${dataset_name} -s ${speaker} -c ${context_window_size} --retrieval_datasets sgd tm1 tm2 tm3 --retrieval_topk ${retrieval_topk} -r ${ratio} -o ${dial_ids_order}

# python ../run_seq2seq.py \
#     --task_name ${task_name} \
#     --train_file ${train_file} \
#     --validation_file ${validation_file} \
#     --source_column ${source_column} \
#     --target_column ${target_column} \
#     --max_source_length ${max_source_length} \
#     --max_target_length ${max_target_length} \
#     --truncation_side ${truncation_side} \
#     --model_name_or_path ${model_name_or_path} \
#     --do_train \
#     --do_eval \
#     --save_strategy epoch \
#     --evaluation_strategy epoch \
#     --save_total_limit 1 \
#     --prediction_loss_only \
#     --load_best_model_at_end \
#     --cache_dir ${cache_dir} \
#     --output_dir ${output_dir} \
#     --logging_dir ${logging_dir} \
#     --overwrite_output_dir \
#     --preprocessing_num_workers 4 \
#     --per_device_train_batch_size ${per_device_train_batch_size} \
#     --per_device_eval_batch_size ${per_device_eval_batch_size} \
#     --gradient_accumulation_steps ${gradient_accumulation_steps} \
#     --learning_rate ${lr} \
#     --num_train_epochs ${num_train_epochs} \
#     --optim adafactor \
#     --gradient_checkpointing

# python ../run_seq2seq.py \
#     --task_name ${task_name} \
#     --test_file ${test_file} \
#     --source_column ${source_column} \
#     --target_column ${target_column} \
#     --max_source_length ${max_source_length} \
#     --max_target_length ${max_target_length} \
#     --truncation_side ${truncation_side} \
#     --model_name_or_path ${output_dir} \
#     --do_predict \
#     --predict_with_generate \
#     --metric_name_or_path ${metric_name_or_path} \
#     --cache_dir ${cache_dir} \
#     --output_dir ${output_dir} \
#     --logging_dir ${logging_dir} \
#     --overwrite_output_dir \
#     --preprocessing_num_workers 4 \
#     --per_device_train_batch_size ${per_device_train_batch_size} \
#     --per_device_eval_batch_size ${per_device_eval_batch_size} \
#     --gradient_accumulation_steps ${gradient_accumulation_steps} \
#     --learning_rate ${lr} \
#     --num_train_epochs ${num_train_epochs} \
#     --optim adafactor \
#     --gradient_checkpointing

# python merge_predict_res.py -d ${dataset_name} -s ${speaker} -c ${context_window_size} -p ${output_dir}/test_generated_predictions.json -o ${dial_ids_order}

python ../../../nlu/evaluate_unified_datasets.py -p ${output_dir}/predictions.json
