import os
import json
import csv

PREPROCESSING_TYPES = ['blur1', 'blur3', 'jpeg70', 'jpeg90', 'noise001', 'noise003', 'salt_pepper001', 'salt_pepper003']
MODELS = ['blendface', 'diffae', 'psp_mix', 'simswap', 'stargan', 'styleclip']
METHODS = ['anti', 'df_rap', 'disrupting', 'leat', 'nullswap', 'pgd', 'scol']

BASE_DIR = "your/project/root/path/robustness_results"  # Adjust this path as needed
EVAL_DIR = "your/project/root/path/my_evaluation_results"  # Adjust this path as needed
OUTPUT_JSON = "your/project/root/path/final_robustness_analysis.json"  # Adjust this path as needed
OUTPUT_CSV = "your/project/root/path/final_robustness_summary.csv"  # Adjust this path as needed

def parse_robustness_csv(file_path):
    if not os.path.exists(file_path): return None
    
    data_map = {}
    baseline = None
    
    with open(file_path, 'r') as f:
        reader = csv.DictReader(f)
        for row in reader:
            p_name = row['preprocessing']
            metrics = {'mse': float(row['mse']), 'lpips': float(row['alex_lpips']), 'brisque': float(row['brisque'])}
            if p_name == 'baseline': baseline = metrics
            else: data_map[p_name] = metrics
                
    if not baseline: return None

    ratios = {}
    for p_name, m in data_map.items():
        if p_name in PREPROCESSING_TYPES:
            ratios[p_name] = {
                'mse_ratio': min(1.0, m['mse'] / (baseline['mse'] + 1e-10)),
                'lpips_ratio': min(1.0, m['lpips'] / (baseline['lpips'] + 1e-10)),
                'brisque_ratio': min(1.0, m['brisque'] / (baseline['brisque'] + 1e-10))
            }
    return ratios

def parse_eval_id_json(file_path):
    if not os.path.exists(file_path): return None
    try:
        with open(file_path, 'r') as f:
            data = json.load(f).get('averages', {})
        base_id = data.get('relative_id_original_mean', 0)
        if base_id == 0: return None
        
        id_ratios = {}
        for prep in PREPROCESSING_TYPES:
            prep_id = data.get(f'relative_id_{prep}_mean', 0)
            id_ratios[prep] = min(1.0, prep_id / base_id)
        return id_ratios
    except: return None

def main():
    final_report = {}
    for method in METHODS:
        method_results = {}

        for model in MODELS:
            folder_name = f"result_{model}_{method}"
            csv_path = os.path.join(EVAL_DIR, folder_name, 'robustness_evaluation.csv')
            json_path = os.path.join(BASE_DIR, method, folder_name, 'eval_id.json')

            csv_data = parse_robustness_csv(csv_path)
            id_data = parse_eval_id_json(json_path)

            if not csv_data or not id_data: continue

            model_prep_scores = {}
            for prep in PREPROCESSING_TYPES:
                if prep in csv_data and prep in id_data:
                    c = csv_data[prep]
                    avg_score = (c['mse_ratio'] + c['lpips_ratio'] + c['brisque_ratio'] + id_data[prep]) / 4
                    model_prep_scores[prep] = {
                        'quality_ratios': c,
                        'id_retention': id_data[prep],
                        'combined_score': avg_score
                    }
            
            if model_prep_scores:
                total_avg = sum(p['combined_score'] for p in model_prep_scores.values()) / len(model_prep_scores)
                method_results[model] = {'robustness_score': total_avg}
                print(f"  - {model:12}: Score {total_avg:.4f}")

        final_report[method] = method_results

    with open(OUTPUT_JSON, 'w') as f: json.dump(final_report, f, indent=2)
    with open(OUTPUT_CSV, 'w', newline='') as f:
        writer = csv.writer(f); writer.writerow(['Method', 'Model', 'Robustness_Score'])
        for m, models in final_report.items():
            for mod, d in models.items(): writer.writerow([m, mod, f"{d['robustness_score']:.4f}"])

if __name__ == "__main__":
    main()