#!/bin/bash

# HEdit Inference Script
# This script runs inference with anchor and trigger token detection

# ========================================
# Configuration - MODIFY THESE PATHS
# ========================================

# Model configuration
MODEL_PATH="./models/your_model"  # Path to your base language model
MLP_CHECKPOINT="./checkpoints/layer_40/best_model.pt"  # Path to trained MLP checkpoint (optional)

# Detection configuration
ANCHOR_K=5  # Number of anchor tokens to identify
TRIGGER_K=5  # Number of trigger tokens to identify
ATTENTION_LAYER=20  # Layer for attention analysis
FFN_LAYER_START=20  # Start layer for FFN analysis
FFN_LAYER_END=21  # End layer for FFN analysis

# Input configuration
INPUT_TEXT="Your input text for reasoning analysis..."
# Alternatively, use INPUT_FILE to read from a file
# INPUT_FILE="./data/test_inputs.txt"

# Output configuration
OUTPUT_DIR="./outputs"

# Device configuration
DEVICE="cuda"  # Use "cpu" if no GPU available

# ========================================
# Run Inference
# ========================================

echo "=========================================="
echo "HEdit Inference"
echo "=========================================="
echo "Model: ${MODEL_PATH}"
echo "MLP checkpoint: ${MLP_CHECKPOINT}"
echo "Output directory: ${OUTPUT_DIR}"
echo "=========================================="

python examples/demo_inference.py \
    --model_path ${MODEL_PATH} \
    --mlp_checkpoint ${MLP_CHECKPOINT} \
    --anchor_k ${ANCHOR_K} \
    --trigger_k ${TRIGGER_K} \
    --attention_layer ${ATTENTION_LAYER} \
    --ffn_layer_start ${FFN_LAYER_START} \
    --ffn_layer_end ${FFN_LAYER_END} \
    --input_text "${INPUT_TEXT}" \
    --output_dir ${OUTPUT_DIR} \
    --device ${DEVICE}

# If using input file instead of text:
# python examples/demo_inference.py \
#     --model_path ${MODEL_PATH} \
#     --mlp_checkpoint ${MLP_CHECKPOINT} \
#     --anchor_k ${ANCHOR_K} \
#     --trigger_k ${TRIGGER_K} \
#     --attention_layer ${ATTENTION_LAYER} \
#     --ffn_layer_start ${FFN_LAYER_START} \
#     --ffn_layer_end ${FFN_LAYER_END} \
#     --input_file ${INPUT_FILE} \
#     --output_dir ${OUTPUT_DIR} \
#     --device ${DEVICE}

echo ""
echo "=========================================="
echo "Inference completed!"
echo "Results saved to: ${OUTPUT_DIR}"
echo "=========================================="
