| | |
| | | #ifndef SOFTMAX_LAYER_H |
| | | #define SOFTMAX_LAYER_H |
| | | #include "layer.h" |
| | | #include "network.h" |
| | | |
| | | #include "opencl.h" |
| | | typedef layer softmax_layer; |
| | | |
| | | typedef struct { |
| | | int inputs; |
| | | int batch; |
| | | float *delta; |
| | | float *output; |
| | | float *jacobian; |
| | | #ifdef GPU |
| | | cl_mem delta_cl; |
| | | cl_mem output_cl; |
| | | #endif |
| | | } softmax_layer; |
| | | |
| | | softmax_layer *make_softmax_layer(int batch, int inputs); |
| | | void forward_softmax_layer(const softmax_layer layer, float *input); |
| | | void backward_softmax_layer(const softmax_layer layer, float *delta); |
| | | void softmax_array(float *input, int n, float temp, float *output); |
| | | softmax_layer make_softmax_layer(int batch, int inputs, int groups); |
| | | void forward_softmax_layer(const softmax_layer l, network_state state); |
| | | void backward_softmax_layer(const softmax_layer l, network_state state); |
| | | |
| | | #ifdef GPU |
| | | void pull_softmax_layer_output(const softmax_layer layer); |
| | | void forward_softmax_layer_gpu(const softmax_layer layer, cl_mem input); |
| | | void backward_softmax_layer_gpu(const softmax_layer layer, cl_mem delta); |
| | | void pull_softmax_layer_output(const softmax_layer l); |
| | | void forward_softmax_layer_gpu(const softmax_layer l, network_state state); |
| | | void backward_softmax_layer_gpu(const softmax_layer l, network_state state); |
| | | #endif |
| | | |
| | | #endif |