import json
import numpy as np

results_file = ""

# gptzero_results_file = "/ai-involvement-in-peer-reviews/DetectorEval/GPTZero/results/new_generations_test_3220.json"
# with open(gptzero_results_file, 'r') as f:
# 	gptzero_results = json.load(f)
# gptzero_keys = set(gptzero_results.keys())

# print(len(gptzero_keys))
# # assert len(gptzero_keys) == 3220

# with open(results_file, 'r') as f:
# 	results_temp = json.load(f)

# results = {}
# for key, val in results_temp.items():
# 	if key in gptzero_keys:
# 		results[key] = val

with open(results_file, 'r') as f:
	results = json.load(f)

def count_freq(predictions):
	freq_dict = {}
	for pred in predictions:
		if pred in freq_dict:
			freq_dict[pred] += 1
		else:
			freq_dict[pred] = 1

	for key in freq_dict:
		freq_dict[key] = freq_dict[key] / len(predictions)

	return freq_dict

anal_dict = {
	"level1": [],
	"level2": [],
	"level3": [],
	"level4": [],
	"/reviews/": []
}

for key, val in results.items():

	# if "gpt_4o" not in key and "3.3" not in key and "/reviews/" not in key:
	# 	continue

	true_labe = '/reviews/'

	for i in range(1,5):
		if f'level{i}' in key:
			true_labe = f'level{i}'

	predicted_label = val["prediction_short"]

	anal_dict[true_labe].append(predicted_label)

consol_dict = {}

for key, val in anal_dict.items():
	freqs = count_freq(val)
	print(f"{key}: {freqs}")
	consol_dict[key] = freqs

print(consol_dict)

import numpy as np

cm = np.zeros((5,3))

for level_idx, level in enumerate(['level1', 'level2', 'level3', 'level4', '/reviews/']):
	for idx, pred in enumerate(['AI', 'Mixed', 'Human']):
		if pred in consol_dict[level]:
			cm[level_idx, idx] = consol_dict[level][pred] * 100

print(print(np.array2string(cm.T, separator=', ')))

'''
level1: {'AI Detected': 0.1927710843373494, 'Fully AI Generated': 0.4457831325301205, 'AI Assisted': 0.28313253012048195, 'Fully Human Written': 0.06626506024096386, 'Mostly Human, AI Assisted': 0.006024096385542169, 'Mostly Human Written': 0.006024096385542169}
level2: {}
level3: {}
level4: {'Fully Human Written': 0.6303030303030303, 'AI Assisted': 0.296969696969697, 'AI Detected': 0.006060606060606061, 'Fully AI Generated': 0.03636363636363636, 'Mostly Human, AI Assisted': 0.01818181818181818, 'Mostly Human, AI Detected': 0.006060606060606061, 'Human Written': 0.006060606060606061}
/reviews/: {}
'''