2022-04-19 13:55:08 +02:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <float.h>
|
|
|
|
|
|
|
|
#include "neural_network.c"
|
|
|
|
#include "neuron_io.c"
|
2022-04-22 15:03:21 +02:00
|
|
|
#include "mnist.c"
|
2022-04-19 13:55:08 +02:00
|
|
|
|
2022-04-19 21:30:23 +02:00
|
|
|
/*
|
|
|
|
Contient un ensemble de fonctions utiles pour le débogage
|
|
|
|
*/
|
|
|
|
void help(char* call) {
|
|
|
|
printf("Usage: %s ( print-poids | print-biais | creer-reseau ) [OPTIONS]\n\n", call);
|
|
|
|
printf("OPTIONS:\n");
|
|
|
|
printf("\tprint-poids:\n");
|
|
|
|
printf("\t\t--reseau | -r [FILENAME]\tFichier contenant le réseau de neurones.\n");
|
|
|
|
printf("\tprint-biais:\n");
|
|
|
|
printf("\t\t--reseau | -r [FILENAME]\tFichier contenant le réseau de neurones.\n");
|
2022-04-22 15:03:21 +02:00
|
|
|
printf("\tcount-labels:\n");
|
|
|
|
printf("\t\t--labels | -l [FILENAME]\tFichier contenant les labels.\n");
|
2022-04-19 21:30:23 +02:00
|
|
|
printf("\tcreer-reseau:\n");
|
|
|
|
printf("\t\t--out | -o [FILENAME]\tFichier où écrire le réseau de neurones.\n");
|
|
|
|
printf("\t\t--number | -n [int]\tNuméro à privilégier\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-04-19 13:55:08 +02:00
|
|
|
void print_biais(char* filename) {
|
|
|
|
Reseau* reseau = lire_reseau(".cache/reseau.bin");
|
|
|
|
|
2022-04-19 16:26:28 +02:00
|
|
|
for (int i=1; i < reseau->nb_couches -1; i++) {
|
2022-04-19 13:55:08 +02:00
|
|
|
printf("Couche %d\n", i);
|
|
|
|
for (int j=0; j < reseau->couches[i]->nb_neurones; j++) {
|
2022-04-22 15:03:21 +02:00
|
|
|
printf("Couche %d\tNeurone %d\tBiais: %f\n", i, j, reseau->couches[i]->neurones[j]->biais);
|
2022-04-19 13:55:08 +02:00
|
|
|
}
|
|
|
|
}
|
2022-04-19 21:30:23 +02:00
|
|
|
suppression_du_reseau_neuronal(reseau);
|
|
|
|
}
|
|
|
|
|
|
|
|
void print_poids(char* filename) {
|
|
|
|
Reseau* reseau = lire_reseau(".cache/reseau.bin");
|
|
|
|
|
|
|
|
for (int i=0; i < reseau->nb_couches -1; i++) {
|
|
|
|
printf("Couche %d\n", i);
|
|
|
|
for (int j=0; j < reseau->couches[i]->nb_neurones; j++) {
|
|
|
|
printf("Couche %d\tNeurone %d\tPoids: [", i, j);
|
|
|
|
for (int k=0; k < reseau->couches[i+1]->nb_neurones; k++) {
|
2022-04-22 15:03:21 +02:00
|
|
|
printf("%f, ", reseau->couches[i]->neurones[j]->poids_sortants[k]);
|
2022-04-19 21:30:23 +02:00
|
|
|
}
|
|
|
|
printf("]\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
suppression_du_reseau_neuronal(reseau);
|
2022-04-19 13:55:08 +02:00
|
|
|
}
|
|
|
|
|
2022-04-22 15:03:21 +02:00
|
|
|
void count_labels(char* filename) {
|
|
|
|
uint32_t number_of_images = read_mnist_labels_nb_images(filename);
|
|
|
|
|
|
|
|
unsigned int* labels = malloc(sizeof(unsigned int)*number_of_images);
|
|
|
|
labels = read_mnist_labels(filename);
|
|
|
|
|
|
|
|
unsigned int* tab[10];
|
|
|
|
|
|
|
|
for (int i=0; i < 10; i++) {
|
|
|
|
tab[i] = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i=0; i < number_of_images; i++) {
|
|
|
|
tab[(int)labels[i]]++;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i=0; i < 10; i++) {
|
|
|
|
printf("Nombre de %d: %d\n", i, tab[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-19 21:30:23 +02:00
|
|
|
void creer_reseau(char* filename, int sortie) {
|
|
|
|
Reseau* reseau = malloc(sizeof(Reseau));
|
|
|
|
Couche* couche;
|
|
|
|
Neurone* neurone;
|
|
|
|
reseau->nb_couches = 3;
|
|
|
|
|
|
|
|
reseau->couches = malloc(sizeof(Couche*)*reseau->nb_couches);
|
|
|
|
int neurones_par_couche[4] = {784, 1, 10, 0};
|
|
|
|
for (int i=0; i < reseau->nb_couches; i++) {
|
|
|
|
reseau->couches[i] = malloc(sizeof(Couche));
|
|
|
|
couche = reseau->couches[i];
|
|
|
|
couche->nb_neurones = neurones_par_couche[i];
|
|
|
|
couche->neurones = malloc(sizeof(Neurone*)*couche->nb_neurones);
|
|
|
|
for (int j=0; j < couche->nb_neurones; j++) {
|
|
|
|
couche->neurones[j] = malloc(sizeof(Neurone));
|
|
|
|
neurone = couche->neurones[j];
|
|
|
|
|
|
|
|
neurone->activation = 0.;
|
|
|
|
neurone->biais = 0.;
|
|
|
|
neurone->z = 0.;
|
|
|
|
|
|
|
|
neurone->d_activation = 0.;
|
|
|
|
neurone->d_biais = 0.;
|
|
|
|
neurone->d_z = 0.;
|
|
|
|
|
|
|
|
neurone->poids_sortants = malloc(sizeof(float)*neurones_par_couche[i+1]);
|
|
|
|
neurone->d_poids_sortants = malloc(sizeof(float)*neurones_par_couche[i+1]);
|
|
|
|
for (int k=0; k < neurones_par_couche[i+1]; k++) {
|
|
|
|
neurone->poids_sortants[k] = 0.;
|
|
|
|
neurone->d_poids_sortants[k] = 0.;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int j=0; j < neurones_par_couche[0]; j++) {
|
|
|
|
reseau->couches[0]->neurones[j]->poids_sortants[0] = 1;
|
|
|
|
}
|
|
|
|
reseau->couches[1]->neurones[0]->poids_sortants[sortie] = 1;
|
|
|
|
ecrire_reseau(filename, reseau);
|
|
|
|
suppression_du_reseau_neuronal(reseau);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2022-04-19 16:26:28 +02:00
|
|
|
int main(int argc, char* argv[]) {
|
2022-04-19 21:30:23 +02:00
|
|
|
if (argc < 2) {
|
|
|
|
printf("Pas d'action spécifiée\n");
|
|
|
|
help(argv[0]);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
if (! strcmp(argv[1], "print-poids")) {
|
|
|
|
char* filename = NULL;
|
|
|
|
int i = 2;
|
|
|
|
while (i < argc) {
|
|
|
|
if ((! strcmp(argv[i], "--reseau"))||(! strcmp(argv[i], "-r"))) {
|
|
|
|
filename = argv[i+1];
|
|
|
|
i += 2;
|
|
|
|
} else {
|
|
|
|
printf("%s : Argument non reconnu\n", argv[i]);
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (! filename) {
|
|
|
|
printf("Pas de fichier spécifié, utilisation de '.cache/reseau.bin'\n");
|
|
|
|
filename = ".cache/reseau.bin";
|
|
|
|
}
|
|
|
|
print_poids(filename);
|
|
|
|
exit(1);
|
|
|
|
} else if (! strcmp(argv[1], "print-biais")) {
|
|
|
|
char* filename = NULL;
|
|
|
|
int i = 2;
|
|
|
|
while (i < argc) {
|
|
|
|
if ((! strcmp(argv[i], "--reseau"))||(! strcmp(argv[i], "-r"))) {
|
|
|
|
filename = argv[i+1];
|
|
|
|
i += 2;
|
|
|
|
} else {
|
|
|
|
printf("%s : Argument non reconnu\n", argv[i]);
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (! filename) {
|
|
|
|
printf("Pas de fichier spécifié, utilisation de '.cache/reseau.bin'\n");
|
|
|
|
filename = ".cache/reseau.bin";
|
|
|
|
}
|
|
|
|
print_biais(filename);
|
|
|
|
exit(1);
|
|
|
|
} else if (! strcmp(argv[1], "creer-reseau")) {
|
|
|
|
char* out = NULL;
|
|
|
|
int n = -1;
|
|
|
|
int i = 2;
|
|
|
|
while (i < argc) {
|
|
|
|
if ((! strcmp(argv[i], "--out"))||(! strcmp(argv[i], "-o"))) {
|
|
|
|
out = argv[i+1];
|
|
|
|
i += 2;
|
|
|
|
} else if ((! strcmp(argv[i], "--number"))||(! strcmp(argv[i], "-n"))) {
|
|
|
|
n = strtol(argv[i+1], NULL, 10);
|
|
|
|
i += 2;
|
|
|
|
} else {
|
|
|
|
printf("%s : Argument non reconnu\n", argv[i]);
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
}
|
2022-04-22 15:03:21 +02:00
|
|
|
} else if (! strcmp(argv[1], "count-labels")) {
|
|
|
|
char* labels = NULL;
|
|
|
|
int i = 2;
|
|
|
|
while (i < argc) {
|
|
|
|
if ((! strcmp(argv[i], "--labels"))||(! strcmp(argv[i], "-l"))) {
|
|
|
|
labels = argv[i+1];
|
|
|
|
i += 2;
|
|
|
|
} else {
|
|
|
|
printf("%s : Argument non reconnu\n", argv[i]);
|
|
|
|
i++;
|
|
|
|
}
|
2022-04-19 21:30:23 +02:00
|
|
|
}
|
2022-04-22 15:03:21 +02:00
|
|
|
if (! labels) {
|
|
|
|
printf("Pas de fichier spécifié, défaut: 'data/mnist/train-labels-idx1-ubyte'\n");
|
|
|
|
labels = "data/mnist/train-labels-idx1-ubyte";
|
2022-04-19 21:30:23 +02:00
|
|
|
}
|
2022-04-22 15:03:21 +02:00
|
|
|
count_labels(labels);
|
2022-04-19 21:30:23 +02:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
printf("Option choisie non reconnue: %s\n", argv[1]);
|
|
|
|
help(argv[0]);
|
2022-04-19 13:55:08 +02:00
|
|
|
return 1;
|
|
|
|
}
|