# experiment.py

import pandas as pd
import os
from discovery_utils import simple_auto_circuit_llava


def auto_circuit_experiment(
    csv_path,
    model,
    processor,
    val_samples,
    val_cache,
    ablation_scheme="mean",
    device="cuda",
    include_mlps=False,
    num_samples=5,
    layer_hidden_index=None,
    target_layers=None,
    batch_size=4,
):
    # 1. Read existing csv and find available experiment IDs
    if os.path.exists(csv_path):
        df = pd.read_csv(csv_path)
        used_experiments = set(df["experiment"].tolist())
    else:
        df = pd.DataFrame(columns=["experiment", "layer", "head", "delta_eigenscore"])
        used_experiments = set()
    # Assign new experiment ID: the smallest unused positive integer
    exp_id = 1
    while exp_id in used_experiments:
        exp_id += 1

    # 2. Call simple_auto_circuit_llava
    result_tuples = simple_auto_circuit_llava(
        model,
        processor,
        val_samples,
        val_cache,
        ablation_scheme=ablation_scheme,
        device=device,
        include_mlps=include_mlps,
        num_samples=num_samples,
        layer_hidden_index=layer_hidden_index,
        target_layers=target_layers,
        batch_size=batch_size
    )
    # 3. Assemble tuples and convert to DataFrame
    data_to_add = [(exp_id, layer, head, delta) for (layer, head, delta) in result_tuples]
    df_new = pd.DataFrame(data_to_add, columns=["experiment", "layer", "head", "delta_eigenscore"])
    # 4. Append to csv and write back
    df_all = pd.concat([df, df_new], ignore_index=True)
    df_all.to_csv(csv_path, index=False)
    print(f"[INFO] Added experiment={exp_id}, total {len(data_to_add)} records.")
    return exp_id
