Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
c70f1cad
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
c70f1cad
编写于
6月 03, 2021
作者:
L
LielinJiang
提交者:
GitHub
6月 03, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add progressbar for datasets downloading (#33302)
* add progressbar for datasets downloading
上级
273f3859
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
19 addition
and
13 deletion
+19
-13
python/paddle/dataset/common.py
python/paddle/dataset/common.py
+7
-3
python/paddle/hapi/progressbar.py
python/paddle/hapi/progressbar.py
+12
-10
未找到文件。
python/paddle/dataset/common.py
浏览文件 @
c70f1cad
...
...
@@ -25,6 +25,7 @@ import importlib
import
paddle.dataset
import
six.moves.cPickle
as
pickle
import
glob
import
paddle
__all__
=
[]
...
...
@@ -95,16 +96,19 @@ def download(url, module_name, md5sum, save_name=None):
chunk_size
=
4096
total_length
=
int
(
total_length
)
total_iter
=
total_length
/
chunk_size
+
1
log_interval
=
total_iter
/
20
if
total_iter
>
20
else
1
log_interval
=
total_iter
/
/
20
if
total_iter
>
20
else
1
log_index
=
0
bar
=
paddle
.
hapi
.
progressbar
.
ProgressBar
(
total_iter
,
name
=
'item'
)
for
data
in
r
.
iter_content
(
chunk_size
=
chunk_size
):
if
six
.
PY2
:
data
=
six
.
b
(
data
)
f
.
write
(
data
)
log_index
+=
1
bar
.
update
(
log_index
,
{})
if
log_index
%
log_interval
==
0
:
sys
.
stderr
.
write
(
"."
)
sys
.
stdout
.
flush
()
bar
.
update
(
log_index
)
except
Exception
as
e
:
# re-try
continue
...
...
python/paddle/hapi/progressbar.py
浏览文件 @
c70f1cad
...
...
@@ -33,7 +33,8 @@ class ProgressBar(object):
width
=
30
,
verbose
=
1
,
start
=
True
,
file
=
sys
.
stdout
):
file
=
sys
.
stdout
,
name
=
'step'
):
self
.
_num
=
num
if
isinstance
(
num
,
int
)
and
num
<=
0
:
raise
TypeError
(
'num should be None or integer (> 0)'
)
...
...
@@ -47,6 +48,7 @@ class ProgressBar(object):
if
start
:
self
.
_start
=
time
.
time
()
self
.
_last_update
=
0
self
.
name
=
name
self
.
_dynamic_display
=
(
(
hasattr
(
self
.
file
,
'isatty'
)
and
...
...
@@ -74,7 +76,7 @@ class ProgressBar(object):
self
.
file
.
flush
()
self
.
_start
=
time
.
time
()
def
update
(
self
,
current_num
,
values
=
None
):
def
update
(
self
,
current_num
,
values
=
{}
):
now
=
time
.
time
()
if
current_num
:
...
...
@@ -83,11 +85,11 @@ class ProgressBar(object):
time_per_unit
=
0
if
time_per_unit
>=
1
or
time_per_unit
==
0
:
fps
=
' - %.0fs/%s'
%
(
time_per_unit
,
'step'
)
fps
=
' - %.0fs/%s'
%
(
time_per_unit
,
self
.
name
)
elif
time_per_unit
>=
1e-3
:
fps
=
' - %.0fms/%s'
%
(
time_per_unit
*
1e3
,
'step'
)
fps
=
' - %.0fms/%s'
%
(
time_per_unit
*
1e3
,
self
.
name
)
else
:
fps
=
' - %.0fus/%s'
%
(
time_per_unit
*
1e6
,
'step'
)
fps
=
' - %.0fus/%s'
%
(
time_per_unit
*
1e6
,
self
.
name
)
info
=
''
if
self
.
_verbose
==
1
:
...
...
@@ -102,7 +104,7 @@ class ProgressBar(object):
if
self
.
_num
is
not
None
:
numdigits
=
int
(
np
.
log10
(
self
.
_num
))
+
1
bar_chars
=
(
'step
%'
+
str
(
numdigits
)
+
'd/%d ['
)
%
(
bar_chars
=
(
self
.
name
+
'
%'
+
str
(
numdigits
)
+
'd/%d ['
)
%
(
current_num
,
self
.
_num
)
prog
=
float
(
current_num
)
/
self
.
_num
prog_width
=
int
(
self
.
_width
*
prog
)
...
...
@@ -116,7 +118,7 @@ class ProgressBar(object):
bar_chars
+=
(
'.'
*
(
self
.
_width
-
prog_width
))
bar_chars
+=
']'
else
:
bar_chars
=
'step
%3d'
%
current_num
bar_chars
=
self
.
name
+
'
%3d'
%
current_num
self
.
_total_width
=
len
(
bar_chars
)
sys
.
stdout
.
write
(
bar_chars
)
...
...
@@ -162,10 +164,10 @@ class ProgressBar(object):
elif
self
.
_verbose
==
2
or
self
.
_verbose
==
3
:
if
self
.
_num
:
numdigits
=
int
(
np
.
log10
(
self
.
_num
))
+
1
count
=
(
'step %'
+
str
(
numdigits
)
+
'd/%d'
)
%
(
current_num
,
self
.
_num
)
count
=
(
self
.
name
+
' %'
+
str
(
numdigits
)
+
'd/%d'
)
%
(
current_num
,
self
.
_num
)
else
:
count
=
'step
%3d'
%
current_num
count
=
self
.
name
+
'
%3d'
%
current_num
info
=
count
+
info
for
k
,
val
in
values
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录