#!/usr/bin/env python3

import argparse
import os
import trackexp
from trackexp.utils import get_data, get_metadata, list_experiments
import pandas as pd

def main():
    # Parse command line arguments
    parser = argparse.ArgumentParser(description='Create a CSV with test accuracies for datasets')
    parser.add_argument('--data_list', type=str, required=True, help='Path to the file containing dataset names')
    parser.add_argument('--output', type=str, default='results.csv', help='Output CSV file path')
    parser.add_argument('--base_dir', type=str, default='trackexp_out', help='Base directory for trackexp outputs')
    args = parser.parse_args()

    # Check if the data list file exists
    if not os.path.isfile(args.data_list):
        print(f"Error: Data list file '{args.data_list}' not found.")
        return 1

    # Read dataset names from the file
    with open(args.data_list, 'r') as f:
        datasets = [line.strip() for line in f if line.strip()]

    # Initialize lists to store results
    results = []

    # Process each dataset
    for dataset in datasets:
        print(f"Processing dataset: {dataset}")

        # Initialize dictionary to store accuracies
        accuracies = {'dataset': dataset}

        # Loss types to process
        loss_types = ['ce', 'fw']

        # Get the test accuracy for each loss type
        for loss in loss_types:
            experiment_name = f"{dataset}__{loss}"
            try:
                # Get test data using the provided base_dir
                test_data = get_data(experiment_name, context='testing', base_dir=args.base_dir)

                # Extract test accuracy (assuming it's the first and only entry)
                if test_data is not None and 'accuracy' in test_data:
                    test_acc = test_data['accuracy'][0] if len(test_data['accuracy']) > 0 else None
                    accuracies[f'{loss}_accuracy'] = test_acc
                else:
                    print(f"Warning: No test accuracy found for {experiment_name}")
                    accuracies[f'{loss}_accuracy'] = None
            except Exception as e:
                print(f"Error processing {experiment_name}: {e}")
                accuracies[f'{loss}_accuracy'] = None

        # Add results to list
        results.append(accuracies)

    # Create DataFrame
    df = pd.DataFrame(results)

    # Save to CSV
    df.to_csv(args.output, index=False)
    print(f"Results saved to {args.output}")

    # Display the DataFrame
    print("\nResults DataFrame:")
    print(df)

    return 0

if __name__ == "__main__":
    exit(main())
