From af4e4f92dc9e5da160eb6c6870a7b38b863f1c6c Mon Sep 17 00:00:00 2001
From: Joseph Redmon <pjreddie@gmail.com>
Date: Tue, 28 Oct 2014 02:45:06 +0000
Subject: [PATCH] getting rid of sub_arrays, nvidia driver memory leak
---
src/connected_layer.h | 30 +++++++++++++++++++++++-------
1 files changed, 23 insertions(+), 7 deletions(-)
diff --git a/src/connected_layer.h b/src/connected_layer.h
index ff5a0ce..1e5b4a7 100644
--- a/src/connected_layer.h
+++ b/src/connected_layer.h
@@ -2,8 +2,13 @@
#define CONNECTED_LAYER_H
#include "activations.h"
+#include "opencl.h"
typedef struct{
+ float learning_rate;
+ float momentum;
+ float decay;
+
int batch;
int inputs;
int outputs;
@@ -16,24 +21,35 @@
float *weight_adapt;
float *bias_adapt;
- float *weight_momentum;
- float *bias_momentum;
-
float *output;
float *delta;
- float dropout;
+ #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;
-connected_layer *make_connected_layer(int batch, int inputs, int outputs, float dropout, ACTIVATION activation);
+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, int train);
+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, float step, float momentum, float decay);
+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);
+#endif
#endif
--
Gitblit v1.10.0