From 0f645836f193e75c4c3b718369e6fab15b5d19c5 Mon Sep 17 00:00:00 2001
From: Joseph Redmon <pjreddie@gmail.com>
Date: Wed, 11 Feb 2015 03:41:03 +0000
Subject: [PATCH] Detection is back, baby\!
---
src/connected_layer.h | 52 +++++++++++++++++++++++++++++++++++++---------------
1 files changed, 37 insertions(+), 15 deletions(-)
diff --git a/src/connected_layer.h b/src/connected_layer.h
index 86815cb..921f06f 100644
--- a/src/connected_layer.h
+++ b/src/connected_layer.h
@@ -4,31 +4,53 @@
#include "activations.h"
typedef struct{
+ float learning_rate;
+ float momentum;
+ float decay;
+
+ int batch;
int inputs;
int outputs;
- double *weights;
- double *biases;
+ float *weights;
+ float *biases;
- double *weight_updates;
- double *bias_updates;
+ float *weight_updates;
+ float *bias_updates;
- double *weight_momentum;
- double *bias_momentum;
+ float *weight_prev;
+ float *bias_prev;
- double *output;
- double *delta;
+ float *output;
+ float *delta;
+
+ #ifdef GPU
+ float * weights_gpu;
+ float * biases_gpu;
- double (* activation)();
- double (* gradient)();
+ float * weight_updates_gpu;
+ float * bias_updates_gpu;
+
+ float * output_gpu;
+ float * delta_gpu;
+ #endif
+ ACTIVATION activation;
+
} connected_layer;
-connected_layer *make_connected_layer(int inputs, int outputs, ACTIVATION activator);
+void secret_update_connected_layer(connected_layer *layer);
+connected_layer *make_connected_layer(int batch, int inputs, int outputs, ACTIVATION activation, float learning_rate, float momentum, float decay);
-void forward_connected_layer(connected_layer layer, double *input);
-void backward_connected_layer(connected_layer layer, double *input, double *delta);
-void learn_connected_layer(connected_layer layer, double *input);
-void update_connected_layer(connected_layer layer, double step, double momentum, double decay);
+void forward_connected_layer(connected_layer layer, float *input);
+void backward_connected_layer(connected_layer layer, float *input, float *delta);
+void update_connected_layer(connected_layer layer);
+#ifdef GPU
+void forward_connected_layer_gpu(connected_layer layer, float * input);
+void backward_connected_layer_gpu(connected_layer layer, float * input, float * delta);
+void update_connected_layer_gpu(connected_layer layer);
+void push_connected_layer(connected_layer layer);
+void pull_connected_layer(connected_layer layer);
+#endif
#endif
--
Gitblit v1.10.0