未验证 提交 8f7b020b 编写于 作者: W Wu Yi 提交者: GitHub

fix develop build issue (#10978)

* fix develop build issue

* fix google style

* cpplint check only fluid
上级 8075a11f
......@@ -19,7 +19,7 @@ BasedOnStyle: Google
IndentWidth: 2
TabWidth: 2
ContinuationIndentWidth: 4
AccessModifierOffset: -2 # The private/protected/public has no indent in class
AccessModifierOffset: -1 # The private/protected/public has no indent in class
Standard: Cpp11
AllowAllParametersOfDeclarationOnNextLine: true
BinPackParameters: false
......
......@@ -94,7 +94,7 @@ void UpdateCallback::apply(Parameter* p) {
}
class UpdateCallbackWrapper {
public:
public:
explicit UpdateCallbackWrapper(const UpdateCallback& callback)
: callback(const_cast<UpdateCallback&>(callback)) {}
......@@ -105,7 +105,7 @@ public:
delete p;
}
private:
private:
UpdateCallback& callback;
};
......
......@@ -59,9 +59,10 @@ class RangeError {};
/// Not support Error, such as access GPU memory directly, etc.
class UnsupportError : public std::runtime_error {
public:
UnsupportError() : std::runtime_error(" "){};
UnsupportError(const std::string& message) : std::runtime_error(message){};
public:
UnsupportError() : std::runtime_error(" ") {}
explicit UnsupportError(const std::string& message)
: std::runtime_error(message) {}
};
/// This type will map to python's list of float.
......@@ -105,7 +106,7 @@ class Matrix {
DISABLE_COPY(Matrix);
static Matrix* createByPaddleMatrixPtr(void* sharedPtr);
public:
public:
virtual ~Matrix();
/**
......@@ -231,7 +232,7 @@ public:
bool isGpu() const;
private:
private:
void* getSharedPtr() const;
MatrixPrivate* m;
......@@ -248,7 +249,7 @@ class Vector {
void* getSharedPtr();
public:
public:
~Vector();
/// Create Vector filled with zero.
......@@ -310,10 +311,10 @@ public:
/// __len__ in python
size_t getSize() const;
private:
private:
VectorPrivate* m;
private:
private:
friend class Parameter;
friend class ParameterOptimizer;
friend struct ParameterTraverseCallbackPrivate;
......@@ -325,7 +326,7 @@ class IVector {
DISABLE_COPY(IVector);
static IVector* createByPaddleVectorPtr(void* ptr);
public:
public:
/// Create IVector filled with zero
static IVector* createZero(size_t sz, bool useGpu = isUsingGpu());
......@@ -389,7 +390,7 @@ public:
/// This method will map to python __len__();
size_t getSize() const;
private:
private:
void* getSharedPtr() const;
friend class Arguments;
......@@ -400,11 +401,11 @@ struct ArgumentsPrivate;
/// The Arguments is actual a std::vector<paddle::Argument> in paddle.
class Arguments {
private:
private:
Arguments(); // Internal Create.
DISABLE_COPY(Arguments);
public:
public:
/**
* Create a arguments with size.
* Note that it can be zero.
......@@ -475,12 +476,12 @@ public:
float sum() const;
private:
private:
static Arguments* createByPaddleArgumentVector(void* ptr);
static Arguments* createByPaddleArgument(const void* ptr);
void* getInternalArgumentsPtr() const;
private:
private:
ArgumentsPrivate* m;
friend class Trainer;
friend class GradientMachine;
......@@ -507,7 +508,7 @@ class ParameterConfig {
static ParameterConfig* createParameterConfigFromParameterPtr(void* ptr);
void* getRawPtr();
public:
public:
~ParameterConfig();
/**
......@@ -515,10 +516,10 @@ public:
*/
std::string toProtoString() const;
private:
private:
ParameterConfigPrivate* m;
private:
private:
friend class Parameter;
friend class ParameterOptimizer;
friend struct ParameterTraverseCallbackPrivate;
......@@ -529,7 +530,7 @@ class OptimizationConfig {
DISABLE_COPY(OptimizationConfig);
OptimizationConfig();
public:
public:
static OptimizationConfig* createFromProtoString(const std::string& str);
~OptimizationConfig();
......@@ -538,7 +539,7 @@ public:
*/
std::string toProtoString();
private:
private:
OptimizationConfigPrivate* m;
friend class TrainerConfig;
......@@ -549,11 +550,11 @@ private:
struct ParameterPrivate;
class Parameter {
private:
private:
Parameter();
DISABLE_COPY(Parameter);
public:
public:
virtual ~Parameter();
/**
......@@ -580,11 +581,11 @@ public:
size_t getSize() const;
private:
private:
static Parameter* createFromRawPtr(void* ptr);
static Parameter* createFromSharedPtr(void* ptr);
private:
private:
ParameterPrivate* m;
friend class UpdateCallbackWrapper;
friend class GradientMachine;
......@@ -598,14 +599,14 @@ struct ModelConfigPrivate;
* It is used by GradientMachine.
*/
class ModelConfig {
private:
private:
ModelConfig();
DISABLE_COPY(ModelConfig);
public:
public:
virtual ~ModelConfig();
private:
private:
ModelConfigPrivate* m;
friend class TrainerConfig;
friend struct TrainerConfigPrivate;
......@@ -619,11 +620,11 @@ struct TrainerConfigPrivate;
* It is used by GradientMachine.
*/
class TrainerConfig {
private:
private:
TrainerConfig();
DISABLE_COPY(TrainerConfig);
public:
public:
virtual ~TrainerConfig();
static TrainerConfig* createFromTrainerConfigFile(
......@@ -634,7 +635,7 @@ public:
OptimizationConfig* getOptimizationConfig() const;
private:
private:
TrainerConfigPrivate* m;
friend class Trainer;
};
......@@ -654,7 +655,7 @@ private:
* @endcode
*/
class UpdateCallback {
public:
public:
virtual ~UpdateCallback();
virtual void apply(Parameter* p);
};
......@@ -664,14 +665,14 @@ class ParameterTraverseCallback {
DISABLE_COPY(ParameterTraverseCallback);
ParameterTraverseCallback();
public:
public:
~ParameterTraverseCallback();
void apply(const std::vector<Vector*>& vecs,
const ParameterConfig& config,
size_t sparseId);
private:
private:
ParameterTraverseCallbackPrivate* m;
friend class ParameterOptimizer;
};
......@@ -686,7 +687,7 @@ class ParameterOptimizer {
DISABLE_COPY(ParameterOptimizer);
ParameterOptimizer();
public:
public:
static ParameterOptimizer* create(OptimizationConfig* config);
~ParameterOptimizer();
......@@ -710,7 +711,7 @@ public:
ParameterTraverseCallback* needSpecialTraversal(
const ParameterConfig& config) const;
private:
private:
ParameterOptimizerPrivate* m;
};
......@@ -718,11 +719,11 @@ class SequenceGenerator;
class Evaluator;
struct GradientMachinePrivate;
class GradientMachine {
private:
private:
GradientMachine();
DISABLE_COPY(GradientMachine);
public:
public:
virtual ~GradientMachine();
/**
......@@ -817,7 +818,7 @@ public:
void eval(Evaluator* evaluator);
private:
private:
GradientMachinePrivate* m;
static GradientMachine* createFromPaddleModelPtr(
......@@ -833,10 +834,10 @@ private:
struct ParameterUpdaterPrivate;
class ParameterUpdater {
private:
private:
ParameterUpdater();
public:
public:
static ParameterUpdater* createLocalUpdater(OptimizationConfig* config);
static ParameterUpdater* createRemoteUpdater(OptimizationConfig* config,
int passCount,
......@@ -911,17 +912,17 @@ public:
*/
void catchUpWith();
private:
private:
ParameterUpdaterPrivate* m;
};
struct EvaluatorPrivate;
class Evaluator {
private:
private:
Evaluator();
DISABLE_COPY(Evaluator);
public:
public:
~Evaluator();
/**
......@@ -945,7 +946,7 @@ public:
double getValue(const std::string name) const;
private:
private:
EvaluatorPrivate* m;
friend class GradientMachine;
......@@ -953,13 +954,13 @@ private:
struct TrainerPrivate;
class Trainer {
private:
private:
TrainerPrivate* m;
Trainer();
Trainer(TrainerConfig* optConfig, GradientMachine* gm);
DISABLE_COPY(Trainer);
public:
public:
virtual ~Trainer();
/// Create A Trainer By TrainerConfig. using paddle command line.
......@@ -1002,7 +1003,7 @@ public:
/// the N-Best results generated from one input sequence.
class ISequenceResults {
public:
public:
virtual ~ISequenceResults();
/// Number of result.
......@@ -1026,7 +1027,7 @@ class SequenceGenerator {
DISABLE_COPY(SequenceGenerator);
SequenceGenerator();
public:
public:
virtual ~SequenceGenerator();
/**
......@@ -1044,10 +1045,10 @@ public:
void setMaxLength(size_t maxlength);
void setBeamSize(size_t beamSize);
private:
private:
static SequenceGenerator* createByGradientMachineSharedPtr(void* ptr);
friend class GradientMachine;
private:
private:
SequenceGeneratorPrivate* m;
};
......@@ -138,7 +138,7 @@ struct SequenceGeneratorPrivate {
maxLength(0UL),
feedback(__create_feedback__()) {}
private:
private:
static paddle::Argument __create_feedback__() {
paddle::Argument feedback;
feedback.ids = paddle::IVector::create(/* size= */ 1, FLAGS_use_gpu);
......@@ -157,7 +157,7 @@ SequenceGenerator::~SequenceGenerator() { delete m; }
class PathSequenceResults : public ISequenceResults {
// ISequenceResults interface
public:
public:
PathSequenceResults(const std::shared_ptr<std::vector<Path>>& path,
const std::shared_ptr<std::vector<std::string>>& dict)
: path_(path), dict_(dict) {}
......@@ -196,7 +196,7 @@ public:
}
}
private:
private:
std::shared_ptr<std::vector<Path>> path_;
std::shared_ptr<std::vector<std::string>> dict_;
};
......
......@@ -26,7 +26,7 @@ enum GradientMatchineCreateMode {
namespace paddle {
class MyNeuralNetwork : public NeuralNetwork {
public:
public:
MyNeuralNetwork(const std::string& name, NeuralNetwork* network)
: NeuralNetwork(name, network) {}
};
......
......@@ -50,7 +50,7 @@ struct PaddleTensor {
* TODO(Superjomn) Prepare another API for NLP-related usages.
*/
class PaddlePredictor {
public:
public:
struct Config;
PaddlePredictor() = default;
PaddlePredictor(const PaddlePredictor&) = delete;
......@@ -66,6 +66,7 @@ public:
// be thread-safe.
virtual std::unique_ptr<PaddlePredictor> Clone() = 0;
virtual bool InitShared() { return false; }
// Destroy the Predictor.
virtual ~PaddlePredictor() {}
......
......@@ -28,7 +28,7 @@ namespace {
// Timer for timer
class Timer {
public:
public:
double start;
double startu;
void tic() {
......@@ -135,8 +135,8 @@ bool PaddlePredictorImpl::Run(const std::vector<PaddleTensor> &inputs,
std::unique_ptr<PaddlePredictor> PaddlePredictorImpl::Clone() {
VLOG(3) << "Predictor::clone";
std::unique_ptr<PaddlePredictorImpl> cls(new PaddlePredictorImpl(config_));
if (!cls->InitShared(this)) {
std::unique_ptr<PaddlePredictor> cls(new PaddlePredictorImpl(config_));
if (!cls->InitShared()) {
LOG(ERROR) << "fail to call InitShared";
return nullptr;
}
......@@ -144,7 +144,7 @@ std::unique_ptr<PaddlePredictor> PaddlePredictorImpl::Clone() {
}
// TODO(panyx0718): Consider merge with Init()?
bool PaddlePredictorImpl::InitShared(PaddlePredictorImpl *cls) {
bool PaddlePredictorImpl::InitShared() {
VLOG(3) << "Predictor::init_shared";
// 1. Define place, executor, scope
if (this->config_.device >= 0) {
......
......@@ -41,7 +41,7 @@ struct VisConfig : public PaddlePredictor::Config {
* Do not use this, just a demo indicating how to customize a Predictor.
*/
class PaddlePredictorImpl : public PaddlePredictor {
public:
public:
explicit PaddlePredictorImpl(const VisConfig &config) : config_(config) {}
bool Init();
......@@ -53,8 +53,8 @@ public:
~PaddlePredictorImpl() override{};
private:
bool InitShared(PaddlePredictorImpl *cls);
private:
bool InitShared();
bool SetFeed(const std::vector<PaddleTensor> &input_datas,
std::vector<paddle::framework::LoDTensor> *feeds);
bool GetFetch(const std::vector<paddle::framework::LoDTensor> &fetchs,
......
......@@ -31,7 +31,7 @@ struct DemoConfig : public PaddlePredictor::Config {
* Do not use this, just a demo indicating how to customize a Predictor.
*/
class DemoPredictor : public PaddlePredictor {
public:
public:
explicit DemoPredictor(const DemoConfig &config) {
LOG(INFO) << "I get other_config " << config.other_config;
}
......
......@@ -31,7 +31,7 @@ namespace hppl {
*/
template <class T>
class Active {
public:
public:
typedef T (*forward)(T);
typedef T (*backward)(T, T);
};
......
......@@ -23,128 +23,128 @@ namespace unary {
template <class T>
class add_scale {
private:
private:
const T p;
public:
public:
INLINE add_scale(const T s) : p(s) {}
INLINE T operator()(const T a) const { return a + p; }
};
template <class T>
class sub_scale {
private:
private:
const T p;
public:
public:
INLINE sub_scale(const T s) : p(s) {}
INLINE T operator()(const T a) const { return a - p; }
};
template <class T>
class mul_scale {
private:
private:
const T p;
public:
public:
INLINE mul_scale(const T s) : p(s) {}
INLINE T operator()(const T a) const { return a * p; }
};
template <class T>
class div_scale {
private:
private:
const T p;
public:
public:
INLINE div_scale(const T s) : p(s) {}
INLINE T operator()(const T a) const { return a / p; }
};
template <class T>
class neg {
public:
public:
INLINE T operator()(const T a) const { return -a; }
};
template <class T>
class exp_op {
public:
public:
INLINE T operator()(const T a) const { return std::exp(a); }
};
template <class T>
class log_op {
public:
public:
INLINE T operator()(const T a) const { return std::log(a); }
};
template <class T>
class sqrt_op {
public:
public:
INLINE T operator()(const T a) const { return std::sqrt(a); }
};
template <class T>
class square {
public:
public:
INLINE T operator()(const T a) const { return a * a; }
};
template <class T>
class reciprocal {
public:
public:
INLINE T operator()(const T a) const { return T(1) / a; }
};
template <class T>
class abs {
public:
public:
INLINE T operator()(const T a) const { return a > 0 ? a : -a; }
};
template <class T>
class sign {
public:
public:
INLINE T operator()(const T a) const { return (a > 0) - (a < 0); }
};
template <class T>
class min {
private:
private:
const T p;
public:
public:
INLINE min(const T s) : p(s) {}
INLINE T operator()(const T a) const { return a > p ? p : a; }
};
template <class T>
class max {
private:
private:
const T p;
public:
public:
INLINE max(const T s) : p(s) {}
INLINE T operator()(const T a) const { return a < p ? p : a; }
};
template <class T>
class pow_op {
private:
private:
const T p;
public:
public:
INLINE pow_op(const T s) : p(s) {}
INLINE T operator()(const T a) const { return std::pow(a, p); }
};
template <class T>
class constant {
private:
private:
const T p;
public:
public:
INLINE constant(const T s) : p(s) {}
INLINE T operator()(int i) const { return p; }
INLINE T operator()(int i, int j) const { return p; }
......@@ -152,80 +152,80 @@ public:
template <class T>
class cmp_eq {
private:
private:
const T p;
public:
public:
INLINE cmp_eq(const T s) : p(s) {}
INLINE bool operator()(const T a) const { return a == p; }
};
template <class T>
class cmp_ne {
private:
private:
const T p;
public:
public:
INLINE cmp_ne(const T s) : p(s) {}
INLINE bool operator()(const T a) const { return a != p; }
};
template <class T>
class cmp_le {
private:
private:
const T p;
public:
public:
INLINE cmp_le(const T s) : p(s) {}
INLINE bool operator()(const T a) const { return a <= p; }
};
template <class T>
class cmp_lt {
private:
private:
const T p;
public:
public:
INLINE cmp_lt(const T s) : p(s) {}
INLINE bool operator()(const T a) const { return a < p; }
};
template <class T>
class cmp_ge {
private:
private:
const T p;
public:
public:
INLINE cmp_ge(const T s) : p(s) {}
INLINE bool operator()(const T a) const { return a >= p; }
};
template <class T>
class cmp_gt {
private:
private:
const T p;
public:
public:
INLINE cmp_gt(const T s) : p(s) {}
INLINE bool operator()(const T a) const { return a > p; }
};
template <class T>
class and_op {
private:
private:
const T p;
public:
public:
INLINE and_op(const T s) : p(s) {}
INLINE bool operator()(const T a) const { return a && p; }
};
template <class T>
class or_op {
private:
private:
const T p;
public:
public:
INLINE or_op(const T s) : p(s) {}
INLINE bool operator()(const T a) const { return a || p; }
};
......@@ -235,96 +235,96 @@ public:
namespace binary {
template <class T>
class add {
public:
public:
INLINE T operator()(const T a, const T b) const { return a + b; }
};
template <class T>
class add_scale {
private:
private:
const T p1;
const T p2;
public:
public:
INLINE add_scale(const T s1, const T s2) : p1(s1), p2(s2) {}
INLINE T operator()(const T a, const T b) const { return p1 * a + p2 * b; }
};
template <class T>
class sub {
public:
public:
INLINE T operator()(const T a, const T b) const { return a - b; }
};
template <class T>
class mul {
public:
public:
INLINE T operator()(const T a, const T b) const { return a * b; }
};
template <class T>
class div {
public:
public:
INLINE T operator()(const T a, const T b) const { return a / b; }
};
template <class T>
class cmp_eq {
public:
public:
INLINE bool operator()(const T a, const T b) const { return a == b; }
};
template <class T>
class cmp_ne {
public:
public:
INLINE bool operator()(const T a, const T b) const { return a != b; }
};
template <class T>
class cmp_le {
public:
public:
INLINE bool operator()(const T a, const T b) const { return a <= b; }
};
template <class T>
class cmp_lt {
public:
public:
INLINE bool operator()(const T a, const T b) const { return a < b; }
};
template <class T>
class cmp_ge {
public:
public:
INLINE bool operator()(const T a, const T b) const { return a >= b; }
};
template <class T>
class cmp_gt {
public:
public:
INLINE bool operator()(const T a, const T b) const { return a > b; }
};
template <class T>
class and_op {
public:
public:
INLINE bool operator()(const T a, const T b) const { return a && b; }
};
template <class T>
class or_op {
public:
public:
INLINE bool operator()(const T a, const T b) const { return a || b; }
};
template <class T>
class min {
public:
public:
INLINE T operator()(const T a, const T b) const { return a > b ? b : a; }
};
template <class T>
class max {
public:
public:
INLINE T operator()(const T a, const T b) const { return a < b ? b : a; }
};
......@@ -332,7 +332,7 @@ public:
#ifndef PADDLE_TYPE_DOUBLE
template <>
class add<__m128> {
public:
public:
INLINE __m128 operator()(const __m128 a, const __m128 b) const {
return _mm_add_ps(a, b);
}
......@@ -340,11 +340,11 @@ public:
template <>
class add_scale<__m128> {
private:
private:
const __m128 p1;
const __m128 p2;
public:
public:
INLINE add_scale(const __m128 s1, const __m128 s2) : p1(s1), p2(s2) {}
INLINE __m128 operator()(const __m128 a, const __m128 b) const {
return _mm_add_ps(_mm_mul_ps(p1, a), _mm_mul_ps(p2, b));
......@@ -353,7 +353,7 @@ public:
template <>
class sub<__m128> {
public:
public:
INLINE __m128 operator()(const __m128 a, const __m128 b) const {
return _mm_sub_ps(a, b);
}
......@@ -361,7 +361,7 @@ public:
template <>
class mul<__m128> {
public:
public:
INLINE __m128 operator()(const __m128 a, const __m128 b) const {
return _mm_mul_ps(a, b);
}
......@@ -369,7 +369,7 @@ public:
template <>
class div<__m128> {
public:
public:
INLINE __m128 operator()(const __m128 a, const __m128 b) const {
return _mm_div_ps(a, b);
}
......@@ -377,7 +377,7 @@ public:
template <>
class min<__m128> {
public:
public:
INLINE __m128 operator()(const __m128 a, const __m128 b) const {
return _mm_min_ps(a, b);
}
......@@ -385,7 +385,7 @@ public:
template <>
class max<__m128> {
public:
public:
INLINE __m128 operator()(const __m128 a, const __m128 b) const {
return _mm_max_ps(a, b);
}
......@@ -393,7 +393,7 @@ public:
#else
template <>
class add<__m128d> {
public:
public:
INLINE __m128d operator()(const __m128d a, const __m128d b) const {
return _mm_add_pd(a, b);
}
......@@ -401,11 +401,11 @@ public:
template <>
class add_scale<__m128d> {
private:
private:
const __m128d p1;
const __m128d p2;
public:
public:
INLINE add_scale(const __m128d s1, const __m128d s2) : p1(s1), p2(s2) {}
INLINE __m128d operator()(const __m128d a, const __m128d b) const {
return _mm_add_pd(_mm_mul_pd(p1, a), _mm_mul_pd(p2, b));
......@@ -414,7 +414,7 @@ public:
template <>
class sub<__m128d> {
public:
public:
INLINE __m128d operator()(const __m128d a, const __m128d b) const {
return _mm_sub_pd(a, b);
}
......@@ -422,7 +422,7 @@ public:
template <>
class mul<__m128d> {
public:
public:
INLINE __m128d operator()(const __m128d a, const __m128d b) const {
return _mm_mul_pd(a, b);
}
......@@ -430,7 +430,7 @@ public:
template <>
class div<__m128d> {
public:
public:
INLINE __m128d operator()(const __m128d a, const __m128d b) const {
return _mm_div_pd(a, b);
}
......@@ -438,7 +438,7 @@ public:
template <>
class min<__m128d> {
public:
public:
INLINE __m128d operator()(const __m128d a, const __m128d b) const {
return _mm_min_pd(a, b);
}
......@@ -446,7 +446,7 @@ public:
template <>
class max<__m128d> {
public:
public:
INLINE __m128d operator()(const __m128d a, const __m128d b) const {
return _mm_max_pd(a, b);
}
......@@ -458,7 +458,7 @@ public:
#ifndef PADDLE_TYPE_DOUBLE
template <>
class add<float32x4_t> {
public:
public:
INLINE float32x4_t operator()(const float32x4_t a,
const float32x4_t b) const {
return vaddq_f32(a, b);
......@@ -467,11 +467,11 @@ public:
template <>
class add_scale<float32x4_t> {
private:
private:
const float32x4_t p1;
const float32x4_t p2;
public:
public:
INLINE add_scale(const float32x4_t s1, const float32x4_t s2)
: p1(s1), p2(s2) {}
INLINE float32x4_t operator()(const float32x4_t a,
......@@ -482,7 +482,7 @@ public:
template <>
class sub<float32x4_t> {
public:
public:
INLINE float32x4_t operator()(const float32x4_t a,
const float32x4_t b) const {
return vsubq_f32(a, b);
......@@ -491,7 +491,7 @@ public:
template <>
class mul<float32x4_t> {
public:
public:
INLINE float32x4_t operator()(const float32x4_t a,
const float32x4_t b) const {
return vmulq_f32(a, b);
......@@ -500,7 +500,7 @@ public:
template <>
class div<float32x4_t> {
public:
public:
INLINE float32x4_t operator()(const float32x4_t a,
const float32x4_t b) const {
float32x4_t tmp = vrecpeq_f32(b);
......@@ -510,7 +510,7 @@ public:
template <>
class min<float32x4_t> {
public:
public:
INLINE float32x4_t operator()(const float32x4_t a,
const float32x4_t b) const {
return vminq_f32(a, b);
......@@ -519,7 +519,7 @@ public:
template <>
class max<float32x4_t> {
public:
public:
INLINE float32x4_t operator()(const float32x4_t a,
const float32x4_t b) const {
return vmaxq_f32(a, b);
......
......@@ -30,7 +30,7 @@ bool hl_lstm_sequence_parallel(int frameSize) {
}
class frameValue {
public:
public:
real *value_;
__device__ frameValue(real *value) : value_(value) {}
template <int reversed, int frameSize>
......
......@@ -33,7 +33,7 @@ namespace paddle {
* \param outputs[0] Image data of NCHW format.
*/
class BlockExpandFunction : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {
// function arguments
strides_ = config.get<std::vector<size_t>>("strides");
......@@ -81,7 +81,7 @@ public:
(size_t)blockW()});
}
protected:
protected:
std::vector<size_t> strides_;
std::vector<size_t> paddings_;
std::vector<size_t> blocks_;
......@@ -101,7 +101,7 @@ protected:
template <DeviceType Device>
class BlockExpandForward : public BlockExpandFunction {
public:
public:
void init(const FuncConfig& config) override {
BlockExpandFunction::init(config);
}
......@@ -149,7 +149,7 @@ public:
template <DeviceType Device>
class BlockExpandBackward : public BlockExpandFunction {
public:
public:
void init(const FuncConfig& config) override {
BlockExpandFunction::init(config);
}
......
......@@ -63,12 +63,12 @@ enum ArgType {
ADD_TO = 2,
};
class BufferArg {
public:
public:
void setArgType(ArgType argType) { argType_ = argType; }
ArgType getArgType() const { return argType_; }
public:
public:
BufferArg(ValueType valueType,
const TensorShape& shape,
ArgType argType = UNSPECIFIED)
......@@ -169,7 +169,7 @@ public:
const SequenceArg& sequence() const;
const SparseMatrixArg& sparse() const;
protected:
protected:
void* buf_;
ValueType valueType_;
TensorShape shape_;
......@@ -185,7 +185,7 @@ protected:
// valueType_ = int32
// if a < b then value_.buf_[a] < value_.buf_[b]
class SequenceIdArg : public BufferArg {
public:
public:
SequenceIdArg(const TensorShape& shape, ArgType argType = UNSPECIFIED)
: BufferArg(VALUE_TYPE_INT32, shape, argType) {
bufferType_ = TENSOR_SEQUENCE_ID;
......@@ -212,7 +212,7 @@ public:
size_t numSeqs() const { return numSeqs_; }
private:
private:
size_t numSeqs_;
};
......@@ -222,7 +222,7 @@ private:
// SequenceArg can be used to represent sequences that contain multiple
// unequal lengths.
class SequenceArg : public BufferArg {
public:
public:
SequenceArg(ValueType valueType,
const TensorShape& shape,
ArgType argType = UNSPECIFIED)
......@@ -255,7 +255,7 @@ public:
SequenceIdArg& getSequenceId() { return startPositions_; }
const SequenceIdArg& getSequenceId() const { return startPositions_; }
private:
private:
SequenceIdArg startPositions_;
};
......@@ -263,7 +263,7 @@ private:
// valueType_ == float or double
// shape_.ndims() == 2
class SparseMatrixArg : public BufferArg {
public:
public:
SparseMatrixArg(void* buf,
ValueType valueType,
const TensorShape& shape,
......@@ -353,7 +353,7 @@ public:
SparseDataType dataType() const { return type_; }
private:
private:
BufferArg row_;
BufferArg col_;
size_t nnz_;
......
......@@ -100,7 +100,7 @@ void ContextProjectionForward<DEVICE_TYPE_CPU>(CpuMatrix& out_mat,
*/
template <DeviceType Device>
class ContextProjectionForwardFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {
context_length_ = config.get<size_t>("context_length");
context_start_ = config.get<int>("context_start");
......@@ -146,7 +146,7 @@ public:
begin_pad_);
}
private:
private:
size_t context_length_;
int context_start_;
size_t begin_pad_;
......@@ -223,7 +223,7 @@ void ContextProjectionBackward<DEVICE_TYPE_CPU>(const CpuMatrix& out_grad_mat,
*/
template <DeviceType Device>
class ContextProjectionBackwardFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {
context_length_ = config.get<size_t>("context_length");
context_start_ = config.get<int>("context_start");
......@@ -278,7 +278,7 @@ public:
total_pad_);
}
private:
private:
size_t context_length_;
int context_start_;
size_t begin_pad_;
......@@ -299,7 +299,7 @@ private:
*/
template <DeviceType Device>
class ContextProjectionBackwardDataFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {
context_length_ = config.get<size_t>("context_length");
context_start_ = config.get<int>("context_start");
......@@ -331,7 +331,7 @@ public:
out_grad_mat, in_grad_mat, seq_vec, context_length_, context_start_);
}
private:
private:
size_t context_length_;
int context_start_;
};
......@@ -348,7 +348,7 @@ private:
*/
template <DeviceType Device>
class ContextProjectionBackwardWeightFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {
context_length_ = config.get<size_t>("context_length");
context_start_ = config.get<int>("context_start");
......@@ -382,7 +382,7 @@ public:
begin_pad_);
}
private:
private:
size_t context_length_;
int context_start_;
size_t begin_pad_;
......
......@@ -56,7 +56,7 @@ namespace paddle {
* H and W is height and width of filter.
*/
class ConvFunctionBase : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {
// function arguments
strides_ = config.get<std::vector<size_t>>("strides");
......@@ -101,7 +101,7 @@ public:
}
}
protected:
protected:
size_t getFilterHeight(const TensorShape& filter) const {
return filter[filter.ndims() - 2];
}
......
......@@ -97,7 +97,7 @@ class CosSimForwardFunc : public FunctionBase {
CosSimForward<Device>(out_mat, in1_mat, in2_mat, scale_);
}
private:
private:
real scale_;
};
......@@ -227,7 +227,7 @@ class CosSimBackwardFunc : public FunctionBase {
out_grad, out_val, in1_val, in2_val, in1_grad, in2_grad, scale_);
}
private:
private:
real scale_;
};
......
......@@ -112,7 +112,7 @@ void CropGrad<DEVICE_TYPE_CPU>(const real* inGrad,
*/
template <DeviceType Device>
class CropFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override { conf_ = config; }
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......@@ -130,7 +130,7 @@ public:
conf_);
}
private:
private:
FuncConfig conf_;
};
......@@ -145,7 +145,7 @@ private:
template <DeviceType Device>
class CropGradFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override { conf_ = config; }
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......@@ -163,7 +163,7 @@ public:
conf_);
}
private:
private:
FuncConfig conf_;
};
......
......@@ -160,7 +160,7 @@ void CrossMapNormalGrad<DEVICE_TYPE_CPU>(real* inputsGrad,
*/
template <DeviceType Device>
class CrossMapNormalFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {
// function arguments
size_ = config.get<size_t>("size");
......@@ -220,7 +220,7 @@ public:
return ops;
}
private:
private:
size_t size_;
real scale_;
real pow_;
......@@ -260,7 +260,7 @@ private:
*/
template <DeviceType Device>
class CrossMapNormalGradFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {
// function arguments
size_ = config.get<size_t>("size");
......@@ -328,7 +328,7 @@ public:
return ops;
}
private:
private:
size_t size_;
real scale_;
real pow_;
......
......@@ -19,7 +19,7 @@ namespace paddle {
template <class T>
class DepthwiseConvFunctor<DEVICE_TYPE_CPU, T> {
public:
public:
void operator()(const T* inputData,
const T* filterData,
int batchSize,
......@@ -43,7 +43,7 @@ public:
template <class T>
class DepthwiseConvGradInputFunctor<DEVICE_TYPE_CPU, T> {
public:
public:
void operator()(const T* outputGrad,
const T* filterData,
int batchSize,
......@@ -66,7 +66,7 @@ public:
template <class T>
class DepthwiseConvGradFilterFunctor<DEVICE_TYPE_CPU, T> {
public:
public:
void operator()(const T* outputGrad,
const T* inputData,
int batchSize,
......@@ -93,7 +93,7 @@ public:
*/
template <DeviceType Device>
class DepthwiseConvFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......@@ -156,7 +156,7 @@ public:
*/
template <DeviceType Device>
class DepthwiseConvGradInputFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......@@ -220,7 +220,7 @@ public:
*/
template <DeviceType Device>
class DepthwiseConvGradFilterFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......
......@@ -44,7 +44,7 @@ namespace paddle {
*/
template <DeviceType Device, class T>
class DepthwiseConvFunctor {
public:
public:
void operator()(const T* inputData,
const T* filterData,
int batchSize,
......@@ -89,7 +89,7 @@ public:
*/
template <DeviceType Device, class T>
class DepthwiseConvGradInputFunctor {
public:
public:
void operator()(const T* outputGrad,
const T* filterData,
int batchSize,
......@@ -135,7 +135,7 @@ public:
*/
template <DeviceType Device, class T>
class DepthwiseConvGradFilterFunctor {
public:
public:
void operator()(const T* outputGrad,
const T* inputData,
int batchSize,
......
......@@ -199,7 +199,7 @@ __global__ void ConvolutionDepthwiseFilterBackward(const int num_i,
template <class T>
class DepthwiseConvFunctor<DEVICE_TYPE_GPU, T> {
public:
public:
void operator()(const T* inputData,
const T* filterData,
int batchSize,
......@@ -249,7 +249,7 @@ public:
template <class T>
class DepthwiseConvGradInputFunctor<DEVICE_TYPE_GPU, T> {
public:
public:
void operator()(const T* outputGrad,
const T* filterData,
int batchSize,
......@@ -300,7 +300,7 @@ public:
template <class T>
class DepthwiseConvGradFilterFunctor<DEVICE_TYPE_GPU, T> {
public:
public:
void operator()(const T* outputGrad,
const T* inputData,
int batchSize,
......
......@@ -46,7 +46,7 @@ int GetCpuCount() { return 1; }
#endif
class EigenDeviceWarpper {
public: // NOLINT
public: // NOLINT
#if EIGEN_USE_THREADS
static Eigen::ThreadPoolDevice* device() {
const int num_cpus = GetCpuCount();
......
......@@ -29,7 +29,7 @@ namespace paddle {
* The argument type of Function::init.
*/
class FuncConfig {
public:
public:
template <typename T>
T get(const std::string& key, Error* err = nullptr) const {
try {
......@@ -59,7 +59,7 @@ public:
return *this;
}
protected:
protected:
mutable std::unordered_map<std::string, any> valueMap_;
};
......@@ -77,7 +77,7 @@ protected:
* in the BufferArgs life time.
*/
class BufferArgs {
public:
public:
BufferArgs() {}
~BufferArgs() {
......@@ -137,7 +137,7 @@ public:
void addArg(SparseMatrixArg& arg) { args_.push_back(&arg); }
private:
private:
std::vector<BufferArg*> args_;
// The BufferArg object is constructed and freed by BufferArgs.
std::vector<BufferArg*> _args_;
......@@ -163,7 +163,7 @@ private:
* If Function has more than one output, each output can have different modes.
*/
class FunctionBase {
public:
public:
virtual ~FunctionBase() {}
virtual void init(const FuncConfig& config) {}
......@@ -192,7 +192,7 @@ public:
static ClassRegistrar<FunctionBase> funcRegistrar_;
protected:
protected:
// numInputs_ and numOutputs_ represents the maximum
// input and output supported by Function.
// Some functions are optimized for input and output,
......
......@@ -39,7 +39,7 @@ struct Allocator<DEVICE_TYPE_GPU> {
// Copy argument1 to argument2
template <DeviceType DType1, DeviceType DType2>
class CopyArgument {
public:
public:
void operator()(const BufferArg& arg1, BufferArg& arg2) {
CHECK_EQ(arg1.valueType(), arg2.valueType());
CHECK_LE(arg1.shape().getElements(), arg2.shape().getElements());
......@@ -95,7 +95,7 @@ public:
*/
template <DeviceType DType1, DeviceType DType2>
class Compare2Function {
public:
public:
typedef typename test::Allocator<DType1>::type Allocator1;
typedef typename test::Allocator<DType2>::type Allocator2;
typedef typename Tensor<real, DType1>::Vector Vector1;
......@@ -305,7 +305,7 @@ public:
std::shared_ptr<FunctionBase> getFunction2() const { return function2_; }
protected:
protected:
// only init cpu argument, gpu argument copy from cpu argument.
void initArg(BufferArg& arg) {
Vector1 vector(arg.shape().getElements(), (real*)arg.data());
......@@ -381,7 +381,7 @@ protected:
}
}
protected:
protected:
std::shared_ptr<FunctionBase> function1_;
std::shared_ptr<FunctionBase> function2_;
std::vector<std::shared_ptr<Allocator1>> func1Memory_;
......@@ -400,7 +400,7 @@ protected:
class CpuGpuFuncCompare
: public Compare2Function<DEVICE_TYPE_CPU, DEVICE_TYPE_GPU> {
public:
public:
CpuGpuFuncCompare(const std::string& name, const FuncConfig& config)
: Compare2Function(name + "-CPU", name + "-GPU", config) {}
......
......@@ -24,7 +24,7 @@ namespace paddle {
*/
template <DeviceType Device>
class GemmConvFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......@@ -136,7 +136,7 @@ public:
*/
template <DeviceType Device>
class GemmConvMobileFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......@@ -297,7 +297,7 @@ public:
*/
template <DeviceType Device>
class GemmConvGradInputFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......@@ -404,7 +404,7 @@ public:
*/
template <DeviceType Device>
class GemmConvGradFilterFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......
......@@ -70,7 +70,7 @@ enum ColFormat { kCFO = 0, kOCF = 1 };
*/
template <ColFormat Format, DeviceType Device, class T>
class Im2ColFunctor {
public:
public:
void operator()(const T* imData,
const TensorShape& imShape,
T* colData,
......@@ -85,7 +85,7 @@ public:
template <ColFormat Format, DeviceType Device, class T>
class Col2ImFunctor {
public:
public:
void operator()(T* imData,
const TensorShape& imShape,
const T* colData,
......@@ -100,7 +100,7 @@ public:
template <class T>
class Im2ColMobileFunctor {
public:
public:
void operator()(const T* imData,
const TensorShape& imShape,
T* colData,
......
......@@ -23,7 +23,7 @@ namespace paddle {
*/
template <class T>
class Im2ColFunctor<kCFO, DEVICE_TYPE_CPU, T> {
public:
public:
void operator()(const T* imData,
const TensorShape& imShape,
T* colData,
......@@ -75,7 +75,7 @@ public:
*/
template <class T>
class Col2ImFunctor<kCFO, DEVICE_TYPE_CPU, T> {
public:
public:
void operator()(T* imData,
const TensorShape& imShape,
const T* colData,
......@@ -130,7 +130,7 @@ template class Col2ImFunctor<kCFO, DEVICE_TYPE_CPU, double>;
*/
template <class T>
class Im2ColFunctor<kOCF, DEVICE_TYPE_CPU, T> {
public:
public:
void operator()(const T* imData,
const TensorShape& imShape,
T* colData,
......@@ -188,7 +188,7 @@ public:
*/
template <class T>
class Col2ImFunctor<kOCF, DEVICE_TYPE_CPU, T> {
public:
public:
void operator()(T* imData,
const TensorShape& imShape,
const T* colData,
......
......@@ -71,7 +71,7 @@ __global__ void im2col(const T* data_im,
*/
template <class T>
class Im2ColFunctor<kCFO, DEVICE_TYPE_GPU, T> {
public:
public:
void operator()(const T* imData,
const TensorShape& imShape,
T* colData,
......@@ -184,7 +184,7 @@ __global__ void col2im(size_t n,
*/
template <class T>
class Col2ImFunctor<kCFO, DEVICE_TYPE_GPU, T> {
public:
public:
void operator()(T* imData,
const TensorShape& imShape,
const T* colData,
......@@ -292,7 +292,7 @@ __global__ void im2colOCF(const T* imData,
*/
template <class T>
class Im2ColFunctor<kOCF, DEVICE_TYPE_GPU, T> {
public:
public:
void operator()(const T* imData,
const TensorShape& imShape,
T* colData,
......@@ -399,7 +399,7 @@ __global__ void col2imOCF(T* imData,
*/
template <class T>
class Col2ImFunctor<kOCF, DEVICE_TYPE_GPU, T> {
public:
public:
void operator()(T* imData,
const TensorShape& imShape,
const T* colData,
......
......@@ -240,7 +240,7 @@ void MulOp<DEVICE_TYPE_CPU>(CpuMatrix& out,
*/
template <DeviceType Device>
class MulFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {
aTrans_ = config.get<bool>("aTrans");
bTrans_ = config.get<bool>("bTrans");
......@@ -335,7 +335,7 @@ public:
}
}
private:
private:
bool aTrans_;
bool bTrans_;
};
......
......@@ -24,7 +24,7 @@ namespace paddle {
*/
template <class T>
class NaiveConvFunctor {
public:
public:
void operator()(const T* inputData,
size_t batchSize,
size_t inputChannels,
......@@ -85,7 +85,7 @@ public:
template <DeviceType Device>
class NaiveConvFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......
......@@ -132,7 +132,7 @@ static inline PadConf castToPadConf(const FuncConfig& conf) {
template <DeviceType Device>
class PadFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override { pad_ = castToPadConf(config); }
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......@@ -157,7 +157,7 @@ public:
pad_);
}
private:
private:
PadConf pad_;
};
......@@ -173,7 +173,7 @@ private:
template <DeviceType Device>
class PadGradFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override { pad_ = castToPadConf(config); }
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......@@ -201,7 +201,7 @@ public:
pad_);
}
private:
private:
PadConf pad_;
};
......
......@@ -129,7 +129,7 @@ void RowConvGrad<DEVICE_TYPE_CPU>(const CpuMatrix& outG,
template <DeviceType Device>
class RowConvFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {}
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......@@ -176,7 +176,7 @@ public:
template <DeviceType Device>
class RowConvGradFunc : public FunctionBase {
// TODO(qingqing): split into RowConvDataFunc and RowConvWeightFunc
public:
public:
void init(const FuncConfig& config) override {}
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......
......@@ -92,7 +92,7 @@ void ScaleSubRegionGrad<DEVICE_TYPE_CPU>(const real* inGrad,
*/
template <DeviceType Device>
class ScaleSubRegionFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override { conf_ = config; }
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......@@ -109,7 +109,7 @@ public:
conf_);
}
private:
private:
FuncConfig conf_;
};
......@@ -124,7 +124,7 @@ private:
template <DeviceType Device>
class ScaleSubRegionGradFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override { conf_ = config; }
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......@@ -141,7 +141,7 @@ public:
conf_);
}
private:
private:
FuncConfig conf_;
};
......
......@@ -75,7 +75,7 @@ void NHWC2NCHW<DEVICE_TYPE_CPU>(real* outputs,
*/
template <DeviceType Device>
class NCHW2NHWCFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {}
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......@@ -108,7 +108,7 @@ public:
*/
template <DeviceType Device>
class NHWC2NCHWFunc : public FunctionBase {
public:
public:
void init(const FuncConfig& config) override {}
void calc(const BufferArgs& inputs, const BufferArgs& outputs) override {
......
......@@ -22,7 +22,7 @@ namespace paddle {
* TensorShape used to represent shape of normal tensor.
*/
class TensorShape {
public:
public:
TensorShape() : ndims_(0), nelements_(0) { initDims(0); }
TensorShape(size_t ndims) : ndims_(ndims), nelements_(1) { initDims(ndims); };
......@@ -80,7 +80,7 @@ public:
bool operator!=(const TensorShape& t) const { return !(*this == t); }
private:
private:
// compute number of elements
void numElements() {
nelements_ = 1;
......
......@@ -21,7 +21,7 @@ namespace paddle {
template <DeviceType Device>
class NeonDepthwiseConvFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......
......@@ -21,7 +21,7 @@ namespace paddle {
template <DeviceType Device>
class NeonDepthwiseConvTransposeFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
}
......
......@@ -46,7 +46,7 @@ nnp_convolution_algorithm get_nnp_convolution_algorithm(
template <DeviceType Device>
class NNPACKConvFunction : public ConvFunctionBase {
public:
public:
void init(const FuncConfig& config) override {
ConvFunctionBase::init(config);
algorithm_ = get_nnp_convolution_algorithm(config.get<std::string>("algo"));
......@@ -231,7 +231,7 @@ public:
}
}
private:
private:
nnp_convolution_algorithm algorithm_;
nnp_convolution_transform_strategy transform_strategy_;
void* workspaceBuffer_;
......
......@@ -44,10 +44,10 @@ static ClassRegistrar<ActivationFunction> gActivationRegistrar;
*/
#define BEGIN_DEFINE_ACTIVATION(ACTIVATION_NAME) \
class ACTIVATION_CLASS_NAME(ACTIVATION_NAME) : public ActivationFunction { \
private: \
private: \
static const std::string name; \
\
public: \
public: \
const std::string& getName() const { return name; }
/**
* @def END_DEFINE_ACTIVATION
......@@ -70,7 +70,7 @@ static ClassRegistrar<ActivationFunction> gActivationRegistrar;
* Do nothing when forward/backward.
*/
class IdentityActivation : public ActivationFunction {
public:
public:
static const std::string name;
Error __must_check forward(Argument& act) {
(void)act;
......
......@@ -31,7 +31,7 @@ struct Argument;
*
*/
class ActivationFunction {
public:
public:
static ActivationFunction* create(const std::string& type);
static std::vector<std::string> getAllRegisteredTypes();
......
......@@ -35,10 +35,10 @@ static ClassRegistrar<ActivationFunction> gMKLDNNActivationRegistrar;
* @def END_MKLDNN_ACTIVATION
*/
#define END_MKLDNN_ACTIVATION(ACT_TYPE) \
private: \
private: \
static const std::string name; \
\
public: \
public: \
const std::string& getName() const { return name; } \
} \
; \
......@@ -63,11 +63,11 @@ public: \
#define DEFINE_MKLDNN_ELTWISE_ACTIVATION( \
ACT_TYPE, BASE_CLASS, ALPHA, BWD_ALPHA) \
BEGIN_MKLDNN_ACTIVATION(ACT_TYPE, BASE_CLASS) \
private: \
private: \
static const float alpha; \
static const float bwdAlpha; \
\
public: \
public: \
float getAlpha() const { return alpha; } \
float getBwdAlpha() const { return bwdAlpha; } \
END_MKLDNN_ACTIVATION(ACT_TYPE) \
......
......@@ -27,7 +27,7 @@ namespace paddle {
* including mkldnn_relu, mkldnn_elu, mkldnn_tanh, mkldnn_softmax
*/
class MKLDNNActivation : public ActivationFunction {
protected:
protected:
// input value element count
size_t cnt_;
// should not merge the resetBwd into resetFwd,
......@@ -43,7 +43,7 @@ protected:
std::vector<mkldnn::primitive> pipelineFwd_;
std::vector<mkldnn::primitive> pipelineBwd_;
public:
public:
MKLDNNActivation() : cnt_(0), needResetBwd_(true) {}
~MKLDNNActivation() {}
static ActivationFunction* create(const std::string& type);
......@@ -72,7 +72,7 @@ class MKLDNNEltwiseActivation : public MKLDNNActivation {
typedef mkldnn::eltwise_backward eltwise_bwd;
typedef mkldnn::algorithm algorithm;
protected:
protected:
// save the forward primitive desc, which can be used backward
std::shared_ptr<eltwise_fwd::primitive_desc> fwdPD_;
// eltwise_bwd need src input value
......@@ -80,7 +80,7 @@ protected:
// use for copy data
std::shared_ptr<mkldnn::reorder> copyInVal_;
public:
public:
MKLDNNEltwiseActivation() {}
~MKLDNNEltwiseActivation() {}
virtual const std::string& getName() const = 0;
......@@ -102,12 +102,12 @@ public:
class MKLDNNSoftmaxActivation : public MKLDNNActivation {
typedef mkldnn::softmax_forward softmax_fwd;
private:
private:
// for backward
MatrixPtr sftMaxSum_;
MatrixPtr sftMaxDot_;
public:
public:
MKLDNNSoftmaxActivation() {}
~MKLDNNSoftmaxActivation() {}
virtual const std::string& getName() const = 0;
......
......@@ -71,7 +71,7 @@ typedef std::shared_ptr<BufferBatch> BufferBatchPtr;
* @brief Data for batch training a neural network
*/
class DataBatch {
public:
public:
DataBatch() : size_(0) { data_.clear(); }
/**
* @brief Get batch size
......@@ -181,7 +181,7 @@ public:
}
}
protected:
protected:
/**
* @brief batch size
*/
......@@ -194,7 +194,7 @@ protected:
};
class BufferBatch {
public:
public:
BufferBatch() {
hlStream_ = HPPL_STREAM_DEFAULT;
hlEvent_ = NULL;
......@@ -235,7 +235,7 @@ public:
void swap(BufferBatch* bufBatch);
void clone(DataBatch* srcBatch, bool useGpu);
protected:
protected:
DataBatch* batchData_;
hl_stream_t hlStream_;
hl_event_t hlEvent_;
......@@ -247,7 +247,7 @@ typedef std::shared_ptr<DataProvider> DataProviderPtr;
typedef Queue<BufferBatch*> BufferBatchQueue;
class DoubleBuffer {
public:
public:
DoubleBuffer(DataProvider* dataPool, bool useGpu, int64_t batchSize = 0);
virtual ~DoubleBuffer();
void removeOneBatch(DataBatch* dataBatch);
......@@ -267,7 +267,7 @@ public:
void setPending(bool pending) { pending_ = pending; }
protected:
protected:
virtual void asyncLoadBatch();
void insertOneBatch(DataBatch* batch);
......@@ -290,7 +290,7 @@ protected:
* one is for input, one is for label.
*/
class DataProvider {
public:
public:
static ClassRegistrar<DataProvider, DataConfig, ModelConfig, bool> registrar_;
static DataProvider* create(const DataConfig& config,
const ModelConfig& modelConfig,
......@@ -359,7 +359,7 @@ public:
*/
virtual int64_t getNextBatchInternal(int64_t size, DataBatch* batch) = 0;
protected:
protected:
DataConfig config_;
bool skipShuffle_;
float usageRatio_;
......@@ -382,7 +382,7 @@ protected:
* necessary configurations such as stream_names
*/
class DummyDataProvider : public DataProvider {
public:
public:
DummyDataProvider(const DataConfig& config, bool useGpu)
: DataProvider(config, useGpu) {}
virtual void shuffle() {}
......@@ -399,7 +399,7 @@ public:
* Data provider for one input and one integer label.
*/
class SimpleDataProviderBase : public DataProvider {
protected:
protected:
/// sample feature dimension
int64_t sampleDim_;
/// the number of samples
......@@ -425,7 +425,7 @@ protected:
RWLock lock_;
public:
public:
SimpleDataProviderBase(const DataConfig& config, bool useGpu, bool withInfo);
~SimpleDataProviderBase() {}
......@@ -440,7 +440,7 @@ public:
/// return the number of samples in the buffer
int64_t fillBuffer();
protected:
protected:
/**
* @brief Fill at most size samples into data and label.
*
......@@ -458,12 +458,12 @@ protected:
};
class SimpleDataProvider : public SimpleDataProviderBase {
public:
public:
SimpleDataProvider(const DataConfig& config, bool useGpu);
~SimpleDataProvider();
virtual void reset();
protected:
protected:
void loadData(const std::string& fileName);
void loadDataFile(const std::string& fileName);
virtual int64_t fillBufferImp(real* data,
......@@ -471,7 +471,7 @@ protected:
int* info,
int64_t size);
protected:
protected:
size_t currentSampleIndex_;
std::vector<int> labels_;
std::vector<real> data_;
......
......@@ -20,7 +20,7 @@ namespace paddle {
template <class T>
class DataProviderGroup : public DataProvider {
protected:
protected:
typedef T ProviderType;
typedef std::shared_ptr<ProviderType> ProviderPtrType;
ProviderPtrType provider_;
......@@ -29,7 +29,7 @@ protected:
std::mutex lock_;
std::unique_ptr<MultiThreadWorker<ProviderType>> loader_;
public:
public:
DataProviderGroup(const DataConfig& config, bool useGpu);
~DataProviderGroup() {}
......@@ -38,7 +38,7 @@ public:
virtual int64_t getSize() { return -1; }
virtual int64_t getNextBatchInternal(int64_t size, DataBatch* batch);
private:
private:
void startLoader();
void stopLoader();
void forceStopLoader();
......
......@@ -19,10 +19,10 @@ limitations under the License. */
namespace paddle {
class MultiDataProvider : public DataProvider {
protected:
protected:
std::vector<std::unique_ptr<DataProvider>> subDataProviders_;
public:
public:
MultiDataProvider(const DataConfig& config,
const ModelConfig& modelConfig,
bool useGpu);
......@@ -33,7 +33,7 @@ public:
virtual int64_t getNextBatchInternal(int64_t size, DataBatch* batch);
bool isTestMode() const { return isTestMode_; }
private:
private:
int totalDataRatio_;
bool isTestMode_;
};
......
......@@ -28,7 +28,7 @@ namespace paddle {
* messages from/to i/ostream.
*/
class ProtoReader {
public:
public:
explicit ProtoReader(std::istream* s, bool dataCompression = false) {
CHECK(s) << "istream pointer is nullptr";
istreamInput_.reset(new google::protobuf::io::IstreamInputStream(s));
......@@ -109,7 +109,7 @@ public:
return true;
}
protected:
protected:
std::unique_ptr<google::protobuf::io::ZeroCopyInputStream> istreamInput_;
std::unique_ptr<google::protobuf::io::GzipInputStream> gzipInput_;
std::unique_ptr<google::protobuf::io::CodedInputStream> codedInput_;
......@@ -144,7 +144,7 @@ protected:
};
class ProtoWriter {
public:
public:
explicit ProtoWriter(std::ostream* s, bool dataCompression = false) {
CHECK(s) << "ostream pointer is nullptr";
ostreamOutput_.reset(new google::protobuf::io::OstreamOutputStream(s));
......@@ -168,7 +168,7 @@ public:
return ret;
}
protected:
protected:
std::unique_ptr<google::protobuf::io::ZeroCopyOutputStream> ostreamOutput_;
std::unique_ptr<google::protobuf::io::GzipOutputStream> gzipOutput_;
std::unique_ptr<google::protobuf::io::CodedOutputStream> codedOutput_;
......
......@@ -23,7 +23,7 @@ limitations under the License. */
namespace paddle {
class PyDataProvider : public DataProvider {
public:
public:
PyDataProvider(const DataConfig& config,
bool useGpu,
bool loadDataAll = true);
......@@ -40,7 +40,7 @@ public:
virtual int64_t getNextBatchInternal(int64_t size, DataBatch* batch);
protected:
protected:
struct ProtoSlot;
// return false if each each sample is one sequence, i.e., independent
// of other samples.
......@@ -73,7 +73,7 @@ protected:
void resetSlots();
void loadData(const std::vector<std::string>& fileList);
protected:
protected:
struct ProtoSlot {
SlotDef::SlotType type;
int dim;
......
......@@ -93,7 +93,7 @@ inline std::ostream& operator<<(std::ostream& os, const SlotHeader& header) {
* prepare step, fill data into argument during fill step.
*/
class IFieldScanner {
public:
public:
DISABLE_COPY(IFieldScanner);
/**
* Ctor.
......@@ -146,7 +146,7 @@ public:
*/
static IFieldScanner* create(SlotHeader* header);
protected:
protected:
SlotHeader* headerPtr_;
};
......@@ -154,7 +154,7 @@ protected:
* Py Data Provider Cache Interface.
*/
class IPyDataProviderCache {
public:
public:
virtual ~IPyDataProviderCache() {}
/**
......@@ -193,7 +193,7 @@ public:
* data. And it support cache strategies.
*/
class PyDataProvider2 : public DataProvider {
public:
public:
/**
* Ctor
*/
......@@ -234,7 +234,7 @@ public:
*/
virtual ~PyDataProvider2() { resetImpl(false); }
private:
private:
void createPyDataObj(const std::string& model,
const std::string& className,
const std::string& fileListName,
......@@ -435,7 +435,7 @@ private:
exit_ = false;
}
private:
private:
std::unique_ptr<std::thread> loadThread_;
std::atomic<bool> exit_;
std::deque<PyObjectPtr> callingContexts_;
......@@ -461,7 +461,7 @@ private:
static PyObjectPtr zeroTuple_;
class PositionRandom {
public:
public:
inline explicit PositionRandom(bool skipRand)
: eng_(ThreadLocalRandomEngine::get()), skipRand_(skipRand) {}
......@@ -476,14 +476,14 @@ private:
}
}
private:
private:
std::default_random_engine& eng_;
std::unique_ptr<std::uniform_int_distribution<size_t>> dist_;
bool skipRand_;
};
// DataProvider interface
public:
public:
/**
* Resetting the PyDataProvider. May start reading thread here.
*/
......@@ -666,7 +666,7 @@ REGISTER_DATA_PROVIDER_EX(py2, PyDataProvider2);
* Scanner for dense slot.
*/
class DenseScanner : public IFieldScanner {
public:
public:
explicit DenseScanner(SlotHeader* ptr) : IFieldScanner(ptr), height_(0) {}
/**
......@@ -708,7 +708,7 @@ public:
++height_;
}
private:
private:
size_t height_;
};
......@@ -716,7 +716,7 @@ private:
* Scanner for index slot
*/
class IndexScanner : public IFieldScanner {
public:
public:
explicit IndexScanner(SlotHeader* ptr) : IFieldScanner(ptr), cnt_(0) {}
/**
......@@ -740,12 +740,12 @@ public:
CHECK(ok) << "Cannot cast int " << py::repr(obj);
}
private:
private:
size_t cnt_;
};
class SparseNonValueScanner : public IFieldScanner {
public:
public:
explicit SparseNonValueScanner(SlotHeader* ptr)
: IFieldScanner(ptr), nnz_(0), height_(0) {}
......@@ -790,7 +790,7 @@ public:
++height_;
}
protected:
protected:
/**
* Set a single sparse index and value.
* @param [out] col sparse index
......@@ -809,7 +809,7 @@ protected:
};
class SparseValueScanner : public SparseNonValueScanner {
public:
public:
explicit SparseValueScanner(SlotHeader* ptr) : SparseNonValueScanner(ptr) {}
virtual void finishPrepare(Argument& argument) {
......@@ -817,7 +817,7 @@ public:
argument.value, height_, headerPtr_->dim, nnz_, FLOAT_VALUE);
}
protected:
protected:
virtual void setData(int* col, real* dat, PyObject* obj) {
py::SequenceHelper s(obj);
SparseNonValueScanner::setData(col, dat, s[0]);
......@@ -829,7 +829,7 @@ protected:
* Sequence Scanner. Scanner for sequence or sub-sequence.
*/
class SequenceScanner : public IFieldScanner {
public:
public:
/**
* Ctor
* @param innerScanner inner scanner for each timestep or sub-sequence.
......@@ -902,7 +902,7 @@ public:
*/
virtual void finishFill(Argument& argument) { inner_->finishFill(argument); }
protected:
protected:
size_t getSize(PyObject* obj) {
py::SequenceHelper s(obj);
auto sc = dynamic_cast<SequenceScanner*>(inner_.get());
......@@ -917,7 +917,7 @@ protected:
}
}
private:
private:
std::unique_ptr<IFieldScanner> inner_;
size_t cnt_;
std::function<ICpuGpuVectorPtr&(Argument&)> getSeqStartPos_;
......@@ -969,7 +969,7 @@ IFieldScanner* IFieldScanner::create(SlotHeader* header) {
* python every pass.
*/
class NoCacheStrategy : public IPyDataProviderCache {
public:
public:
virtual bool reset() { return true; }
virtual void drop(std::deque<PyObjectPtr>* data) { data->clear(); }
......@@ -984,7 +984,7 @@ public:
* The rest passes, will load data from memory.
*/
class CacheOnePassInMemory : public IPyDataProviderCache {
public:
public:
CacheOnePassInMemory()
: objPool_(new std::deque<PyObjectPtr>()),
droppedPool_(new std::deque<PyObjectPtr>()) {}
......@@ -1011,7 +1011,7 @@ public:
virtual std::deque<PyObjectPtr>* load() { return objPool_.get(); }
private:
private:
std::unique_ptr<std::deque<PyObjectPtr>> objPool_;
std::unique_ptr<std::deque<PyObjectPtr>> droppedPool_;
};
......
......@@ -22,7 +22,7 @@ namespace paddle {
* calculate sequence-to-sequence edit distance
*/
class CTCErrorEvaluator : public Evaluator {
private:
private:
MatrixPtr outActivations_;
int numTimes_, numClasses_, numSequences_, blank_;
real deletions_, insertions_, substitutions_;
......@@ -197,7 +197,7 @@ private:
(real)seqClassficationError_ / numSequences_;
}
public:
public:
CTCErrorEvaluator()
: numTimes_(0),
numClasses_(0),
......
......@@ -77,7 +77,7 @@ class ChunkEvaluator : public Evaluator {
std::set<int> excludedChunkTypes_;
mutable std::unordered_map<std::string, real> values_;
public:
public:
virtual void init(const EvaluatorConfig& config) {
Evaluator::init(config);
if (config.chunk_scheme() == "IOB") {
......@@ -276,7 +276,7 @@ public:
return "chunk";
}
private:
private:
void storeLocalValues() const {
CHECK_GE(numOutputSegments_, 0);
CHECK_GE(numLabelSegments_, 0);
......
......@@ -28,7 +28,7 @@ namespace paddle {
* The config file api is detection_map_evaluator.
*/
class DetectionMAPEvaluator : public Evaluator {
public:
public:
DetectionMAPEvaluator()
: evaluateDifficult_(false), cpuOutput_(nullptr), cpuLabel_(nullptr) {}
......@@ -132,7 +132,7 @@ public:
LOG(FATAL) << "Distribute detection evaluation not implemented.";
}
protected:
protected:
void calcTFPos(const size_t batchSize,
const vector<map<size_t, vector<NormalizedBBox>>>& allGTBBoxes,
const vector<map<size_t, vector<pair<real, NormalizedBBox>>>>&
......@@ -287,7 +287,7 @@ protected:
real getValueImpl() const { return calcMAP(); }
private:
private:
real overlapThreshold_; // overlap threshold when determining whether matched
bool evaluateDifficult_; // whether evaluate difficult ground truth
size_t backgroundId_; // class index of background
......
......@@ -38,7 +38,7 @@ void Evaluator::eval(const NeuralNetwork& nn) {
* The config file api is classification_error_evaluator.
*/
class ClassificationErrorEvaluator : public Evaluator {
public:
public:
/*
ClassificationErrorEvaluator() : totalScore2_(0) {}
......@@ -124,7 +124,7 @@ public:
}
// Evaluator interface
protected:
protected:
std::string getTypeImpl() const { return "classification_error"; }
};
......@@ -135,7 +135,7 @@ protected:
*/
class SequenceClassificationErrorEvaluator
: public ClassificationErrorEvaluator {
public:
public:
virtual void updateSamplesNum(const std::vector<Argument>& arguments) {
numSamples_ += arguments[0].getNumSequences();
}
......@@ -166,7 +166,7 @@ public:
}
// Evaluator interface
protected:
protected:
std::string getTypeImpl() const { return "seq_classification_error"; }
};
REGISTER_EVALUATOR(seq_classification_error,
......@@ -178,7 +178,7 @@ REGISTER_EVALUATOR(seq_classification_error,
* The config file api is sum_evaluator.
*/
class SumEvaluator : public Evaluator {
public:
public:
SumEvaluator() : cpuLabel_(nullptr), cpuWeight_(nullptr) {}
virtual void updateSamplesNum(const std::vector<Argument>& arguments) {
......@@ -255,12 +255,12 @@ public:
mergeResultsOfAllClients(client);
}
private:
private:
IVectorPtr cpuLabel_;
MatrixPtr cpuWeight_;
// Evaluator interface
protected:
protected:
std::string getTypeImpl() const { return "sum"; }
};
/**
......@@ -274,7 +274,7 @@ protected:
*
*/
class ColumnSumEvaluator : public Evaluator {
public:
public:
explicit ColumnSumEvaluator(int32_t colIdx)
: colIdx_(colIdx), colNum_(0), sum_(nullptr) {}
......@@ -368,13 +368,13 @@ public:
client->reduce(&numSamples_, &numSamples_, 1, FLAGS_trainer_id, 0);
}
private:
private:
int32_t colIdx_;
size_t colNum_;
MatrixPtr sum_; /* cpu matrix */
// Evaluator interface
protected:
protected:
std::string getTypeImpl() const {
if (colIdx_ == -1)
return "last-column-sum";
......@@ -1018,7 +1018,7 @@ static InitFunction __reg_type_auc_sum__([]() {
* The config file api is value_printer_evaluator.
*/
class ValuePrinter : public NotGetableEvaluator {
public:
public:
virtual void eval(const NeuralNetwork& nn) {
for (const std::string& name : config_.input_layers()) {
nn.getLayer(name)->getOutput().printValueString(LOG(INFO),
......@@ -1038,7 +1038,7 @@ REGISTER_EVALUATOR(value_printer, ValuePrinter);
* The config file api is gradient_printer_evaluator.
*/
class GradientPrinter : public NotGetableEvaluator {
public:
public:
virtual void eval(const NeuralNetwork& nn) {
for (const std::string& name : config_.input_layers()) {
const Argument& argu = nn.getLayer(name)->getOutput();
......@@ -1061,11 +1061,11 @@ REGISTER_EVALUATOR(gradient_printer, GradientPrinter);
* The config file api is maxid_printer_evaluator.
*/
class MaxIdPrinter : public NotGetableEvaluator {
private:
private:
IVectorPtr maxIds_;
MatrixPtr maxValues_;
public:
public:
MaxIdPrinter() {}
virtual void eval(const NeuralNetwork& nn) {
......@@ -1103,12 +1103,12 @@ REGISTER_EVALUATOR(max_id_printer, MaxIdPrinter);
* The config file api is maxframe_printer_evaluator.
*/
class MaxFramePrinter : public NotGetableEvaluator {
private:
private:
IVectorPtr maxIds_;
MatrixPtr maxValues_;
MatrixPtr value_;
public:
public:
MaxFramePrinter() {
value_ =
Matrix::create(nullptr, /* height= */ 1, 1, /* trans= */ false, false);
......@@ -1190,7 +1190,7 @@ REGISTER_EVALUATOR(max_frame_printer, MaxFramePrinter);
*
*/
class SequenceTextPrinter : public NotGetableEvaluator {
private:
private:
/// dict_file, which contains a list of tokens
std::vector<std::string> dict_;
/// result_file, which is the output file
......@@ -1203,7 +1203,7 @@ private:
/// store the probability associated with each sequence
std::vector<MatrixPtr> cpuIn_;
public:
public:
SequenceTextPrinter() {}
virtual void init(const EvaluatorConfig& config) {
......@@ -1334,7 +1334,7 @@ REGISTER_EVALUATOR(seq_text_printer, SequenceTextPrinter);
* The config file api is classification_error_printer_evaluator.
*/
class ClassificationErrorPrinter : public ClassificationErrorEvaluator {
public:
public:
virtual void updateSamplesNum(const std::vector<Argument>& arguments) {}
virtual real evalImp(std::vector<Argument>& arguments) {
......
......@@ -40,7 +40,7 @@ class NeuralNetwork;
* has been by a trained model.
*/
class Evaluator {
public:
public:
static Evaluator* create(const EvaluatorConfig& config);
Evaluator() : numSamples_(0), totalScore_(0) {}
......@@ -172,7 +172,7 @@ public:
return this->getTypeImpl();
}
protected:
protected:
/**
* @brief getValueImpl The simplest way to define getValue result. If this
* evaluator doesn't contain multiple fields, and do not throw any error, just
......@@ -191,7 +191,7 @@ protected:
*/
virtual std::string getTypeImpl() const { return "base"; }
protected:
protected:
EvaluatorConfig config_;
double numSamples_;
double totalScore_;
......@@ -204,7 +204,7 @@ protected:
*/
class NotGetableEvaluator : public Evaluator {
// Evaluator interface
public:
public:
void getNames(std::vector<std::string>* names) {}
real getValue(const std::string& name, Error* err) const {
......@@ -219,7 +219,7 @@ public:
};
class DummyEvaluator : public Evaluator {
public:
public:
DummyEvaluator() {}
virtual void init(const EvaluatorConfig&) {}
virtual void start() {}
......@@ -232,7 +232,7 @@ public:
virtual void printStats(std::ostream&) const {}
// Evaluator interface
protected:
protected:
std::string getTypeImpl() const;
};
/**
......@@ -251,7 +251,7 @@ protected:
*
*/
class AucEvaluator : public Evaluator {
public:
public:
AucEvaluator(int32_t colIdx)
: colIdx_(colIdx),
realColumnIdx_(0),
......@@ -269,7 +269,7 @@ public:
virtual void distributeEval(ParameterClient2* client);
private:
private:
static const uint32_t kBinNum_ = (1 << 24) - 1;
static const int kNegativeLabel_ = 0;
double statPos_[kBinNum_ + 1];
......@@ -292,7 +292,7 @@ private:
double calcAuc() const;
// Evaluator interface
protected:
protected:
real getValueImpl() const;
std::string getTypeImpl() const;
};
......@@ -305,7 +305,7 @@ protected:
* dense value.
*/
class RankAucEvaluator : public Evaluator {
public:
public:
// evaluate ranking AUC
virtual void start();
......@@ -317,7 +317,7 @@ public:
mergeResultsOfAllClients(client);
}
private:
private:
MatrixPtr output_;
MatrixPtr click_;
MatrixPtr pv_;
......@@ -329,7 +329,7 @@ private:
size_t size);
// Evaluator interface
protected:
protected:
std::string getTypeImpl() const;
};
......@@ -344,7 +344,7 @@ protected:
* The config file api is precision_recall_evaluator.
*/
class PrecisionRecallEvaluator : public Evaluator {
public:
public:
// Evaluate precision, recall and F1 score
PrecisionRecallEvaluator()
: isMultiBinaryLabel_(false),
......@@ -379,7 +379,7 @@ public:
StatsInfo() : TP(0.0), TN(0.0), FP(0.0), FN(0.0) {}
};
private:
private:
bool isMultiBinaryLabel_;
std::vector<StatsInfo> statsInfo_;
......@@ -444,7 +444,7 @@ private:
* The config file api is pnpair_evaluator.
*/
class PnpairEvaluator : public Evaluator {
public:
public:
PnpairEvaluator()
: cpuOutput_(nullptr),
cpuLabel_(nullptr),
......@@ -491,7 +491,7 @@ public:
<< " calc total neg pair: " << pairArray_[1];
}
private:
private:
static const uint32_t kPairArrayNum_ = 2;
double pairArray_[kPairArrayNum_];
MatrixPtr cpuOutput_;
......@@ -500,7 +500,7 @@ private:
MatrixPtr cpuWeight_;
// Evaluator interface
protected:
protected:
real getValueImpl() const {
return pairArray_[0] / ((pairArray_[1] <= 0) ? 1.0 : pairArray_[1]);
}
......
......@@ -73,7 +73,7 @@ class GradientMachine;
typedef std::shared_ptr<GradientMachine> GradientMachinePtr;
class GradientMachine {
public:
public:
enum CreateMode {
kNormal = 0,
kSgdSparseCpuTraining = 3,
......@@ -240,7 +240,7 @@ public:
*/
virtual void releaseOutput() {}
protected:
protected:
virtual void onLoadParameter() {}
std::vector<ParameterPtr> parameters_;
......
......@@ -19,14 +19,14 @@ limitations under the License. */
namespace paddle {
class IGradientMachineMode {
public:
public:
virtual ~IGradientMachineMode() {}
public: // interfaces
/**
* @brief create current mode's gradient machine by model config.
* @param config model config
*/
public: // interfaces
/**
* @brief create current mode's gradient machine by model config.
* @param config model config
*/
virtual GradientMachine* create(const ModelConfig& config) = 0;
/**
......@@ -55,14 +55,14 @@ public: // interfaces
*/
virtual bool needTrainWholeDataInOneBatch() const = 0;
public: // static methods.
/**
* @brief register a custom gradient machine mode.
* @note For user to register a custom gradient machine mode, id should >=
* kCustom.
* @param mode mode id.
* @param ptr mode description object.
*/
public: // static methods.
/**
* @brief register a custom gradient machine mode.
* @note For user to register a custom gradient machine mode, id should >=
* kCustom.
* @param mode mode id.
* @param ptr mode description object.
*/
static void regGradientMachineMode(
int32_t mode, std::unique_ptr<IGradientMachineMode>&& ptr) {
modes_.insert(std::make_pair(mode, std::move(ptr)));
......@@ -141,7 +141,7 @@ public: // static methods.
}
}
private:
private:
static std::unordered_map<int32_t, std::unique_ptr<IGradientMachineMode>>
modes_;
};
......
......@@ -166,7 +166,7 @@ struct GradBuffer {
* the merged gradient to parameter server.
*/
class MultiGradientMachine : public GradientMachine {
public:
public:
enum TaskType {
TASK_FORWARD_BACKWARD = 0,
TASK_FORWARD = 1,
......@@ -213,7 +213,7 @@ public:
/// The gradietns will be copied to each thread in the computing threads.
virtual void setOutputGrad(const std::vector<Argument>& args);
protected:
protected:
friend class TrainerThread;
std::vector<TrainerThreadPtr>& getAllThreads() { return threads_; }
......@@ -281,7 +281,7 @@ protected:
int paraMainThread(int pid) const { return paraMainThread_[pid]; }
protected:
protected:
virtual void forwardImp(const std::vector<Argument>& inArgs,
std::vector<Argument>* outArgs,
PassType passType,
......@@ -298,7 +298,7 @@ protected:
void allocGradBufs();
protected:
protected:
bool useGpu_;
bool hasNonstaticCpuParamters_;
......@@ -342,7 +342,7 @@ protected:
};
class TrainerThread {
public:
public:
TrainerThread(const ModelConfig& config,
int threadId,
MultiGradientMachine* multiMachine);
......@@ -392,7 +392,7 @@ public:
/// Whether the thread has input data.
bool hasInputData() { return batchSize_ != 0; }
protected:
protected:
void mergeCpuGradients();
void mergeGradSparse(
......@@ -421,7 +421,7 @@ protected:
/// GradientMachine::backward
void doCallback(int pid);
protected:
protected:
MultiGradientMachine* multiMachine_;
ModelConfig config_;
/// whether the thread should stop
......
......@@ -122,7 +122,7 @@ void MultiNetwork::finish() {
}
class MultiCombinedEvaluator : public Evaluator {
public:
public:
MultiCombinedEvaluator() {}
void addEvaluator(std::unique_ptr<Evaluator>&& evaluator) {
evaluators_.emplace_back(std::move(evaluator));
......@@ -167,7 +167,7 @@ public:
}
}
protected:
protected:
std::vector<std::unique_ptr<Evaluator>> evaluators_;
};
......
......@@ -22,7 +22,7 @@ limitations under the License. */
namespace paddle {
class MultiNetwork : public NeuralNetwork {
public:
public:
explicit MultiNetwork(std::string subModelName = "")
: NeuralNetwork(subModelName) {}
......@@ -58,7 +58,7 @@ public:
virtual void finish();
protected:
protected:
std::vector<std::unique_ptr<NeuralNetwork>> subNetworks_;
};
} // namespace paddle
......@@ -362,7 +362,7 @@ void NeuralNetwork::releaseOutput() {
#ifndef PADDLE_MOBILE_INFERENCE
class CombinedEvaluator : public Evaluator {
public:
public:
void addEvaluator(std::unique_ptr<Evaluator>&& evaluator) {
evaluators_.emplace_back(std::move(evaluator));
}
......@@ -400,11 +400,11 @@ public:
}
}
protected:
protected:
std::vector<std::unique_ptr<Evaluator>> evaluators_;
// Evaluator interface
public:
public:
/**
* @brief getNames will return all inside evaluators' names.
* @param names [out]: return names.
......@@ -435,7 +435,7 @@ public:
});
}
private:
private:
template <typename T>
T getMethodHelper(const std::string& name,
Error* err,
......@@ -454,7 +454,7 @@ private:
};
class SubnetEvaluator : public CombinedEvaluator {
public:
public:
SubnetEvaluator(const std::string& layerName,
std::unique_ptr<Evaluator>&& evaluator)
: layerName_(layerName) {
......@@ -473,7 +473,7 @@ public:
<< " in submodel " << nn.getName();
}
protected:
protected:
std::string layerName_;
};
......
......@@ -56,7 +56,7 @@ void parameterInitNN(int paramId,
std::vector<ParameterPtr>* sharedParams);
class NeuralNetwork : public GradientMachine {
public:
public:
virtual void init(const ModelConfig& config,
ParamInitCallback callback = nullptr,
const std::vector<ParameterType>& parameterTypes =
......@@ -144,7 +144,7 @@ public:
*/
void releaseOutput();
protected:
protected:
/**
* The constructor of NeuralNetwork.
* The sub networks can get parameters_ and parameterMap_
......
......@@ -32,7 +32,7 @@ enum TaskType {
* multiple threads in parallel.
*/
class ParallelNeuralNetwork : public NeuralNetwork {
public:
public:
ParallelNeuralNetwork(std::string subModelName = "",
NeuralNetwork *rootNetwork = nullptr)
: NeuralNetwork(subModelName, rootNetwork) {}
......@@ -66,7 +66,7 @@ public:
// virtual void eval(Evaluator* evaluator);
protected:
protected:
bool useGpu_;
/// number of gpu devices
int numDevices_;
......@@ -74,7 +74,7 @@ protected:
};
class ParallelThread {
public:
public:
ParallelThread(int threadId, int deviceId, bool useGpu);
~ParallelThread();
void jobEnqueue(LayerPtr layer, TaskType task);
......@@ -87,10 +87,10 @@ public:
}
void setForwardPassType(PassType passType) { passType_ = passType; }
protected:
protected:
void computeThread();
public:
public:
struct Job {
LayerPtr layer_;
TaskType task_;
......@@ -98,7 +98,7 @@ public:
typedef Queue<Job> JobQueue;
JobQueue queue_;
protected:
protected:
/// from 0 to threads-1
int threadId_;
/// the GPU device Id which the computeThread_ used
......
......@@ -96,7 +96,7 @@ static InitFunction __init__diy_prob_method(
std::numeric_limits<int>::max());
class BeamSearchControlCallbacks {
public:
public:
RecurrentGradientMachine::BeamSearchCandidatesAdjustCallback
beamSearchCandidateAdjust;
RecurrentGradientMachine::NormOrDropNodeCallback normOrDropNode;
......@@ -115,7 +115,7 @@ public:
};
class BeamSearchStatisticsCallbacks {
public:
public:
RecurrentGradientMachine::EachStepCallback onEachStepStarted;
RecurrentGradientMachine::EachStepCallback onEachStepStoped;
......@@ -148,11 +148,11 @@ RecurrentGradientMachine::RecurrentGradientMachine(
* so it's should not be placed in root network.
*/
class BootBiasLayer : public Layer {
protected:
protected:
std::unique_ptr<Weight> biases_;
IVectorPtr cpuIds_;
public:
public:
explicit BootBiasLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -30,7 +30,7 @@ class BeamSearchControlCallbacks;
class BeamSearchStatisticsCallbacks;
class RecurrentGradientMachine : public NeuralNetwork {
public:
public:
RecurrentGradientMachine(const std::string& subModelName,
NeuralNetwork* rootNetwork);
......@@ -290,7 +290,7 @@ public:
return this->finalPaths_;
}
protected:
protected:
std::vector<Argument::SeqInfo> commonSeqInfo_;
ICpuGpuVectorPtr sequenceStartPositions_;
void calcSequenceStartPositions();
......@@ -447,7 +447,7 @@ protected:
MatrixPtr cpuProb_;
IVectorPtr cpuEos_;
private:
private:
/*
* @return beam size in beam search
*/
......
......@@ -33,10 +33,10 @@ namespace paddle {
* The config file api is addto_layer.
*/
class AddtoLayer : public Layer {
protected:
protected:
std::unique_ptr<Weight> biases_;
public:
public:
explicit AddtoLayer(const LayerConfig& config) : Layer(config) {}
~AddtoLayer() {}
......
......@@ -26,11 +26,11 @@ namespace paddle {
* called to set one and only one real layer
*/
class AgentLayer : public Layer {
protected:
protected:
LayerPtr realLayer_;
int numSamples_;
public:
public:
explicit AgentLayer(const LayerConfig& config) : Layer(config) {}
~AgentLayer() {}
......@@ -55,14 +55,14 @@ public:
* GatherAgentLayer collect a complete sequence.
*/
class GatherAgentLayer : public Layer {
protected:
protected:
std::vector<LayerPtr> realLayers_;
std::vector<IVectorPtr> idsVec_;
// we don't clear idsVec_ vector to aviod IVector alloc/free
IVectorPtr allIds_;
std::vector<int> idIndex_;
public:
public:
explicit GatherAgentLayer(const LayerConfig& config) : Layer(config) {}
virtual ~GatherAgentLayer() {}
......@@ -95,7 +95,7 @@ public:
* if it is, the agent will select a few ids in real layer.
*/
class ScatterAgentLayer : public Layer {
protected:
protected:
LayerPtr realLayer_;
IVectorPtr ids_;
IVectorPtr cpuIds_;
......@@ -113,7 +113,7 @@ protected:
// true for setRealLayer, false for setRealLayerAndOutput
bool selectionMode_;
public:
public:
explicit ScatterAgentLayer(const LayerConfig& config) : Layer(config) {}
virtual ~ScatterAgentLayer() {}
......
......@@ -37,7 +37,7 @@ namespace paddle {
* The config file api is pooling_layer.
*/
class AverageLayer : public SequencePoolLayer {
public:
public:
enum AverageStrategy { kAverage = 0, kSum = 1, kAverageSquareRootN = 2 };
explicit AverageLayer(const LayerConfig& config)
: SequencePoolLayer(config) {}
......@@ -48,7 +48,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
protected:
protected:
int mode_;
};
} // namespace paddle
......@@ -40,7 +40,7 @@ namespace paddle {
*/
class BatchNormBaseLayer : public Layer {
public:
public:
explicit BatchNormBaseLayer(const LayerConfig& config) : Layer(config) {}
~BatchNormBaseLayer() {}
......@@ -61,7 +61,7 @@ public:
*/
void calFeatureMapSize();
protected:
protected:
/// Batch normalization scale parameter, which is referred to as gamma in
/// in original paper.
std::unique_ptr<Weight> weight_;
......
......@@ -27,7 +27,7 @@ namespace paddle {
*/
class BatchNormalizationLayer : public BatchNormBaseLayer {
public:
public:
explicit BatchNormalizationLayer(const LayerConfig& config)
: BatchNormBaseLayer(config), firstTest_(true) {}
......@@ -38,7 +38,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
protected:
protected:
/// Load pre-calculated mean and std.
void setMeanAndStd();
......
......@@ -26,13 +26,13 @@ namespace paddle {
* @note The config file api is bilinear_interp_layer.
*/
class BilinearInterpLayer : public Layer {
protected:
protected:
size_t outImgH_, outImgW_;
size_t inImgH_, inImgW_;
real ratioH_, ratioW_;
size_t numChannels_;
public:
public:
explicit BilinearInterpLayer(const LayerConfig& config) : Layer(config) {}
virtual ~BilinearInterpLayer() {}
......
......@@ -40,7 +40,7 @@ namespace paddle {
* The config file api is block_expand_layer.
*/
class BlockExpandLayer : public Layer {
protected:
protected:
/**
* @brief Calculate outputH_ and outputW_ and return block number which
* actually is time steps.
......@@ -53,7 +53,7 @@ protected:
TensorShape inputShape_;
TensorShape outputShape_;
public:
public:
explicit BlockExpandLayer(const LayerConfig& config) : Layer(config) {}
~BlockExpandLayer() {}
......
......@@ -30,14 +30,14 @@ namespace paddle {
* See LinearChainCRF.h for the detail of the CRF formulation.
*/
class CRFDecodingLayer : public CRFLayer {
public:
public:
explicit CRFDecodingLayer(const LayerConfig& config) : CRFLayer(config) {}
bool init(const LayerMap& layerMap,
const ParameterMap& parameterMap) override;
void forward(PassType passType) override;
void backward(const UpdateCallback& callback) override;
protected:
protected:
std::unique_ptr<LinearChainCRF> crf_;
};
......
......@@ -27,14 +27,14 @@ namespace paddle {
* See class LinearChainCRF for the detail of the CRF formulation.
*/
class CRFLayer : public Layer {
public:
public:
explicit CRFLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
const ParameterMap& parameterMap) override;
void forward(PassType passType) override;
void backward(const UpdateCallback& callback) override;
protected:
protected:
size_t numClasses_;
ParameterPtr parameter_;
std::vector<LinearChainCRF> crfs_;
......
......@@ -20,7 +20,7 @@ limitations under the License. */
namespace paddle {
class CTCLayer : public Layer {
public:
public:
explicit CTCLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
const ParameterMap& parameterMap) override;
......@@ -31,7 +31,7 @@ public:
const Argument& softmaxSeqs,
const Argument& labelSeqs);
protected:
protected:
size_t numClasses_;
bool normByTimes_;
std::vector<LinearChainCTC> ctcs_;
......
......@@ -24,11 +24,11 @@ namespace paddle {
*/
class ClipLayer : public Layer {
protected:
protected:
double min_;
double max_;
public:
public:
explicit ClipLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -23,7 +23,7 @@ namespace paddle {
* each input as one row for the output of this layer and apply activation.
*/
class ConcatenateLayer : public Layer {
public:
public:
explicit ConcatenateLayer(const LayerConfig& config) : Layer(config) {}
~ConcatenateLayer() {}
......@@ -97,7 +97,7 @@ void ConcatenateLayer::backward(const UpdateCallback& callback) {
* processed by a Projection.
*/
class ConcatenateLayer2 : public Layer {
public:
public:
explicit ConcatenateLayer2(const LayerConfig& config) : Layer(config) {}
~ConcatenateLayer2() {}
......@@ -108,7 +108,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
protected:
protected:
std::vector<std::unique_ptr<Projection>> projections_;
std::vector<Argument> projOutput_;
std::vector<std::pair<size_t, size_t>> projCol_;
......
......@@ -42,7 +42,7 @@ namespace paddle {
* The config file api is context_projection.
*/
class ContextProjection : public Projection {
public:
public:
/**
* Constructor. If context_start is zero and context_lenth is one, it will
* set trainable_padding false. trainable_padding is an optional arguments
......@@ -63,7 +63,7 @@ public:
virtual bool init();
protected:
protected:
std::unique_ptr<Weight> weight_;
/// number of extra timesteps added at the beginning
size_t beginPad_;
......
......@@ -26,7 +26,7 @@ namespace paddle {
* calculate convolution operation.
*/
class Conv3DLayer : public ConvBaseLayer {
public:
public:
explicit Conv3DLayer(const LayerConfig& config) : ConvBaseLayer(config) {}
~Conv3DLayer() {}
......@@ -40,7 +40,7 @@ public:
void bpropWeights(int i);
size_t getSize();
protected:
protected:
// Figure out the dimensions for individual gemms.
IntV M_; /// numFilters_ / filter_group_;
IntV N_; /// channels_ * filterSizeZ_ * filterSize_ * filterSizeY_
......
......@@ -24,7 +24,7 @@ namespace paddle {
*/
class ConvBaseLayer : public Layer {
protected:
protected:
typedef std::vector<int> IntV;
/// True if it's deconv layer, false if it's convolution layer
......@@ -88,7 +88,7 @@ protected:
/// of output size.
bool caffeMode_;
public:
public:
explicit ConvBaseLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -29,7 +29,7 @@ namespace paddle {
*/
class ConvBaseOperator : public Operator {
public:
public:
ConvBaseOperator(const OperatorConfig &config, bool useGpu);
/**
* Free workspace in device and destroy cudnn tensor descriptor.
......@@ -46,7 +46,7 @@ public:
hl_destroy_convolution_descriptor(convDesc_);
}
protected:
protected:
/**
* Get convolution parameters from layer config and
* initialize member variables.
......
......@@ -23,7 +23,7 @@ namespace paddle {
* @brief Base class for ConvProjection and ConvTransProjection.
*/
class ConvBaseProjection : public Projection {
public:
public:
/**
* Constructor.
*/
......@@ -33,7 +33,7 @@ public:
~ConvBaseProjection();
protected:
protected:
void getConvParams();
void initCudnn();
......
......@@ -29,7 +29,7 @@ namespace paddle {
*/
class ConvOperator : public ConvBaseOperator {
public:
public:
ConvOperator(const OperatorConfig &config, bool useGpu)
: ConvBaseOperator(config, useGpu) {}
/**
......
......@@ -23,7 +23,7 @@ namespace paddle {
* @brief Convolution projection do the same calculation with CudnnConvLayer.
*/
class ConvProjection : public ConvBaseProjection {
public:
public:
/**
* Constructor.
*/
......
......@@ -42,7 +42,7 @@ namespace paddle {
*/
class ConvShiftLayer : public Layer {
public:
public:
explicit ConvShiftLayer(const LayerConfig& config) : Layer(config) {}
~ConvShiftLayer() {}
......
......@@ -29,7 +29,7 @@ namespace paddle {
*/
class ConvTransOperator : public ConvBaseOperator {
public:
public:
ConvTransOperator(const OperatorConfig &config, bool useGpu)
: ConvBaseOperator(config, useGpu) {}
/**
......
......@@ -23,7 +23,7 @@ namespace paddle {
* @brief Convolution projection do the same calculation with CudnnConvLayer.
*/
class ConvTransProjection : public ConvBaseProjection {
public:
public:
/**
* Constructor.
*/
......
......@@ -36,7 +36,7 @@ namespace paddle {
* The config file api is linear_comb_layer.
*/
class ConvexCombinationLayer : public Layer {
protected:
protected:
/// A matrix pointer pointing to second input.
MatrixPtr tmpMtx0;
/// A matrix pointer pointing to first input.
......@@ -44,7 +44,7 @@ protected:
/// A matrix pointer pointing to output.
MatrixPtr tmpRow1;
public:
public:
explicit ConvexCombinationLayer(const LayerConfig& config) : Layer(config) {}
~ConvexCombinationLayer() {}
......
......@@ -33,7 +33,7 @@ namespace paddle {
* The config file api is cos_sim.
*/
class CosSimLayer : public Layer {
public:
public:
explicit CosSimLayer(const LayerConfig& config) : Layer(config) {}
~CosSimLayer() {}
......
......@@ -32,7 +32,7 @@ namespace paddle {
*/
class CosSimVecMatLayer : public Layer {
protected:
protected:
MatrixPtr tmpMtx0;
MatrixPtr tmpMtx1;
MatrixPtr tmpRow0;
......@@ -40,7 +40,7 @@ protected:
MatrixPtr tmpRow2;
MatrixPtr tmpRow3;
public:
public:
explicit CosSimVecMatLayer(const LayerConfig& config) : Layer(config) {}
~CosSimVecMatLayer() {}
......
......@@ -716,7 +716,7 @@ void HuberTwoClassification::backwardImp(Matrix& output,
* \f]
*/
class SumCostLayer : public Layer {
public:
public:
explicit SumCostLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -29,7 +29,7 @@ namespace paddle {
* handled by the base class.
*/
class CostLayer : public Layer {
public:
public:
explicit CostLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -51,7 +51,7 @@ public:
Argument& label,
Matrix& outputGrad) = 0;
protected:
protected:
LayerPtr weightLayer_;
real coeff_;
};
......@@ -65,7 +65,7 @@ protected:
* \f]
*/
class MultiClassCrossEntropy : public CostLayer {
public:
public:
explicit MultiClassCrossEntropy(const LayerConfig& config)
: CostLayer(config) {}
......@@ -95,7 +95,7 @@ public:
* In Proceedings of the ACL 2014 Conference.
*/
class MultiClassCrossEntropyWithSelfNorm : public CostLayer {
public:
public:
explicit MultiClassCrossEntropyWithSelfNorm(const LayerConfig& config)
: CostLayer(config) {}
......@@ -108,7 +108,7 @@ public:
Argument& label,
Matrix& outputGrad) override;
protected:
protected:
MatrixPtr sftMaxSum_;
MatrixPtr sumInv_;
};
......@@ -120,7 +120,7 @@ protected:
* \f]
*/
class SoftBinaryClassCrossEntropy : public CostLayer {
public:
public:
explicit SoftBinaryClassCrossEntropy(const LayerConfig& config)
: CostLayer(config) {}
......@@ -133,7 +133,7 @@ public:
Argument& label,
Matrix& outputGrad) override;
protected:
protected:
MatrixPtr targetPerDim_;
};
......@@ -145,7 +145,7 @@ protected:
* \f]
*/
class SumOfSquaresCostLayer : public CostLayer {
public:
public:
explicit SumOfSquaresCostLayer(const LayerConfig& config)
: CostLayer(config) {}
......@@ -171,7 +171,7 @@ public:
* x = output - label
*/
class SmoothL1CostLayer : public CostLayer {
public:
public:
explicit SmoothL1CostLayer(const LayerConfig& config) : CostLayer(config) {}
bool init(const LayerMap& layerMap,
......@@ -197,7 +197,7 @@ public:
* Rank useing Gradient Descent.
*/
class RankingCost : public Layer {
public:
public:
explicit RankingCost(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -225,7 +225,7 @@ public:
(void)outputGrad;
}
private:
private:
double posPairCount_;
double negPairCount_;
MatrixPtr margin_;
......@@ -250,7 +250,7 @@ private:
* with Nonsmooth Cost Functions.
*/
class LambdaCost : public Layer {
public:
public:
explicit LambdaCost(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -270,7 +270,7 @@ public:
real* gradData,
int size);
private:
private:
MatrixPtr marginGrad_;
int truncationSize_;
int maxSortSize_;
......@@ -287,10 +287,10 @@ private:
* \f]
*/
class MultiBinaryLabelCrossEntropy : public CostLayer {
protected:
protected:
MatrixPtr targetPerDim_;
public:
public:
explicit MultiBinaryLabelCrossEntropy(const LayerConfig& config)
: CostLayer(config) {}
......@@ -308,7 +308,7 @@ public:
* A base layer for HuberRegressionLoss and HuberTwoClassification.
*/
class HuberCost : public CostLayer {
public:
public:
std::vector<Argument> tmpCpuInput_;
explicit HuberCost(const LayerConfig& config) : CostLayer(config) {}
......@@ -331,7 +331,7 @@ public:
* Loss = delta * abs(y - f) - 0.5 * delta^2, otherwise
*/
class HuberRegressionLoss : public HuberCost {
public:
public:
explicit HuberRegressionLoss(const LayerConfig& config) : HuberCost(config) {}
bool init(const LayerMap& layerMap,
......@@ -343,7 +343,7 @@ public:
Argument& label,
Matrix& outputGrad) override;
protected:
protected:
real delta_;
};
......@@ -356,7 +356,7 @@ protected:
* Loss = 0, otherwise
*/
class HuberTwoClassification : public HuberCost {
public:
public:
explicit HuberTwoClassification(const LayerConfig& config)
: HuberCost(config) {}
......
......@@ -28,7 +28,7 @@ namespace paddle {
* crop input as this shape conf
*/
class CropLayer : public Layer {
public:
public:
explicit CropLayer(const LayerConfig& config) : Layer(config) {}
~CropLayer() {}
......@@ -38,7 +38,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
protected:
protected:
void setOutDims();
void setInDims();
......
......@@ -44,7 +44,7 @@ struct BeamExpansion {
typedef std::shared_ptr<BeamExpansion> BeamExpansionPtr;
class CostForOneSequence {
public:
public:
CostForOneSequence()
: beamSize_(0), validExpansionCount_(0), goldAsExtraPath_(false) {}
void setData(const BeamExpansionPtr bPtr, size_t beamSize) {
......@@ -64,7 +64,7 @@ public:
real forward();
void backward();
private:
private:
void calValidExpandStep();
void constructTotalExpansion();
size_t initLastExpansion();
......@@ -93,14 +93,14 @@ private:
};
class CrossEntropyOverBeam : public Layer {
public:
public:
explicit CrossEntropyOverBeam(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
const ParameterMap& parameterMap) override;
void forward(PassType passType) override;
void backward(const UpdateCallback& callback) override;
private:
private:
void checkInputs();
void copyInputsToCpu();
void resizeOutput();
......
......@@ -30,7 +30,7 @@ namespace paddle {
*/
class CudnnBatchNormLayer : public BatchNormBaseLayer {
public:
public:
explicit CudnnBatchNormLayer(const LayerConfig& config)
: BatchNormBaseLayer(config) {}
......@@ -46,7 +46,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
protected:
protected:
/// Epsilon value used in the batch normalization formula.
/// Same epsilon value should be used in forward and backward functions.
double eps_;
......
......@@ -31,14 +31,14 @@ namespace paddle {
* The config file api is img_conv_layer.
*/
class CudnnConvBaseLayer : public ConvBaseLayer {
protected:
protected:
std::vector<std::unique_ptr<ProjectionConfig>> projConf_;
std::vector<std::unique_ptr<Projection>> projections_;
hl_tensor_descriptor biasDesc_;
hl_tensor_descriptor outputDesc_;
public:
public:
explicit CudnnConvBaseLayer(const LayerConfig& config)
: ConvBaseLayer(config) {}
......
......@@ -26,7 +26,7 @@ namespace paddle {
*/
class CudnnPoolLayer : public PoolLayer {
protected:
protected:
int windowHeight, windowWidth;
int heightPadding, widthPadding, strideHeight, strideWidth;
int imageH_, imageW_, outputH_, outputW_;
......@@ -40,7 +40,7 @@ protected:
/// A description of a pooling operation.
hl_pooling_descriptor poolingDesc_;
public:
public:
static bool typeCheck(const std::string& poolType,
hl_pooling_mode_t* mode = nullptr);
explicit CudnnPoolLayer(const LayerConfig& config);
......
......@@ -25,7 +25,7 @@ namespace paddle {
* The config file api is data_layer.
*/
class DataLayer : public Layer {
public:
public:
explicit DataLayer(const LayerConfig& config) : Layer(config) {}
virtual void setData(const Argument& data) { data_ = data; }
......@@ -58,10 +58,10 @@ public:
}
}
private:
private:
void copyDataToOutput(Argument& output);
protected:
protected:
Argument data_;
};
......
......@@ -37,7 +37,7 @@ namespace paddle {
*/
class DataNormLayer : public Layer {
public:
public:
enum NormalizationStrategy { kZScore = 0, kMinMax = 1, kDecimalScaling = 2 };
explicit DataNormLayer(const LayerConfig& config) : Layer(config) {}
......@@ -50,7 +50,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
protected:
protected:
int mode_;
std::unique_ptr<Weight> weight_;
MatrixPtr min_;
......
......@@ -27,7 +27,7 @@ namespace paddle {
* calculate deconvolution3D operation.
*/
class DeConv3DLayer : public ConvBaseLayer {
public:
public:
explicit DeConv3DLayer(const LayerConfig& config) : ConvBaseLayer(config) {}
~DeConv3DLayer() {}
bool init(const LayerMap& layerMap, const ParameterMap& parameterMap);
......@@ -40,7 +40,7 @@ public:
void bpropWeights(int i);
size_t getSize();
protected:
protected:
// Figure out the dimensions for individual gemms.
IntV M_; /// numFilters_ / filter_group_;
IntV N_; /// channels_ * filterSizeZ_ * filterSize_ * filterSizeY_
......
......@@ -33,7 +33,7 @@ namespace paddle {
*/
class DetectionOutputLayer : public Layer {
public:
public:
explicit DetectionOutputLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap, const ParameterMap& parameterMap);
......@@ -42,7 +42,7 @@ public:
void backward(const UpdateCallback& callback = nullptr) {}
protected:
protected:
inline LayerPtr getPriorBoxLayer() { return inputLayers_[0]; }
inline LayerPtr getLocInputLayer(size_t index) {
......@@ -53,7 +53,7 @@ protected:
return inputLayers_[1 + inputNum_ + index];
}
private:
private:
size_t numClasses_; // number of classes
size_t inputNum_; // number of input layers
real nmsThreshold_;
......
......@@ -27,7 +27,7 @@ namespace paddle {
* The config file api is dotmul_operator.
*/
class DotMulOperator : public Operator {
public:
public:
DotMulOperator(const OperatorConfig& config, bool useGpu);
virtual void forward();
virtual void backward();
......
......@@ -26,14 +26,14 @@ namespace paddle {
* The config file api is dotmul_projection.
*/
class DotMulProjection : public Projection {
public:
public:
DotMulProjection(const ProjectionConfig& config,
const ParameterPtr& parameter,
bool useGpu);
virtual void forward();
virtual void backward(const UpdateCallback& callback);
protected:
protected:
/// shared memory with parameter
std::unique_ptr<Weight> weight_;
};
......
......@@ -27,7 +27,7 @@ namespace paddle {
*/
class DotProdLayer : public Layer {
public:
public:
explicit DotProdLayer(const LayerConfig& config) : Layer(config) {}
~DotProdLayer() {}
......
......@@ -24,7 +24,7 @@ namespace paddle {
* It is used by recurrent layer group.
*/
class EosIdCheckLayer : public Layer {
public:
public:
explicit EosIdCheckLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -29,7 +29,7 @@ namespace paddle {
*/
class ExpandConvLayer : public ConvBaseLayer {
public:
public:
explicit ExpandConvLayer(const LayerConfig& config) : ConvBaseLayer(config) {}
~ExpandConvLayer() {}
......@@ -42,7 +42,7 @@ public:
size_t getOutputSize();
protected:
protected:
std::vector<TensorShape> inputShape_;
std::vector<TensorShape> filterShape_;
std::vector<TensorShape> outputShape_;
......
......@@ -37,7 +37,7 @@ namespace paddle {
*/
class ExpandLayer : public Layer {
protected:
protected:
std::unique_ptr<Weight> biases_;
/// if input[0] is dense data, ExpandLevel=kNonSeq;
/// if input[0] is sequence data, ExpandLevel=kSeq
......@@ -48,7 +48,7 @@ protected:
/// of input[1]
ICpuGpuVectorPtr expandStartsPos_;
public:
public:
explicit ExpandLayer(const LayerConfig& config) : Layer(config) {}
~ExpandLayer() {}
......
......@@ -42,7 +42,7 @@ namespace paddle {
*/
class FactorizationMachineLayer : public Layer {
protected:
protected:
// The latent vectors, shape: (size, factorSize_)
// Each row of the latentVectors_ matrix is the latent vector
// corresponding to one input feature dimension
......@@ -50,7 +50,7 @@ protected:
// The hyperparameter that defines the dimensionality of the factorization
size_t factorSize_;
private:
private:
// Store the square values of the letent vectors matrix
MatrixPtr latentVectorsSquare_;
// Store the square values of input matrix
......@@ -65,7 +65,7 @@ private:
// Negative identity matrix
MatrixPtr negOnes_;
public:
public:
explicit FactorizationMachineLayer(const LayerConfig& config)
: Layer(config) {}
~FactorizationMachineLayer() {}
......
......@@ -38,11 +38,11 @@ namespace paddle {
*/
class FeatureMapExpandLayer : public Layer {
private:
private:
int numFilters_;
bool asRowVector_;
public:
public:
explicit FeatureMapExpandLayer(const LayerConfig& config) : Layer(config) {}
~FeatureMapExpandLayer() {}
......
......@@ -28,14 +28,14 @@ namespace paddle {
* The config file api is full_matrix_projection.
*/
class FullMatrixProjection : public Projection {
public:
public:
FullMatrixProjection(const ProjectionConfig& config,
const ParameterPtr& parameter,
bool useGpu);
virtual void forward();
virtual void backward(const UpdateCallback& callback);
protected:
protected:
std::unique_ptr<Weight> weight_;
};
......
......@@ -28,11 +28,11 @@ namespace paddle {
*/
class FullyConnectedLayer : public Layer {
protected:
protected:
WeightList weights_;
std::unique_ptr<Weight> biases_;
public:
public:
explicit FullyConnectedLayer(const LayerConfig& config) : Layer(config) {}
~FullyConnectedLayer() {}
......
......@@ -47,7 +47,7 @@ namespace paddle {
*/
class GatedRecurrentLayer : public Layer, public GruCompute {
public:
public:
explicit GatedRecurrentLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -63,7 +63,7 @@ public:
LayerStatePtr getState() override;
protected:
protected:
void forwardSequence(int batchSize,
size_t numSequences,
const int* starts,
......@@ -79,7 +79,7 @@ protected:
MatrixPtr inputValue);
void backwardBatch(int batchSize, MatrixPtr inputGrad);
protected:
protected:
std::unique_ptr<Weight> weight_;
std::unique_ptr<Weight> gateWeight_;
std::unique_ptr<Weight> stateWeight_;
......
......@@ -17,7 +17,7 @@ limitations under the License. */
namespace paddle {
class GetOutputLayer : public Layer {
public:
public:
explicit GetOutputLayer(const LayerConfig& config) : Layer(config) {}
~GetOutputLayer() {}
......
......@@ -21,7 +21,7 @@ limitations under the License. */
namespace paddle {
class GruCompute {
public:
public:
void init(LayerConfig &config);
template <bool useGpu>
......@@ -33,7 +33,7 @@ public:
int frameSize,
int batchSize = 1);
public:
public:
hl_activation_mode_t activeNode_;
hl_activation_mode_t activeGate_;
};
......
......@@ -44,13 +44,13 @@ namespace paddle {
* The config file api if gru_step_layer.
*/
class GruStepLayer : public Layer, public GruCompute {
protected:
protected:
Argument gate_;
Argument resetOutput_;
std::unique_ptr<Weight> weight_;
std::unique_ptr<Weight> bias_;
public:
public:
explicit GruStepLayer(const LayerConfig& config) : Layer(config) {}
~GruStepLayer() {}
......
......@@ -58,7 +58,7 @@ namespace paddle {
* The config file api is hsigmod_layer.
*/
class HierarchicalSigmoidLayer : public Layer {
public:
public:
explicit HierarchicalSigmoidLayer(const LayerConfig& config)
: Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -66,7 +66,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback) override;
protected:
protected:
/**
* The last of inputs is label layer.
*/
......
......@@ -26,7 +26,7 @@ namespace paddle {
* The config file api is identity_projection.
*/
class IdentityProjection : public Projection {
public:
public:
IdentityProjection(const ProjectionConfig& config,
const ParameterPtr& parameter,
bool useGpu);
......@@ -68,7 +68,7 @@ void IdentityProjection::backward(const UpdateCallback& callback) {
* The config file api is identity_projection.
*/
class IdentityOffsetProjection : public Projection {
public:
public:
IdentityOffsetProjection(const ProjectionConfig& config,
const ParameterPtr& parameter,
bool useGpu);
......
......@@ -33,12 +33,12 @@ namespace paddle {
*/
class InterpolationLayer : public Layer {
protected:
protected:
/// weightLast = 1 - weight
MatrixPtr weightLast_;
MatrixPtr tmpMatrix;
public:
public:
explicit InterpolationLayer(const LayerConfig& config) : Layer(config) {}
~InterpolationLayer() {}
......
......@@ -17,14 +17,14 @@ limitations under the License. */
namespace paddle {
class KmaxSeqScoreLayer : public Layer {
private:
private:
MatrixPtr scores_;
size_t beamSize_;
void kmaxScorePerSeq(const real* score,
real* sortedRes,
const ICpuGpuVectorPtr seqStartPos);
public:
public:
explicit KmaxSeqScoreLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -33,7 +33,7 @@ namespace paddle {
*/
class L2DistanceLayer : public Layer {
public:
public:
explicit L2DistanceLayer(const LayerConfig& config) : Layer(config) {}
~L2DistanceLayer() {}
......@@ -43,7 +43,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
private:
private:
// Store the result of subtracting Input2 from Input1 in forward computation,
// which will be reused in backward computation.
MatrixPtr inputSub_;
......
......@@ -60,7 +60,7 @@ enum PADDLE_DEVICE_ID {
* Define necessary variables and functions for every layer.
*/
class Layer {
protected:
protected:
/// Layer config
LayerConfig config_;
/// whether to use GPU
......@@ -112,7 +112,7 @@ protected:
/// Layer backward function
std::vector<std::shared_ptr<FunctionBase>> backward_;
public:
public:
/**
* Wait until all input value ready.
* Called before Layer::forward() function.
......@@ -137,7 +137,7 @@ public:
*/
virtual void markAllInputGrad();
protected:
protected:
/**
* Create layer function. Function is called in forward or backward.
* \param function, Layer::forward_ or Layer::backward_
......@@ -252,7 +252,7 @@ protected:
*/
void addOutputArgument(int deviceId);
public:
public:
explicit Layer(const LayerConfig& config, bool useGpu = FLAGS_use_gpu);
virtual ~Layer() {}
......@@ -490,7 +490,7 @@ public:
*/
virtual void onPassEnd() {}
protected:
protected:
/**
* Forward of activation function.
*/
......
......@@ -19,7 +19,7 @@ limitations under the License. */
namespace paddle {
class LinearChainCRF {
public:
public:
/**
* The size of para must be \f$(numClasses + 2) * numClasses\f$.
* The first numClasses values of para are for starting weights (\f$a\f$).
......@@ -71,7 +71,7 @@ public:
*/
MatrixPtr getXGrad() { return matGrad_; }
protected:
protected:
int numClasses_;
MatrixPtr a_;
MatrixPtr b_;
......
......@@ -20,7 +20,7 @@ limitations under the License. */
namespace paddle {
class LinearChainCTC {
public:
public:
LinearChainCTC(int numClasses, bool normByTimes);
// Calculate the negative log probability as loss
......@@ -35,7 +35,7 @@ public:
int* labelSeq,
int labelSeqLen);
protected:
protected:
int numClasses_, blank_, totalSegments_, totalTime_;
bool normByTimes_;
bool isInvalid_;
......
......@@ -21,7 +21,7 @@ limitations under the License. */
namespace paddle {
class LstmCompute {
public:
public:
void init(LayerConfig &config);
/**
......@@ -57,7 +57,7 @@ public:
hl_lstm_grad grad,
int frameSize);
public:
public:
hl_activation_mode_t activeNode_;
hl_activation_mode_t activeGate_;
hl_activation_mode_t activeState_;
......
......@@ -71,7 +71,7 @@ namespace paddle {
*/
class LstmLayer : public Layer, public LstmCompute {
public:
public:
explicit LstmLayer(const LayerConfig &config) : Layer(config) {}
bool init(const LayerMap &layerMap,
......@@ -87,7 +87,7 @@ public:
LayerStatePtr getState() override;
protected:
protected:
/**
* @brief Compute lstm forward one sequence by one sequence.
* @param batchSize The batchSize is not equal to the batch_size in
......@@ -165,7 +165,7 @@ protected:
*/
void getPrevBatchState(size_t numSequences);
protected:
protected:
/// Learned parameters, shape: (size, 4*size).
/// The weight ([size, 4*size]) contains \f$W_{hi}, W_{hf}, W_{hc}, W_{ho}\f$.
std::unique_ptr<Weight> weight_;
......
......@@ -22,7 +22,7 @@ namespace paddle {
* LstmStepLayer used in recurrent layer group.
*/
class LstmStepLayer : public Layer, public LstmCompute {
protected:
protected:
Argument state_;
Argument gate_;
Argument stateActive_;
......@@ -30,7 +30,7 @@ protected:
MatrixPtr checkIgGrad_, checkFgGrad_, checkOgGrad_;
std::unique_ptr<Weight> weight_;
public:
public:
explicit LstmStepLayer(const LayerConfig& config) : Layer(config) {}
~LstmStepLayer() {}
......
......@@ -19,7 +19,7 @@ limitations under the License. */
namespace paddle {
class CoordIterator {
public:
public:
std::vector<int> dims_;
std::vector<bool> directions_;
std::vector<int> curPos_;
......@@ -51,7 +51,7 @@ public:
}
}
public:
public:
CoordIterator(std::vector<int> dim, std::vector<bool> directions)
: dims_(dim), directions_(directions), end_(false) {
CHECK_EQ(dims_.size(), directions_.size());
......@@ -178,7 +178,7 @@ public:
* */
class MDLstmLayer : public LstmLayer {
public:
public:
explicit MDLstmLayer(const LayerConfig& config) : LstmLayer(config) {}
bool init(const LayerMap& layerMap,
......@@ -188,13 +188,13 @@ public:
void backward(const UpdateCallback& callback) override;
protected:
protected:
void forwardOneSequence(int start, CoordIterator& coordIter);
void backwardOneSequence(int start, CoordIterator& coordIter);
void forwardGate2OutputSequence(int start, CoordIterator& coordIter);
void backwardGate2OutputSequence(int start, CoordIterator& coordIter);
protected:
protected:
std::vector<Argument> frameInputGate_;
std::vector<Argument> frameForgetGate_;
std::vector<Argument> frameOutputGate_;
......
......@@ -25,7 +25,7 @@ namespace paddle {
* The config file api is mkldnn_addto
*/
class MKLDNNAddtoLayer : public MKLDNNLayer {
protected:
protected:
// layer size == ic * ih * iw == oc * oh *ow, and can not be changed
size_t layerSize_;
......@@ -38,7 +38,7 @@ protected:
std::vector<std::shared_ptr<mkldnn::primitive>> fwdBias_;
std::shared_ptr<mkldnn::primitive> bwdBias_;
public:
public:
explicit MKLDNNAddtoLayer(const LayerConfig& config) : MKLDNNLayer(config) {}
~MKLDNNAddtoLayer() {}
......@@ -59,7 +59,7 @@ public:
void updateWeights(const UpdateCallback& callback) override;
protected:
protected:
void resetFwdBuffers(std::vector<MKLDNNMatrixPtr>& inputs,
MKLDNNMatrixPtr& bias,
MKLDNNMatrixPtr& out);
......
......@@ -31,7 +31,7 @@ typedef enum {
*
*/
class CPUEngine {
public:
public:
static CPUEngine& Instance() {
// Thread-safe in C++11.
static CPUEngine myInstance;
......@@ -46,12 +46,12 @@ public:
mkldnn::engine& getEngine() { return cpuEngine_; }
protected:
protected:
CPUEngine() : cpuEngine_(mkldnn::engine::cpu, 0) {}
// CPUEngine() : cpuEngine_(mkldnn::engine::cpu_lazy, 0) {}
~CPUEngine() {}
private:
private:
mkldnn::engine cpuEngine_;
};
......@@ -60,7 +60,7 @@ private:
*
*/
class MKLDNNStream {
public:
public:
MKLDNNStream() : ready_(false) { resetState(); }
virtual ~MKLDNNStream() {}
......@@ -89,7 +89,7 @@ public:
ready_ = true;
}
private:
private:
bool ready_;
std::shared_ptr<mkldnn::stream> stream_;
};
......
......@@ -27,7 +27,7 @@ typedef mkldnn::batch_normalization_backward bn_bwd;
* The config file api is mkldnn_batch_norm
*/
class MKLDNNBatchNormLayer : public MKLDNNLayer {
protected:
protected:
// save forward primitive_desc, which can be used backward
std::shared_ptr<bn_fwd::primitive_desc> fwdPD_;
......@@ -62,7 +62,7 @@ protected:
MKLDNNMatrixPtr mean_;
MKLDNNMatrixPtr var_;
public:
public:
explicit MKLDNNBatchNormLayer(const LayerConfig& config)
: MKLDNNLayer(config), useGlobalStats_(true), hasInitedWgt_(false) {}
......@@ -88,7 +88,7 @@ public:
void convertWeightsFromPaddle() override;
protected:
protected:
void initWeight();
/**
* cal moving mean and variance.
......
......@@ -25,7 +25,7 @@ namespace paddle {
* The config file api is mkldnn_concat
*/
class MKLDNNConcatLayer : public MKLDNNLayer {
protected:
protected:
std::vector<std::shared_ptr<mkldnn::primitive>> bwds_;
// input channel numbers
std::vector<int> channels_;
......@@ -35,7 +35,7 @@ protected:
// if axis_ == 1, concat channel (default)
int axis_;
public:
public:
explicit MKLDNNConcatLayer(const LayerConfig& config)
: MKLDNNLayer(config), axis_(1) {}
......@@ -75,7 +75,7 @@ public:
return totalSize;
}
protected:
protected:
void resetFwdBuffers(std::vector<MKLDNNMatrixPtr>& inputs,
MKLDNNMatrixPtr& out);
void resetFwdPD(std::shared_ptr<mkldnn::concat::primitive_desc>& pd,
......
......@@ -28,7 +28,7 @@ typedef mkldnn::convolution_backward_data conv_bwdData;
* The config file api is mkldnn_conv
*/
class MKLDNNConvLayer : public MKLDNNLayer {
protected:
protected:
// padding height and width
int ph_, pw_;
// stride height and width
......@@ -59,7 +59,7 @@ protected:
std::unique_ptr<Weight> weight_;
std::unique_ptr<Weight> biases_;
public:
public:
explicit MKLDNNConvLayer(const LayerConfig& config)
: MKLDNNLayer(config), hasInitedWgt_(false), caffeMode_(true) {}
......@@ -92,7 +92,7 @@ public:
<< ", sw: " << sw_ << ", dh: " << dh_ << ", dw: " << dw_;
}
protected:
protected:
/**
* load the dims settings of this conv
*/
......
......@@ -28,7 +28,7 @@ typedef mkldnn::inner_product_backward_data fc_bwdData;
* The config file api is mkldnn_fc
*/
class MKLDNNFcLayer : public MKLDNNLayer {
protected:
protected:
// input layer size, can not be change after init
size_t iLayerSize_; // == ic * ih * iw
......@@ -42,7 +42,7 @@ protected:
std::unique_ptr<Weight> weight_;
std::unique_ptr<Weight> biases_;
public:
public:
explicit MKLDNNFcLayer(const LayerConfig& config)
: MKLDNNLayer(config), hasInitedWgt_(false) {}
......@@ -68,7 +68,7 @@ public:
void convertWeightsToPaddle() override;
protected:
protected:
void resetFwdBuffers(MKLDNNMatrixPtr& in,
MKLDNNMatrixPtr& wgt,
MKLDNNMatrixPtr& bias,
......
......@@ -27,7 +27,7 @@ typedef mkldnn::lrn_backward lrn_bwd;
* The config file api is mkldnn_lrn
*/
class MKLDNNLRNLayer : public MKLDNNLayer {
protected:
protected:
// save forward primitive_desc, which can be used in backward
std::shared_ptr<lrn_fwd::primitive_desc> fwdPD_;
// according to https://github.com/01org/mkl-dnn/blob/master/tests/gtests/
......@@ -37,7 +37,7 @@ protected:
int localSize_;
float alpha_, beta_; // scale and pow in paddle
public:
public:
explicit MKLDNNLRNLayer(const LayerConfig& config) : MKLDNNLayer(config) {}
~MKLDNNLRNLayer() {}
......@@ -56,7 +56,7 @@ public:
std::vector<MKLDNNMatrixPtr>& inputs,
MKLDNNMatrixPtr& out) override;
protected:
protected:
void resetFwdBuffers(MKLDNNMatrixPtr& in, MKLDNNMatrixPtr& out);
void resetFwdPD(std::shared_ptr<lrn_fwd::primitive_desc>& pd,
MKLDNNMatrixPtr in,
......
......@@ -33,7 +33,7 @@ typedef std::shared_ptr<MKLDNNLayer> MKLDNNLayerPtr;
*
*/
class MKLDNNLayer : public Layer {
protected:
protected:
// batch size
int bs_;
// their sizes are always from the first input layer
......@@ -95,7 +95,7 @@ protected:
// tmp input argument to save input grad, only used to merge grad
Argument tmpInArg_;
public:
public:
explicit MKLDNNLayer(const LayerConfig& config)
: Layer(config),
ih_(0),
......@@ -162,7 +162,7 @@ public:
*/
void addOutputArgument(int deviceId) { Layer::addOutputArgument(deviceId); }
protected:
protected:
/**
* Some layers may have different condition to reset the forward.
* The function returns the condition that do not need reset forward.
......@@ -233,7 +233,7 @@ protected:
*/
void resetMergeGrad(MKLDNNMatrixPtr& out);
protected:
protected:
/**
* Set deviceId of this layer.
*/
......@@ -340,7 +340,7 @@ protected:
}
}
private:
private:
/**
* clear all grad
*/
......
......@@ -27,7 +27,7 @@ typedef mkldnn::pooling_backward pool_bwd;
* The config file api is mkldnn_pool
*/
class MKLDNNPoolLayer : public MKLDNNLayer {
protected:
protected:
// padding height and width
int ph_, pw_;
// stride height and width
......@@ -44,7 +44,7 @@ protected:
// test_pooling_forward.cpp, pool need workspace for backward
std::shared_ptr<mkldnn::memory> workspace_;
public:
public:
explicit MKLDNNPoolLayer(const LayerConfig& config) : MKLDNNLayer(config) {}
~MKLDNNPoolLayer() {}
......@@ -70,7 +70,7 @@ public:
<< ", sw: " << sw_;
}
protected:
protected:
void resetFwdBuffers(MKLDNNMatrixPtr& in, MKLDNNMatrixPtr& out);
void resetFwdPD(std::shared_ptr<pool_fwd::primitive_desc>& pd,
MKLDNNMatrixPtr in,
......
......@@ -29,7 +29,7 @@ namespace paddle {
*/
class MKLPackedRecurrentLayer : public RecurrentLayer {
public:
public:
explicit MKLPackedRecurrentLayer(const LayerConfig& config)
: RecurrentLayer(config) {}
......@@ -38,7 +38,7 @@ public:
void backward(const UpdateCallback& callback) override;
protected:
protected:
void forwardBatch(int batchSize,
size_t numSequences,
const int* starts) override;
......@@ -47,7 +47,7 @@ protected:
size_t numSequences,
const int* starts) override;
protected:
protected:
/// packed_weight_ contains same data with
/// RecurrentLayer::weight_ but is packed
std::unique_ptr<MKLPackedWeight> packed_weight_;
......
......@@ -21,7 +21,7 @@ limitations under the License. */
namespace paddle {
class MKLPackedWeight {
protected:
protected:
/// The pointer of weight
real *weight_;
/// The pointer of cblas packed gemm to weight
......@@ -30,7 +30,7 @@ protected:
size_t width_;
bool transW_;
public:
public:
explicit MKLPackedWeight(MatrixPtr weight, bool transW = false) {
packedWeight_ = nullptr;
weight_ = weight->getData();
......@@ -59,7 +59,7 @@ public:
dst->getWidth());
}
protected:
protected:
void pack_(real *src) {
if (!packedWeight_) {
packedWeight_ = cblas_sgemm_alloc(CblasBMatrix, 1, width_, height_);
......
......@@ -23,11 +23,11 @@ namespace paddle {
* The config file api is maxid_layer.
*/
class MaxIdLayer : public Layer {
private:
private:
/// a predetermined number of best states at each level
size_t beamSize_;
public:
public:
explicit MaxIdLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -39,11 +39,11 @@ namespace paddle {
*/
class MaxLayer : public SequencePoolLayer {
protected:
protected:
// maxIndex_[i][j] = k : the value at (i, j) is from input[k].
IVectorPtr maxIndex_;
public:
public:
explicit MaxLayer(const LayerConfig& config) : SequencePoolLayer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -29,7 +29,7 @@ namespace paddle {
*/
class MaxOutLayer : public Layer {
protected:
protected:
size_t groups_;
size_t imgSizeH_, imgSizeW_;
/// outputChannels_ = channels_ / groups_
......@@ -38,7 +38,7 @@ protected:
size_t featLen_;
IVectorPtr maxoutId_;
public:
public:
/// return imgSizeH_ * imgSizeW_ * outputChannels_;
size_t getSize();
......
......@@ -23,10 +23,10 @@ namespace paddle {
* @brief Basic parent layer of different kinds of pooling
*/
class MaxPoolWithMaskLayer : public PoolLayer {
protected:
protected:
Argument mask_;
public:
public:
explicit MaxPoolWithMaskLayer(const LayerConfig& config)
: PoolLayer(config) {}
......
......@@ -30,7 +30,7 @@ namespace paddle {
* The config file api is mixed_layer.
*/
class MixedLayer : public Layer {
public:
public:
explicit MixedLayer(const LayerConfig& config) : Layer(config) {}
~MixedLayer() {}
......@@ -52,7 +52,7 @@ public:
*/
LayerStatePtr getState() override;
protected:
protected:
std::vector<std::unique_ptr<Projection>> projections_;
std::vector<std::unique_ptr<Operator>> operators_;
/// the matrix size of projection state
......
......@@ -41,7 +41,7 @@ namespace paddle {
*/
class MultiBoxLossLayer : public CostLayer {
public:
public:
explicit MultiBoxLossLayer(const LayerConfig& config) : CostLayer(config) {}
bool init(const LayerMap& layerMap, const ParameterMap& parameterMap);
......@@ -54,7 +54,7 @@ public:
void backwardImp(Matrix& outputValue, Argument& label, Matrix& outputGrad) {}
protected:
protected:
inline LayerPtr getPriorBoxLayer() { return inputLayers_[0]; }
inline LayerPtr getLabelLayer() { return inputLayers_[1]; }
inline LayerPtr getLocInputLayer(size_t index) {
......@@ -64,7 +64,7 @@ protected:
return inputLayers_[2 + inputNum_ + index];
}
protected:
protected:
size_t numClasses_;
real overlapThreshold_;
real negPosRatio_;
......
......@@ -29,7 +29,7 @@ namespace paddle {
* The computational complexity of generate one sample is O(1).
*/
class MultinomialSampler {
public:
public:
MultinomialSampler(const real* prob, int size);
//! protobuf always using double.
......@@ -53,7 +53,7 @@ public:
return gen1([&g, this]() { return rand_(g); });
}
protected:
protected:
/**
* @brief Generation
* @param[in] rand rand is a real random number distribution
......
......@@ -37,7 +37,7 @@ namespace paddle {
*/
class MultiplexLayer : public Layer {
protected:
protected:
/**
* @brief A struct is used to save the copy information, includes input
* layer index and copy size.
......@@ -64,7 +64,7 @@ protected:
/// Temporary matrix pointer to point to output data.
MatrixPtr tmpDest_;
public:
public:
explicit MultiplexLayer(const LayerConfig& config) : Layer(config) {}
~MultiplexLayer() {}
......@@ -75,7 +75,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
private:
private:
/**
* @brief Calculate copy info for input layers.
*/
......
......@@ -54,7 +54,7 @@ class NCELayer : public Layer {
IVectorPtr labelIds_;
public:
public:
explicit NCELayer(const LayerConfig& config)
: Layer(config),
numClasses_(config.num_classes()),
......
......@@ -27,7 +27,7 @@ namespace paddle {
* @note Normalize the input in local region
*/
class NormLayer : public Layer {
public:
public:
explicit NormLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -49,12 +49,12 @@ public:
* Need to implement in the futrue.
*/
class ResponseNormLayer : public NormLayer {
protected:
protected:
size_t channels_, size_, outputX_, imgSize_, outputY_, imgSizeY_;
real scale_, pow_;
MatrixPtr denoms_;
public:
public:
explicit ResponseNormLayer(const LayerConfig& config) : NormLayer(config) {}
bool init(const LayerMap& layerMap,
......@@ -76,7 +76,7 @@ public:
* Cheng-Yang Fu, Alexander C. Berg. SSD: Single Shot MultiBox Detector
*/
class CrossChannelNormLayer : public NormLayer {
public:
public:
explicit CrossChannelNormLayer(const LayerConfig& config)
: NormLayer(config) {}
bool init(const LayerMap& layerMap, const ParameterMap& parameterMap);
......@@ -85,7 +85,7 @@ public:
MatrixPtr createSampleMatrix(MatrixPtr data, size_t iter, size_t spatialDim);
MatrixPtr createSpatialMatrix(MatrixPtr data, size_t iter, size_t spatialDim);
protected:
protected:
size_t channels_;
std::unique_ptr<Weight> scale_;
MatrixPtr scaleDiff_;
......
......@@ -28,7 +28,7 @@ class CMRProjectionNormLayer : public ResponseNormLayer {
size_t imgSizeH_, imgSizeW_;
size_t outputH_, outputW_;
public:
public:
explicit CMRProjectionNormLayer(const LayerConfig& config)
: ResponseNormLayer(config) {}
......@@ -41,7 +41,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
protected:
protected:
TensorShape shape_;
};
} // namespace paddle
......@@ -34,7 +34,7 @@ namespace paddle {
* @note: Operator can't have parameters.
*/
class Operator {
public:
public:
static Operator* create(const OperatorConfig& config, bool useGpu);
Operator(const OperatorConfig& config, bool useGpu)
......@@ -81,7 +81,7 @@ public:
*/
virtual LayerStatePtr getState() { return nullptr; }
protected:
protected:
/// Config of operator
OperatorConfig config_;
bool useGpu_;
......
......@@ -28,12 +28,12 @@ namespace paddle {
*/
class OuterProdLayer : public Layer {
protected:
protected:
MatrixPtr tmpMtx0;
MatrixPtr tmpRow0;
MatrixPtr tmpRow1;
public:
public:
explicit OuterProdLayer(const LayerConfig& config) : Layer(config) {}
~OuterProdLayer() {}
......
......@@ -24,7 +24,7 @@ namespace paddle {
* the 4th dimenstion according padc_, padh_ and padw_.
*/
class PadLayer : public Layer {
public:
public:
explicit PadLayer(const LayerConfig& config) : Layer(config) {}
~PadLayer() {}
......@@ -34,7 +34,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
protected:
protected:
void setOutDims(const size_t batchSize);
void setTensorDim(const size_t batchSize);
......
......@@ -36,7 +36,7 @@ namespace paddle {
*/
class ParameterReluLayer : public Layer {
protected:
protected:
std::unique_ptr<Weight> weight_;
/**
......@@ -51,7 +51,7 @@ protected:
*/
size_t partialSum_;
public:
public:
explicit ParameterReluLayer(const LayerConfig& config) : Layer(config) {}
~ParameterReluLayer() {}
......
......@@ -26,7 +26,7 @@ namespace paddle {
* Pools the input within regions
*/
class Pool3DLayer : public Layer {
public:
public:
explicit Pool3DLayer(const LayerConfig& config) : Layer(config) {}
~Pool3DLayer() {}
......@@ -36,7 +36,7 @@ public:
void backward(const UpdateCallback& callback) override;
size_t getSize();
protected:
protected:
int channels_;
int sizeX_, sizeY_, sizeZ_;
int strideW_, strideH_, strideD_;
......
......@@ -26,7 +26,7 @@ namespace paddle {
* Pools the input within regions
*/
class PoolLayer : public Layer {
protected:
protected:
size_t channels_, sizeX_, stride_, outputX_, imgSize_;
int confPadding_;
......@@ -40,7 +40,7 @@ protected:
bool excludeMode_;
public:
public:
explicit PoolLayer(const LayerConfig& config) : Layer(config) {}
/**
......
......@@ -20,7 +20,7 @@ limitations under the License. */
namespace paddle {
class PoolProjection : public Projection {
protected:
protected:
size_t imgSizeY_, imgSize_;
size_t outputY_, outputX_;
size_t strideY_, stride_;
......@@ -30,7 +30,7 @@ protected:
std::string poolType_;
bool excludeMode_;
public:
public:
PoolProjection(const ProjectionConfig& config,
ParameterPtr parameter,
bool useGpu);
......@@ -45,7 +45,7 @@ public:
};
class MaxPoolProjection : public PoolProjection {
public:
public:
MaxPoolProjection(const ProjectionConfig& config,
ParameterPtr parameter,
bool useGpu)
......@@ -56,7 +56,7 @@ public:
};
class AvgPoolProjection : public PoolProjection {
public:
public:
AvgPoolProjection(const ProjectionConfig& config,
ParameterPtr parameter,
bool useGpu)
......
......@@ -24,13 +24,13 @@ namespace paddle {
* @brief Basic parent layer of different kinds of pooling
*/
class PoolProjectionLayer : public PoolLayer {
protected:
protected:
size_t imgSizeH_, imgSizeW_;
size_t outputH_, outputW_;
std::unique_ptr<PoolProjection> poolProjection_;
ProjectionConfig projectionConfig_;
public:
public:
explicit PoolProjectionLayer(const LayerConfig& config) : PoolLayer(config) {
PoolConfig* conf = projectionConfig_.mutable_pool_conf();
*conf = config_.inputs(0).pool_conf();
......
......@@ -32,10 +32,10 @@ namespace paddle {
*/
class PowerLayer : public Layer {
protected:
protected:
MatrixPtr tmpMtx;
public:
public:
explicit PowerLayer(const LayerConfig& config) : Layer(config) {}
~PowerLayer() {}
......
......@@ -17,7 +17,7 @@ limitations under the License. */
namespace paddle {
class PrintLayer : public Layer {
public:
public:
explicit PrintLayer(const LayerConfig& config) : Layer(config) {}
void forward(PassType passType) override {
......
......@@ -28,7 +28,7 @@ namespace paddle {
*/
class PriorBoxLayer : public Layer {
public: // NOLINT
public: // NOLINT
explicit PriorBoxLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
const ParameterMap& parameterMap) override;
......@@ -36,7 +36,7 @@ public: // NOLINT
void forward(PassType passType) override;
void backward(const UpdateCallback& callback) override {}
protected: // NOLINT
protected: // NOLINT
int numPriors_;
std::vector<int> minSize_;
std::vector<int> maxSize_;
......
......@@ -37,7 +37,7 @@ namespace paddle {
* to output Argument.
*/
class Projection {
public:
public:
static Projection* create(const ProjectionConfig& config,
ParameterPtr parameter,
bool useGpu);
......@@ -98,7 +98,7 @@ public:
*/
size_t getOutputSize() const { return config_.output_size(); }
protected:
protected:
/**
* Create layer function. Function is called in forward or backward.
* \param function, Layer::forward_ or Layer::backward_
......@@ -119,7 +119,7 @@ protected:
func->init(config);
}
protected:
protected:
/// Config of projection
ProjectionConfig config_;
/// Parameter of projection
......
......@@ -33,7 +33,7 @@ namespace paddle {
*/
class ROIPoolLayer : public Layer {
protected:
protected:
size_t channels_;
size_t width_;
size_t height_;
......@@ -44,7 +44,7 @@ protected:
// Since there is no int matrix, use real maxtrix instead.
MatrixPtr maxIdxs_;
public:
public:
explicit ROIPoolLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -40,7 +40,7 @@ namespace paddle {
*/
class RecurrentLayer : public Layer {
public:
public:
explicit RecurrentLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -56,7 +56,7 @@ public:
LayerStatePtr getState() override;
protected:
protected:
/**
* @brief If user do not set --rnn_use_batch=true, it will
* compute rnn forward one sequence by one sequence in default.
......@@ -110,7 +110,7 @@ protected:
size_t numSequences,
const int* starts);
protected:
protected:
std::unique_ptr<Weight> weight_;
std::unique_ptr<Weight> bias_;
......
......@@ -27,7 +27,7 @@ namespace paddle {
* between RecurrentLayerGroupBegin and RecurrentLayerGroupEnd.
*/
class RecurrentLayerGroup : public Layer {
public:
public:
explicit RecurrentLayerGroup(const LayerConfig& config) : Layer(config) {}
void initSubNetwork(NeuralNetwork* rootNetwork,
......@@ -58,7 +58,7 @@ public:
callback(*network_);
}
private:
private:
std::unique_ptr<RecurrentGradientMachine> network_;
};
......
......@@ -24,7 +24,7 @@ namespace paddle {
* resize matrix: (height * width / size) * size
*/
class ResizeLayer : public Layer {
public:
public:
explicit ResizeLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -32,7 +32,7 @@ namespace paddle {
*/
class RotateLayer : public Layer {
public:
public:
explicit RotateLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap, const ParameterMap& parameterMap);
......@@ -40,7 +40,7 @@ public:
void forward(PassType passType);
void backward(const UpdateCallback& callback = nullptr);
private:
private:
int batchSize_;
int size_;
int height_;
......
......@@ -22,7 +22,7 @@ namespace paddle {
* \brief Row Convolution Layer.
*/
class RowConvLayer : public Layer {
public:
public:
explicit RowConvLayer(const LayerConfig& config) : Layer(config) {}
~RowConvLayer() {}
......@@ -32,7 +32,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
protected:
protected:
// Row convolution weight, context_lenght_ * fan_out.
// fan_out is the size of output feature.
std::unique_ptr<Weight> weight_;
......
......@@ -26,12 +26,12 @@ namespace paddle {
*/
class RowL2NormLayer : public Layer {
protected:
protected:
MatrixPtr inSquare_;
MatrixPtr l2NormReciprocal_;
MatrixPtr dotSum_;
public:
public:
explicit RowL2NormLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -31,7 +31,7 @@ class SamplingIdLayer : public Layer {
std::uniform_real_distribution<double> rand1_;
std::vector<Argument> tmpCpuInput_;
public:
public:
explicit SamplingIdLayer(const LayerConfig& config)
: Layer(config), rand1_(0, 1) {}
......
......@@ -30,11 +30,11 @@ namespace paddle {
*/
class ScaleShiftLayer : public Layer {
protected:
protected:
std::unique_ptr<Weight> scale_;
std::unique_ptr<Weight> offset_;
public:
public:
explicit ScaleShiftLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -29,7 +29,7 @@ namespace paddle {
* region.
*/
class ScaleSubRegionLayer : public Layer {
public:
public:
explicit ScaleSubRegionLayer(const LayerConfig& config) : Layer(config) {}
~ScaleSubRegionLayer() {}
......@@ -40,7 +40,7 @@ public:
void backward(const UpdateCallback& callback = nullptr);
protected:
protected:
TensorShape shape_;
TensorShape indicesShape_;
size_t imgH_;
......
......@@ -32,7 +32,7 @@ namespace paddle {
*/
class ScalingLayer : public Layer {
public:
public:
explicit ScalingLayer(const LayerConfig& config) : Layer(config) {}
~ScalingLayer() {}
......
......@@ -17,7 +17,7 @@ limitations under the License. */
namespace paddle {
class ScalingProjection : public Projection {
public:
public:
ScalingProjection(const ProjectionConfig& config,
const ParameterPtr& parameter,
bool useGpu)
......@@ -48,7 +48,7 @@ public:
}
}
protected:
protected:
std::unique_ptr<Weight> weight_;
};
......
......@@ -33,11 +33,11 @@ namespace paddle {
* The config file api is selective_fc_layer.
*/
class SelectiveFullyConnectedLayer : public Layer {
protected:
protected:
WeightList weights_;
std::unique_ptr<Weight> biases_;
private:
private:
/**
* Get selected columns each forward.
*/
......@@ -60,7 +60,7 @@ private:
/// if true, means output_.value is the same as Fc Layer
bool fullOutput_;
public:
public:
explicit SelectiveFullyConnectedLayer(const LayerConfig& config)
: Layer(config), selCols_(nullptr) {}
......@@ -94,7 +94,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
private:
private:
/**
* @brief Make SelectiveFC act as FullyConnectedLayer
*/
......
......@@ -29,10 +29,10 @@ namespace paddle {
*/
class SequenceConcatLayer : public Layer {
protected:
protected:
std::unique_ptr<Weight> biases_;
public:
public:
explicit SequenceConcatLayer(const LayerConfig& config) : Layer(config) {}
~SequenceConcatLayer() {}
......
......@@ -38,12 +38,12 @@ namespace paddle {
*/
class SequenceLastInstanceLayer : public SequencePoolLayer {
protected:
protected:
MatrixPtr tmpSrc_;
MatrixPtr tmpDest_;
std::vector<int> instanceIds_;
public:
public:
explicit SequenceLastInstanceLayer(const LayerConfig& config)
: SequencePoolLayer(config) {}
......
......@@ -41,7 +41,7 @@ namespace paddle {
*/
class SequencePoolLayer : public Layer {
protected:
protected:
int type_;
std::unique_ptr<Weight> biases_;
enum SequenceLevel { kNonSeq = 0, kSeq = 1 };
......@@ -51,7 +51,7 @@ protected:
// Whether the input sequence is reversed or not.
bool reversed_ = false;
public:
public:
explicit SequencePoolLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -29,12 +29,12 @@ namespace paddle {
*/
class SequenceReshapeLayer : public Layer {
protected:
protected:
std::unique_ptr<Weight> biases_;
MatrixPtr reshapedOutputGrad;
public:
public:
explicit SequenceReshapeLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -21,7 +21,7 @@ limitations under the License. */
namespace paddle {
class SequenceSliceLayer : public Layer {
public:
public:
explicit SequenceSliceLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -30,7 +30,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
private:
private:
/*
* TODO(caoying)
* In PaddePaddle, currently all matrices are real number types,
......
......@@ -39,7 +39,7 @@ namespace paddle {
*
*/
class SequenceToBatch {
public:
public:
explicit SequenceToBatch(bool useGpu) : useGpu_(useGpu) {}
/* resize and calculate the batchIndex_ */
......@@ -82,7 +82,7 @@ public:
numBatch_ = seq2batch.numBatch_;
}
protected:
protected:
void sequence2BatchCopy(Matrix &batch,
Matrix &sequence,
IVector &seq2BatchIdx,
......
......@@ -44,14 +44,14 @@ namespace paddle {
* The config file api is slice_projection.
*/
class SliceProjection : public Projection {
public:
public:
SliceProjection(const ProjectionConfig& config,
const ParameterPtr& parameter,
bool useGpu);
virtual void forward();
virtual void backward(const UpdateCallback& callback);
protected:
protected:
std::vector<std::pair<size_t, size_t>> slices_;
};
......
......@@ -36,7 +36,7 @@ namespace paddle {
*/
class SlopeInterceptLayer : public Layer {
public:
public:
explicit SlopeInterceptLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -29,7 +29,7 @@ namespace paddle {
*/
class SpatialPyramidPoolLayer : public Layer {
protected:
protected:
size_t channels_;
size_t imgSizeW_;
size_t imgSizeH_;
......@@ -40,7 +40,7 @@ protected:
std::vector<Argument> projOutput_;
std::vector<std::pair<size_t, size_t>> projCol_;
public:
public:
explicit SpatialPyramidPoolLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -21,7 +21,7 @@ limitations under the License. */
namespace paddle {
class SubNestedSequenceLayer : public Layer {
public:
public:
explicit SubNestedSequenceLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -30,7 +30,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback = nullptr) override;
private:
private:
/*
* This functions generates the indices of rows in a batch according to the
* indices of selected sub-sequence in each sequence.
......
......@@ -27,12 +27,12 @@ namespace paddle {
*/
class SubSequenceLayer : public Layer {
protected:
protected:
std::unique_ptr<Weight> biases_;
MatrixPtr tmpSrc_;
MatrixPtr tmpDest_;
public:
public:
explicit SubSequenceLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -32,13 +32,13 @@ namespace paddle {
*/
class SumToOneNormLayer : public Layer {
protected:
protected:
/// reciprocalRowSum_ = \f$1 / \sum_{k=1}^N in[k]\f$
MatrixPtr reciprocalRowSum_;
/// dotSum = output_.grad \f$.*\f$ output_.value
MatrixPtr dotSum_;
public:
public:
explicit SumToOneNormLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -22,7 +22,7 @@ namespace paddle {
* \brief This layer calculate softmax in image channel dimension.
*/
class SwitchOrderLayer : public Layer {
public:
public:
explicit SwitchOrderLayer(const LayerConfig& config) : Layer(config) {}
~SwitchOrderLayer() {}
......@@ -34,7 +34,7 @@ public:
void setInDims();
void setOutDims();
protected:
protected:
std::vector<std::shared_ptr<FunctionBase>> nchw2nhwc_;
std::vector<std::shared_ptr<FunctionBase>> nhwc2nchw_;
TensorShape inDims_;
......
......@@ -32,7 +32,7 @@ namespace paddle {
* @note If \f$ids[i] = -1\f$, it will be ignored.
*/
class TableProjection : public Projection {
public:
public:
TableProjection(const ProjectionConfig& config,
const ParameterPtr& parameter,
bool useGpu);
......@@ -43,7 +43,7 @@ public:
virtual void forward();
virtual void backward(const UpdateCallback& callback);
protected:
protected:
std::unique_ptr<Weight> table_;
};
......
......@@ -37,11 +37,11 @@ namespace paddle {
*/
class TensorLayer : public Layer {
protected:
protected:
WeightList weights_;
std::unique_ptr<Weight> biases_;
public:
public:
explicit TensorLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -29,7 +29,7 @@ namespace paddle {
* The config file api is trans_layer.
*/
class TransLayer : public Layer {
public:
public:
explicit TransLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......
......@@ -24,14 +24,14 @@ namespace paddle {
* The config file api is trans_full_matrix_projection.
*/
class TransposedFullMatrixProjection : public Projection {
public:
public:
TransposedFullMatrixProjection(const ProjectionConfig& config,
ParameterPtr parameter,
bool useGPu);
virtual void forward();
virtual void backward(const UpdateCallback& callback);
protected:
protected:
std::unique_ptr<Weight> weight_;
};
......
......@@ -30,7 +30,7 @@ namespace paddle {
*/
class UpsampleLayer : public Layer {
public:
public:
explicit UpsampleLayer(const LayerConfig& config) : Layer(config) {}
~UpsampleLayer() {}
......@@ -42,7 +42,7 @@ public:
size_t getOutputSize();
protected:
protected:
size_t scale_, scaleY_;
size_t upsampleSize_, upsampleSizeY_;
size_t padOutX_, padOutY_;
......
......@@ -23,7 +23,7 @@ DECLARE_int32(trainer_id);
namespace paddle {
class ValidationLayer : public Layer {
public:
public:
explicit ValidationLayer(const LayerConfig& config) : Layer(config) {}
bool init(const LayerMap& layerMap,
......@@ -51,7 +51,7 @@ public:
* AucValidation
*/
class AucValidation : public ValidationLayer {
public:
public:
explicit AucValidation(const LayerConfig& config)
: ValidationLayer(config),
cpuOutput_(nullptr),
......@@ -72,7 +72,7 @@ public:
};
std::vector<PredictionResult> predictArray_;
private:
private:
bool passBegin_;
std::unique_ptr<Evaluator> evaluator_;
MatrixPtr cpuOutput_;
......@@ -84,7 +84,7 @@ private:
* positive-negative pair rate Validation
*/
class PnpairValidation : public ValidationLayer {
public:
public:
explicit PnpairValidation(const LayerConfig& config)
: ValidationLayer(config) {}
......@@ -95,7 +95,7 @@ public:
void onPassEnd() override;
private:
private:
bool passBegin_;
std::unique_ptr<Evaluator> evaluator_;
};
......
......@@ -26,7 +26,7 @@ namespace paddle {
* The config file api is warp_ctc_layer.
*/
class WarpCTCLayer : public Layer {
public:
public:
explicit WarpCTCLayer(const LayerConfig& config) : Layer(config) {}
~WarpCTCLayer() {}
......@@ -35,7 +35,7 @@ public:
void forward(PassType passType) override;
void backward(const UpdateCallback& callback) override;
protected:
protected:
/**
* sequence matrix and batch matrix copy:
* sequence (s0, s0, s0, s0; s1, s1; s2, s2, s2; s3)
......@@ -49,7 +49,7 @@ protected:
const ICpuGpuVectorPtr& seqStartPositions,
bool normByTimes);
protected:
protected:
size_t numClasses_;
size_t blank_;
size_t maxSequenceLength_;
......
......@@ -44,7 +44,7 @@ class MKLDNNTester {
std::vector<VectorPtr> paraValues;
};
protected:
protected:
std::vector<TestConfig> configs_;
vector<string> layerNames_;
vector<vector<DataLayerPtr>> dataLayers_;
......@@ -65,7 +65,7 @@ protected:
/// passType, PASS_TRAIN, PASS_TEST or PASS_GC (Gradient Check pass)
PassType passType_;
public:
public:
explicit MKLDNNTester(size_t iter = 3, float epsilon = 1e-4) {
iter_ = iter;
eps_ = epsilon;
......@@ -75,7 +75,7 @@ public:
~MKLDNNTester() {}
public:
public:
void run(const TestConfig& dnn,
const TestConfig& ref,
size_t batchSize,
......@@ -97,7 +97,7 @@ public:
bool use_mkldnn,
size_t iter = 2);
private:
private:
void reset(const TestConfig& dnn, const TestConfig& ref, size_t batchSize);
void setInputImgSize();
void runOnce();
......
......@@ -27,7 +27,7 @@ using namespace paddle; // NOLINT
using namespace std; // NOLINT
class MultinomialSamplerTester : public MultinomialSampler {
public:
public:
MultinomialSamplerTester(real* prob, int size)
: MultinomialSampler(prob, size) {}
......
......@@ -26,7 +26,7 @@ DECLARE_int32(seed);
using namespace paddle; // NOLINT
using namespace std; // NOLINT
class TrainerForTest : public paddle::Trainer {
public:
public:
void startTrain() {
GradientMachine& gm = *this->trainerInternal_.getGradientMachine();
gm.start();
......
......@@ -225,7 +225,7 @@ TEST(Layer, RecurrentLayer) {
#include "paddle/gserver/layers/RecurrentLayer.h"
template <class T>
class TestRecurrentLayer {
public:
public:
LayerConfig config_;
bool useGpu_;
bool useBatch_;
......
......@@ -27,7 +27,7 @@ namespace paddle {
* This is the base class of all Allocator class.
*/
class Allocator {
public:
public:
virtual ~Allocator() {}
virtual void* alloc(size_t size) = 0;
virtual void free(void* ptr) = 0;
......@@ -38,7 +38,7 @@ public:
* @brief CPU allocator implementation.
*/
class CpuAllocator : public Allocator {
public:
public:
~CpuAllocator() {}
/**
......@@ -76,7 +76,7 @@ public:
* @brief GPU allocator implementation.
*/
class GpuAllocator : public Allocator {
public:
public:
~GpuAllocator() {}
/**
......@@ -107,7 +107,7 @@ public:
* @brief CPU pinned memory allocator implementation.
*/
class CudaHostAllocator : public Allocator {
public:
public:
~CudaHostAllocator() {}
/**
......
......@@ -43,7 +43,7 @@ typedef bool_constant<bool, true> true_type;
address += row * ld + col;
class MatrixOffset {
public:
public:
size_t aCol_;
size_t aRow_;
size_t bCol_;
......@@ -72,14 +72,14 @@ public:
template <class T>
class BaseMatrixT : public TensorExpression<BaseMatrixT<T>, T> {
public:
public:
size_t height_, width_;
size_t stride_;
T* data_;
bool trans_;
bool useGpu_;
public:
public:
virtual ~BaseMatrixT() {}
BaseMatrixT(size_t height, size_t width, T* data, bool trans, bool useGpu)
: height_(height),
......
......@@ -22,7 +22,7 @@ limitations under the License. */
namespace paddle {
class CpuSparseMatrix : public Matrix {
public:
public:
CpuSparseMatrix(size_t height,
size_t width,
size_t nnz, /* used to allocate space */
......@@ -291,10 +291,10 @@ public:
LOG(FATAL) << "not supported!";
}
private:
private:
MatrixPtr clone(size_t height = 0, size_t width = 0, bool useGpu = false);
protected:
protected:
void sparseResize();
/*for csr , record row start position, for csc, record row index for every no
* zero value*/
......@@ -310,10 +310,10 @@ protected:
static ThreadLocal<std::vector<CpuSparseMatrixPtr>> cpuLocalMats_;
// BaseMatrixT interface
public:
public:
bool isSparse() const { return true; }
private:
private:
using Matrix::mul;
using Matrix::copyFrom;
using Matrix::rowMax;
......@@ -329,7 +329,7 @@ private:
namespace paddle {
class CpuSparseMatrix : public Matrix {
public:
public:
CpuSparseMatrix(size_t height,
size_t width,
size_t nnz, /* used to allocate space */
......
......@@ -31,17 +31,17 @@ namespace paddle {
template <typename Arg>
class CopyToCpu {
public:
public:
explicit CopyToCpu(Arg& arg) : arg_(arg) {}
Arg& copiedArg() const { return arg_; }
private:
private:
Arg& arg_;
};
template <>
class CopyToCpu<Matrix> {
public:
public:
explicit CopyToCpu(Matrix& arg) : arg_(arg) {
if (arg.useGpu()) {
CHECK(!arg.isTransposed()) << "Not supported";
......@@ -59,14 +59,14 @@ public:
}
Matrix& copiedArg() const { return copied_ ? *copied_ : arg_; }
private:
private:
Matrix& arg_;
MatrixPtr copied_;
};
template <>
class CopyToCpu<const Matrix> {
public:
public:
explicit CopyToCpu(const Matrix& arg) : arg_(arg) {
if (arg.useGpu()) {
CHECK(!arg.isTransposed()) << "Not supported";
......@@ -79,14 +79,14 @@ public:
}
const Matrix& copiedArg() const { return copied_ ? *copied_ : arg_; }
private:
private:
const Matrix& arg_;
MatrixPtr copied_;
};
template <>
class CopyToCpu<IVector> {
public:
public:
explicit CopyToCpu(IVector& arg) : arg_(arg) {
if (arg.useGpu()) {
copied_ = IVector::create(arg.getSize(), /* useGpu= */ false);
......@@ -100,14 +100,14 @@ public:
}
IVector& copiedArg() const { return copied_ ? *copied_ : arg_; }
private:
private:
IVector& arg_;
IVectorPtr copied_;
};
template <>
class CopyToCpu<const IVector> {
public:
public:
explicit CopyToCpu(const IVector& arg) : arg_(arg) {
if (arg.useGpu()) {
copied_ = IVector::create(arg.getSize(), /* useGpu= */ false);
......@@ -116,7 +116,7 @@ public:
}
const IVector& copiedArg() const { return copied_ ? *copied_ : arg_; }
private:
private:
const IVector& arg_;
IVectorPtr copied_;
};
......@@ -128,7 +128,7 @@ class GpuFuncWrapperImp;
template <typename F, typename R, typename... Args>
class GpuFuncWrapperBase {
public:
public:
typedef R ResultType;
R operator()(F&& f, Args... args) {
return f(CopyToCpu<typename std::remove_reference<Args>::type>(args)
......
......@@ -35,7 +35,7 @@ typedef std::shared_ptr<MKLDNNMatrix> MKLDNNMatrixPtr;
*
*/
class MKLDNNMatrix : public CpuMatrix, public mkldnn::memory {
public:
public:
MKLDNNMatrix(CpuMatrixPtr m, mkldnn::memory::primitive_desc pd)
: CpuMatrix(m->getData(), m->getHeight(), m->getWidth(), false),
mkldnn::memory(pd, m->getData()),
......@@ -107,7 +107,7 @@ public:
dst.copyFrom(*m_);
}
public:
public:
/**
* Reorder this MKLDNNMatrix from other format.
* Support inplace reorder.
......@@ -226,7 +226,7 @@ public:
*/
mkldnn::engine getEngine() { return getPrimitiveDesc().get_engine(); }
protected:
protected:
/**
* Do reorder once.
* Can support inplace.
......@@ -248,7 +248,7 @@ protected:
set_data_handle(data);
}
private:
private:
// save the CpuMatrixPtr in case the buffer released outside
CpuMatrixPtr m_;
};
......
......@@ -77,7 +77,7 @@ typedef std::shared_ptr<CpuSparseMatrix> CpuSparseMatrixPtr;
* instead.
*/
class Matrix : public BaseMatrix {
protected:
protected:
Matrix(MemoryHandlePtr memHandle,
size_t height,
size_t width,
......@@ -95,11 +95,11 @@ protected:
static ThreadLocal<MatrixPtr> tmpMat_;
public:
public:
size_t elementCnt_; // maximal number of elements which can be held in data_
MemoryHandlePtr memoryHandle_;
public:
public:
virtual ~Matrix() {}
static MatrixPtr create(MemoryHandlePtr memHandle,
......@@ -412,7 +412,7 @@ public:
LOG(FATAL) << "Not implemented";
}
public:
public:
/// Only set all variables to 0 or NULL but not free them.
virtual void clear() {
height_ = 0;
......@@ -1228,7 +1228,7 @@ inline std::ostream& operator<<(std::ostream& os, const Matrix& mat) {
}
class GpuMatrix : public Matrix {
public:
public:
GpuMatrix();
GpuMatrix(size_t height, size_t width, bool trans = false);
......@@ -1660,11 +1660,11 @@ public:
};
class CpuMatrix : public Matrix {
private:
private:
MatrixPtr sftmaxSum_;
MatrixPtr sftmaxDot_;
public:
public:
CpuMatrix(size_t height, size_t width, bool trans = false);
CpuMatrix(real* data, size_t height, size_t width, bool trans = false)
: Matrix(data, height, width, trans, false) {}
......@@ -1892,7 +1892,7 @@ public:
real* getRow(size_t row) { return BaseMatrix::rowBuf(row); }
virtual real* getRowBuf(size_t row) { return getRow(row); }
public:
public:
/// add b to each sample of this.
void addBias(Matrix& b, real scale);
void addSharedBias(Matrix& b, real scale);
......@@ -2128,7 +2128,7 @@ public:
};
class SharedCpuMatrix : public CpuMatrix {
public:
public:
#ifndef PADDLE_MOBILE_INFERENCE
/* blockNum is number of partitions of the matrix */
SharedCpuMatrix(int blockNum, size_t height, size_t width, bool trans = false)
......@@ -2160,12 +2160,12 @@ public:
~SharedCpuMatrix() {}
public:
public:
virtual void mul(CpuSparseMatrix* a, CpuMatrix* b, real scaleAB, real scaleT);
virtual void add(Matrix& b, real p1, real p2);
virtual void add(real p1, real p2);
private:
private:
using Matrix::mul;
void initShared(int blockNum);
void initBlock(int blockNum);
......
......@@ -27,7 +27,7 @@ struct SimpleCode {
inline bool calcBit(int bit) const { return c_ & (1 << bit); }
inline int getLength() const { return findLastSet(c_) - 1; }
private:
private:
size_t c_;
};
......@@ -39,7 +39,7 @@ struct SimpleCodeTable {
size_t size() const { return numClasses_; }
int getMaxCodeLength() const { return findLastSet(numClasses_ - 1); }
private:
private:
size_t numClasses_;
int maxCodeLength_;
};
......
......@@ -20,16 +20,16 @@ limitations under the License. */
namespace paddle {
class MemoryHandle {
protected:
protected:
explicit MemoryHandle(size_t size);
virtual ~MemoryHandle() {}
public:
public:
void* getBuf() const { return buf_; }
size_t getSize() const { return size_; }
size_t getAllocSize() const { return allocSize_; }
protected:
protected:
PoolAllocator* allocator_;
size_t size_; // the requested size
size_t allocSize_; // the allocated size
......@@ -43,7 +43,7 @@ protected:
* The raw handle will be released at destructor
*/
class GpuMemoryHandle : public MemoryHandle {
public:
public:
explicit GpuMemoryHandle(size_t size);
virtual ~GpuMemoryHandle();
};
......@@ -54,7 +54,7 @@ public:
* The raw handle will be released at destructor
*/
class CpuMemoryHandle : public MemoryHandle {
public:
public:
explicit CpuMemoryHandle(size_t size);
virtual ~CpuMemoryHandle();
};
......
......@@ -27,7 +27,7 @@ namespace paddle {
* @brief Memory pool allocator implementation.
*/
class PoolAllocator {
public:
public:
/**
* @brief constructor.
* @param allocator a Allocator object.
......@@ -47,7 +47,7 @@ public:
void free(void* ptr, size_t size);
std::string getName() { return name_; }
private:
private:
void freeAll();
void printAll();
std::unique_ptr<Allocator> allocator_;
......
......@@ -26,7 +26,7 @@ namespace paddle {
* If not set memory handler, then the data could be auto growth.
*/
class RowBuffer {
public:
public:
/**
* @brief RowBuffer create a auto-growth row buffer. The row length is width.
* @param width the length of each row, a.k.a matrix width.
......@@ -129,7 +129,7 @@ public:
*/
inline size_t getWidth() const { return width_; }
private:
private:
//! TODO(yuyang18): Add resize method to CpuMemHandlePtr, then we can get rid
//! of std::vector here.
CpuMemHandlePtr preallocatedBuf_;
......
......@@ -25,7 +25,7 @@ namespace paddle {
typedef std::shared_ptr<_hl_sparse_matrix_s> hl_sparse_matrix_s_ptr;
class GpuSparseMatrix : public Matrix {
public:
public:
MemoryHandlePtr sMemoryHandle_;
int* rows_;
int* cols_;
......@@ -36,7 +36,7 @@ public:
SparseValueType valueType_;
SparseFormat format_;
public:
public:
GpuSparseMatrix(size_t height,
size_t width,
size_t nnz, /* used to allocate space */
......@@ -73,7 +73,7 @@ public:
bool trans,
MemoryHandlePtr sMemoryHandle);
protected:
protected:
struct Element {
int row;
int col;
......@@ -82,7 +82,7 @@ protected:
: row(rowIn), col(colIn), val(valIn) {}
};
public:
public:
~GpuSparseMatrix() {}
void resize(size_t newHeight,
......@@ -211,13 +211,13 @@ public:
*/
void rowMax(IVector& maxIds, Matrix& maxVal);
protected:
protected:
void sparseResize();
void copyRow(int offsets, size_t colNum, const sparse_non_value_t* row);
void copyRow(int offsets, size_t colNum, const sparse_float_value_t* row);
public:
public:
void mul(const Matrix& a, const Matrix& b, real scaleAB, real scaleT);
void copyFrom(CpuSparseMatrix& src, hl_stream_t stream);
......@@ -228,10 +228,10 @@ public:
void trimFromCSC(const CpuSparseMatrix& src);
// BaseMatrixT interface
public:
public:
bool isSparse() const { return true; }
private:
private:
using Matrix::mul;
using Matrix::copyFrom;
using Matrix::rowMax;
......@@ -248,7 +248,7 @@ private:
namespace paddle {
class GpuSparseMatrix : public Matrix {
public:
public:
GpuSparseMatrix(size_t height,
size_t width,
size_t nnz, /* used to allocate space */
......
......@@ -29,7 +29,7 @@ namespace paddle {
* Sparse Row
*/
class SparseRowCpuMatrix : public CpuMatrix {
public:
public:
struct IndexDict {
// In the following, global id means the row id in the original matrix.
// Local id means the row id in the local storage which only contains
......@@ -53,7 +53,7 @@ public:
virtual ~SparseRowCpuMatrix() {}
public:
public:
/**
* Get the row buf
*
......@@ -163,7 +163,7 @@ public:
return indexDictHandle_->localIndices;
}
protected:
protected:
template <typename Func>
void apply(Func f) {
f(buf_->data(), localIndices_->size() * width_);
......@@ -204,7 +204,7 @@ class SyncThreadPool;
/// For prefetching parameters from remote Parameter server
class SparsePrefetchRowCpuMatrix : public SparseRowCpuMatrix {
public:
public:
SparsePrefetchRowCpuMatrix(CpuMemHandlePtr dataHandle,
size_t height,
size_t width,
......@@ -229,13 +229,13 @@ public:
*/
void setupIndices();
protected:
protected:
void addRows(const unsigned int* ids, size_t len);
SyncThreadPool* pool_;
};
class SparseAutoGrowRowCpuMatrix : public SparseRowCpuMatrix {
public:
public:
SparseAutoGrowRowCpuMatrix(size_t height,
size_t width,
IndexDictPtr indexDictHandle = nullptr,
......@@ -258,7 +258,7 @@ public:
};
class CacheRowCpuMatrix : public SparseAutoGrowRowCpuMatrix {
public:
public:
CacheRowCpuMatrix(size_t height,
size_t width,
IndexDictPtr indexDictHandle = nullptr,
......@@ -287,7 +287,7 @@ public:
virtual void mul(CpuSparseMatrix* a, CpuMatrix* b, real scaleAB, real scaleT);
public:
public:
CpuVectorPtr sourceDataVec_;
real* sourceData_;
};
......@@ -299,7 +299,7 @@ public:
* ids are hashed by worker thread id.
*/
class SparseRowIdsCpuMatrix : public CpuMatrix {
public:
public:
SparseRowIdsCpuMatrix(CpuMemHandlePtr dataHandle,
size_t height,
size_t width,
......@@ -310,7 +310,7 @@ public:
std::vector<uint32_t>& getIds(size_t threadId) { return idsArray_[threadId]; }
private:
private:
std::vector<std::vector<uint32_t>> idsArray_;
};
......@@ -320,13 +320,13 @@ private:
namespace paddle {
class SparseRowCpuMatrix : public CpuMatrix {
public:
public:
void reserveStore() {}
void clearIndices() {}
};
class SparsePrefetchRowCpuMatrix : public SparseRowCpuMatrix {
public:
public:
void setupIndices() {}
void addRows(MatrixPtr input) {}
void addRows(IVectorPtr ids) {}
......
......@@ -25,7 +25,7 @@ namespace paddle {
* @brief Storage manager for multiple devices.
*/
class StorageEngine {
public:
public:
/**
* @return Storage singleton
*/
......@@ -41,7 +41,7 @@ public:
*/
PoolAllocator* getCpuAllocator();
protected:
protected:
StorageEngine();
~StorageEngine();
RWLock lock_;
......
......@@ -21,7 +21,7 @@ namespace paddle {
*/
template <typename Derived, class T>
class TensorApply {
public:
public:
explicit INLINE TensorApply(const Derived& p)
: data_(p.data_),
stride_(p.stride_),
......@@ -52,7 +52,7 @@ public:
*/
template <typename Derived, class T>
class TensorApply<const Derived, T> {
public:
public:
explicit INLINE TensorApply(const Derived& p)
: data_(p.data_),
stride_(p.stride_),
......@@ -77,7 +77,7 @@ public:
template <typename Derived, class T>
class TensorApply<const TensorExpression<Derived, T>, T> {
public:
public:
explicit TensorApply(const TensorExpression<Derived, T>& expr)
: expr_(expr.derived()) {}
......@@ -97,7 +97,7 @@ public:
*/
template <class OP, typename ArgType, class T>
class TensorApply<const TensorUnaryOp<OP, ArgType, T>, T> {
public:
public:
explicit INLINE TensorApply(const TensorUnaryOp<OP, ArgType, T>& expr)
: op_(expr.op_), expr_(expr.expr_) {}
......@@ -118,7 +118,7 @@ public:
*/
template <class OP, typename LhsType, typename RhsType, class T>
class TensorApply<const TensorBinaryOp<OP, LhsType, RhsType, T>, T> {
public:
public:
explicit INLINE TensorApply(
const TensorBinaryOp<OP, LhsType, RhsType, T>& expr)
: op_(expr.op_), lhs_(expr.lhs_), rhs_(expr.rhs_) {
......@@ -153,7 +153,7 @@ public:
*/
template <typename ArgType1, typename ArgType2, typename ArgType3, class T>
class TensorApply<const TensorTernaryOp<ArgType1, ArgType2, ArgType3, T>, T> {
public:
public:
explicit INLINE TensorApply(
const TensorTernaryOp<ArgType1, ArgType2, ArgType3, T>& expr)
: expr1_(expr.expr1_), expr2_(expr.expr2_), expr3_(expr.expr3_) {
......@@ -192,7 +192,7 @@ public:
*/
template <class OP, typename ArgType, class T>
class TensorApply<const TensorConstant<OP, ArgType, T>, T> {
public:
public:
explicit INLINE TensorApply(const TensorConstant<OP, ArgType, T>& expr)
: op_(expr.op_), expr_(expr.expr_) {}
......
......@@ -25,7 +25,7 @@ namespace paddle {
*/
template <typename LhsType, typename RhsType, class T>
class TensorAssignOp {
public:
public:
explicit TensorAssignOp(const LhsType& lhs, const RhsType& rhs)
: lhs_(lhs), rhs_(rhs) {
#ifndef __CUDA_ARCH__
......@@ -49,7 +49,7 @@ public:
}
INLINE bool useGpu() const { return lhs_.useGpu(); }
private:
private:
TensorApply<LhsType, T> lhs_;
TensorApply<const RhsType, T> rhs_;
};
......
......@@ -40,7 +40,7 @@ class TensorAssignOp;
*/
template <typename Derived, class T>
class TensorExpression {
public:
public:
/**
* Element wise unary expression.
*/
......@@ -355,7 +355,7 @@ public:
return TensorAssignOp<Derived, ExpressionType, T>(derived(), expr);
}
protected:
protected:
const Derived& derived() const { return *static_cast<const Derived*>(this); }
};
......@@ -365,7 +365,7 @@ protected:
template <class OP, typename ExprType, class T>
class TensorUnaryOp
: public TensorExpression<TensorUnaryOp<OP, ExprType, T>, T> {
public:
public:
explicit TensorUnaryOp(const OP op, const ExprType& expr)
: op_(op), expr_(expr) {}
......@@ -379,7 +379,7 @@ public:
template <class OP, typename LhsType, typename RhsType, class T>
class TensorBinaryOp
: public TensorExpression<TensorBinaryOp<OP, LhsType, RhsType, T>, T> {
public:
public:
explicit TensorBinaryOp(const OP op, const LhsType& lhs, const RhsType& rhs)
: op_(op), lhs_(lhs), rhs_(rhs) {}
......@@ -395,7 +395,7 @@ template <typename ExprType1, typename ExprType2, typename ExprType3, class T>
class TensorTernaryOp : public TensorExpression<
TensorTernaryOp<ExprType1, ExprType2, ExprType3, T>,
T> {
public:
public:
explicit TensorTernaryOp(const ExprType1& expr1,
const ExprType2& expr2,
const ExprType3& expr3)
......@@ -412,7 +412,7 @@ public:
template <class OP, typename ExprType, class T>
class TensorConstant
: public TensorExpression<TensorConstant<OP, ExprType, T>, T> {
public:
public:
explicit TensorConstant(const OP op, const ExprType& expr)
: op_(op), expr_(expr) {}
......
......@@ -40,13 +40,13 @@ class Matrix;
template <class T>
class BaseVector : public BaseMatrixT<T> {
public:
public:
BaseVector(size_t size, T* data, bool useGpu)
: BaseMatrixT<T>(1, size, data, false, useGpu), size_(this->width_) {}
~BaseVector() {}
protected:
protected:
size_t& size_;
};
......@@ -57,7 +57,7 @@ protected:
*/
template <class T>
class VectorT : public BaseVector<T> {
protected:
protected:
VectorT(size_t size, MemoryHandlePtr memoryHandle, size_t offset, bool useGpu)
: BaseVector<T>(size,
reinterpret_cast<T*>(memoryHandle->getBuf()) + offset,
......@@ -71,7 +71,7 @@ protected:
VectorT(size_t size, T* data, bool useGpu)
: BaseVector<T>(size, data, useGpu) {}
public:
public:
virtual ~VectorT() {}
static std::shared_ptr<VectorT<T>> create(size_t size, bool useGpu);
......@@ -281,7 +281,7 @@ public:
}
}
protected:
protected:
friend class GpuVectorT<T>;
friend class CpuVectorT<T>;
virtual void copyTo(CpuVectorT<T>* dest) const = 0;
......@@ -297,7 +297,7 @@ std::ostream& operator<<(std::ostream& os, const VectorT<T>& vec) {
template <class T>
class GpuVectorT : public VectorT<T> {
public:
public:
explicit GpuVectorT(size_t size);
GpuVectorT(size_t size, GpuMemHandlePtr memHandle, size_t offset)
: VectorT<T>(size, memHandle, offset, true) {}
......@@ -343,14 +343,14 @@ public:
TensorGpuApply<T>(*this, expr);
}
protected:
protected:
virtual void copyTo(CpuVectorT<T>* dest) const;
virtual void copyTo(GpuVectorT<T>* dest) const;
};
template <class T>
class CpuVectorT : public VectorT<T> {
public:
public:
explicit CpuVectorT(size_t size);
CpuVectorT(size_t size, MemoryHandlePtr memoryHandle, size_t offset)
: VectorT<T>(size, memoryHandle, offset, false) {}
......@@ -415,7 +415,7 @@ public:
template <class T>
class ParallelCpuVectorT : public CpuVectorT<T> {
public:
public:
ParallelCpuVectorT(size_t size, SyncThreadPool* pool)
: CpuVectorT<T>(size), pool_(pool) {}
......@@ -434,7 +434,7 @@ public:
virtual void exec(SyncThreadPool::JobFunc jobFunc);
private:
private:
typedef std::function<void(CpuVectorT<T>& vec)> ExecFunc;
void parallelExec(ExecFunc func);
SyncThreadPool* pool_;
......@@ -445,7 +445,7 @@ private:
*/
template <class T>
class CpuGpuVectorT {
public:
public:
/**
* @brief An enum type of SyncedFlag using to
* mark data memory is in CPU or GPU.
......@@ -670,7 +670,7 @@ public:
setSync(flag);
}
protected:
protected:
void resizeOrCreate(size_t size, bool useGpu);
/**
......
......@@ -32,7 +32,7 @@ using paddle::CpuVectorT;
using paddle::GpuVectorT;
class AssertEqual {
public:
public:
AssertEqual(real err = 0) : err_(err) {}
inline bool operator()(real a, real b) {
......@@ -51,7 +51,7 @@ public:
return true;
}
private:
private:
real err_;
};
......@@ -60,71 +60,71 @@ class CopyToCpu;
template <>
class CopyToCpu<CpuMatrix> {
public:
public:
explicit CopyToCpu(const CpuMatrix& arg) : arg_(arg) {}
const CpuMatrix& copiedArg() const { return arg_; }
private:
private:
const CpuMatrix& arg_;
};
template <>
class CopyToCpu<GpuMatrix> {
public:
public:
explicit CopyToCpu(const GpuMatrix& arg)
: arg_(arg.getHeight(), arg.getWidth()) {
arg_.copyFrom(arg);
}
CpuMatrix& copiedArg() { return arg_; }
private:
private:
CpuMatrix arg_;
};
template <>
class CopyToCpu<Matrix> {
public:
public:
explicit CopyToCpu(const Matrix& arg)
: arg_(arg.getHeight(), arg.getWidth()) {
arg_.copyFrom(arg);
}
CpuMatrix& copiedArg() { return arg_; }
private:
private:
CpuMatrix arg_;
};
template <typename T>
class CopyToCpu<CpuVectorT<T>> {
public:
public:
explicit CopyToCpu(const CpuVectorT<T>& arg) : arg_(arg) {}
const CpuVectorT<T>& copiedArg() const { return arg_; }
private:
private:
const CpuVectorT<T>& arg_;
};
template <typename T>
class CopyToCpu<GpuVectorT<T>> {
public:
public:
explicit CopyToCpu(const GpuVectorT<T>& arg) : arg_(arg.getSize()) {
arg_.copyFrom(arg);
}
CpuVectorT<T>& copiedArg() { return arg_; }
private:
private:
CpuVectorT<T> arg_;
};
template <typename T>
class CopyToCpu<VectorT<T>> {
public:
public:
explicit CopyToCpu(const VectorT<T>& arg) : arg_(arg.getSize()) {
arg_.copyFrom(arg);
}
CpuVectorT<T>& copiedArg() { return arg_; }
private:
private:
CpuVectorT<T> arg_;
};
......
......@@ -56,31 +56,31 @@ using paddle::GpuSparseMatrix;
template <typename T1, typename T2>
class ReplaceType {
public:
public:
typedef T1 type;
};
template <>
class ReplaceType<BaseMatrix, CpuMatrix> {
public:
public:
typedef CpuMatrix type;
};
template <>
class ReplaceType<BaseMatrix, GpuMatrix> {
public:
public:
typedef GpuMatrix type;
};
template <>
class ReplaceType<Matrix, CpuMatrix> {
public:
public:
typedef CpuMatrix type;
};
template <>
class ReplaceType<Matrix, GpuMatrix> {
public:
public:
typedef GpuMatrix type;
};
......@@ -180,25 +180,25 @@ R call(C& obj, R (FC::*f)(FArgs...), Args&&... args) {
template <typename T>
class ReturnType {
public:
public:
typedef T type;
};
template <>
class ReturnType<CpuMatrix> {
public:
public:
typedef GpuMatrix type;
};
template <>
class ReturnType<CpuIVector> {
public:
public:
typedef GpuIVector type;
};
template <>
class ReturnType<CpuSparseMatrix> {
public:
public:
typedef GpuSparseMatrix type;
};
......@@ -234,7 +234,7 @@ GpuSparseMatrix autoArgs(CpuSparseMatrix& v) {
}
class AutoCompare {
public:
public:
/**
* err is the allowed calculation error.
* The smaller the value of err,
......@@ -285,7 +285,7 @@ public:
TensorCheck(compare, cpu, gpu);
}
protected:
protected:
CpuMatrix cpu;
GpuMatrix gpu;
AssertEqual compare;
......
......@@ -39,7 +39,7 @@ real f(Matrix& mat1,
}
class Functor {
public:
public:
real operator()(Matrix& mat1,
const Matrix& mat2,
IVector& vec1,
......@@ -49,7 +49,7 @@ public:
return a_;
}
private:
private:
real a_;
};
......
......@@ -28,14 +28,14 @@ DEFINE_double(max_diff, 1e-13, "max diff allowed");
#endif
class SetMaxDiff {
public:
public:
explicit SetMaxDiff(double max_diff) {
max_diff_ = FLAGS_max_diff;
FLAGS_max_diff = max_diff;
}
~SetMaxDiff() { FLAGS_max_diff = max_diff_; }
private:
private:
double max_diff_;
};
......
......@@ -32,7 +32,7 @@ const int TGT_SIZE = 21;
const int CHANNELS = 3;
class PerturbationTest : public testing::Test {
protected:
protected:
virtual void SetUp() { generateTestImages(gpuImages_); }
virtual void TearDown() {}
......
......@@ -20,7 +20,7 @@ namespace paddle {
namespace optimizer {
class AdadeltaOptimizer : public ParameterOptimizer {
public:
public:
AdadeltaOptimizer(
Tensor *parameter, LrPolicy *lr, double rho, double epsilon, double decay)
: ParameterOptimizer(parameter, lr),
......@@ -40,7 +40,7 @@ public:
std::string SerializeState();
void DeserializeState(const std::string &state);
private:
private:
Tensor *accum_gradient_;
Tensor *accum_delta_;
Tensor *update_delta_;
......
......@@ -20,7 +20,7 @@ namespace paddle {
namespace optimizer {
class AdagradOptimizer : public ParameterOptimizer {
public:
public:
AdagradOptimizer(Tensor *parameter,
LrPolicy *lr,
double epsilon,
......@@ -36,7 +36,7 @@ public:
std::string SerializeState();
void DeserializeState(const std::string &state);
private:
private:
Tensor *accum_gradient_;
double epsilon_;
double decay_;
......
......@@ -20,7 +20,7 @@ namespace paddle {
namespace optimizer {
class AdamOptimizer : public ParameterOptimizer {
public:
public:
AdamOptimizer(Tensor *parameter,
LrPolicy *lr,
double beta_1,
......@@ -42,7 +42,7 @@ public:
std::string SerializeState();
void DeserializeState(const std::string &state);
private:
private:
Tensor *momentums_;
Tensor *velocitys_;
double beta_1_;
......
......@@ -20,7 +20,7 @@ namespace paddle {
namespace optimizer {
class LrPolicy {
public:
public:
virtual ~LrPolicy() {}
virtual double LearningRate(const uint64_t num_sample_passed) = 0;
virtual std::string SerializeState() = 0;
......@@ -29,7 +29,7 @@ public:
// constant learning rate policy
class ConstLr final : public LrPolicy {
public:
public:
ConstLr(double lr) : learning_rate_(lr){};
double LearningRate(const uint64_t num_sample_passed) {
return learning_rate_;
......@@ -45,12 +45,12 @@ public:
learning_rate_ = state.learning_rate();
}
private:
private:
double learning_rate_;
};
class LinearLr final : public LrPolicy {
public:
public:
LinearLr(double lr, double lr_decay_a, double lr_decay_b)
: learning_rate_(lr), lr_decay_a_(lr_decay_a), lr_decay_b_(lr_decay_b) {}
double LearningRate(const uint64_t num_sample_passed) {
......@@ -72,7 +72,7 @@ public:
lr_decay_b_ = state.lr_decay_b();
}
private:
private:
double learning_rate_;
double lr_decay_a_;
double lr_decay_b_;
......
......@@ -26,7 +26,7 @@ namespace paddle {
namespace optimizer {
class ParameterOptimizer {
public:
public:
/**
* @brief update hook for algorithm need to traverse parameter more than
* once.
......@@ -45,7 +45,7 @@ public:
virtual std::string SerializeState() = 0;
virtual void DeserializeState(const std::string &state) = 0;
protected:
protected:
Tensor *parameter_;
// learning rate policy
LrPolicy *lr_policy_;
......
......@@ -38,7 +38,7 @@ paddle::optimizer::Tensor* FixedTensor(size_t size) {
}
class OptimizerTest : public testing::Test {
public:
public:
virtual ~OptimizerTest() {}
// init paddle::optimizer::Tensor shape
const size_t kSize = 5;
......@@ -115,7 +115,7 @@ public:
}
}
private:
private:
std::vector<paddle::optimizer::ParameterOptimizer*> opts_;
paddle::OptimizerConfig config_;
};
......
......@@ -20,7 +20,7 @@ namespace paddle {
namespace optimizer {
class SGDOptimizer : public ParameterOptimizer {
public:
public:
SGDOptimizer(Tensor* parameter, LrPolicy* lr, double m, double d, bool n)
: ParameterOptimizer(parameter, lr),
momentums_(nullptr),
......@@ -39,7 +39,7 @@ public:
std::string SerializeState();
void DeserializeState(const std::string& state);
private:
private:
Tensor* momentums_;
double momentum_;
double decay_;
......
......@@ -26,7 +26,7 @@ namespace optimizer {
template <class T>
class TensorT {
public:
public:
TensorT(size_t size) : height_(1), width_(size) {
// new T[size]() initializes all element to zero value.
data_ptr_ = std::shared_ptr<T>(new T[size](), std::default_delete<T[]>());
......@@ -54,7 +54,7 @@ public:
// TODO: replace with tensorshape
size_t size() const { return this->width_ * this->height_; }
protected:
protected:
size_t height_;
size_t width_;
std::shared_ptr<T> data_ptr_;
......
......@@ -21,7 +21,7 @@ namespace paddle {
// After Optimization, parameter values are further averaged within
// time range.
class AverageOptimizer : public ParameterOptimizer {
public:
public:
// if *useParameterApply* set, use PARAMETER_APPLY to store averaged parameter
// else use PARAMETER_VALUE, and value backup in PARAMETER_GRADIENT
AverageOptimizer(const OptimizationConfig& optConfig,
......@@ -65,7 +65,7 @@ public:
virtual void setNoDecay() { optimizer_->setNoDecay(); }
protected:
protected:
std::unique_ptr<ParameterOptimizer> optimizer_;
bool useApply_;
......@@ -98,7 +98,7 @@ protected:
// Average Optimizer with Sparse support.
class AverageSparseOptimizer : public AverageOptimizer {
public:
public:
AverageSparseOptimizer(const OptimizationConfig& optConfig,
ParameterOptimizer* optimizer,
bool useParameterApply)
......@@ -130,7 +130,7 @@ public:
t0Vec_.assign(t0Vec_.size(), 0);
}
protected:
protected:
/**
* counting batches, clear after catch up with
* t(timer_) is current time,
......
......@@ -22,7 +22,7 @@ namespace paddle {
// Plain SGD optimization.
class SgdOptimizer : public ParameterOptimizer {
public:
public:
explicit SgdOptimizer(const OptimizationConfig& optConfig)
: ParameterOptimizer(optConfig) {
addParameterType(PARAMETER_MOMENTUM);
......@@ -77,7 +77,7 @@ class SparseMomentumParameterOptimizer : public ParameterOptimizer {
\gamma_t: learning rate at the t'th step
*/
public:
public:
explicit SparseMomentumParameterOptimizer(
const OptimizationConfig& optConfig);
virtual void init(size_t numRows, const ParameterConfig* config);
......@@ -89,7 +89,7 @@ public:
const ParameterConfig& config) const;
virtual void finishBatch();
private:
private:
real alpha_;
real beta_;
real tau_;
......@@ -98,7 +98,7 @@ private:
real momentum_;
real decayRate_;
protected:
protected:
int64_t timer_;
mutable std::vector<int64_t> t0Vec_;
bool isParameterSparse_;
......@@ -109,7 +109,7 @@ protected:
* http://www.magicbroom.info/Papers/DuchiHaSi10.pdf
*/
class AdagradParameterOptimizer : public ParameterOptimizer {
public:
public:
explicit AdagradParameterOptimizer(const OptimizationConfig& optConfig)
: ParameterOptimizer(optConfig) {
addParameterType(PARAMETER_MOMENTUM);
......@@ -129,7 +129,7 @@ public:
virtual TraverseCallback needSpecialTraversal(
const ParameterConfig& config) const;
protected:
protected:
int64_t numUpdates_;
static const int64_t kMaxNumAccumulates = 16384;
};
......@@ -139,7 +139,7 @@ protected:
* http://www.matthewzeiler.com/pubs/googleTR2012/googleTR2012.pdf
*/
class AdaDeltaParameterOptimizer : public ParameterOptimizer {
public:
public:
explicit AdaDeltaParameterOptimizer(const OptimizationConfig& optConfig)
: ParameterOptimizer(optConfig) {
addParameterType(PARAMETER_MOMENTUM);
......@@ -158,14 +158,14 @@ public:
const ParameterConfig& config,
size_t sparseId) const;
protected:
protected:
real rou_;
real epsilon_;
};
// RMSProp Parameter Optimization.
class RMSPropParameterOptimizer : public ParameterOptimizer {
public:
public:
explicit RMSPropParameterOptimizer(const OptimizationConfig& optConfig)
: ParameterOptimizer(optConfig) {
addParameterType(PARAMETER_MOMENTUM);
......@@ -191,7 +191,7 @@ public:
const ParameterConfig& config,
size_t sparseId) const;
protected:
protected:
real rou_;
real epsilon_;
......@@ -208,7 +208,7 @@ protected:
// Decayed AdaGrad Optimization.
class DecayedAdagradParameterOptimizer : public ParameterOptimizer {
public:
public:
explicit DecayedAdagradParameterOptimizer(const OptimizationConfig& optConfig)
: ParameterOptimizer(optConfig) {
addParameterType(PARAMETER_MOMENTUM);
......@@ -233,7 +233,7 @@ public:
const ParameterConfig& config,
size_t sparseId) const;
protected:
protected:
real rou_;
real epsilon_;
......@@ -253,7 +253,7 @@ protected:
* Reference Paper: http://arxiv.org/abs/1412.6980 Algorithm 1
*/
class AdamParameterOptimizer : public ParameterOptimizer {
public:
public:
explicit AdamParameterOptimizer(const OptimizationConfig& optConfig)
: ParameterOptimizer(optConfig),
beta1_(optConfig.adam_beta1()),
......@@ -275,7 +275,7 @@ public:
const ParameterConfig& config,
size_t sparseId) const;
protected:
protected:
real beta1_;
real beta2_;
real epsilon_;
......@@ -288,7 +288,7 @@ protected:
* Reference Paper: http://arxiv.org/abs/1412.6980 Algorithm 2
*/
class AdamaxParameterOptimizer : public ParameterOptimizer {
public:
public:
explicit AdamaxParameterOptimizer(const OptimizationConfig& optConfig)
: ParameterOptimizer(optConfig),
beta1_(optConfig.adam_beta1()),
......@@ -305,7 +305,7 @@ public:
const ParameterConfig& config,
size_t sparseId) const;
protected:
protected:
real beta1_;
real beta2_;
int64_t step_;
......@@ -315,7 +315,7 @@ protected:
// Used in pserver,
// when PARAMETER_DELTA stores in PARAMETER_GRADIENT.
class AddOptimizer : public ParameterOptimizer {
public:
public:
explicit AddOptimizer(const OptimizationConfig& optConfig)
: ParameterOptimizer(optConfig) {}
......@@ -333,7 +333,7 @@ public:
// A optimizer which does nothing.
class DummyOptimizer : public ParameterOptimizer {
public:
public:
explicit DummyOptimizer(const OptimizationConfig& optConfig)
: ParameterOptimizer(optConfig) {}
......@@ -344,7 +344,7 @@ public:
// Do gradient clipping before sgd update
class OptimizerWithGradientClipping : public ParameterOptimizer {
public:
public:
OptimizerWithGradientClipping(const OptimizationConfig& optConfig,
ParameterOptimizer* optimizer)
: ParameterOptimizer(optConfig), optimizer_(optimizer) {
......@@ -374,7 +374,7 @@ public:
virtual void setNoDecay() { optimizer_->setNoDecay(); }
protected:
protected:
std::unique_ptr<ParameterOptimizer> optimizer_;
};
......
......@@ -28,20 +28,20 @@ LearningRateScheduler* LearningRateScheduler::create(
// LRS stands for LearningRateScheduler
class BaseLRS : public LearningRateScheduler {
public:
public:
explicit BaseLRS(const OptimizationConfig& config)
: learningRate_(config.learning_rate()),
a_(config.learning_rate_decay_a()),
b_(config.learning_rate_decay_b()) {}
protected:
protected:
real learningRate_;
real a_;
real b_;
};
class ConstLRS : public BaseLRS {
public:
public:
explicit ConstLRS(const OptimizationConfig& config) : BaseLRS(config) {}
virtual real calcLearningRate(int64_t numSamplesProcessed, int64_t pass) {
return learningRate_;
......@@ -50,7 +50,7 @@ public:
REGISTER_LEARNING_RATE_SCHEDULER(constant, ConstLRS);
class PolyLRS : public BaseLRS {
public:
public:
explicit PolyLRS(const OptimizationConfig& config) : BaseLRS(config) {}
virtual real calcLearningRate(int64_t numSamplesProcessed, int64_t pass) {
return learningRate_ * pow(1.0 + a_ * numSamplesProcessed, -b_);
......@@ -59,7 +59,7 @@ public:
REGISTER_LEARNING_RATE_SCHEDULER(poly, PolyLRS);
class CaffePolyLRS : public BaseLRS {
public:
public:
explicit CaffePolyLRS(const OptimizationConfig& config) : BaseLRS(config) {}
virtual real calcLearningRate(int64_t numSamplesProcessed, int64_t pass) {
if (numSamplesProcessed > a_) {
......@@ -78,7 +78,7 @@ public:
REGISTER_LEARNING_RATE_SCHEDULER(caffe_poly, CaffePolyLRS);
class ExpLRS : public BaseLRS {
public:
public:
explicit ExpLRS(const OptimizationConfig& config) : BaseLRS(config) {}
virtual real calcLearningRate(int64_t numSamplesProcessed, int64_t pass) {
double decayRatio = (double)numSamplesProcessed / b_;
......@@ -88,7 +88,7 @@ public:
REGISTER_LEARNING_RATE_SCHEDULER(exp, ExpLRS);
class DiscreteExpLRS : public BaseLRS {
public:
public:
explicit DiscreteExpLRS(const OptimizationConfig& config) : BaseLRS(config) {}
virtual real calcLearningRate(int64_t numSamplesProcessed, int64_t pass) {
int numDecays = floor(numSamplesProcessed / b_);
......@@ -98,7 +98,7 @@ public:
REGISTER_LEARNING_RATE_SCHEDULER(discexp, DiscreteExpLRS);
class LinearLRS : public BaseLRS {
public:
public:
explicit LinearLRS(const OptimizationConfig& config) : BaseLRS(config) {}
virtual real calcLearningRate(int64_t numSamplesProcessed, int64_t pass) {
return std::max(learningRate_ - a_ * numSamplesProcessed, b_);
......@@ -113,7 +113,7 @@ REGISTER_LEARNING_RATE_SCHEDULER(linear, LinearLRS);
then learning_rate = learning_rate_base * rate_i
*/
class ManualLRS : public BaseLRS {
public:
public:
explicit ManualLRS(const OptimizationConfig& config)
: BaseLRS(config), currentSegment_(0), lastNum_(0) {
std::vector<std::string> pieces;
......@@ -151,7 +151,7 @@ public:
return learningRate_ * rates_.back();
}
protected:
protected:
std::vector<real> rates_;
std::vector<int64_t> segments_;
size_t currentSegment_;
......@@ -161,7 +161,7 @@ protected:
REGISTER_LEARNING_RATE_SCHEDULER(manual, ManualLRS);
class PassManualLRS : public ManualLRS {
public:
public:
explicit PassManualLRS(const OptimizationConfig& config)
: ManualLRS(config) {}
virtual real calcLearningRate(int64_t numSamplesProcessed, int64_t pass) {
......
......@@ -26,7 +26,7 @@ namespace paddle {
})
class LearningRateScheduler {
public:
public:
static LearningRateScheduler* create(const OptimizationConfig& config);
virtual ~LearningRateScheduler() {}
virtual real calcLearningRate(int64_t numSamplesProcessed, int64_t pass) = 0;
......
......@@ -20,7 +20,7 @@ namespace paddle {
// add regularizer for objective function to do optimization
class OptimizerWithRegularizer : public ParameterOptimizer {
public:
public:
static ParameterOptimizer* create(const OptimizationConfig& optConfig,
const ParameterConfig& paraConfig,
bool isParameterSparse,
......@@ -67,7 +67,7 @@ public:
regularizer_->update(vecs, config, optimizer_->getLearningRate(), 0, 1);
}
protected:
protected:
std::unique_ptr<ParameterOptimizer> optimizer_;
Regularizer* regularizer_;
......@@ -84,7 +84,7 @@ protected:
// Regularized Loss function for every num of batches
class OptimizerWithRegularizerEveryNumBatches
: public OptimizerWithRegularizer {
public:
public:
OptimizerWithRegularizerEveryNumBatches(const OptimizationConfig& optConfig,
ParameterOptimizer* optimizer,
Regularizer* regularizer)
......@@ -112,7 +112,7 @@ public:
virtual TraverseCallback startCatchUpWith() const;
virtual void finishCatchUpWith() { baseTimer_ = timer_; }
protected:
protected:
bool isRegularizationBatch(const ParameterConfig& config) const {
return ((timer_ + 1) % config.num_batches_regularization() == 0);
}
......@@ -125,7 +125,7 @@ protected:
// Regularized Loss function with Sparse support
class OptimizerWithRegularizerSparse : public OptimizerWithRegularizer {
public:
public:
OptimizerWithRegularizerSparse(const OptimizationConfig& optConfig,
ParameterOptimizer* optimizer,
Regularizer* regularizer)
......@@ -145,7 +145,7 @@ public:
t0Vec_.assign(t0Vec_.size(), 0);
}
protected:
protected:
/**
* t0Vec_ are last occur time of i rows
* if one block is update by multi threads,
......
......@@ -58,7 +58,7 @@ class Parameter;
typedef std::shared_ptr<Parameter> ParameterPtr;
class Parameter {
public:
public:
Parameter(const ParameterConfig& config, bool useGpu, bool doInit = true);
const std::string& getName() const { return config_.name(); }
......@@ -311,7 +311,7 @@ public:
}
}
protected:
protected:
/**
* @brief create matrix to matType.
*
......@@ -326,7 +326,7 @@ protected:
void clearUpdate() { updateCounter_ = 0; }
protected:
protected:
ParameterConfig config_;
bool useGpu_;
......@@ -363,7 +363,7 @@ protected:
std::vector<std::shared_ptr<IParameterUpdaterHook>> updaterHooks_;
public:
public:
void setSharedCount(int cnt) { sharedCount_ = cnt; }
int getSharedCount() { return sharedCount_; }
......
......@@ -30,12 +30,12 @@ namespace paddle {
* may be called many times, should be no state change between calls.
*/
class ParameterOptimizer {
public:
public:
typedef std::function<void(
const VectorPtr vecs[], const ParameterConfig& config, size_t sparseId)>
TraverseCallback;
public:
public:
explicit ParameterOptimizer(const OptimizationConfig& optConfig)
: applyDecay_(true),
optConfig_(optConfig),
......@@ -175,7 +175,7 @@ public:
static ParameterOptimizer* create(const OptimizationConfig& optConfig,
bool inPserver = false);
protected:
protected:
typedef std::vector<ParameterOptimizer::TraverseCallback> TraverseCallbackVec;
static TraverseCallback composeCallbacks(
......
......@@ -21,7 +21,7 @@ namespace paddle {
class ParameterOptimizer;
class ParameterUpdater {
public:
public:
ParameterUpdater() : parameterTypes_{PARAMETER_VALUE, PARAMETER_GRADIENT} {}
virtual ~ParameterUpdater() {}
......@@ -89,7 +89,7 @@ public:
virtual void setForwardbackwardTime(uint64_t delta) {}
#endif
protected:
protected:
virtual void updateImpl(Parameter* para) = 0;
std::vector<ParameterType> parameterTypes_;
......@@ -101,7 +101,7 @@ protected:
// part of all Parameters. It's useful when we need different
// update strategy for different Parameter.
class ParameterUpdaterComposite : public ParameterUpdater {
public:
public:
ParameterUpdaterComposite() {}
virtual ~ParameterUpdaterComposite() {}
......@@ -173,7 +173,7 @@ public:
[&](int tid, size_t numThreads) { updaters_[tid]->restore(); });
}
protected:
protected:
virtual void updateImpl(Parameter* para) {}
std::vector<std::unique_ptr<ParameterUpdater>> updaters_;
std::unique_ptr<SyncThreadPool> syncThreadPool_;
......
......@@ -37,7 +37,7 @@ namespace paddle {
*/
class StaticPruningHook : public IParameterUpdaterHook {
public:
public:
explicit StaticPruningHook(const ParameterUpdaterHookConfig &hookConfig)
: initCount_(0) {
sparsityRatio_ = hookConfig.sparsity_ratio();
......@@ -96,7 +96,7 @@ public:
paraVec->dotMul(*maskVec_);
}
private:
private:
SameThreadChecker updateThreadChecker_;
std::atomic<size_t> initCount_;
VectorPtr maskVec_;
......@@ -116,12 +116,12 @@ IParameterUpdaterHook::~IParameterUpdaterHook() {}
* May be extracted to Util.h to unify the hasher.
*/
class StringIntPairHasher {
public:
public:
size_t operator()(const std::pair<std::string, int> &k) const {
return intHasher_(strHasher_(k.first) + k.second);
}
private:
private:
std::hash<std::string> strHasher_;
std::hash<int> intHasher_;
};
......
......@@ -29,7 +29,7 @@ class Parameter;
* parameter optimization.
*/
class IParameterUpdaterHook {
public:
public:
virtual ~IParameterUpdaterHook();
/**
......@@ -53,7 +53,7 @@ public:
*/
virtual void init(Parameter* para) = 0;
protected:
protected:
/**
* Ctor.
*/
......
......@@ -20,7 +20,7 @@ namespace paddle {
// Regularizer function for parameter, e.g. L1/L2
class Regularizer {
public:
public:
virtual void update(const VectorPtr vecs[],
const ParameterConfig& paraConfig,
real learningRate, // learningrate from optimizer
......
......@@ -23,12 +23,12 @@ limitations under the License. */
namespace paddle {
class Weight {
private:
private:
MatrixPtr weight_;
MatrixPtr weightGrad_;
ParameterPtr parameter_;
public:
public:
Weight(size_t height, size_t width, ParameterPtr parameter);
Weight(size_t height, size_t width, ParameterPtr parameter, size_t offset);
......
......@@ -24,7 +24,7 @@ limitations under the License. */
using namespace paddle; // NOLINT
class CommonTest : public ::testing::Test {
protected:
protected:
CommonTest() : testStat_("test") {}
virtual ~CommonTest() {}
virtual void SetUp() {
......@@ -51,7 +51,7 @@ protected:
virtual void TreaDown() { LOG(INFO) << "All Test Finished."; }
protected:
protected:
std::vector<std::pair<real, real>> valueUint_;
std::vector<size_t> sizeVec_;
real learningRate_;
......
......@@ -32,7 +32,7 @@ namespace paddle {
* connections.
*/
class BaseClient {
protected:
protected:
typedef std::unique_ptr<std::thread> ThreadPtr;
typedef std::vector<std::vector<iovec>> InputIovs;
typedef std::vector<SendParameterRequest> SendRequest;
......@@ -49,7 +49,7 @@ protected:
SendDataRequestVec parallelDataRequests;
};
public:
public:
explicit BaseClient(bool separate = false, int numPorts = FLAGS_ports_num);
virtual ~BaseClient();
......@@ -141,7 +141,7 @@ public:
return dataType;
}
protected:
protected:
/// for a > 0, b > 0:
/// return the smallest x s.t. b*x >= a
static int divup(int a, int b) { return (a + b - 1) / b; }
......@@ -264,7 +264,7 @@ protected:
*/
virtual void recv(int threadId) = 0;
protected:
protected:
bool stopping_;
/// nodes * ports that means the number of real pservers
int serviceNum_;
......
......@@ -41,7 +41,7 @@ class SocketServer : public Thread {
// rdmaCpu controls the cpu affinity of RDMA server daemon,
// which could benifit performance. rdmaCpu = -1 means TCP
// is used instead of RDMA transport.
public:
public:
SocketServer(const std::string& addr, int port, int rdmaCpu);
~SocketServer();
......@@ -50,7 +50,7 @@ public:
typedef std::function<void(const std::vector<iovec>& outputIovs)>
ResponseCallback;
protected:
protected:
//
// The derived class needs to implement this function
// to handle the request received by SocketWorker
......@@ -70,13 +70,13 @@ protected:
friend class SocketWorker;
private:
private:
void rdmaServer();
void tcpServer();
void detach() {} // detach accept thread is forbidden
protected:
protected:
enum ChannelType tcpRdma_;
// for rdma
int rdmaCpu_;
......@@ -96,7 +96,7 @@ protected:
* @note all parameter processing will run in the context of this worker
*/
class SocketWorker : public Thread {
public:
public:
SocketWorker(std::unique_ptr<SocketChannel>&& channel, SocketServer* server)
: channel_(std::move(channel)), server_(server) {}
......@@ -104,7 +104,7 @@ public:
virtual void run();
protected:
protected:
std::unique_ptr<SocketChannel> channel_;
SocketServer* server_;
enum ChannelType tcpRdma_;
......@@ -118,12 +118,12 @@ protected:
* single cpu core for better load balance performance
*/
class RdmaClientDaemons {
private:
private:
RdmaClientDaemons();
static std::unique_ptr<RdmaClientDaemons> daemons_;
public:
public:
static RdmaClientDaemons* get() {
std::call_once(RdmaClientDaemons::initDataFlag_,
&RdmaClientDaemons::getInstance);
......@@ -141,10 +141,10 @@ public:
~RdmaClientDaemons();
public:
public:
friend class SocketClient;
private:
private:
static std::once_flag initDataFlag_;
static void getInstance() {
if (!daemons_.get()) daemons_.reset(new RdmaClientDaemons());
......@@ -162,19 +162,19 @@ private:
* read data
*/
class SocketClient {
public:
public:
SocketClient(const std::string& serverAddr,
int serverPort,
enum ChannelType channelType);
SocketChannel* getChannel() { return channel_.get(); }
protected:
protected:
std::unique_ptr<SocketChannel> channel_;
struct sxi_socket* socketDaemon_;
enum ChannelType tcpRdma_;
private:
private:
void RdmaClient(const std::string& serverAddr, int serverPort);
void TcpClient(const std::string& serverAddr, int serverPort);
};
......
......@@ -50,11 +50,11 @@ struct PServerVector {
* @brief A class to help to prepare server-side operations.
*/
class PreparedOperations {
protected:
protected:
class ResultsAdder;
struct LocalOperationResult;
public:
public:
/**
* Offers an easy way to prepare operations that will be performed on
* server-side.
......@@ -93,7 +93,7 @@ public:
return ResultsAdder(&localResults_.back());
}
protected:
protected:
void addOperationHelper(Operation* op) {}
/**
......@@ -151,7 +151,7 @@ protected:
* @brief ResultsAdder offers easy ways to quickly store operation results.
*/
class ResultsAdder {
public:
public:
explicit ResultsAdder(LocalOperationResult* localResult)
: localResult_(localResult) {}
template <typename... Args>
......@@ -172,11 +172,11 @@ protected:
addResult(args...);
}
protected:
protected:
LocalOperationResult* localResult_;
};
protected:
protected:
DoOperationRequest request_;
std::vector<iovec> inputIovs_;
struct LocalOperationResult {
......@@ -214,7 +214,7 @@ struct ParameterSegments {
* waiting until all parameters are received to CPU host end.
*/
class ParameterClient2 : public BaseClient {
public:
public:
/** Constructor.
* @param separate True if sending and recieving activities are separated
* into 2 threads, otherwise false.
......@@ -232,7 +232,7 @@ public:
static int calcParameterBlockSize(const std::vector<ParameterPtr>& parameters,
size_t serviceNum);
public:
public:
bool init(const std::vector<ParameterPtr>& parameters);
/// service functions
......@@ -514,7 +514,7 @@ public:
void setForwardbackwardTime(uint64_t delta) { forwardbackwordTime_ = delta; }
#endif
protected:
protected:
template <typename ProtoIn, typename ProtoOut>
void multiCall(const char* funcName,
const ProtoIn& request,
......@@ -529,7 +529,7 @@ protected:
}
}
private:
private:
void destroy();
/**
......@@ -573,7 +573,7 @@ private:
/// start necessary threads for threadPool
void initThreads();
protected:
protected:
/// start port number of pserver
/// it deduce all ports for dense and sparse with some rules
int port_;
......
......@@ -71,7 +71,7 @@ namespace paddle {
* to prevent from being polluted.
*/
class ParameterServer2 : public ProtoServer {
protected:
protected:
/// parameter_ mutex.
RWLock parameterMutex_;
......@@ -169,7 +169,7 @@ protected:
template <typename T, size_t AlignBytes>
class ReadWriteBuffer
: public std::vector<T, AlignedAllocator<T, AlignBytes>> {
public:
public:
static_assert(sizeof(T) % AlignBytes == 0 || AlignBytes % sizeof(T) == 0,
"Type T must be able to aligned.");
......@@ -229,7 +229,7 @@ protected:
return r;
}
private:
private:
size_t curOffset_;
};
......@@ -298,17 +298,17 @@ protected:
/// barrier performance tuning sync-sgd required
std::atomic<int64_t> batchId_;
public:
public:
struct Buffer {
real* base;
size_t size;
};
protected:
protected:
/// async gradient commit control
bool asyncGrdientCommitCheckAndStat(const SendParameterRequest& request);
public:
public:
/// disable default parameter for overloading
/// @rdmaCpu:the id of cpu core hosting RDMA server(0-N)
/// -1 means using TCP transport instead of RDMA
......@@ -437,7 +437,7 @@ public:
void saveValueVector(const SaveValueRequest& request,
ProtoResponseCallback callback);
public:
public:
/**
* @brief initialize parameter server
*/
......@@ -512,7 +512,7 @@ public:
SendParameterResponse* response,
std::vector<Buffer>* outputBuffers);
protected:
protected:
void mergeSegments(BlockSegments* segments);
/// set the unused segments to zero
......@@ -641,7 +641,7 @@ protected:
const VectorPtr vecs[],
const ParameterOptimizer::TraverseCallback& callback);
public:
public:
typedef void (ParameterServer2::*OperatorFunction)(const Operation& operation,
OperationResult* result);
......
......@@ -28,7 +28,7 @@ namespace paddle {
* by gflags or proto.
*/
class ParameterServerController final {
public:
public:
DISABLE_COPY(ParameterServerController);
/**
......@@ -67,7 +67,7 @@ public:
*/
void wait();
private:
private:
std::vector<std::unique_ptr<ParameterServer2>> parameterServers_;
};
......
......@@ -34,7 +34,7 @@ namespace paddle {
* for single NIC hardward with --port=N(N>1) for small cluster job.
*/
class ProtoServer : public SocketServer {
public:
public:
/// rdmaCpu controls the cpu affinity of RDMA server daemon,
/// which could benifit performance. rdmaCpu = -1 means TCP
/// is used instead of RDMA transport.
......@@ -87,7 +87,7 @@ public:
std::unique_ptr<MsgReader> msgReader,
ProtoResponseCallbackEx callback)> func);
protected:
protected:
/**
* @brief handle rpc request
* @param[in] msgReader Message reader for reading data from connection
......@@ -111,7 +111,7 @@ protected:
void registerServiceFunctionImp(const std::string& funcName,
ServiceFunction func);
protected:
protected:
/// Tuning bare network overhead: the beginning of receiving request
ThreadLocal<struct timeval> handleRequestBegin_;
......@@ -120,7 +120,7 @@ protected:
};
class ProtoClient : public SocketClient {
public:
public:
ProtoClient(const std::string& serverAddr,
int serverPort,
enum ChannelType channelType = F_TCP)
......
......@@ -33,7 +33,7 @@ enum ChannelType {
/// reading a set of blocks of data from SocketChannel.
class MsgReader {
public:
public:
MsgReader(SocketChannel* channel, size_t numIovs);
~MsgReader() {
/// ensure all data blocks have been processed
......@@ -75,7 +75,7 @@ public:
void readBlocks(const std::vector<void*>& bufs);
void readNextBlock(void* buf);
protected:
protected:
SocketChannel* channel_;
std::vector<size_t> blockLengths_;
size_t currentBlockIndex_;
......@@ -84,7 +84,7 @@ protected:
/// APIs for reading and writing byte stream data or naive iov data
/// from the APIs both RDMA and TCP exhibits byte stream style
class SocketChannel {
public:
public:
SocketChannel(int socket, const std::string& peerName)
: tcpSocket_(socket), peerName_(peerName) {
tcpRdma_ = F_TCP;
......@@ -137,7 +137,7 @@ public:
/// return null to indicate socket is closed
std::unique_ptr<MsgReader> readMessage();
protected:
protected:
struct MessageHeader {
int64_t totalLength; /// include the header
int64_t numIovs;
......
......@@ -31,7 +31,7 @@ namespace paddle {
* if unbalanced distribution exhibts by default.
*/
class SparseParameterDistribution {
public:
public:
/// serviceNum means the number of ParameterServers
explicit SparseParameterDistribution(size_t serviceNum);
~SparseParameterDistribution() {}
......@@ -39,7 +39,7 @@ public:
void probeDistribution(int serverId, size_t data);
void checkAndResetDistribution();
private:
private:
std::vector<size_t> data_;
std::atomic<size_t> totBytes_;
......
......@@ -30,12 +30,12 @@ struct MessageHeader {
};
class Thread {
public:
public:
void start();
virtual void run() = 0;
virtual ~Thread() {}
protected:
protected:
std::unique_ptr<std::thread> thread_;
};
......@@ -44,13 +44,13 @@ void Thread::start() {
}
class SocketChannel {
public:
public:
explicit SocketChannel(int socket) : socket_(socket) {}
int getSocketFd() const { return socket_; }
uint64_t readAll(void* buf, size_t size);
uint64_t writeAll(const void* buf, size_t size);
protected:
protected:
int socket_;
};
......@@ -79,7 +79,7 @@ uint64_t SocketChannel::writeAll(const void* buf, size_t size) {
}
class SocketWorker : public Thread {
public:
public:
explicit SocketWorker(int socket) : channel_(socket) {}
virtual void run();
......@@ -88,19 +88,19 @@ public:
// write n bytes
protected:
protected:
SocketChannel channel_;
std::string buffer_;
};
class SocketServer : public Thread {
public:
public:
explicit SocketServer(int port)
: port_(port), socket_(0), maxPendingConnections_(100) {}
virtual void run();
protected:
protected:
int port_;
int socket_;
int maxPendingConnections_;
......@@ -161,11 +161,11 @@ void SocketWorker::run() {
}
class SocketClient {
public:
public:
SocketClient(const std::string& serverAddr, int serverPort);
SocketChannel* getChannel() const { return channel_.get(); }
protected:
protected:
std::unique_ptr<SocketChannel> channel_;
};
......
......@@ -26,7 +26,7 @@ DEFINE_string(server_addr, "127.0.0.1", "assign server address");
DEFINE_int32(server_cpu, 0, "assign server cpu");
class ParameterServer2Tester : public ParameterServer2 {
public:
public:
ParameterServer2Tester(std::string serverAddr,
int port,
int rdmaCpu = -1,
......@@ -88,7 +88,7 @@ public:
void waitPassFinishTest();
void synchronizeTest();
protected:
protected:
ParameterClient2 client_;
vector<ParameterConfig> clientConfigs_;
vector<ParameterPtr> parameters_;
......
......@@ -28,7 +28,7 @@ DEFINE_bool(benchmark, false, "Do benchmark. Skip some tests");
using namespace paddle; // NOLINT
class MyServer : public ProtoServer {
public:
public:
explicit MyServer(int port, int rdmaCpu = -1)
: ProtoServer(FLAGS_server_addr, port, rdmaCpu),
status_(PSERVER_STATUS_NOT_SET) {
......@@ -62,7 +62,7 @@ public:
callback(response);
}
protected:
protected:
PServerStatus status_;
std::string buffer_;
};
......
......@@ -29,7 +29,7 @@ namespace paddle {
* New remote parameter updater for dense parameters that use cclient of go.
*/
class NewRemoteParameterUpdater : public ParameterUpdater {
public:
public:
NewRemoteParameterUpdater(const OptimizationConfig& config,
const std::string pserverSpec);
NewRemoteParameterUpdater(const OptimizationConfig& config,
......@@ -61,13 +61,13 @@ public:
virtual void startPass();
virtual bool finishPass();
protected:
protected:
/**
* work need to do after finishBatch
*/
virtual void updateImpl(Parameter* para);
private:
private:
int parameterSize() { return (int)parameters_.size(); }
/**
......@@ -104,7 +104,7 @@ private:
}
}
protected:
protected:
const OptimizationConfig& trainerConfig_;
/// internal parameter client object for exchanging data with pserver
paddle_pserver_client parameterClient_;
......
......@@ -56,7 +56,7 @@ struct ParameterUtilConfig {
* Utility class for loading and saving parameters
*/
class ParameterUtil {
public:
public:
/**
* Ctor.
*
......@@ -115,7 +115,7 @@ public:
}
}
private:
private:
std::shared_ptr<TrainerConfigHelper> config_;
std::unique_ptr<ParameterUtilConfig> intConfig_;
GradientMachinePtr gserver_;
......
......@@ -36,7 +36,7 @@ namespace paddle {
* @brief Parameter Updater for SGD, and local(not cluster) run.
*/
class SgdLocalUpdater : public ParameterUpdater {
public:
public:
/**
* @brief Ctor. Initialize optimizer locally by optConfig.
* @param optConfig optimization config.
......@@ -131,7 +131,7 @@ public:
}
}
protected:
protected:
/**
* @brief update method. Update value from gradient.
* @param para parameter that will be updated.
......@@ -159,7 +159,7 @@ protected:
* @deprecated
*/
class SgdCpuUpdater : public SgdLocalUpdater, public Deprecated {
public:
public:
explicit SgdCpuUpdater(const OptimizationConfig& optConfig)
: SgdLocalUpdater(optConfig),
Deprecated(
......@@ -178,7 +178,7 @@ public:
optimizer_->finishBatch();
}
protected:
protected:
/**
* @brief do nothing.
* @param para
......@@ -192,7 +192,7 @@ protected:
* It will do model average in cpu to reduce gpu memory comsuption.
*/
class SgdUpdaterWithCpuAverager : public SgdLocalUpdater {
public:
public:
/**
* @brief Ctor.
*
......@@ -233,12 +233,12 @@ public:
*/
virtual void restore();
protected:
protected:
virtual void updateImpl(Parameter* para);
void updateFunc(Parameter* para);
protected:
protected:
std::unique_ptr<ParameterOptimizer> averager_;
/**
......
......@@ -53,7 +53,7 @@ namespace paddle {
* backward and communication is not supported.
*/
class RemoteParameterUpdater : public ParameterUpdater {
public:
public:
RemoteParameterUpdater(
const OptimizationConfig& config,
int expectedPassCount,
......@@ -101,7 +101,7 @@ public:
virtual void apply();
virtual void restore();
protected:
protected:
/**
* control all pservers with all trainers for sync-sgd
*/
......@@ -128,7 +128,7 @@ protected:
*/
void copyParametersFromDevice(ParameterType parameterType);
protected:
protected:
/// Optimization config used to guide initialization and finishBatch
OptimizationConfig config_;
/// internal parameter client object for exchanging data with pserver
......@@ -178,7 +178,7 @@ protected:
* It contains separate send and recv thread for pipeline usage.
*/
class ConcurrentRemoteParameterUpdater : public RemoteParameterUpdater {
public:
public:
ConcurrentRemoteParameterUpdater(
OptimizationConfig config,
int expectedPassCount,
......@@ -194,7 +194,7 @@ public:
*/
virtual void finishBatch(real cost);
protected:
protected:
virtual void updateImpl(Parameter* para);
/// internal thread called in send thread
void send(Parameter* para); // para == NULL indicate end of a minibatch
......@@ -221,7 +221,7 @@ protected:
return (numBatches_ + 1) % config_.num_batches_per_send_parameter() == 0;
}
private:
private:
/// send thread used for overlapping
std::unique_ptr<std::thread> sendThread_;
/// recv thread used for overlapping
......@@ -263,7 +263,7 @@ private:
* to encapsulate sparse specified message for all pservers.
*/
class SparseRemoteParameterUpdater : public ParameterUpdater {
public:
public:
SparseRemoteParameterUpdater(const OptimizationConfig& config,
int expectedPassCount,
bool testing);
......@@ -303,7 +303,7 @@ public:
}
#endif
protected:
protected:
/// update implimentation, not implemented
virtual void updateImpl(Parameter* para) {}
......@@ -313,7 +313,7 @@ protected:
/// start controller thread
void startController();
protected:
protected:
/// optimization config
OptimizationConfig config_;
/// internal parameter client
......@@ -335,7 +335,7 @@ protected:
* it directly call internal dense and sparse udpater individually.
*/
class SparseRemoteParameterUpdaterComposite : public ParameterUpdaterComposite {
public:
public:
enum {
UPDATER_SPARSE_REMOTE = 0, // execute in sync thread pool(tid:0)
UPDATER_NORMAL = 1, // execute in Owner thread(tid:1)
......@@ -364,7 +364,7 @@ public:
};
class ParameterUpdaterCreators {
public:
public:
/**
* @brief add a creator to create custom ParameterUpdater while training.
* The creator is a function with type (alogrithm, optConfig, isLocal,
......@@ -407,7 +407,7 @@ public:
return nullptr;
}
private:
private:
static std::vector<std::function<ParameterUpdater*(
const std::string&, const OptimizationConfig&, bool, size_t)>>
constructors_;
......
......@@ -38,7 +38,7 @@ namespace paddle {
* It is a private class for Trainer.
*/
class Tester {
public:
public:
/**
* Ctor
* @param config Trainer Config.
......@@ -87,7 +87,7 @@ public:
*/
void test();
protected:
protected:
std::shared_ptr<ParameterClient2> testParameterClient_;
std::shared_ptr<TrainerConfigHelper> config_;
std::unique_ptr<TesterConfig> intconfig_;
......@@ -107,7 +107,7 @@ protected:
real cost;
} testContext_;
private:
private:
/**
* Test one batch by batchId. It is only used for testOnePass.
*
......
......@@ -39,7 +39,7 @@ namespace paddle {
class.
*/
class SgdThreadUpdater : public ParameterUpdater {
public:
public:
explicit SgdThreadUpdater(const OptimizationConfig& optConfig);
virtual ~SgdThreadUpdater() {}
......@@ -57,7 +57,7 @@ public:
virtual void apply();
virtual void restore();
protected:
protected:
// This is the function that will be eventualy called by the GradientMachine.
// used only for GPU update.
virtual void updateImpl(Parameter* para);
......
......@@ -41,7 +41,7 @@ namespace paddle {
* train/test a NeuralNetwork.
*/
class Trainer {
public:
public:
/**
* Ctor.
* @return
......@@ -138,7 +138,7 @@ public:
*/
ParameterUtil* getParameterUtilPtr();
protected:
protected:
/**
* Train one pass of data.
*
......@@ -159,10 +159,10 @@ protected:
void createTester();
private:
private:
std::unique_ptr<TesterConfig> createTesterConfig();
protected:
protected:
std::shared_ptr<TrainerConfigHelper> config_;
std::shared_ptr<TrainerStats> stats_;
......
......@@ -37,7 +37,7 @@ class DataConfig;
* Define a macro to unify 'final' keyword
*/
class TrainerConfigHelper /*final*/ {
public:
public:
DISABLE_COPY(TrainerConfigHelper);
/**
......@@ -193,7 +193,7 @@ public:
*/
static std::shared_ptr<TrainerConfigHelper> createFromFlagConfig();
private:
private:
static std::string getConfigNameFromPassId(int passId,
const std::string& modelPath);
......
......@@ -34,7 +34,7 @@ namespace paddle {
* the core training class for driving training logic
*/
class TrainerInternal {
public:
public:
struct ParaStat {
real maxAbsGrad;
real avgAbsGrad;
......@@ -126,7 +126,7 @@ public:
UpdateCallback updateCallback,
bool doPipelineUpdate);
protected:
protected:
std::shared_ptr<ParameterUpdater> parameterUpdater_;
GradientMachinePtr gradientMachine_;
std::shared_ptr<TrainerConfigHelper> config_;
......
......@@ -37,7 +37,7 @@ namespace paddle {
* through one mini-batch.
*/
class TrainerStats {
public:
public:
/**
* @brief reset all stats.
*
......@@ -147,7 +147,7 @@ public:
return os.str();
}
private:
private:
int64_t numProcessed_;
real totalCost_;
real currentCost_;
......
......@@ -125,7 +125,7 @@ enum { INDENT_WIDTH = 2 };
struct null {};
class value {
public:
public:
typedef std::vector<value> array;
typedef std::map<std::string, value> object;
union _storage {
......@@ -139,11 +139,11 @@ public:
object* object_;
};
protected:
protected:
int type_;
_storage u_;
public:
public:
value();
value(int type, bool);
explicit value(bool b);
......@@ -179,7 +179,7 @@ public:
void serialize(Iter os, bool prettify = false) const;
std::string serialize(bool prettify = false) const;
private:
private:
template <typename T>
value(const T*); // intentionally defined to block implicit conversion of
// pointer to bool
......@@ -588,13 +588,13 @@ inline std::string value::_serialize(int indent) const {
template <typename Iter>
class input {
protected:
protected:
Iter cur_, end_;
int last_ch_;
bool ungot_;
int line_;
public:
public:
input(const Iter& first, const Iter& last)
: cur_(first), end_(last), last_ch_(-1), ungot_(false), line_(1) {}
int getc() {
......@@ -873,7 +873,7 @@ inline bool _parse(Context& ctx, input<Iter>& in) {
}
class deny_parse_context {
public:
public:
bool set_null() { return false; }
bool set_bool(bool) { return false; }
#ifdef PICOJSON_USE_INT64
......@@ -898,10 +898,10 @@ public:
};
class default_parse_context {
protected:
protected:
value* out_;
public:
public:
default_parse_context(value* out) : out_(out) {}
bool set_null() {
*out_ = value();
......@@ -949,18 +949,18 @@ public:
return _parse(ctx, in);
}
private:
private:
default_parse_context(const default_parse_context&);
default_parse_context& operator=(const default_parse_context&);
};
class null_parse_context {
public:
public:
struct dummy_str {
void push_back(int) {}
};
public:
public:
null_parse_context() {}
bool set_null() { return true; }
bool set_bool(bool) { return true; }
......@@ -985,7 +985,7 @@ public:
return _parse(*this, in);
}
private:
private:
null_parse_context(const null_parse_context&);
null_parse_context& operator=(const null_parse_context&);
};
......
......@@ -38,7 +38,7 @@ DECLARE_int32(num_passes);
DECLARE_int32(saving_period);
class TrainerForTest : public paddle::Trainer {
public:
public:
inline const std::shared_ptr<ParameterUpdater>& getParameterUpdaterForTest() {
return this->trainerInternal_.getParameterUpdater();
}
......
......@@ -41,7 +41,7 @@ namespace paddle {
*/
template <class BaseClass, typename... CreateArgs>
class ClassRegistrar {
public:
public:
typedef std::function<BaseClass*(CreateArgs...)> ClassCreator;
// Register a class using a creation function.
......@@ -74,7 +74,7 @@ public:
}
}
protected:
protected:
std::map<std::string, ClassCreator> creatorMap_;
};
......
......@@ -35,7 +35,7 @@ enum simd_t {
// clang-format on
class SIMDFlags final {
public:
public:
DISABLE_COPY(SIMDFlags);
SIMDFlags();
......@@ -46,7 +46,7 @@ public:
return !((simd_flags_ & flags) ^ flags);
}
private:
private:
int simd_flags_ = SIMD_NONE;
};
......
......@@ -49,7 +49,7 @@ namespace paddle {
*/
template <typename T>
class CustomStackTrace {
public:
public:
/**
* @brief Pop out an item from the top of the stack if item == top.
* Else, just set status to popping.
......@@ -136,7 +136,7 @@ public:
p.push(item);
}
private:
private:
/**
* Get thread local attribute, and save them into a map (threadId => TYPE*)
*
......@@ -174,7 +174,7 @@ private:
return this->getThreadLocal(this->isPushing_, this->pushingBuffers_);
}
private:
private:
mutable std::mutex mtx_;
std::unordered_map<std::thread::id, std::stack<T>*> stackBuffers_;
......
......@@ -95,7 +95,7 @@ namespace paddle {
* log(FATAL) and CHECK in Paddle, 'check' method will be removed.
*/
class Error {
public:
public:
/**
* Construct a no-error value.
*/
......@@ -138,7 +138,7 @@ public:
*/
bool isOK() const { return msg_ == nullptr; }
private:
private:
std::shared_ptr<std::string> msg_;
};
......
......@@ -78,7 +78,7 @@ enum ParameterType {
using namespace enumeration_wrapper; // NOLINT
class TrainAlgorithm {
public:
public:
static const std::string SGD;
static const std::string AsyncSGD;
static const std::string OWLQN;
......
......@@ -42,7 +42,7 @@ namespace paddle {
* Use unlock() to unlock the lock.
*/
class RWLock {
public:
public:
RWLock() { pthread_rwlock_init(&rwlock_, NULL); }
~RWLock() { pthread_rwlock_destroy(&rwlock_); }
RWLock(const RWLock&) = delete;
......@@ -62,7 +62,7 @@ public:
void lock_shared() { pthread_rwlock_rdlock(&rwlock_); }
void unlock() { pthread_rwlock_unlock(&rwlock_); }
protected:
protected:
pthread_rwlock_t rwlock_;
};
......@@ -71,7 +71,7 @@ protected:
* using RAII management mechanism.
*/
class ReadLockGuard {
public:
public:
/**
* @brief Construct Function. Lock on rwlock in read mode.
*/
......@@ -86,7 +86,7 @@ public:
*/
~ReadLockGuard() { rwlock_->unlock(); }
protected:
protected:
RWLock* rwlock_;
};
......@@ -98,7 +98,7 @@ protected:
*/
class SpinLockPrivate;
class SpinLock {
public:
public:
DISABLE_COPY(SpinLock);
SpinLock();
~SpinLock();
......@@ -107,7 +107,7 @@ public:
void lock();
void unlock();
private:
private:
SpinLockPrivate* m;
};
......@@ -116,7 +116,7 @@ private:
*/
class SemaphorePrivate;
class Semaphore {
public:
public:
//! Disable copy & assign
Semaphore(const Semaphore& other) = delete;
Semaphore& operator=(const Semaphore&& other) = delete;
......@@ -124,7 +124,7 @@ public:
//! Enable move.
Semaphore(Semaphore&& other) : m(std::move(other.m)) {}
public:
public:
/**
* @brief Construct Function.
* @param[in] initValue the initial value of the
......@@ -156,7 +156,7 @@ public:
*/
void post();
private:
private:
SemaphorePrivate* m;
};
......@@ -166,7 +166,7 @@ private:
*/
class ThreadBarrierPrivate;
class ThreadBarrier {
public:
public:
DISABLE_COPY(ThreadBarrier);
/**
......@@ -184,7 +184,7 @@ public:
*/
void wait();
private:
private:
ThreadBarrierPrivate* m;
};
......@@ -192,7 +192,7 @@ private:
* A wrapper for condition variable with mutex.
*/
class LockedCondition : public std::condition_variable {
public:
public:
/**
* @brief execute op and notify one thread which was blocked.
* @param[in] op a thread can do something in op before notify.
......@@ -235,7 +235,7 @@ public:
*/
std::mutex* mutex() { return &mutex_; }
protected:
protected:
std::mutex mutex_;
};
......
......@@ -55,12 +55,12 @@ std::string callPythonFunc(const std::string& moduleName,
* NOTE: the lock of this guard is reentrant or recursive.
*/
class PyGuard {
public:
public:
PyGuard();
PyGuard(const PyGuard& other) = delete;
PyGuard& operator=(const PyGuard& other) = delete;
private:
private:
std::lock_guard<std::recursive_mutex> guard_;
};
......@@ -133,7 +133,7 @@ std::string getPyCallStack();
* Implements getAttr method for object.
*/
class ObjectHelper {
public:
public:
explicit ObjectHelper(const PyObjectPtr& obj) : obj_(obj) {}
/**
......@@ -192,7 +192,7 @@ public:
return PyObject_IsTrue(tmp.get());
}
private:
private:
const PyObjectPtr& obj_;
};
......@@ -202,7 +202,7 @@ private:
* The python sequence means list or tuple.
*/
class SequenceHelper {
public:
public:
explicit SequenceHelper(const PyObjectPtr& seq) : seq_(seq.get()) {
CHECK(PySequence_Check(seq_));
}
......@@ -248,12 +248,12 @@ public:
}
}
private:
private:
PyObject* seq_;
};
class DictHelper {
public:
public:
explicit DictHelper(PyObject* d) : dict_(d) {}
explicit DictHelper(const PyObjectPtr& d) : dict_(d.get()) {}
......@@ -275,7 +275,7 @@ public:
this->set(key, list);
}
private:
private:
inline void checkDict() { CHECK(PyDict_Check(this->dict_)); }
PyObject* dict_;
......@@ -289,7 +289,7 @@ inline static bool isCallable(const PyObjectPtr& obj) {
* Wrap a callable object.
*/
class CallableHelper {
public:
public:
explicit CallableHelper(const PyObjectPtr& obj) : obj_(obj) {
CHECK(py::isCallable(obj_));
}
......@@ -315,7 +315,7 @@ public:
return PyObject_Call(obj_.get(), args.get(), kwargs.get());
}
private:
private:
const PyObjectPtr& obj_;
PyObjectPtr args;
PyObjectPtr kwargs;
......
......@@ -56,7 +56,7 @@ namespace paddle {
*/
template <class T>
class Queue {
public:
public:
/**
* @brief Construct Function. Default capacity of Queue is zero.
*/
......@@ -147,7 +147,7 @@ public:
});
}
private:
private:
std::deque<T> elements_;
int numElements_;
std::mutex queueLock_;
......@@ -185,7 +185,7 @@ private:
*/
template <typename T>
class BlockingQueue {
public:
public:
/**
* @brief Construct Function.
* @param[in] capacity the max numer of elements the queue can have.
......@@ -244,7 +244,7 @@ public:
return queue_.empty();
}
private:
private:
std::mutex mutex_;
std::condition_variable notEmpty_;
std::condition_variable notFull_;
......
......@@ -33,7 +33,7 @@ namespace paddle {
class Stat;
class StatInfo {
public:
public:
explicit StatInfo(Stat* stat = nullptr) : stat_(stat) {
total_ = 0;
max_ = 0;
......@@ -61,7 +61,7 @@ class Stat;
typedef std::shared_ptr<Stat> StatPtr;
class StatSet {
public:
public:
explicit StatSet(const std::string& name) : name_(name) {}
~StatSet() {}
......@@ -102,7 +102,7 @@ public:
// pserver code logic, -_- ).
void reset(bool clearRawData = true);
private:
private:
std::unordered_map<std::string, StatPtr> statSet_;
const std::string name_;
RWLock lock_;
......@@ -112,7 +112,7 @@ extern StatSet globalStat;
/*@brief : a simple stat*/
class Stat {
public:
public:
explicit Stat(const std::string& statName)
: destructStat_(nullptr), name_(statName), openThreadInfo_(false) {}
~Stat() {}
......@@ -137,7 +137,7 @@ public:
friend class StatInfo;
private:
private:
void mergeThreadStat(StatInfo& allThreadStat);
std::mutex lock_;
......@@ -164,7 +164,7 @@ inline uint64_t nowInMicroSec() {
* A simple help class to measure time interval
*/
class Timer {
public:
public:
explicit Timer(bool autoStart = true) : total_(0), startStamp_(0) {
if (autoStart) {
start();
......@@ -181,13 +181,13 @@ public:
void reset() { total_ = 0; }
protected:
protected:
uint64_t total_;
uint64_t startStamp_;
};
class TimerOnce {
public:
public:
TimerOnce(Stat* stat,
const char* info = "",
uint64_t threshold = -1,
......@@ -208,7 +208,7 @@ public:
stat_->addSample(span);
}
private:
private:
Stat* stat_;
const char* info_;
Timer timer_;
......@@ -280,11 +280,11 @@ inline StatSet& registerTimerArg2(uint64_t threshold = -1,
#endif // DISABLE_TIMER
class GpuProfiler final {
public:
public:
GpuProfiler(std::string statName, std::string info);
~GpuProfiler();
private:
private:
std::lock_guard<std::recursive_mutex> guard_;
};
......
......@@ -29,7 +29,7 @@ namespace paddle {
*/
class Thread {
public:
public:
/**
* @brief Construct Function. Default thread pointer is null.
*/
......@@ -62,7 +62,7 @@ public:
*/
virtual void run() = 0;
protected:
protected:
std::unique_ptr<std::thread> thread_;
};
......@@ -73,7 +73,7 @@ protected:
* Use addJob() to add a new job to the job queue.
*/
class ThreadWorker : protected Thread {
public:
public:
typedef std::function<void()> JobFunc;
/**
......@@ -116,7 +116,7 @@ public:
finishCV_.wait([this] { return empty_; });
}
protected:
protected:
/**
* @brief Execute jobs in the job queue sequentianlly,
* @note If finish all the jobs in the job queue,
......@@ -150,7 +150,7 @@ protected:
* JobFunc can use tid to divide input data.
*/
class SyncThreadPool {
public:
public:
typedef std::function<void(int tid, size_t numThreads)> JobFunc;
/**
......@@ -236,7 +236,7 @@ public:
}
}
protected:
protected:
/**
* @brief Start all the workers in the pool, call their run() function.
*/
......@@ -285,7 +285,7 @@ protected:
}
}
protected:
protected:
pid_t ownerThreadId_;
bool stopping_;
ThreadBarrier jobStartBarrier_;
......@@ -323,7 +323,7 @@ protected:
*/
template <class T>
class MultiThreadWorker {
public:
public:
typedef T ResultType;
typedef std::shared_ptr<ResultType> ResultPtrType;
typedef std::function<ResultPtrType()> JobFunc;
......@@ -424,7 +424,7 @@ public:
*/
bool testResult() { return results_.empty(); }
protected:
protected:
/**
* @brief Do the jobs in the job queue sequentianlly
* and enqueue the result into the result queue.
......@@ -476,7 +476,7 @@ protected:
* thread pool.
*/
class AsyncThreadPool {
public:
public:
typedef std::function<void()> JobFunc;
AsyncThreadPool() { LOG(FATAL) << "Not implemented"; }
......@@ -594,7 +594,7 @@ public:
}
}
protected:
protected:
/**
* @brief Execute the jobs in the job queue.
*/
......@@ -606,7 +606,7 @@ protected:
}
}
private:
private:
std::vector<std::unique_ptr<std::thread>> workers_;
Queue<JobFunc> jobs_;
bool stopping_;
......
......@@ -49,7 +49,7 @@ namespace paddle {
*/
template <class T>
class ThreadLocal {
public:
public:
ThreadLocal() {
CHECK_EQ(pthread_key_create(&threadSpecificKey_, dataDestructor), 0);
}
......@@ -92,7 +92,7 @@ public:
*/
operator T*() { return get(); }
private:
private:
static void dataDestructor(void* p) { delete (T*)p; }
pthread_key_t threadSpecificKey_;
......@@ -111,7 +111,7 @@ private:
*/
template <class T>
class ThreadLocalD {
public:
public:
ThreadLocalD() { CHECK_EQ(pthread_key_create(&threadSpecificKey_, NULL), 0); }
~ThreadLocalD() {
pthread_key_delete(threadSpecificKey_);
......@@ -150,7 +150,7 @@ public:
*/
T& operator*() { return *get(); }
private:
private:
static void dataDestructor(void* p) { delete (T*)p; }
void updateMap(T* p) {
......@@ -172,7 +172,7 @@ private:
* @brief Thread-safe C-style random API.
*/
class ThreadLocalRand {
public:
public:
/**
* initSeed just like srand,
* called by main thread,
......@@ -205,7 +205,7 @@ public:
*/
static int getDefaultSeed() { return defaultSeed_; }
protected:
protected:
static unsigned int defaultSeed_;
static ThreadLocal<unsigned int> seed_;
};
......@@ -214,7 +214,7 @@ protected:
* @brief Thread-safe C++ style random engine.
*/
class ThreadLocalRandomEngine {
public:
public:
/**
* get random_engine for each thread.
*
......@@ -222,7 +222,7 @@ public:
*/
static std::default_random_engine& get();
protected:
protected:
static ThreadLocal<std::default_random_engine> engine_;
};
......
......@@ -179,7 +179,7 @@ void loadFileList(const std::string& fileListFileName,
*/
void registerInitFunction(std::function<void()> func, int priority = 0);
class InitFunction {
public:
public:
explicit InitFunction(std::function<void()> func, int priority = 0) {
registerInitFunction(func, priority);
}
......@@ -191,7 +191,7 @@ public:
* When the SetDevice object is destructed, it will restore device environment.
*/
class SetDevice {
public:
public:
explicit SetDevice(int deviceId) {
isSet_ = deviceId >= 0;
devId_ = 0;
......@@ -206,7 +206,7 @@ public:
}
}
protected:
protected:
bool isSet_;
int devId_;
};
......@@ -240,7 +240,7 @@ inline void enablePeerAccess(int d1, int d2) {
* }
*/
class AsyncGpuBlock {
public:
public:
AsyncGpuBlock() : syncFlag_(hl_get_sync_flag()) { hl_set_sync_flag(false); }
~AsyncGpuBlock() {
if (syncFlag_) {
......@@ -249,7 +249,7 @@ public:
}
}
private:
private:
bool syncFlag_;
};
......@@ -378,7 +378,7 @@ std::string join(const std::string& part1,
* A Checker for each invoke of method in same thread.
*/
class SameThreadChecker {
public:
public:
SameThreadChecker() {}
/**
......@@ -400,7 +400,7 @@ public:
<< invokeThreadId_ << " current invoked in " << curThreadId;
}
private:
private:
std::once_flag onceFlag_;
std::thread::id invokeThreadId_;
};
......@@ -421,7 +421,7 @@ private:
*/
template <typename KType, typename VType, typename Hash>
class WeakKVCache {
public:
public:
WeakKVCache() {}
std::shared_ptr<VType> get(const KType& key,
......@@ -442,7 +442,7 @@ public:
return retVal;
}
private:
private:
std::mutex lock_;
std::unordered_map<KType, std::weak_ptr<VType>, Hash> storage_;
};
......@@ -453,7 +453,7 @@ private:
*/
template <typename CallbackType, typename... Args>
class ScopedCallbacks {
public:
public:
ScopedCallbacks(CallbackType enter, CallbackType exit, Args&... args)
: exit_(std::bind(exit, args...)) {
enter(args...);
......@@ -464,7 +464,7 @@ public:
~ScopedCallbacks() { exit_(); }
private:
private:
std::function<void()> exit_;
};
......@@ -475,7 +475,7 @@ private:
*/
template <typename T, size_t Alignment>
class AlignedAllocator {
public:
public:
/// std campatible typedefs.
typedef T* pointer;
typedef const T* const_pointer;
......@@ -552,12 +552,12 @@ public:
return this->allocate(n);
}
private:
private:
AlignedAllocator& operator=(const AlignedAllocator&); // disable
};
class Deprecated {
public:
public:
explicit Deprecated(const std::string& msg = "") {
if (msg.empty()) {
LOG(WARNING) << "This class is deprecated, please do not use this class.";
......
......@@ -19,7 +19,7 @@ limitations under the License. */
namespace paddle {
class SemaphorePrivate {
public:
public:
sem_t sem;
};
......@@ -45,7 +45,7 @@ void Semaphore::post() { sem_post(&m->sem); }
#ifdef PADDLE_USE_PTHREAD_SPINLOCK
class SpinLockPrivate {
public:
public:
inline SpinLockPrivate() { pthread_spin_init(&lock_, 0); }
inline ~SpinLockPrivate() { pthread_spin_destroy(&lock_); }
......@@ -63,7 +63,7 @@ public:
// clang-format on
class SpinLockPrivate {
public:
public:
inline void lock() {
while (lock_.test_and_set(std::memory_order_acquire)) {
}
......@@ -86,7 +86,7 @@ void SpinLock::unlock() { m->unlock(); }
#ifdef PADDLE_USE_PTHREAD_BARRIER
class ThreadBarrierPrivate {
public:
public:
pthread_barrier_t barrier_;
inline explicit ThreadBarrierPrivate(int count) {
......@@ -101,7 +101,7 @@ public:
#else
class ThreadBarrierPrivate {
public:
public:
pthread_mutex_t mutex_;
pthread_cond_t cond_;
int count_;
......
......@@ -21,7 +21,7 @@ limitations under the License. */
namespace paddle {
class SemaphorePrivate {
public:
public:
~SemaphorePrivate() { dispatch_release(sem); }
dispatch_semaphore_t sem;
......@@ -45,7 +45,7 @@ void Semaphore::wait() {
void Semaphore::post() { dispatch_semaphore_signal(m->sem); }
class SpinLockPrivate {
public:
public:
std::atomic_flag lock_ = ATOMIC_FLAG_INIT;
char padding_[64 - sizeof(lock_)]; // Padding to cache line size
};
......@@ -61,7 +61,7 @@ void SpinLock::lock() {
void SpinLock::unlock() { m->lock_.clear(std::memory_order_release); }
class ThreadBarrierPrivate {
public:
public:
pthread_mutex_t mutex_;
pthread_cond_t cond_;
int count_;
......
......@@ -4,8 +4,12 @@ TOTAL_ERRORS=0
# The trick to remove deleted files: https://stackoverflow.com/a/2413151
for file in $(git diff --cached --name-status | awk '$1 != "D" {print $2}'); do
cpplint $file;
TOTAL_ERRORS=$(expr $TOTAL_ERRORS + $?);
if [[ $file =~ ^(paddle/api/.*|paddle/capi/.*|paddle/contrib/.*|paddle/cuda/.*|paddle/function/.*|paddle/gserver/.*|paddle/math/.*|paddle/optimizer/.*|paddle/parameter/.*|paddle/pserver/.*|paddle/trainer/.*|paddle/utils/.*) ]]; then
continue;
else
cpplint $file;
TOTAL_ERRORS=$(expr $TOTAL_ERRORS + $?);
fi
done
exit $TOTAL_ERRORS
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册