Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
5f9cd8c9
P
Paddle
项目概览
BaiXuePrincess
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
5f9cd8c9
编写于
6月 06, 2017
作者:
D
dzhwinter
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
"rename test file name"
上级
26e9c4e2
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
147 addition
and
146 deletion
+147
-146
paddle/optimizer/CMakeLists.txt
paddle/optimizer/CMakeLists.txt
+2
-0
paddle/optimizer/optimizer_factory_test.cpp
paddle/optimizer/optimizer_factory_test.cpp
+0
-31
paddle/optimizer/parameter_optimizer.cc
paddle/optimizer/parameter_optimizer.cc
+22
-22
paddle/optimizer/parameter_optimizer.h
paddle/optimizer/parameter_optimizer.h
+0
-3
paddle/optimizer/parameter_optimizer_test.cpp
paddle/optimizer/parameter_optimizer_test.cpp
+109
-0
paddle/optimizer/regularizer.cc
paddle/optimizer/regularizer.cc
+0
-26
paddle/optimizer/regularizer.h
paddle/optimizer/regularizer.h
+0
-45
proto/OptimizerConfig.proto
proto/OptimizerConfig.proto
+14
-19
未找到文件。
paddle/optimizer/CMakeLists.txt
浏览文件 @
5f9cd8c9
...
...
@@ -26,3 +26,5 @@ add_dependencies(optimizer gen_proto_cpp)
add_simple_unittest
(
optimizer_test
)
add_simple_unittest
(
optimizer_factory_test
)
add_simple_unittest
(
Tensor_test
)
add_simple_unittest
(
parameter_optimizer_test
)
add_dependencies
(
parameter_optimizer_test optimizer
)
paddle/optimizer/optimizer_factory_test.cpp
浏览文件 @
5f9cd8c9
#include "optimizer_factory.h"
#include "gtest/gtest.h"
#include "parameter_optimizer.h"
#define float TestType;
class
OptimizerTest
:
public
testing
::
Test
{
public:
virtual
void
SetUp
()
{
paddle
::
OptimizerConfig
config
;
config
.
set_learning_rate
(
0.01
);
config
.
set_decay
(
0.0
);
config
.
set_momentum
(
0.0
);
config
.
set_nesterov
(
false
);
config
.
set_lr_decay_a
(
0.9
);
config
.
set_lr_decay_b
(
0.1
);
std
::
string
config_proto
=
config
.
SerializeAsString
();
ParameterOptimizer
<
TestType
>::
create
(
config_proto
,
)
}
virtual
void
TearDown
()
{}
private:
ParameterOptimizer
<
TestType
>*
o
;
};
TEST_F
(
OptimizerTest
,
createOptimizer
)
{}
int
main
(
int
argc
,
char
**
argv
)
{
testing
::
InitGoogleTest
(
&
argc
,
argv
);
return
RUN_ALL_TESTS
();
}
paddle/optimizer/parameter_optimizer.cc
浏览文件 @
5f9cd8c9
#include <glog/logging.h>
//
#include "adadelta_optimizer.h"
//
#include "adagrad_optimizer.h"
//
#include "adam_optimizer.h"
#include "adadelta_optimizer.h"
#include "adagrad_optimizer.h"
#include "adam_optimizer.h"
#include "lr_policy.h"
#include "sgd_optimizer.h"
...
...
@@ -18,13 +18,13 @@ ParameterOptimizer *ParameterOptimizer::create(
auto
select_lr_policy
=
[
=
](
const
OptimizerConfig
&
config
)
->
BaseLr
*
{
std
::
string
s
(
config
.
lr_policy
());
if
(
s
==
"ConstLr"
)
return
new
ConstLr
(
config
.
lr_config
().
learning_rate
());
if
(
s
==
"ConstLr"
)
return
new
ConstLr
(
config
.
const_lr
().
learning_rate
());
if
(
s
==
"LinearLr"
)
return
new
LinearLr
(
config
.
l
r_config
().
learning_rate
(),
config
.
l
r_config
().
lr_decay_a
(),
config
.
l
r_config
().
lr_decay_b
());
return
new
LinearLr
(
config
.
l
inear_lr
().
learning_rate
(),
config
.
l
inear_lr
().
lr_decay_a
(),
config
.
l
inear_lr
().
lr_decay_b
());
// default
return
n
ew
ConstLr
(
config
.
lr_config
().
learning_rate
())
;
return
n
ullptr
;
};
BaseLr
*
lr
=
select_lr_policy
(
config
);
auto
select_optimizer
=
...
...
@@ -36,20 +36,20 @@ ParameterOptimizer *ParameterOptimizer::create(
config
.
sgd
().
nesterov
(),
lr
);
}
//
if (s == "Adadelta") {
//
return new AdagradOptimizer(
//
config.adagrad().epsilon(), config.adagrad().decay(), lr);
//
}
//
if (s == "Adagrad") {
//
return new AdagradOptimizer(
//
config.adagrad().epsilon(), config.adagrad().decay(), lr);
//
}
//
if (s == "Adam") {
//
return new AdadeltaOptimizer(config.adadelta().rho(),
//
config.adadelta().epsilon(),
//
config.adadelta().decay(),
//
lr);
//
}
if
(
s
==
"Adadelta"
)
{
return
new
AdagradOptimizer
(
config
.
adagrad
().
epsilon
(),
config
.
adagrad
().
decay
(),
lr
);
}
if
(
s
==
"Adagrad"
)
{
return
new
AdagradOptimizer
(
config
.
adagrad
().
epsilon
(),
config
.
adagrad
().
decay
(),
lr
);
}
if
(
s
==
"Adam"
)
{
return
new
AdadeltaOptimizer
(
config
.
adadelta
().
rho
(),
config
.
adadelta
().
epsilon
(),
config
.
adadelta
().
decay
(),
lr
);
}
// default
return
new
SGDOptimizer
(
config
.
sgd
().
momentum
(),
config
.
sgd
().
decay
(),
...
...
paddle/optimizer/parameter_optimizer.h
浏览文件 @
5f9cd8c9
...
...
@@ -17,9 +17,6 @@ public:
* @brief update hook for algorithm need to traverse parameter more than
* once.
*/
// use config for pack trainig state
ParameterOptimizer
(
const
OptimizerConfig
&
config
)
:
config_
(
config
){};
ParameterOptimizer
(
BaseLr
*
lr
)
:
lr_policy
(
lr
),
num_sample_passed
(
0
)
{}
virtual
~
ParameterOptimizer
()
{
delete
parameter_
;
};
...
...
paddle/optimizer/parameter_optimizer_test.cpp
0 → 100644
浏览文件 @
5f9cd8c9
#include "parameter_optimizer.h"
#include <cmath>
#include <tuple>
#include <vector>
#include "adadelta_optimizer.h"
#include "adagrad_optimizer.h"
#include "adam_optimizer.h"
#include "gtest/gtest.h"
#include "sgd_optimizer.h"
using
namespace
paddle
;
using
namespace
paddle
::
optimizer
;
Tensor
*
fill_n_Tensor
(
size_t
size
)
{
real
*
ptr
=
new
real
[
size
];
Tensor
*
param
=
new
Tensor
(
ptr
,
size
);
Tensor
&
p
=
*
param
;
for
(
auto
i
=
0
;
i
<
p
.
size
();
++
i
)
{
p
[
i
]
=
(
float
)
rand
()
/
(
float
)
RAND_MAX
;
}
return
param
;
}
Tensor
*
fix_n_Tensor
(
size_t
size
)
{
real
*
ptr
=
new
real
[
size
];
Tensor
*
param
=
new
Tensor
(
ptr
,
size
);
Tensor
&
p
=
*
param
;
for
(
auto
i
=
0
;
i
<
p
.
size
();
++
i
)
{
p
[
i
]
=
i
;
}
return
param
;
}
class
OptimizerTest
:
public
testing
::
Test
{
public:
// init tensor shape
const
size_t
size
=
5
;
virtual
void
SetUp
()
{
create_sgd
();
create_adam
();
}
virtual
void
TearDown
()
{}
void
create_sgd
()
{
config
.
set_optimizer_name
(
"SGD"
);
config
.
mutable_sgd
()
->
set_momentum
(
0.0
);
config
.
mutable_sgd
()
->
set_decay
(
0.0
);
config
.
mutable_sgd
()
->
set_nesterov
(
false
);
config
.
set_lr_policy
(
"ConstLr"
);
config
.
mutable_const_lr
()
->
set_learning_rate
(
0.1
);
ParameterOptimizer
*
opt
=
ParameterOptimizer
::
create
(
config
.
SerializeAsString
());
opts
.
push_back
(
opt
);
}
void
create_adam
()
{
config
.
set_optimizer_name
(
"Adam"
);
config
.
mutable_adam
()
->
set_beta_1
(
0.9
);
config
.
mutable_adam
()
->
set_beta_2
(
0.1
);
config
.
mutable_adam
()
->
set_epsilon
(
1e-3
);
config
.
mutable_adam
()
->
set_decay
(
0.0
);
config
.
set_lr_policy
(
"ConstLr"
);
config
.
mutable_const_lr
()
->
set_learning_rate
(
0.1
);
ParameterOptimizer
*
opt
=
ParameterOptimizer
::
create
(
config
.
SerializeAsString
());
opts
.
push_back
(
opt
);
}
void
test_set_weight
()
{
Tensor
*
p
=
fill_n_Tensor
(
size
);
for
(
size_t
i
=
0
;
i
<
opts
.
size
();
++
i
)
{
opts
[
i
]
->
set_weight
(
p
);
}
}
void
test_get_weight
()
{
Tensor
*
p
=
fix_n_Tensor
(
size
);
for
(
size_t
i
=
0
;
i
<
opts
.
size
();
++
i
)
{
opts
[
i
]
->
set_weight
(
p
);
}
for
(
size_t
i
=
0
;
i
<
opts
.
size
();
++
i
)
{
real
*
newp
=
(
real
*
)
opts
[
i
]
->
get_weight
();
for
(
size_t
j
=
0
;
j
<
size
;
++
j
)
{
EXPECT_EQ
(
newp
[
j
],
(
*
p
)[
j
]);
}
}
}
void
test_update
()
{
Tensor
*
g
=
fix_n_Tensor
(
size
);
for
(
size_t
i
=
0
;
i
<
opts
.
size
();
++
i
)
{
opts
[
i
]
->
update
(
g
);
}
}
private:
std
::
vector
<
ParameterOptimizer
*>
opts
;
OptimizerConfig
config
;
};
TEST_F
(
OptimizerTest
,
test_set_get_weight
)
{
test_set_weight
();
test_get_weight
();
}
TEST_F
(
OptimizerTest
,
test_update
)
{
test_update
();
}
int
main
(
int
argc
,
char
**
argv
)
{
testing
::
InitGoogleTest
(
&
argc
,
argv
);
return
RUN_ALL_TESTS
();
}
paddle/optimizer/regularizer.cc
已删除
100644 → 0
浏览文件 @
26e9c4e2
#include "regularizer.h"
namespace
paddle
{
namespace
optimizer
{
template
<
class
T
>
Regularizer
<
T
>*
Regularizer
<
T
>::
create
(
const
std
::
string
&
config
)
{
paddle
::
OptimizerConfig
config
;
Regularizer
<
T
>*
r
;
if
(
config
.
regularizer_type
()
==
paddle
::
OptimizerConfig_RegularizerType_L1
)
{
r
=
new
L1Regularizer
<
T
>
(
config
);
}
else
if
(
config
.
regularizer_type
()
==
paddle
::
OptimizerConfig_RegularizerType_L2
)
{
r
=
new
L2Regularizer
<
T
>
(
config
);
break
;
}
return
r
;
}
template
class
L1Regularizer
<
float
>;
template
class
L1Regularizer
<
double
>;
template
class
L2Regularizer
<
float
>;
template
class
L2Regularizer
<
double
>;
}
// namespace optimizer
}
// namespace paddle
paddle/optimizer/regularizer.h
已删除
100644 → 0
浏览文件 @
26e9c4e2
#ifndef PADDLE_OPITMIZER_REGULARIZER_H_
#define PADDLE_OPTIMIZER_REGULARIZER_H_
#include "OptimizerConfig.pb.h"
#include "Tensor.h"
namespace
paddle
{
namespace
optimizer
{
/**
* @brief regularizer in L1, L2
*/
template
<
class
T
>
class
Regularizer
{
public:
/**
* @brief regularizer update interface
* @param param need to update
* @return void
*/
static
Regularizer
*
create
(
const
std
::
string
&
config
);
virtual
void
update
(
Tensor
<
T
>
&
parameter
)
=
0
;
private:
std
::
string
regularizer_name
;
OptimizerConfig
config_
;
};
template
<
class
T
>
class
L1Regularizer
{
public:
void
update
(
Tensor
<
T
>
&
parameter
);
};
template
<
class
T
>
class
L2Regularizer
{
public:
void
update
(
Tensor
<
T
>
&
parameter
);
};
}
// namespace optimizer
}
// namespace paddle
#endif
proto/OptimizerConfig.proto
浏览文件 @
5f9cd8c9
...
...
@@ -52,7 +52,12 @@ message AdamConfig {
optional
double
decay
=
44
;
}
message
LearningRateConfig
{
message
ConstLr
{
// learninRate Policy
required
double
learning_rate
=
40
[
default
=
1.0
];
}
message
LinearLr
{
// learninRate Policy
required
double
learning_rate
=
40
[
default
=
1.0
];
optional
double
lr_decay_a
=
25
;
...
...
@@ -62,36 +67,26 @@ message LearningRateConfig {
message
OptimizerConfig
{
// common config of optimizer
// algorithm config, type : string
// SGD = 1;
// Adadelta = 2;
// Adagrad = 3;
// Adam = 4;
required
string
optimizer_name
=
1
;
// algorithm config
enum
OptimizerType
{
SGD
=
1
;
Adadelta
=
2
;
Adagrad
=
3
;
Adam
=
4
;
}
required
OptimizerType
optimizer_type
=
2
;
optional
SGDConfig
sgd
=
3
;
optional
AdadeltaConfig
adadelta
=
4
;
optional
AdagradConfig
adagrad
=
5
;
optional
AdamConfig
adam
=
6
;
// learning rate runtime policy config
// lr_policy : string
// lr_policy
, type
: string
// ConstLr = 0;
// LinearLr = 1;
required
string
lr_policy
=
11
;
required
LearningRateConfig
lr_config
=
12
;
optional
ConstLr
const_lr
=
12
;
optional
LinearLr
linear_lr
=
15
;
optional
uint64
num_sample_passed
=
13
[
default
=
0
];
// reqularizer config
enum
RegularizerType
{
L1
=
1
;
L2
=
2
;
L1L2
=
3
;
}
optional
RegularizerType
regularizer_type
=
21
;
// common config of optimizer
optional
double
clipnorm
=
101
;
optional
double
clipvalue
=
102
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录