import os
import pandas as pd

def write_csv(dir_path, metrics, config):
    """
    Write the evaluation results into two CSV files: success_rate.csv and avg_rmse.csv
    
    Args:
    dir_path: CSV file directory path
    metrics: Dictionary of Evaluation Metrics
    config: configuration parameters
    """
    os.makedirs(dir_path, exist_ok=True)
    success_rate_path = os.path.join(dir_path, 'success_rate.csv')
    avg_rmse_path = os.path.join(dir_path, 'avg_rmse.csv')
    
    #Get the maximum tau value
    max_tau = max(metrics.keys())
    seed = config['exp']['seed']
    
    #Prepare new data rows
    success_rate_row = {'seed': seed}
    avg_rmse_row = {'seed': seed}
    
    for tau, metric in metrics.items():
        success_rate_row[f'tau_{tau}'] = f"{metric['success_rate']:.3f}"
        avg_rmse_row[f'tau_{tau}'] = f"{metric['avg_rmse']:.3f}"
    
    #Process success_rate.csv
    if os.path.exists(success_rate_path):
        try:
            df_success = pd.read_csv(success_rate_path)
            #Check if there are already rows with the same seed
            # if seed in df_success['seed'].values:
            ## Update existing rows
            #     df_success.loc[df_success['seed'] == seed, success_rate_row.keys()] = list(success_rate_row.values())
            # else:
            #Add New Line
            #     df_success = pd.concat([df_success, pd.DataFrame([success_rate_row])], ignore_index=True)
            df_success = pd.concat([df_success, pd.DataFrame([success_rate_row])], ignore_index=True)
        except Exception as e:
            print(f"Failed to read success_rate.csv: {e}")
            df_success = pd.DataFrame([success_rate_row])
    else:
        df_success = pd.DataFrame([success_rate_row])
    
    #Process avg_rmse.csv
    if os.path.exists(avg_rmse_path):
        try:
            df_rmse = pd.read_csv(avg_rmse_path)
            #Check if there are already rows with the same seed
            # if seed in df_rmse['seed'].values:
            ## Update existing rows
            #     df_rmse.loc[df_rmse['seed'] == seed, avg_rmse_row.keys()] = list(avg_rmse_row.values())
            # else:
            #Add New Line
            #     df_rmse = pd.concat([df_rmse, pd.DataFrame([avg_rmse_row])], ignore_index=True)
            df_rmse = pd.concat([df_rmse, pd.DataFrame([avg_rmse_row])], ignore_index=True)
        except Exception as e:
            print(f"Failed to read avg_rmse.csv: {e}")
            df_rmse = pd.DataFrame([avg_rmse_row])
    else:
        df_rmse = pd.DataFrame([avg_rmse_row])
    
    #Save DataFrame to CSV
    df_success.to_csv(success_rate_path, index=False)
    df_rmse.to_csv(avg_rmse_path, index=False)
    print(f"Success rate results saved to {success_rate_path}")
    print(f"RMSE results saved to {avg_rmse_path}")