#!/bin/bash
# Set paths to your scripts and files
MODEL_PATH='your pretrained model path'
TRAINING_SCRIPT="src/main.py  --net CNN7 --bn --bn2 --lr 0.0005 --custom_schedule 28 32 \
--epochs 36 --eps_end 0.00392157 --eps_test 0.00392157 --dataset tinyimagenet \
--end_epoch_eps 16 --cert_reg bound_reg --lambda_ratio 0.4 --l1 1e-6 \
--eps_test_L2 0.14117647058 --eps_end_L2 0.14117647058 --joint --lambda_ratio_L2 0.00001 --max --lp --gp --reverse --lbd 0.5 --start_epoch 0 \
--saved_net $MODEL_PATH"

cd ~/CURE

source ~/anaconda3/bin/activate
conda activate CURE
export PYTHONPATH=$PWD:$PYTHONPATH

# Step 1: Run the training script and capture the output
TRAINING_OUTPUT=$(python $TRAINING_SCRIPT)
# Step 2: Extract the model path from the training script's output
MODEL_PATH=$(echo "$TRAINING_OUTPUT" | grep "Model saved as:" | awk '{print $4}')
# Check if MODEL_PATH was successfully extracted
if [ -z "$MODEL_PATH" ]; then
    echo "Error: Model path could not be found in the training script output."
    exit 1
fi
echo "Model path extracted: $MODEL_PATH"



cd ~/alpha-beta-CROWN/complete_verifier/
conda activate alpha-beta-crown

# Step 4: Run the analysis script
python abcrown.py --config exp_configs/tinyimagenet_l2.yaml --complete_verifier skip --share_alphas --onnx_path $MODEL_PATH > out_l2_tiny_ours_finetune.txt
python abcrown.py --config exp_configs/tinyimagenet_l1.yaml --complete_verifier skip --share_alphas --onnx_path $MODEL_PATH > out_l1_tiny_ours_finetune.txt
python abcrown.py --config exp_configs/tinyimagenet_linf.yaml --complete_verifier skip --share_alphas --onnx_path $MODEL_PATH > out_linf_tiny_ours_finetune.txt

# Step 5: calculate union accuracy
python cal_union.py --dataset tiny --file_path ours_finetune

echo "completed."
