From aa5996d58e68edfbefe51061856aecd549dd09c4 Mon Sep 17 00:00:00 2001
From: Joseph Redmon <pjreddie@gmail.com>
Date: Tue, 13 Jan 2015 01:27:08 +0000
Subject: [PATCH] Faster
---
src/connected_layer.h | 26 +++++++++++++++++++++-----
1 files changed, 21 insertions(+), 5 deletions(-)
diff --git a/src/connected_layer.h b/src/connected_layer.h
index e9e461c..c3b8cb1 100644
--- a/src/connected_layer.h
+++ b/src/connected_layer.h
@@ -2,6 +2,7 @@
#define CONNECTED_LAYER_H
#include "activations.h"
+#include "opencl.h"
typedef struct{
float learning_rate;
@@ -17,25 +18,40 @@
float *weight_updates;
float *bias_updates;
- float *weight_adapt;
- float *bias_adapt;
-
- float *weight_momentum;
- float *bias_momentum;
+ float *weight_prev;
+ float *bias_prev;
float *output;
float *delta;
+ #ifdef GPU
+ cl_mem weights_cl;
+ cl_mem biases_cl;
+
+ cl_mem weight_updates_cl;
+ cl_mem bias_updates_cl;
+
+ cl_mem output_cl;
+ cl_mem delta_cl;
+ #endif
ACTIVATION activation;
} connected_layer;
+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, 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, cl_mem input);
+void backward_connected_layer_gpu(connected_layer layer, cl_mem input, cl_mem 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