tipe/COMPTE_RENDU.md

5.1 KiB
Raw Permalink Blame History

Compte rendu

Ce fichier recense l'avancement global du projet et les différentes étapes franchies (avec leurs commits et date).

22 Avril 2022 MNIST, premiers résultats sur le réseau dense. b30bedd

Le réseau minimise la fonction d'erreur (différence entre sortie voulue et obtenue).
Cela donne comme résultat une précision de 10.2% en moyenne soit à peine mieux qu'aléatoire.
Chaque image renvoie les mêmes poids sur la dernière couche.
Voici un tableau comparant la fréquence d'apparition de chaque chiffre et l'activation associée sur la dernière couche :

Chiffre Nombre doccurrences dans le set d'entraînement Activation du neurone sortant Rapport
0 23692 0.483112 49040
1 26968 0.508133 53072
2 23832 0.492748 48365
3 24524 0.536703 45693
4 23368 0.532142 43913
5 21684 0.501488 43239
6 23672 0.518371 45666
7 25060 0.499134 50206
8 23404 0.512515 45665
9 23796 0.556504 42759



25 Avril 2022 Optimisation de la taille des époques. 698e72f

Le réseau donne des probabilités dont la somme est de 1 (grâce à softmax).
Un problème de sur-ajustement apparaît, résultant à de mauvais résultats sur des nouvelles données.
Plus le réseau contient de couches, plus sa convergence vers des probabilités convenables est longue.
Voici un tableau comparant les exactitudes des différentes époques et les dimensions du réseau sur les 60 000 images (train) :

Dimensions Epoque 0 Epoque 1 Epoque 2 Epoque 3 Epoque 4 Epoque 5 Epoque 6 Epoque 7 Epoque 8 Epoque 9 Epoque 10 Epoque 11 Epoque 12 Epoque 13 Epoque 14 Epoque 15 Epoque 16 Epoque 17 Epoque 18 Epoque 19 Epoque 20 Epoque 1 nouveau dataset (t10k)
784x10 10.5% 15.4% 26.6% 38.5% 50.2% 55.3% 59.8% 63.0% 65.9% 68.1% 70.0% 71.5% 72.9% 74.0% 74.9% 75.8% 76.6% 77.3% 78.0% 78.5% 79.0% 80.0%
784x16x10 10.9% 14.7% 18.3% 21.9% 24.7% 26.9% 28.8% 30.2% 31.4% 32.5% 33.9% 35.1% 36.2% 37.2% 38.0% 38.7% 39.5% 40.1% 40.6% 41.1% 41.5% 42.8%
784x16x16x10 9.1% 9.5% 10.8% 12.9% 14.4% 15.4% 16.1% 16.6% 17.1% 17.6% 18.1% 18.6% 19.1% 19.6% 20.0% 20.4% 20.8% 21.2% 21.6% 21.9% 22.2% 23.0%
784x16x16x16x10 11.0% 11.0% 11.1% 11.2% 11.1% 11.2% 11.2% 11.2% 11.3% 11.6% 11.8% 12.3% 12.9% 13.5% 14.0% 14.5% 15.0% 15.3% 15.6% 15.9% 16.1% 16.1%



14 Mai 2022 Implémentation du multithreading. d40212d

Le problème qui se posera dans le futur est celui de la puissance de calcul nécessaire.
Pour l'optimiser, il faut donc utiliser au maximum les ressources disponibles.




28 Septembre 2022 Enregistrement des fichiers du CNN a478a45

Le réseau neuronal simple donnant des résultats convaincants (approximativement 90% de réussite sur l'échantillon de test), Le réseau neuronal convolutif a commencé à être développé depuis 6532ad2.
Ce commit introduit l'enregistrement du réseau de neurones convolutif, suivi de près par les tests unitaires correspondants b12a03c




30 Novembre 2022 Réparation du NN simple ffc0c6e

Après un peu de débogage sur le réseau convolutif, on s'est rendu compte que le réseau simple ne fonctionnait pas bien avec des couches intermédiaires et du multithreading.
Le problème principal étant la découpe des batches étant la même à chaque époque.
Après implémentation d'un mélange de Knuth, tout est rentré dans l'ordre donnant des résultats encore plus satisfaisants pour les couches intermédiaires. (De l'ordre de 70% avec deux couches intermédiaires et utilisation du multithreading).




25 Janvier 2023 Premiers résultats sur la seconde implémentation 220d0a7

Premiers résultats sur le réseau simple_one qui suit la structure du premier réseau.
La backpropagation des poids ne fonctionne cependant pas sur les couches de convolution et de pooling.




18 Février 2023 Amélioration des résultats sur la seconde implémentation a461e07

Améliorations significative des résultats sur le réseau simple_one atteignant: -92% avec une linéarisation et une dense (1x32x32, 80, 10) La backpropagation fonctionne également sur la convolution. Le réseau LeNet5 donne 60% de réussite environ




27 Mars 2023 Implémentation d'Adam Optimizer 5f684d9

Adam Optimizer est complètement implémenté, donnant jusqu'à 97.5% de réussite sur MNIST (avec LeNet-5) avec un bon choix de paramètres. (détaillés dans le README)