| | #ifndef CAFFE_MVN_LAYER_HPP_ |
| | #define CAFFE_MVN_LAYER_HPP_ |
| |
|
| | #include <vector> |
| |
|
| | #include "caffe/blob.hpp" |
| | #include "caffe/layer.hpp" |
| | #include "caffe/proto/caffe.pb.h" |
| |
|
| | namespace caffe { |
| |
|
| | |
| | |
| | |
| | |
| | |
| | template <typename Dtype> |
| | class MVNLayer : public Layer<Dtype> { |
| | public: |
| | explicit MVNLayer(const LayerParameter& param) |
| | : Layer<Dtype>(param) {} |
| | virtual void Reshape(const vector<Blob<Dtype>*>& bottom, |
| | const vector<Blob<Dtype>*>& top); |
| |
|
| | virtual inline const char* type() const { return "MVN"; } |
| | virtual inline int ExactNumBottomBlobs() const { return 1; } |
| | virtual inline int ExactNumTopBlobs() const { return 1; } |
| |
|
| | protected: |
| | virtual void Forward_cpu(const vector<Blob<Dtype>*>& bottom, |
| | const vector<Blob<Dtype>*>& top); |
| | virtual void Forward_gpu(const vector<Blob<Dtype>*>& bottom, |
| | const vector<Blob<Dtype>*>& top); |
| | virtual void Backward_cpu(const vector<Blob<Dtype>*>& top, |
| | const vector<bool>& propagate_down, const vector<Blob<Dtype>*>& bottom); |
| | virtual void Backward_gpu(const vector<Blob<Dtype>*>& top, |
| | const vector<bool>& propagate_down, const vector<Blob<Dtype>*>& bottom); |
| |
|
| | Blob<Dtype> mean_, variance_, temp_; |
| |
|
| | |
| | Blob<Dtype> sum_multiplier_; |
| | Dtype eps_; |
| | }; |
| |
|
| | } |
| |
|
| | #endif |
| |
|