#!/bin/bash

read -p "Enter the cuda card number: " card
read -p "Enter the num of classes: " num_class
read -p "Enter the method name (string): " method_name
read -p "Enter if use label disambiguation (boolean): " confidence_boolean
read -p "Enter the partial label type (string): " partial_type_name

echo "cuda card number: $card"
echo "method name: $method_name"
echo "if use ld: $confidence_boolean"
echo "partial label type: $partial_type_name"

if [[ $method_name == "PGNA_PL" ]] || [[ $method_name == "PGNA_PL_wtihout_PG" ]] || [[ $method_name == "PGNA_Other_OriginMixup" ]] || [[ $method_name == "PGNA_PL_FullySupervision" ]]
then
  read -p "Enter temperature for self distilling: " temperature
  read -p "Enter rate for beta_parameter:" beta_parameter

  gamme_value=0.5
  for i in 1 2 3 4 5
  do
    if [[ $confidence_boolean == true ]]
    then
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --use-confidence --gamma $gamme_value --run-idx $i --temperature $temperature --num-class $num_class --beta_parameter $beta_parameter
      wait
    else
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --gamma $gamme_value --run-idx $i --temperature $temperature --num-class $num_class --beta_parameter $beta_parameter
      wait
    fi
  done

elif [[ $method_name == "DNPL" ]] || [[ $method_name == "FullySupervision" ]]
then
  for i in 1 2 3 4 5
  do
    CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --run-idx $i --num-class $num_class
    wait
  done

elif [[ $method_name == "PRODEN" ]] || [[ $method_name == "CAVL" ]] || [[ $method_name == "CR" ]]
then
  for i in 1 2 3 4 5
  do
    if [[ $confidence_boolean == true ]]
    then
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --use-confidence --run-idx $i --num-class $num_class
      wait
    else
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --run-idx $i --num-class $num_class
      wait
    fi
  done

elif [[ $method_name == "LW" ]]
then
  read -p "Enter the loss name (string): " loss_name
  read -p "Enter the beta value (int): " beta_value

  for i in 1 2 3 4 5
  do
    if [[ $confidence_boolean == true ]]
    then
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --use-confidence --loss $loss_name --beta $beta_value --run-idx $i --num-class $num_class
      wait
    else
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --loss $loss_name --beta $beta_value --run-idx $i --num-class $num_class
      wait
    fi
  done


elif [[ $method_name == "PGNA_PL_wtihout_NA" ]] ||  [[ $method_name == "PG_Other_NA__Gauss" ]] || [[ $method_name == "PG_Other_NA__PepperSalt" ]] || [[ $method_name == "PG_Other_NA__Mask" ]]
then
  read -p "Enter temperature for self distilling: " temperature
  read -p "Enter rate for aug q:" q_aug

  gamme_value=0.5
  for i in 1 2 3 4 5
  do
    if [[ $confidence_boolean == true ]]
    then
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --use-confidence --gamma $gamme_value --run-idx $i --temperature $temperature --q_aug $q_aug --num-class $num_class
      wait
    else
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --gamma $gamme_value --run-idx $i --temperature $temperature --q_aug $q_aug --num-class $num_class
      wait
    fi
  done


elif [[ $method_name == "PiCO" ]]
then
  read -p "Enter if use contrastive learning (boolean): " contrastive_boolean
  read -p "Enter size of queue: " quene_size
  if [[ $contrastive_boolean == true ]]
  then
    gamme_value=0.5
  else
    gamme_value=0.0
  fi

  for i in 1 2 3 4 5
  do
    if [[ $confidence_boolean == true ]]
    then
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --use-confidence --gamma $gamme_value --run-idx $i --moco_queue $quene_size --num-class $num_class
      wait
    else
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --gamma $gamme_value --run-idx $i --moco_queue $quene_size --num-class $num_class
      wait
    fi
  done


elif [[ $method_name == 'PaPI' ]]
then
  for i in 1 2 3 4 5
  do
    if [[ $confidence_boolean == true ]]
    then
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --use-confidence --run-idx $i --num-class $num_class
      wait
    else
      CUDA_VISIBLE_DEVICES=$card python ./main.py --optimizer 'sgd' --lr 0.01 --partial-type $partial_type_name --method $method_name --use-scheduler --run-idx $i --num-class $num_class
      wait
    fi
  done

else
  echo "Error!"
  exit

fi











