export PYTHONWARNINGS="ignore"          
export CUDA_VISIBLE_DEVICES=0          

DATA_ROOT="EGN/10xgenomics"  
# mkdir -p logs exemplar index exemplar/index

for fold in 0 1 2; do
  echo ">>> [build_exemplar] fold=$fold"
  python3 build_exemplar.py \
    --index_dir index \
    --save_dir exemplar \
    --TORCH_HOME "$TORCH_HOME_PATH" \
    --data "$DATA_ROOT" \
    --fold "$fold" | tee "logs/build_exemplar_fold${fold}.log"
done

echo "== index files =="
find index -maxdepth 2 -type f | head
echo "== exemplar files =="
find exemplar -maxdepth 2 -type f | head
timestamp=$(date +"%Y_%m_%d_%H_%M_%S")

for fold in 0; do
  echo ">>> [train] fold=$fold"
  python3 main_eca.py \
    --num_nodes 1 \
    --gpus 1 \
    --epoch 50 \
    --batch 32 \
    --workers 20 \
    --size 256 \
    --data "$DATA_ROOT" \
    --fold "$fold" \
    --lr 8.123245085588692e-05 \
    --weight_decay 0 \
    --dim 1024 \
    --heads 16 \
    --mlp_dim 4096 \
    --depth 8 \
    --timestamp "$timestamp" \
    --seed 42 \
    --bhead 8 \
    --bdim 64 \
    --bfre 2 \
    --player 2 \
    --linear_projection True \
    --index_path exemplar/$fold/index \
    --emb_path exemplar \
    --mdim 2048 \
    --output eca_results \
    --use_eca \
    --eca_use_sra \
    --lambda_pcc 0.05808361216819946 \
    --lambda_gamma 0.0396760507705299 \
    --eca_T_min 0.6051038616257767 \
    --eca_beta_temp 3.569555631200623 \
    --eca_gamma_max 0.200864022049432 \
    --numk 6 | tee "eca_logs/train_fold${fold}.log"
done