Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
PaddleRec
提交
8a9c5d24
P
PaddleRec
项目概览
BaiXuePrincess
/
PaddleRec
与 Fork 源项目一致
Fork自
PaddlePaddle / PaddleRec
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleRec
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
8a9c5d24
编写于
4月 01, 2020
作者:
T
tangwei
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add cluster training
上级
7901e0b3
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
113 addition
and
17 deletion
+113
-17
examples/train.py
examples/train.py
+25
-0
trainer/factory.py
trainer/factory.py
+85
-0
trainer/single_train.py
trainer/single_train.py
+2
-3
trainer/trainer.py
trainer/trainer.py
+1
-14
未找到文件。
examples/train.py
浏览文件 @
8a9c5d24
# Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.# Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import
yaml
from
..
trainer
.
factory
import
TrainerFactory
...
...
trainer/factory.py
0 → 100644
浏览文件 @
8a9c5d24
# Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.# Copyright (c) 2019 PaddlePaddle Authors. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import
os
import
yaml
from
.single_train
import
SingleTrainerWithDataloader
from
.single_train
import
SingleTrainerWithDataset
from
.cluster_train
import
ClusterTrainerWithDataloader
from
.cluster_train
import
ClusterTrainerWithDataset
from
.ctr_trainer
import
CtrPaddleTrainer
from
..utils
import
envs
class
TrainerFactory
(
object
):
def
__init__
(
self
):
pass
@
staticmethod
def
_build_trainer
(
config
):
train_mode
=
envs
.
get_global_env
(
"train.trainer"
)
reader_mode
=
envs
.
get_global_env
(
"train.reader.mode"
)
if
train_mode
==
"SingleTraining"
:
if
reader_mode
==
"dataset"
:
trainer
=
SingleTrainerWithDataset
()
elif
reader_mode
==
"dataloader"
:
trainer
=
SingleTrainerWithDataloader
()
else
:
raise
ValueError
(
"reader only support dataset/dataloader"
)
elif
train_mode
==
"ClusterTraining"
:
if
reader_mode
==
"dataset"
:
trainer
=
ClusterTrainerWithDataset
()
elif
reader_mode
==
"dataloader"
:
trainer
=
ClusterTrainerWithDataloader
()
else
:
raise
ValueError
(
"reader only support dataset/dataloader"
)
elif
train_mode
==
"CtrTrainer"
:
trainer
=
CtrPaddleTrainer
(
config
)
else
:
raise
ValueError
(
"trainer only support SingleTraining/ClusterTraining"
)
return
trainer
@
staticmethod
def
create
(
config
):
_config
=
None
if
isinstance
(
config
,
dict
):
_config
=
config
elif
isinstance
(
config
,
str
):
if
os
.
path
.
exists
(
config
)
and
os
.
path
.
isfile
(
config
):
with
open
(
config
,
'r'
)
as
rb
:
_config
=
yaml
.
load
(
rb
.
read
())
else
:
raise
ValueError
(
"unknown config about eleps"
)
envs
.
set_global_envs
(
_config
)
trainer
=
TrainerFactory
.
_build_trainer
(
_config
)
return
trainer
trainer/single_train.py
浏览文件 @
8a9c5d24
...
...
@@ -39,9 +39,8 @@ def need_save(epoch_id, epoch_interval, is_last=False):
class
SingleTrainer
(
Trainer
):
def
__init__
(
self
,
config
=
None
,
yaml_file
=
None
):
Trainer
.
__init__
(
self
,
config
,
yaml_file
)
def
__init__
(
self
,
config
=
None
):
Trainer
.
__init__
(
self
,
config
)
self
.
exe
=
fluid
.
Executor
(
fluid
.
CPUPlace
())
...
...
trainer/trainer.py
浏览文件 @
8a9c5d24
...
...
@@ -24,20 +24,7 @@ class Trainer(object):
"""
__metaclass__
=
abc
.
ABCMeta
def
__init__
(
self
,
config
=
None
,
yaml_file
=
None
):
if
not
config
and
not
yaml_file
:
raise
ValueError
(
"config and yaml file have at least one not empty"
)
if
config
and
yaml_file
:
print
(
"config and yaml file are all assigned, will use yaml file: {}"
.
format
(
yaml_file
))
if
yaml_file
:
with
open
(
yaml_file
,
"r"
)
as
rb
:
config
=
yaml
.
load
(
rb
.
read
())
envs
.
set_global_envs
(
config
)
def
__init__
(
self
,
config
=
None
):
self
.
_status_processor
=
{}
self
.
_context
=
{
'status'
:
'uninit'
,
'is_exit'
:
False
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录