SignsDetectionAI/main.py

94 lines
3.7 KiB
Python

import os
import cv2
from src.pipeline import ObjectDetectionPipeline
from src.classifiers.bayesian import BayesianClassifier
from collections import defaultdict
if __name__ == "__main__":
# Chemin vers le modèle entraîné
model_path = "models/bayesian_modelPAGE.pth"
# Chargement du modèle bayésien
print(f"Chargement du modèle bayésien depuis {model_path}")
bayesian_model = BayesianClassifier()
try:
bayesian_model.load_model(model_path)
print(f"Modèle bayésien chargé depuis {model_path}")
except Exception as e:
print(f"Erreur lors du chargement du modèle : {e}")
exit(1)
# Chemin de l'image de test
image_path = "data/page.png"
if not os.path.exists(image_path):
print(f"L'image de test {image_path} n'existe pas.")
exit(1)
# Initialisation du dossier de sortie
output_dir = "output"
if not os.path.exists(output_dir):
os.makedirs(output_dir)
# Initialisation de la pipeline
print("Initialisation de la pipeline...")
pipeline = ObjectDetectionPipeline(image_path=image_path, model=bayesian_model, output_dir=output_dir)
# Chargement de l'image
print("Chargement de l'image...")
try:
pipeline.load_image()
except FileNotFoundError as e:
print(e)
exit(1)
# Détection et classification des objets
print("Détection et classification des objets...")
try:
class_counts, detected_objects = pipeline.detect_and_classify_objects()
except Exception as e:
print(f"Erreur lors de la détection/classification : {e}")
exit(1)
# Sauvegarde et affichage des résultats
print("Sauvegarde et affichage des résultats...")
pipeline.display_results(class_counts, detected_objects)
# Chargement des comptes réels manuels avec distinction entre minuscule et majuscule
true_counts_manual = {
'A_': 30, 'A': 30, 'B_': 4, 'B': 0, 'C_': 14, 'C': 14, 'D_': 17, 'D': 17,
'E_': 68, 'E': 69, 'F_': 2, 'F': 2, 'G_': 8, 'G': 8, 'H_': 9, 'H': 9,
'I_': 26, 'I': 25, 'J_': 1, 'J': 0, 'K_': 0, 'K': 0, 'L_': 20, 'L': 19,
'M_': 15, 'M': 15, 'N_': 30, 'N': 29, 'O_': 37, 'O': 37, 'P_': 23, 'P': 22,
'Q_': 5, 'Q': 4, 'R_': 28, 'R': 27, 'S_': 26, 'S': 25, 'T_': 38, 'T': 38,
'U_': 25, 'U': 25, 'V_': 7, 'V': 6, 'W_': 1, 'W': 0, 'X_': 2, 'X': 2,
'Y_': 6, 'Y': 5, 'Z_': 3, 'Z': 2,
'1': 8, '2': 11, '3': 2, '4': 1, '5': 2, '6': 1, '7': 1, '8': 3, '9': 3
}
# Chargement des résultats détectés depuis results.txt
results_path = "output/results.txt"
detected_counts = defaultdict(int)
if os.path.exists(results_path):
with open(results_path, "r") as f:
for line in f:
char, count = line.strip().split(":")
detected_counts[char.strip()] = int(count.strip())
else:
print(f"Le fichier {results_path} n'existe pas.")
exit(1)
# Calcul du pourcentage de précision
print("Calcul du pourcentage de précision...")
total_true = sum(true_counts_manual.values())
common_keys = set(true_counts_manual.keys()) & set(detected_counts.keys())
correctly_detected = sum(min(detected_counts[char], true_counts_manual[char]) for char in common_keys)
precision = (correctly_detected / total_true) * 100 if total_true > 0 else 0
# Afficher les résultats
print("\nRésultats de comparaison :")
for char in sorted(common_keys):
print(f"{char}: True={true_counts_manual[char]}, Detected={detected_counts[char]}")
print(f"\nPrécision globale : {precision:.2f}%")
print(f"Les résultats ont été sauvegardés dans le dossier : {output_dir}")