syntax = "proto2"; option optimize_for = LITE_RUNTIME; package paddle; message SGDConfig { // SGD // momentum: float >= 0. Parameter updates momentum. // decay: float >= 0. Learning rate decay over each update. // nesterov: boolean. Whether to apply Nesterov momentum. optional double momentum = 21 [default = 0.0]; optional double decay = 23 [default = 0.0]; optional bool nesterov =24 [default = false]; } message AdadeltaConfig { // Adadelta // It is recommended to leave it at the default value. // rho: float >= 0. // epsilon: float >= 0. Fuzz factor. // decay: float >= 0. Learning rate decay over each update. // reference : [Adadelta - an adaptive learning rate method](http://arxiv.org/abs/1212.5701) optional double rho = 33 [default = 0.90]; optional double epsilon = 31 [default = 1e-5]; optional double decay = 32 [default = 0.0]; } message AdagradConfig { // Adagrad // epsilon: float >= 0. // decay: float >= 0. Learning rate decay over each update. // reference : [Adaptive Subgradient Methods for Online Learning and Stochastic Optimization](http://www.jmlr.org/papers/volume12/duchi11a/duchi11a.pdf) optional double epsilon = 41 [default = 1e-5]; optional double decay = 42 [default = 0.0]; } message AdamConfig { // Adaj // beta_1: float, 0 < beta < 1. Generally close to 1. // beta_2: float, 0 < beta < 1. Generally close to 1. // epsilon: float >= 0. Fuzz factor. // decay: float >= 0. Learning rate decay over each update. // reference : [Adam - A Method for Stochastic Optimization](http://arxiv.org/abs/1412.6980v8) optional double beta_1 = 41; optional double beta_2 = 42; optional double epsilon = 43; optional double decay = 44; } message ConstLrConfig { // learninRate Policy optional double learning_rate = 1 [default = 1.0]; } message LinearLrConfig { // learninRate Policy optional double learning_rate = 1 [default = 1.0]; optional double lr_decay_a = 2; optional double lr_decay_b = 3; } message TensorProto { enum DataType { PADDLE_ELEMENT_TYPE_INT32 = 0; PADDLE_ELEMENT_TYPE_UINT32 = 1; PADDLE_ELEMENT_TYPE_INT64 = 2; PADDLE_ELEMENT_TYPE_UINT64 = 3; PADDLE_ELEMENT_TYPE_FLOAT32 = 4; PADDLE_ELEMENT_TYPE_FLOAT64 = 5; } optional DataType data_type = 1; repeated bytes content = 2; } message LrPolicyState { // learninRate Policy optional double learning_rate = 1 [default = 1.0]; optional double lr_decay_a = 2; optional double lr_decay_b = 3; } message SGDOptimizerState { optional LrPolicyState lrstate = 101; optional double num_sample_passed = 104; // state optional TensorProto parameter = 1; optional TensorProto momentums = 2; } message AdadeltaOptimizerState { // learning rate policy optional LrPolicyState lr_state = 101; optional double num_sample_passed = 104; // state optional TensorProto parameter = 1; optional TensorProto accum_gradient = 2; optional TensorProto accum_delta = 3; optional TensorProto update_delta = 4; } message AdagradOptimizerState { optional LrPolicyState lrstate = 101; optional double num_sample_passed = 104; // state optional TensorProto parameter = 1; optional TensorProto accum_gradient = 2; } message AdamOptimizerState { optional LrPolicyState lrstate = 101; optional double num_sample_passed = 104; // state optional TensorProto parameter = 1; optional TensorProto momentums = 2; optional TensorProto velocitys = 3; } message OptimizerConfig { enum Optimizer { SGD = 1; Adadelta = 2; Adagrad = 3; Adam = 4; } optional Optimizer optimizer = 1; optional SGDConfig sgd = 3; optional AdadeltaConfig adadelta = 4; optional AdagradConfig adagrad = 5; optional AdamConfig adam = 6; enum LrPolicy { Const = 0; Linear = 1; } optional LrPolicy lr_policy = 11; optional ConstLrConfig const_lr = 12; optional LinearLrConfig linear_lr = 13; // common config of optimizer // gradient clip when L2 exceeding value optional double clip_norm = 101; // gradient clip when L1 exceeding value optional double clip_value = 102; }