Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
Paddle
提交
2412dee3
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看板
提交
2412dee3
编写于
5月 21, 2018
作者:
T
tangwei12
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
code optimized
上级
06aa23b0
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
33 addition
and
22 deletion
+33
-22
python/paddle/fluid/io.py
python/paddle/fluid/io.py
+33
-22
未找到文件。
python/paddle/fluid/io.py
浏览文件 @
2412dee3
...
...
@@ -454,17 +454,16 @@ def get_parameter_value_by_name(name, executor, program=None):
return
get_parameter_value
(
var
,
executor
)
SUCCESS
=
"_SUCCESS"
BEGIN_SECS
=
None
SUCCESS_MARK_FILENAME
=
"_SUCCESS"
def
save_checkpoint
(
executor
,
dirname
,
keep_max
=
3
,
save_secs
=
600
,
dirname
=
None
,
max_num_checkpoints
=
3
,
save_
interval_
secs
=
600
,
main_program
=
None
):
"""
Save Variables to Checkp
int Dir
Save Variables to Checkp
oint Directory
:param dirname
:param keep_max
...
...
@@ -472,20 +471,19 @@ def save_checkpoint(executor,
:param main_program
"""
if
dirname
is
None
:
raise
Exception
(
"save checkpoint dir can not be none"
)
dirname
=
os
.
getcwd
(
)
if
not
os
.
path
.
isdir
(
dirname
):
os
.
makedirs
(
dirname
)
global
BEGIN_SECS
if
BEGIN_SECS
is
not
None
:
if
time
.
time
()
-
BEGIN_SECS
<
save_secs
:
serial
=
_get_lastest_checkpoint_dir
(
dirname
)
if
serial
>=
0
and
not
_interval_secs_exceed
(
os
.
path
.
join
(
dirname
,
str
(
serial
)),
save_interval_secs
)
:
return
BEGIN_SECS
=
time
.
time
()
serial
=
_get_lastest_checkpoint_dir
(
dirname
)
+
1
serial
=
serial
+
1
cur_dir
=
os
.
path
.
join
(
dirname
,
str
(
serial
))
# save_persistables(executor, cur_dir, main_program)
save_vars
(
executor
,
dirname
=
cur_dir
,
...
...
@@ -494,10 +492,10 @@ def save_checkpoint(executor,
predicate
=
is_checkpoint_var
,
filename
=
None
)
_write_success
(
cur_dir
)
_lru_delete
(
dirname
,
keep_max
)
_lru_delete
(
dirname
,
max_num_checkpoints
)
def
restore_checkpoint
(
dirname
,
executor
,
main_program
=
None
):
def
restore_checkpoint
(
executor
,
dirname
=
None
,
main_program
=
None
):
"""
Load Variables from Checkpint Dir
...
...
@@ -505,15 +503,16 @@ def restore_checkpoint(dirname, executor, main_program=None):
:param executor
:param main_program
"""
if
dirname
is
None
and
os
.
path
.
isdir
(
dirname
):
raise
Exception
(
"restore checkpoint can not load variables from %s"
%
dirname
)
if
dirname
is
None
:
dirname
=
os
.
getcwd
()
serial
=
_get_lastest_checkpoint_dir
(
dirname
)
if
serial
<
0
:
return
cur_dir
=
os
.
path
.
join
(
dirname
,
str
(
serial
))
# load_persistables(executor, cur_dir, main_program)
load_vars
(
executor
,
dirname
=
cur_dir
,
...
...
@@ -523,6 +522,10 @@ def restore_checkpoint(dirname, executor, main_program=None):
def
is_checkpoint_var
(
var
):
"""
VarType will fliter out FEED_MINIBATCH FETCH_LIST RAW
VarName will fliter out Gradient
"""
if
var
.
desc
.
type
()
==
core
.
VarDesc
.
VarType
.
FEED_MINIBATCH
or
\
var
.
desc
.
type
()
==
core
.
VarDesc
.
VarType
.
FETCH_LIST
or
\
var
.
desc
.
type
()
==
core
.
VarDesc
.
VarType
.
RAW
:
...
...
@@ -534,6 +537,13 @@ def is_checkpoint_var(var):
return
var
.
persistable
def
_interval_secs_exceed
(
dirname
,
save_interval_secs
):
dir_time
=
os
.
path
.
getmtime
(
dirname
)
if
save_interval_secs
>
(
time
.
time
()
-
dir_time
):
return
False
return
True
def
_lru_delete
(
dirname
,
keep_max
=
3
):
"""
retain checkpoint nums with keep_max
...
...
@@ -560,7 +570,7 @@ def _write_success(dirname):
"""
write _SUCCESS to checkpoint dir
"""
success_file
=
os
.
path
.
join
(
dirname
,
SUCCESS
)
success_file
=
os
.
path
.
join
(
dirname
,
SUCCESS
_MARK_FILENAME
)
with
open
(
success_file
,
'a'
):
pass
...
...
@@ -584,7 +594,8 @@ def _get_lastest_checkpoint_dir(checkpoint_dir):
except
ValueError
:
return
-
1
success_path
=
os
.
path
.
join
(
checkpoint_dir
,
cur_dir
,
SUCCESS
)
success_path
=
os
.
path
.
join
(
checkpoint_dir
,
cur_dir
,
SUCCESS_MARK_FILENAME
)
if
os
.
path
.
isfile
(
success_path
):
return
int
(
cur_dir
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录