import os
import csv

path = "/home/40430660@eeecs.qub.ac.uk/InterpretGatedNetwork/result/DNN/"
required_archs = {"FCN", "ResNet", "PatchTST"}
threshold = 0.7

# Dictionary to store performance: {dataset_name: {arch: max_accuracy}}
results = {}

for filename in os.listdir(path):
    if filename.endswith(".csv"):
        full_path = os.path.join(path, filename)
        try:
            with open(full_path, mode='r') as f:
                reader = csv.DictReader(f)
                for row in reader:
                    ds = row['dataset']
                    arch = row['dnn_type']
                    acc = float(row['test_accuracy'])
                    
                    if ds not in results:
                        results[ds] = {}
                    
                    # Store the highest accuracy found for this arch/dataset combo
                    if arch in required_archs:
                        if arch not in results[ds] or acc > results[ds][arch]:
                            results[ds][arch] = acc
        except Exception as e:
            print(f"Error reading {filename}: {e}")

print(f"--- High-Performance Audit (> {threshold*100}%) ---")
passed_all = []

count = 0
for ds, arch_data in results.items():
    # Check if all 3 archs exist AND all are > 0.7
    if all(arch in arch_data for arch in required_archs):
        if all(arch_data[a] > threshold for a in required_archs):
            passed_all.append(ds)
            print(f"✅ {ds}:")
            count += 1
            for a in required_archs:
                print(f"   - {a}: {arch_data[a]:.4f}")

if not passed_all:
    print("No datasets met the >70% accuracy requirement across all three architectures.")
else:
    print(f"Total datasets meeting criteria: {count}")
print(f"--- End of Audit ---")
