Render first neural network
This commit is contained in:
parent
c83039098c
commit
55448bf44a
6 changed files with 53 additions and 49 deletions
|
@ -25,11 +25,11 @@
|
||||||
|
|
||||||
// Declare functions
|
// Declare functions
|
||||||
|
|
||||||
int cx_glinit(GLFWwindow **);
|
|
||||||
int cx_glrun(GLFWwindow *);
|
|
||||||
|
|
||||||
|
int cx_glinit(GLFWwindow **);
|
||||||
int cx_nninit(Neural_Network **);
|
int cx_nninit(Neural_Network **);
|
||||||
int cx_nnrun(Neural_Network *);
|
|
||||||
|
int cx_run(GLFWwindow *, Neural_Network *);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
|
|
||||||
typedef struct _neuron {
|
typedef struct _neuron {
|
||||||
float value;
|
float value;
|
||||||
float *weights; // Biases of the neuron towards the next layer,
|
float *synapses; // Synapses of the neuron towards the next layer,
|
||||||
// NULL if output layer
|
// NULL if output layer
|
||||||
} Neuron;
|
} Neuron;
|
||||||
|
|
||||||
|
|
56
src/cx.c
56
src/cx.c
|
@ -97,7 +97,7 @@ cx_glinit(GLFWwindow **window) {
|
||||||
glfwWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE);
|
glfwWindowHint(GLFW_OPENGL_FORWARD_COMPAT, GL_TRUE);
|
||||||
|
|
||||||
// Open a window and create its OpenGL context
|
// Open a window and create its OpenGL context
|
||||||
*window = glfwCreateWindow(1920, 1080, "CONTROL-X", NULL, NULL);
|
*window = glfwCreateWindow(1280, 720, "CONTROL-X", NULL, NULL);
|
||||||
if (*window == NULL) {
|
if (*window == NULL) {
|
||||||
fprintf(stderr, "Failed to open GLFW window.\n");
|
fprintf(stderr, "Failed to open GLFW window.\n");
|
||||||
glfwTerminate();
|
glfwTerminate();
|
||||||
|
@ -122,8 +122,19 @@ cx_glinit(GLFWwindow **window) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
cx_nnrun(Neural_Network *nn) {
|
||||||
|
|
||||||
|
// Establish a neural interface.
|
||||||
|
float *input_buffer = malloc(64*sizeof(float));
|
||||||
|
float *output_buffer;
|
||||||
|
|
||||||
|
output_buffer = neural_process(nn, input_buffer);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
cx_glrun(GLFWwindow *window) {
|
cx_run(GLFWwindow *window, Neural_Network *nn) {
|
||||||
Model *model;
|
Model *model;
|
||||||
ModelRegistry *mr;
|
ModelRegistry *mr;
|
||||||
Model *neural_network_model;
|
Model *neural_network_model;
|
||||||
|
@ -137,19 +148,36 @@ cx_glrun(GLFWwindow *window) {
|
||||||
// Establish a model registry
|
// Establish a model registry
|
||||||
mr = modelRegistry_new();
|
mr = modelRegistry_new();
|
||||||
// Fill the model registry with mesh models
|
// Fill the model registry with mesh models
|
||||||
for (int j = 0; j < 8; j++) {
|
for (int j = 0; j < nn->layer_count; j++) {
|
||||||
for (int i = 0; i < 64; i++) {
|
Neural_Layer *nl = nn->layers[j];
|
||||||
|
for (int i = 0; i < nl->layer_size; i++) {
|
||||||
// Load model to render from file
|
// Load model to render from file
|
||||||
//Model *model = model_load("../3d_assets/triangle.obj");
|
//Model *model = model_load("../3d_assets/triangle.obj");
|
||||||
|
for (int k = 0; k < nl->layer_size_next; k++) {
|
||||||
|
model = model_line((-.90)
|
||||||
|
+ ((GLfloat)2 * i * .90/(nl->layer_size-1)),
|
||||||
|
|
||||||
|
.90 - ((GLfloat)2 * j *.90/(nn->layer_count)),
|
||||||
|
|
||||||
|
(-.90)
|
||||||
|
+ ((GLfloat)2 * k * .90/(nl->layer_size_next-1)),
|
||||||
|
|
||||||
|
.90 - ((GLfloat)2 * (j+1) *.90/(nn->layer_count)),
|
||||||
|
|
||||||
|
.001 // girth
|
||||||
|
);
|
||||||
|
modelRegistry_register(mr, model);
|
||||||
|
}
|
||||||
|
|
||||||
model = model_circle(0, (GLfloat)1/64);
|
model = model_circle(0, (GLfloat)1/64);
|
||||||
GLfloat *translation_matrix = matrix_new();
|
GLfloat *translation_matrix = matrix_new();
|
||||||
GLfloat *aspectRatio_matrix = matrix_new();
|
GLfloat *aspectRatio_matrix = matrix_new();
|
||||||
aspectRatio_matrix[0] = (GLfloat)9/16;
|
aspectRatio_matrix[0] = (GLfloat)9/16;
|
||||||
|
|
||||||
translation_matrix[3] = (((GLfloat)-1*16/9)*.90)
|
translation_matrix[3] = (((GLfloat)-1*16/9)*.90)
|
||||||
+ ((GLfloat)1/32 * i * (((GLfloat)16/9))*.90);
|
+ ((GLfloat)1/(nl->layer_size-1)*2 * i * (((GLfloat)16/9))*.90);
|
||||||
|
|
||||||
translation_matrix[7] = .90 - ((GLfloat)1/4 * j *.90);
|
translation_matrix[7] = .90 - ((GLfloat)1/(nn->layer_count)*2 * j *.90);
|
||||||
|
|
||||||
model->transformations[0] = translation_matrix;
|
model->transformations[0] = translation_matrix;
|
||||||
model->transformations[1] = aspectRatio_matrix;
|
model->transformations[1] = aspectRatio_matrix;
|
||||||
|
@ -157,11 +185,9 @@ cx_glrun(GLFWwindow *window) {
|
||||||
model_colorWhite(model);
|
model_colorWhite(model);
|
||||||
|
|
||||||
modelRegistry_register(mr, model);
|
modelRegistry_register(mr, model);
|
||||||
}
|
|
||||||
}
|
|
||||||
model = model_line(-0.5, 0, 0.5, 0, 0.015);
|
|
||||||
modelRegistry_register(mr, model);
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Remainder from cursor experiments, might be useful later
|
// Remainder from cursor experiments, might be useful later
|
||||||
double xpos, ypos;
|
double xpos, ypos;
|
||||||
|
@ -199,14 +225,4 @@ cx_nninit(Neural_Network **nn) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
|
||||||
cx_nnrun(Neural_Network *nn) {
|
|
||||||
|
|
||||||
// Establish a neural interface.
|
|
||||||
float *input_buffer = malloc(64*sizeof(float));
|
|
||||||
float *output_buffer;
|
|
||||||
|
|
||||||
output_buffer = neural_process(nn, input_buffer);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,6 @@ main(void) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
retval = cx_glrun(window);
|
retval = cx_run(window, nn);
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
18
src/model.c
18
src/model.c
|
@ -67,9 +67,7 @@ model_load(const char *path) {
|
||||||
for (int j = 0; j < 3; j++) {
|
for (int j = 0; j < 3; j++) {
|
||||||
for (int k = 0; k < 3; k++) {
|
for (int k = 0; k < 3; k++) {
|
||||||
self->object[i*12+j*4+k] = vertices[(faces[i*3+j]-1)*3+k];
|
self->object[i*12+j*4+k] = vertices[(faces[i*3+j]-1)*3+k];
|
||||||
printf("%f, ", vertices[(faces[i*3+j]-1)*3+k]);
|
|
||||||
}
|
}
|
||||||
printf("\n");
|
|
||||||
self->object[i*12+j*4+3] = 1;
|
self->object[i*12+j*4+3] = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -201,9 +199,6 @@ model_line(float x1, float y1, float x2, float y2, float girth) {
|
||||||
+(cos(M_PI/2) * y_diff))
|
+(cos(M_PI/2) * y_diff))
|
||||||
/ line_length * girth / 2;
|
/ line_length * girth / 2;
|
||||||
|
|
||||||
printf("%f, ", normal_x);
|
|
||||||
printf("%f,\n", normal_y);
|
|
||||||
|
|
||||||
self = model_new(6);
|
self = model_new(6);
|
||||||
|
|
||||||
if (self == NULL) {
|
if (self == NULL) {
|
||||||
|
@ -213,38 +208,27 @@ model_line(float x1, float y1, float x2, float y2, float girth) {
|
||||||
self->object[0] = x1 + normal_x;
|
self->object[0] = x1 + normal_x;
|
||||||
self->object[1] = y1 + normal_y;
|
self->object[1] = y1 + normal_y;
|
||||||
self->object[3] = 1;
|
self->object[3] = 1;
|
||||||
printf("%f, ", self->object[0]);
|
|
||||||
printf("%f,\n", self->object[1]);
|
|
||||||
|
|
||||||
self->object[4] = x1 - normal_x;
|
self->object[4] = x1 - normal_x;
|
||||||
self->object[5] = y1 - normal_y;
|
self->object[5] = y1 - normal_y;
|
||||||
self->object[7] = 1;
|
self->object[7] = 1;
|
||||||
printf("%f, ", self->object[4]);
|
|
||||||
printf("%f,\n", self->object[5]);
|
|
||||||
|
|
||||||
self->object[8] = x2 + normal_x;
|
self->object[8] = x2 + normal_x;
|
||||||
self->object[9] = y2 + normal_y;
|
self->object[9] = y2 + normal_y;
|
||||||
self->object[11] = 1;
|
self->object[11] = 1;
|
||||||
printf("%f, ", self->object[8]);
|
|
||||||
printf("%f,\n", self->object[9]);
|
|
||||||
|
|
||||||
self->object[12] = x1 - normal_x;
|
self->object[12] = x1 - normal_x;
|
||||||
self->object[13] = y1 - normal_y;
|
self->object[13] = y1 - normal_y;
|
||||||
self->object[15] = 1;
|
self->object[15] = 1;
|
||||||
printf("%f, ", self->object[12]);
|
|
||||||
printf("%f,\n", self->object[13]);
|
|
||||||
|
|
||||||
self->object[16] = x2 + normal_x;
|
self->object[16] = x2 + normal_x;
|
||||||
self->object[17] = y2 + normal_y;
|
self->object[17] = y2 + normal_y;
|
||||||
self->object[19] = 1;
|
self->object[19] = 1;
|
||||||
printf("%f, ", self->object[16]);
|
|
||||||
printf("%f,\n", self->object[17]);
|
|
||||||
|
|
||||||
self->object[20] = x2 - normal_x;
|
self->object[20] = x2 - normal_x;
|
||||||
self->object[21] = y2 - normal_y;
|
self->object[21] = y2 - normal_y;
|
||||||
self->object[23] = 1;
|
self->object[23] = 1;
|
||||||
printf("%f, ", self->object[20]);
|
|
||||||
printf("%f,\n", self->object[21]);
|
|
||||||
return self;
|
return self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
18
src/neural.c
18
src/neural.c
|
@ -7,7 +7,7 @@ nl_new(size_t layer_size, size_t layer_size_next) {
|
||||||
self->neurons = calloc(layer_size, sizeof(Neuron));
|
self->neurons = calloc(layer_size, sizeof(Neuron));
|
||||||
|
|
||||||
for (int i = 0; i < layer_size; i++) {
|
for (int i = 0; i < layer_size; i++) {
|
||||||
self->neurons[i].weights = calloc(layer_size_next, sizeof(float));
|
self->neurons[i].synapses = calloc(layer_size_next, sizeof(float));
|
||||||
}
|
}
|
||||||
|
|
||||||
self->layer_size = layer_size;
|
self->layer_size = layer_size;
|
||||||
|
@ -31,17 +31,21 @@ neural_new(size_t input_size, size_t output_size, size_t layer_count) {
|
||||||
// The difference between layer sizes, hidden layers step between the two
|
// The difference between layer sizes, hidden layers step between the two
|
||||||
// sizes in linear fashion.
|
// sizes in linear fashion.
|
||||||
ssize_t layer_diff;
|
ssize_t layer_diff;
|
||||||
|
ssize_t layer_step;
|
||||||
|
|
||||||
|
self->layer_count = layer_count;
|
||||||
self->layers = malloc(layer_count * sizeof(Neural_Layer *));
|
self->layers = malloc(layer_count * sizeof(Neural_Layer *));
|
||||||
layer_diff = (ssize_t) output_size - input_size;
|
layer_diff = (ssize_t) output_size - input_size;
|
||||||
|
|
||||||
// Calculate sizes of individual layers and allocate them.
|
// Calculate sizes of individual layers and allocate them.
|
||||||
for (int i = 0; i < layer_count; i++) {
|
for (int i = 0; i < layer_count; i++) {
|
||||||
self->layers[i] = nl_new(input_size
|
self->layers[i] = nl_new(input_size
|
||||||
+ (layer_diff / ((ssize_t)layer_count-(i))),
|
+ (layer_diff * i / ((ssize_t)layer_count-1)),
|
||||||
input_size +
|
|
||||||
(layer_diff / ((ssize_t)layer_count-(i+1)))
|
i < (layer_count-1) ?
|
||||||
? i < i-1 : 0);
|
(input_size + (layer_diff * (i+1)
|
||||||
|
/ ((ssize_t)layer_count-1)))
|
||||||
|
: 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
return self;
|
return self;
|
||||||
|
@ -57,7 +61,7 @@ neural_randomize(Neural_Network *self) {
|
||||||
for (int i = 0; i < self->layer_count; i++) {
|
for (int i = 0; i < self->layer_count; i++) {
|
||||||
nl = self->layers[i];
|
nl = self->layers[i];
|
||||||
for (int j = 0; j < nl->layer_size; j++) {
|
for (int j = 0; j < nl->layer_size; j++) {
|
||||||
fread(nl->neurons[j].weights, sizeof(float), nl->layer_size_next, f);
|
fread(nl->neurons[j].synapses, sizeof(float), nl->layer_size_next, f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -76,7 +80,7 @@ neural_process(Neural_Network *self, float *input) {
|
||||||
for (int j = 0; j < nl->layer_size; j++) {
|
for (int j = 0; j < nl->layer_size; j++) {
|
||||||
// MATH GOES BRRRRRRRR
|
// MATH GOES BRRRRRRRR
|
||||||
dot_prod += nl->neurons[j].value
|
dot_prod += nl->neurons[j].value
|
||||||
* nl->neurons[j].weights[j];
|
* nl->neurons[j].synapses[j];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue