wandb_project_name=permutation

task=relu
encoding_method=standard
epochs=2

# max_steps_per_epoch=1000
batch_size=128

count=2
# for task in sum prod gcd remainder
# do
# Dataset parameter settings
nvars=0
field=ZZ
max_coefficient=-20
max_coefficient=500
max_degree=1
num_digits=50
max_seq_len=101

# Specify data load path
exp_name=relu_gpt2_single_layer
data_class=small
data_name=data # data, data-inv, etc.
data_path=/mnt/nfs/data/${data_class}/${task}/n=${num_digits}/${data_name}

# Specify save destination
run_name=${exp_name}_${data_class}_${task}_digits=${num_digits}
run_name_sub=${exp_name}_digits=${num_digits}_bs=${batch_size}
save_path=/mnt/nfs/results/${data_class}/${task}/${run_name_sub}

mkdir -p $save_path
CUDA_VISIBLE_DEVICES=$count python3 src/main.py  --save_path $save_path \
                                            --data_path $data_path \
                                            --task $task \
                                            --epochs $epochs \
                                            --num_batch $batch_size \
                                            --nhead 1 \
                                            --num_encoder_layers 1 \
                                            --exp_name $wandb_project_name \
                                            --exp_id $run_name \
                                            --num_variables $nvars \
                                            --field $field \
                                            --max_coefficient $max_coefficient \
                                            --max_degree $max_degree \
                                            --encoding_method $encoding_method \
                                            --model gpt2 \
                                            --max_sequence_length $max_seq_len > ${save_path}/run.log &

count=$((count+1))

data_name=data-inv # data, data-inv, etc.
data_path=/mnt/nfs/data/${data_class}/${task}/n=${num_digits}/${data_name}

# Specify save destination
run_name=${exp_name}_${data_class}_${task}_digits=${num_digits}_inverse
run_name_sub=${exp_name}_digits=${num_digits}_bs=${batch_size}_inverse
save_path=/mnt/nfs/results/${data_class}/${task}/${run_name_sub}


mkdir -p $save_path
CUDA_VISIBLE_DEVICES=$count python3 src/main.py  --save_path $save_path \
                                            --data_path $data_path \
                                            --task $task \
                                            --epochs $epochs \
                                            --num_batch $batch_size \
                                            --nhead 1 \
                                            --num_encoder_layers 1 \
                                            --exp_name $wandb_project_name \
                                            --exp_id $run_name \
                                            --num_variables $nvars \
                                            --field $field \
                                            --max_coefficient $max_coefficient \
                                            --max_degree $max_degree \
                                            --encoding_method $encoding_method \
                                            --model gpt2 \
                                            --max_sequence_length $max_seq_len > ${save_path}/run.log &
                                            
# count=$((count+1))

# data_name=data-rand # data, data-inv, etc.
# data_path=/mnt/nfs/data/${data_class}/${task}/n=${num_digits}/${data_name}

# # Specify save destination
# run_name=${exp_name}_${data_class}_${task}_digits=${num_digits}_randperm
# run_name_sub=${exp_name}_digits=${num_digits}_bs=${batch_size}_randperm
# save_path=/mnt/nfs/results/${data_class}/${task}/${run_name_sub}


# mkdir -p $save_path
# CUDA_VISIBLE_DEVICES=$count python3 src/main.py  --save_path $save_path \
#                                             --data_path $data_path \
#                                             --task $task \
#                                             --epochs $epochs \
#                                             --num_batch $batch_size \
#                                             --nhead 1 \
#                                             --num_encoder_layers 1 \
#                                             --exp_name $wandb_project_name \
#                                             --exp_id $run_name \
#                                             --num_variables $nvars \
#                                             --field $field \
#                                             --max_coefficient $max_coefficient \
#                                             --max_degree $max_degree \
#                                             --encoding_method $encoding_method \
#                                             --model gpt2 \
#                                             --max_sequence_length $max_seq_len > ${save_path}/run.log &



# count=$((count+1))

# data_name=data-one # data, data-inv, etc.
# data_path=/mnt/nfs/data/${data_class}/${task}/n=${num_digits}/${data_name}

# # Specify save destination
# run_name=${exp_name}_${data_class}_${task}_digits=${num_digits}_oneperm
# run_name_sub=${exp_name}_digits=${num_digits}_bs=${batch_size}_oneperm
# save_path=/mnt/nfs/results/${data_class}/${task}/${run_name_sub}


# mkdir -p $save_path
# CUDA_VISIBLE_DEVICES=$count python3 src/main.py  --save_path $save_path \
#                                             --data_path $data_path \
#                                             --task $task \
#                                             --epochs $epochs \
#                                             --num_batch $batch_size \
#                                             --nhead 1 \
#                                             --num_encoder_layers 1 \
#                                             --exp_name $wandb_project_name \
#                                             --exp_id $run_name \
#                                             --num_variables $nvars \
#                                             --field $field \
#                                             --max_coefficient $max_coefficient \
#                                             --max_degree $max_degree \
#                                             --encoding_method $encoding_method \
#                                             --model gpt2 \
#                                             --max_sequence_length $max_seq_len > ${save_path}/run.log &
                                            
