Add free(neuron->last_back_weights);

This commit is contained in:
augustin64 2022-05-14 14:46:48 +02:00
parent 1772f369d8
commit dfb33147f3
3 changed files with 20 additions and 21 deletions

View File

@ -81,13 +81,14 @@ void deletion_of_network(Network* network) {
Layer* layer;
Neuron* neuron;
for (int i=0; i<network->nb_layers; i++) {
for (int i=0; i < network->nb_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
for (int j=0; j<network->layers[i]->nb_neurons; j++) {
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++) {
neuron = layer->neurons[j];
free(neuron->weights);
free(neuron->back_weights);
free(neuron->last_back_weights);
}
}
free(layer->neurons); // On libère enfin la liste des neurones de la couche

View File

@ -125,9 +125,7 @@ int write_network(char* filename, Network* network) {
nb_neurons[i] = network->layers[i]->nb_neurons;
}
nb_neurons[nb_layers] = 0;
fwrite(buffer, sizeof(buffer), 1, ptr);
for (int i=0; i < nb_layers; i++) {
for (int j=0; j < nb_neurons[i]; j++) {
write_neuron(network->layers[i]->neurons[j], nb_neurons[i+1], ptr);

View File

@ -56,58 +56,56 @@ void print_weights(char* filename) {
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);
unsigned int* labels = (unsigned int*)malloc(sizeof(unsigned int)*number_of_images);
labels = read_mnist_labels(filename);
unsigned int* tab[10];
unsigned int tab[10];
for (int i=0; i < 10; i++) {
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]]++;
}
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) {
Network* network = malloc(sizeof(Network));
Network* network = (Network*)malloc(sizeof(Network));
Layer* layer;
Neuron* neuron;
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};
for (int i=0; i < network->nb_layers; i++) {
network->layers[i] = malloc(sizeof(Layer));
layer = network->layers[i];
layer = (Layer*)malloc(sizeof(Layer));
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++) {
layer->neurons[j] = malloc(sizeof(Neuron));
neuron = layer->neurons[j];
neuron = (Neuron*)malloc(sizeof(Neuron));
neuron->bias = 0.;
neuron->z = 0.;
neuron->back_bias = 0.;
neuron->last_back_bias = 0.;
neuron->weights = malloc(sizeof(float)*neurons_per_layer[i+1]);
neuron->back_weights = malloc(sizeof(float)*neurons_per_layer[i+1]);
neuron->last_back_weights = malloc(sizeof(float)*neurons_per_layer[i+1]);
neuron->weights = (float*)malloc(sizeof(float)*neurons_per_layer[i+1]);
neuron->back_weights = (float*)malloc(sizeof(float)*neurons_per_layer[i+1]);
neuron->last_back_weights = (float*)malloc(sizeof(float)*neurons_per_layer[i+1]);
for (int k=0; k < neurons_per_layer[i+1]; k++) {
neuron->weights[k] = 0.;
neuron->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++) {
network->layers[0]->neurons[j]->weights[0] = 1;
}
@ -176,6 +174,8 @@ int main(int argc, char* argv[]) {
i++;
}
}
create_network(out, n);
exit(1);
} else if (! strcmp(argv[1], "count-labels")) {
char* labels = NULL;
int i = 2;