mirror of
https://github.com/augustin64/projet-tipe
synced 2025-01-23 23:26: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;
|
||||
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
|
||||
|
@ -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);
|
||||
|
@ -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;
|
||||
|
Loading…
Reference in New Issue
Block a user