mirror of
https://github.com/augustin64/projet-tipe
synced 2025-01-24 15:36:25 +01:00
Add free(neuron->last_back_weights);
This commit is contained in:
parent
1772f369d8
commit
dfb33147f3
@ -81,13 +81,14 @@ void deletion_of_network(Network* network) {
|
|||||||
Layer* layer;
|
Layer* layer;
|
||||||
Neuron* neuron;
|
Neuron* neuron;
|
||||||
|
|
||||||
for (int i=0; i<network->nb_layers; i++) {
|
for (int i=0; i < network->nb_layers; i++) {
|
||||||
layer = network->layers[i];
|
layer = network->layers[i];
|
||||||
if (i!=network->nb_layers-1) { // On exclut la dernière couche dont les neurones ne contiennent pas de poids sortants
|
if (i != network->nb_layers-1) { // On exclut la dernière couche dont les neurones ne contiennent pas de poids sortants
|
||||||
for (int j=0; j<network->layers[i]->nb_neurons; j++) {
|
for (int j=0; j < network->layers[i]->nb_neurons; j++) {
|
||||||
neuron = layer->neurons[j];
|
neuron = layer->neurons[j];
|
||||||
free(neuron->weights);
|
free(neuron->weights);
|
||||||
free(neuron->back_weights);
|
free(neuron->back_weights);
|
||||||
|
free(neuron->last_back_weights);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
free(layer->neurons); // On libère enfin la liste des neurones de la couche
|
free(layer->neurons); // On libère enfin la liste des neurones de la couche
|
||||||
|
@ -125,9 +125,7 @@ int write_network(char* filename, Network* network) {
|
|||||||
nb_neurons[i] = network->layers[i]->nb_neurons;
|
nb_neurons[i] = network->layers[i]->nb_neurons;
|
||||||
}
|
}
|
||||||
nb_neurons[nb_layers] = 0;
|
nb_neurons[nb_layers] = 0;
|
||||||
|
|
||||||
fwrite(buffer, sizeof(buffer), 1, ptr);
|
fwrite(buffer, sizeof(buffer), 1, ptr);
|
||||||
|
|
||||||
for (int i=0; i < nb_layers; i++) {
|
for (int i=0; i < nb_layers; i++) {
|
||||||
for (int j=0; j < nb_neurons[i]; j++) {
|
for (int j=0; j < nb_neurons[i]; j++) {
|
||||||
write_neuron(network->layers[i]->neurons[j], nb_neurons[i+1], ptr);
|
write_neuron(network->layers[i]->neurons[j], nb_neurons[i+1], ptr);
|
||||||
|
@ -56,58 +56,56 @@ void print_weights(char* filename) {
|
|||||||
void count_labels(char* filename) {
|
void count_labels(char* filename) {
|
||||||
uint32_t number_of_images = read_mnist_labels_nb_images(filename);
|
uint32_t number_of_images = read_mnist_labels_nb_images(filename);
|
||||||
|
|
||||||
unsigned int* labels = malloc(sizeof(unsigned int)*number_of_images);
|
unsigned int* labels = (unsigned int*)malloc(sizeof(unsigned int)*number_of_images);
|
||||||
labels = read_mnist_labels(filename);
|
labels = read_mnist_labels(filename);
|
||||||
|
|
||||||
unsigned int* tab[10];
|
unsigned int tab[10];
|
||||||
|
|
||||||
for (int i=0; i < 10; i++) {
|
for (int i=0; i < 10; i++) {
|
||||||
tab[i] = 0;
|
tab[i] = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i=0; i < number_of_images; i++) {
|
for (int i=0; i < (int)number_of_images; i++) {
|
||||||
tab[(int)labels[i]]++;
|
tab[(int)labels[i]]++;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i=0; i < 10; i++) {
|
for (int i=0; i < 10; i++) {
|
||||||
printf("Nombre de %d: %d\n", i, tab[i]);
|
printf("Nombre de %d: %x\n", i, tab[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void create_network(char* filename, int sortie) {
|
void create_network(char* filename, int sortie) {
|
||||||
Network* network = malloc(sizeof(Network));
|
Network* network = (Network*)malloc(sizeof(Network));
|
||||||
Layer* layer;
|
Layer* layer;
|
||||||
Neuron* neuron;
|
Neuron* neuron;
|
||||||
network->nb_layers = 3;
|
network->nb_layers = 3;
|
||||||
|
|
||||||
network->layers = malloc(sizeof(Layer*)*network->nb_layers);
|
network->layers = (Layer**)malloc(sizeof(Layer*)*network->nb_layers);
|
||||||
int neurons_per_layer[4] = {784, 1, 10, 0};
|
int neurons_per_layer[4] = {784, 1, 10, 0};
|
||||||
for (int i=0; i < network->nb_layers; i++) {
|
for (int i=0; i < network->nb_layers; i++) {
|
||||||
network->layers[i] = malloc(sizeof(Layer));
|
layer = (Layer*)malloc(sizeof(Layer));
|
||||||
layer = network->layers[i];
|
|
||||||
layer->nb_neurons = neurons_per_layer[i];
|
layer->nb_neurons = neurons_per_layer[i];
|
||||||
layer->neurons = malloc(sizeof(Neuron*)*layer->nb_neurons);
|
layer->neurons = (Neuron**)malloc(sizeof(Neuron*)*layer->nb_neurons);
|
||||||
for (int j=0; j < layer->nb_neurons; j++) {
|
for (int j=0; j < layer->nb_neurons; j++) {
|
||||||
layer->neurons[j] = malloc(sizeof(Neuron));
|
neuron = (Neuron*)malloc(sizeof(Neuron));
|
||||||
neuron = layer->neurons[j];
|
|
||||||
|
|
||||||
neuron->bias = 0.;
|
neuron->bias = 0.;
|
||||||
neuron->z = 0.;
|
neuron->z = 0.;
|
||||||
|
|
||||||
neuron->back_bias = 0.;
|
neuron->back_bias = 0.;
|
||||||
neuron->last_back_bias = 0.;
|
neuron->last_back_bias = 0.;
|
||||||
|
neuron->weights = (float*)malloc(sizeof(float)*neurons_per_layer[i+1]);
|
||||||
neuron->weights = malloc(sizeof(float)*neurons_per_layer[i+1]);
|
neuron->back_weights = (float*)malloc(sizeof(float)*neurons_per_layer[i+1]);
|
||||||
neuron->back_weights = malloc(sizeof(float)*neurons_per_layer[i+1]);
|
neuron->last_back_weights = (float*)malloc(sizeof(float)*neurons_per_layer[i+1]);
|
||||||
neuron->last_back_weights = malloc(sizeof(float)*neurons_per_layer[i+1]);
|
|
||||||
for (int k=0; k < neurons_per_layer[i+1]; k++) {
|
for (int k=0; k < neurons_per_layer[i+1]; k++) {
|
||||||
neuron->weights[k] = 0.;
|
neuron->weights[k] = 0.;
|
||||||
neuron->back_weights[k] = 0.;
|
neuron->back_weights[k] = 0.;
|
||||||
neuron->last_back_weights[k] = 0.;
|
neuron->last_back_weights[k] = 0.;
|
||||||
}
|
}
|
||||||
|
layer->neurons[j] = neuron;
|
||||||
}
|
}
|
||||||
|
network->layers[i] = layer;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int j=0; j < neurons_per_layer[0]; j++) {
|
for (int j=0; j < neurons_per_layer[0]; j++) {
|
||||||
network->layers[0]->neurons[j]->weights[0] = 1;
|
network->layers[0]->neurons[j]->weights[0] = 1;
|
||||||
}
|
}
|
||||||
@ -176,6 +174,8 @@ int main(int argc, char* argv[]) {
|
|||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
create_network(out, n);
|
||||||
|
exit(1);
|
||||||
} else if (! strcmp(argv[1], "count-labels")) {
|
} else if (! strcmp(argv[1], "count-labels")) {
|
||||||
char* labels = NULL;
|
char* labels = NULL;
|
||||||
int i = 2;
|
int i = 2;
|
||||||
|
Loading…
Reference in New Issue
Block a user