#!/bin/bash
# Attention Visualization Script
#
# Usage:
#   bash run_simple.sh <input_json> <output_dir> <lora_model> [gpu_id]
# Example:
#   bash run_simple.sh ./data/samples.jsonl ./outputs EditScore/EditScore-Qwen3-VL-8B-Instruct 0

# Uncomment and modify to activate your conda environment
# source "$(dirname $(which conda))/../etc/profile.d/conda.sh"
# conda activate your_environment

# Arguments
INPUT_JSON=$1
OUTPUT_DIR=$2
LORA_MODEL=$3
GPU_ID=${4:-0}

if [ -z "$INPUT_JSON" ] || [ -z "$OUTPUT_DIR" ] || [ -z "$LORA_MODEL" ]; then
    echo "Usage: bash run_simple.sh <input_json> <output_dir> <lora_model> [gpu_id]"
    echo "Example: bash run_simple.sh ./data/samples.jsonl ./outputs EditScore/EditScore-Qwen3-VL-8B-Instruct 0"
    exit 1
fi

export CUDA_VISIBLE_DEVICES=${GPU_ID}

# Configuration
SAMPLE_NUM="200"
VIS_TYPES="reasoning,score,edit_region"

# Attention layer configuration
# Default: layers 31-35 (high-level reasoning and decision layers)
LAYER_RANGE="31,32,33,34,35"

# Dynamic transparency parameter (1.0=linear, 1.5=moderate, 2.0=strong)
ALPHA_POWER="1"

mkdir -p ${OUTPUT_DIR}
mkdir -p logs

echo "Starting attention visualization..."
echo "Input: ${INPUT_JSON}"
echo "Output: ${OUTPUT_DIR}"
echo "LoRA Model: ${LORA_MODEL}"
echo "GPU: ${GPU_ID}"
echo "=========================================="

python run_attention_inference.py \
    --input_file ${INPUT_JSON} \
    --output_dir ${OUTPUT_DIR} \
    --sample_num ${SAMPLE_NUM} \
    --lora_model ${LORA_MODEL} \
    --visualize_types ${VIS_TYPES} \
    --layer_range ${LAYER_RANGE} \
    --alpha_power ${ALPHA_POWER} \
    --max_image_size 1200 2>&1 | tee logs/attention_viz.log

echo "Done!"