import json
import pandas as pd

# Path to your JSON file
file_path = '/home/abdulr81/RestWork/REST/llm_judge/data/mt_bench/model_answer/rest-vicuna-7b-v1.5-temperature-0.0-top_p-0.jsonl'

# Initialize list to store per query acceptance rates
acceptance_rates = []

# Function to calculate acceptance rates
def calculate_acceptance_rate(file_path):
    with open(file_path, "r") as f:
        for line in f:
            entry = json.loads(line)
            choices = entry.get('choices', [])
            for choice in choices:
                accept_lengths = choice.get("accept_lengths:", [])
                
                # Calculate acceptance rate
                if accept_lengths:
                    total_tokens = sum(accept_lengths)
                    acceptance_rate = total_tokens / len(accept_lengths)
                    acceptance_rates.append(acceptance_rate)

calculate_acceptance_rate(file_path)

# Prepare the data for display
acceptance_rates_summary = {
    'acceptance_rates': acceptance_rates,
    'average_acceptance_rate': sum(acceptance_rates) / len(acceptance_rates) if acceptance_rates else 0
}

# Convert to DataFrame for better display
acceptance_rates_df = pd.DataFrame({
    'Acceptance Rates': acceptance_rates
})

# Display the dataframe
print("Acceptance Rates Summary:")
print(acceptance_rates_df)
print("Average Acceptance Rate:", acceptance_rates_summary['average_acceptance_rate'])
