#!/bin/bash
# Pipeline for Qwen Gradient Evaluation

# Ensure conda is initialized
source $(conda info --base)/etc/profile.d/conda.sh
conda activate negation

# Configuration
DATA_DIR="[PATH]/data/TREx"
OUTPUT_BASE="output_grads_qwen"
MAX_SAMPLES=10

# Models
MODEL_1="Qwen/Qwen3-4B-Instruct-2507"
MODEL_2="Qwen/Qwen3-30B-A3B-Instruct-2507"

# Function to run pipeline for a model
run_pipeline() {
    MODEL_NAME=$1
    DIR_NAME=$2
    
    echo "========================================================"
    echo "Starting Pipeline for $MODEL_NAME"
    echo "========================================================"
    
    # # Run Standard Evaluation (span_obj)
    # OUTPUT_DIR_STD="${OUTPUT_BASE}/${DIR_NAME}/span_obj"
    # mkdir -p "$OUTPUT_DIR_STD"
    
    # echo "[1/4] Running Standard Evaluation (span_obj)..."
    # python3 scripts/eval_grad_qwen.py \
    #     --model_name "$MODEL_NAME" \
    #     --data_dir "$DATA_DIR" \
    #     --output_dir "$OUTPUT_DIR_STD" \
    #     --max_samples $MAX_SAMPLES \
    #     --eval_mode span_obj
        
    # echo "[2/4] Running Standard Analysis..."
    # python3 scripts/analyze_grads_qwen.py \
    #     --input_dir "$OUTPUT_DIR_STD" \
    #     --output_file "${OUTPUT_DIR_STD}/analysis"

    # Run New Evaluation (span_logprob)
    OUTPUT_DIR_NEW="${OUTPUT_BASE}/${DIR_NAME}/span_logprob"
    mkdir -p "$OUTPUT_DIR_NEW"

    echo "[3/4] Running New Evaluation (span_logprob)..."
    python3 scripts/eval_grad_qwen.py \
        --model_name "$MODEL_NAME" \
        --data_dir "$DATA_DIR" \
        --output_dir "$OUTPUT_DIR_NEW" \
        --max_samples $MAX_SAMPLES \
        --eval_mode span_logprob \
        --grad_scope default
        
    echo "[4/4] Running New Analysis..."
    python3 scripts/analyze_grads_qwen.py \
        --input_dir "$OUTPUT_DIR_NEW" \
        --output_file "${OUTPUT_DIR_NEW}/analysis"
        
    echo "Finished $MODEL_NAME"
}

# Run for Model 1
run_pipeline "$MODEL_1" "4B"

# Run for Model 2
# run_pipeline "$MODEL_2" "30B"

echo "Full Pipeline Complete."
