Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleHub
提交
9dfd6e56
P
PaddleHub
项目概览
PaddlePaddle
/
PaddleHub
1 年多 前同步成功
通知
283
Star
12117
Fork
2091
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
200
列表
看板
标记
里程碑
合并请求
4
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleHub
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
200
Issue
200
列表
看板
标记
里程碑
合并请求
4
合并请求
4
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
9dfd6e56
编写于
1月 01, 2019
作者:
Z
Zeyu Chen
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add test downloader
上级
5dc25a43
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
201 addition
and
41 deletion
+201
-41
paddle_hub/__init__.py
paddle_hub/__init__.py
+2
-1
paddle_hub/downloader.py
paddle_hub/downloader.py
+22
-8
paddle_hub/module.py
paddle_hub/module.py
+138
-30
paddle_hub/module_desc.proto
paddle_hub/module_desc.proto
+12
-2
paddle_hub/test_downloader.py
paddle_hub/test_downloader.py
+27
-0
未找到文件。
paddle_hub/__init__.py
浏览文件 @
9dfd6e56
...
@@ -5,4 +5,5 @@ from __future__ import print_function
...
@@ -5,4 +5,5 @@ from __future__ import print_function
import
paddle.fluid
as
fluid
import
paddle.fluid
as
fluid
from
paddle_hub.module
import
Module
from
paddle_hub.module
import
Module
from
paddle_hub.module
import
ModuleSpec
from
paddle_hub.module
import
ModuleDesc
from
paddle_hub.downloader
import
download_and_uncompress
paddle_hub/downloader.py
浏览文件 @
9dfd6e56
# 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.
# coding=utf-8
# coding=utf-8
from
__future__
import
print_function
from
__future__
import
print_function
from
__future__
import
division
from
__future__
import
division
...
@@ -17,14 +31,11 @@ tqdm prograss hook
...
@@ -17,14 +31,11 @@ tqdm prograss hook
"""
"""
__all__
=
[
__all__
=
[
'MODULE_HOME'
,
'MODULE_HOME'
,
'download'
,
'md5file'
,
'split'
,
'cluster_files_reader'
,
'download'
,
'convert'
,
'download_and_uncompress'
'md5file'
,
'split'
,
'cluster_files_reader'
,
'convert'
,
]
]
# TODO(ZeyuChen) add environment varialble to set MODULE_HOME
MODULE_HOME
=
os
.
path
.
expanduser
(
'~/.cache/paddle/module'
)
MODULE_HOME
=
os
.
path
.
expanduser
(
'~/.cache/paddle/module'
)
...
@@ -58,8 +69,7 @@ def download_and_uncompress(url, save_name=None):
...
@@ -58,8 +69,7 @@ def download_and_uncompress(url, save_name=None):
if
not
os
.
path
.
exists
(
dirname
):
if
not
os
.
path
.
exists
(
dirname
):
os
.
makedirs
(
dirname
)
os
.
makedirs
(
dirname
)
#TODO add download md5 file to verify file completeness
#TODO(ZeyuChen) add download md5 file to verify file completeness
file_name
=
os
.
path
.
join
(
file_name
=
os
.
path
.
join
(
dirname
,
dirname
,
url
.
split
(
'/'
)[
-
1
]
if
save_name
is
None
else
save_name
)
url
.
split
(
'/'
)[
-
1
]
if
save_name
is
None
else
save_name
)
...
@@ -83,6 +93,7 @@ def download_and_uncompress(url, save_name=None):
...
@@ -83,6 +93,7 @@ def download_and_uncompress(url, save_name=None):
with
open
(
file_name
,
'wb'
)
as
f
:
with
open
(
file_name
,
'wb'
)
as
f
:
shutil
.
copyfileobj
(
r
.
raw
,
f
)
shutil
.
copyfileobj
(
r
.
raw
,
f
)
else
:
else
:
#TODO(ZeyuChen) upgrade to tqdm process
with
open
(
file_name
,
'wb'
)
as
f
:
with
open
(
file_name
,
'wb'
)
as
f
:
dl
=
0
dl
=
0
total_length
=
int
(
total_length
)
total_length
=
int
(
total_length
)
...
@@ -95,6 +106,8 @@ def download_and_uncompress(url, save_name=None):
...
@@ -95,6 +106,8 @@ def download_and_uncompress(url, save_name=None):
sys
.
stdout
.
flush
()
sys
.
stdout
.
flush
()
print
(
"file download completed!"
,
file_name
)
print
(
"file download completed!"
,
file_name
)
#TODO(ZeyuChen) add md5 check error and file incompleted error, then raise
# them and catch them
with
tarfile
.
open
(
file_name
,
"r:gz"
)
as
tar
:
with
tarfile
.
open
(
file_name
,
"r:gz"
)
as
tar
:
file_names
=
tar
.
getnames
()
file_names
=
tar
.
getnames
()
print
(
file_names
)
print
(
file_names
)
...
@@ -169,6 +182,7 @@ class DownloadManager(object):
...
@@ -169,6 +182,7 @@ class DownloadManager(object):
if
__name__
==
"__main__"
:
if
__name__
==
"__main__"
:
# TODO(ZeyuChen) add unit test
link
=
"http://paddlehub.bj.bcebos.com/word2vec/word2vec-dim16-simple-example-1.tar.gz"
link
=
"http://paddlehub.bj.bcebos.com/word2vec/word2vec-dim16-simple-example-1.tar.gz"
module_path
=
download_and_uncompress
(
link
)
module_path
=
download_and_uncompress
(
link
)
...
...
paddle_hub/module.py
浏览文件 @
9dfd6e56
...
@@ -3,35 +3,120 @@ from __future__ import division
...
@@ -3,35 +3,120 @@ from __future__ import division
from
__future__
import
print_function
from
__future__
import
print_function
import
paddle.fluid
as
fluid
import
paddle.fluid
as
fluid
import
paddle_hub
as
hub
import
numpy
as
np
# import paddle_hub as hub
import
tempfile
import
tempfile
import
os
import
os
from
collections
import
defaultdict
class
Module
(
object
):
from
paddle_hub.downloader
import
download_and_uncompress
def
__init__
(
self
,
module_url
):
module_dir
=
download_and_extract
(
module_url
)
def
__init__
(
self
,
module_name
,
module_dir
=
None
):
if
module_dir
is
None
:
self
.
module_dir
=
tempfile
.
gettempdir
()
else
:
self
.
module_dir
=
module_dir
self
.
module_name
=
module_name
self
.
module_dir
=
os
.
path
.
join
(
self
.
module_dir
,
self
.
module_name
)
print
(
"create module dir folder at {}"
.
format
(
self
.
module_dir
))
self
.
_mkdir
(
self
.
module_dir
)
self
.
feed_list
=
[]
self
.
output_list
=
[]
pass
def
save_dict
(
self
,
word_dict
):
class
Module
(
object
):
with
open
(
os
.
path
.
join
(
self
.
module_dir
,
"tokens.txt"
),
"w"
)
as
fo
:
def
__init__
(
self
,
module_url
):
#map(str, word_dict)
# donwload module
dict_str
=
"
\n
"
.
join
(
word_dict
)
#module_dir = downloader.download_and_uncompress(module_url)
fo
.
write
(
dict_str
)
module_dir
=
download_and_uncompress
(
module_url
)
# load paddle inference model
place
=
fluid
.
CPUPlace
()
self
.
exe
=
fluid
.
Executor
(
fluid
.
CPUPlace
())
[
self
.
inference_program
,
self
.
feed_target_names
,
self
.
fetch_targets
]
=
fluid
.
io
.
load_inference_model
(
dirname
=
module_dir
,
executor
=
self
.
exe
)
print
(
"inference_program"
)
print
(
self
.
inference_program
)
print
(
"feed_target_names"
)
print
(
self
.
feed_target_names
)
print
(
"fetch_targets"
)
print
(
self
.
fetch_targets
)
# load assets
# self._load_assets(module_dir)
def
__call__
(
self
,
inputs
=
None
,
signature
=
None
):
word_ids_lod_tensor
=
self
.
_process_input
(
inputs
)
np_words_id
=
np
.
array
(
word_ids_lod_tensor
)
print
(
"word_ids_lod_tensor
\n
"
,
np_words_id
)
results
=
self
.
exe
.
run
(
self
.
inference_program
,
feed
=
{
self
.
feed_target_names
[
0
]:
word_ids_lod_tensor
},
fetch_list
=
self
.
fetch_targets
,
return_numpy
=
False
)
# return_numpy=Flase is important
print
(
self
.
feed_target_names
)
print
(
self
.
fetch_targets
)
# np_result = np.array(results[0])
return
np_result
def
get_vars
(
self
):
return
self
.
inference_program
.
list_vars
()
def
get_input_vars
(
self
):
for
var
in
self
.
inference_program
.
list_vars
():
print
(
var
)
if
var
.
name
==
"words"
:
return
var
# return self.fetch_targets
def
get_module_output
(
self
):
for
var
in
self
.
inference_program
.
list_vars
():
print
(
var
)
if
var
.
name
==
"embedding_0.tmp_0"
:
return
var
def
get_inference_program
(
self
):
return
self
.
inference_program
# for text sequence input, transform to lod tensor as paddle graph's input
def
_process_input
(
self
,
inputs
):
# words id mapping and dealing with oov
# transform to lod tensor
seq
=
[]
for
s
in
inputs
:
seq
.
append
(
self
.
_word_id_mapping
(
s
))
lod_tensor
=
self
.
seq2lod_tensor
(
seq
)
return
lod_tensor
def
seq2lod_tensor
(
self
,
seq_inputs
,
place
=
fluid
.
CPUPlace
()):
""" sequence to lod tensor, need to determine which space"""
lod
=
[]
lod
.
append
([])
for
s
in
seq_inputs
:
# generate lod
lod
[
0
].
append
(
len
(
s
))
# print("seq", seq_inputs)
# print("lod", lod)
lod_tensor
=
fluid
.
create_lod_tensor
(
seq_inputs
,
lod
,
place
)
return
lod_tensor
def
_word_id_mapping
(
self
,
inputs
):
return
list
(
map
(
lambda
x
:
self
.
dict
[
x
],
inputs
))
# load assets folder
def
_load_assets
(
self
,
module_dir
):
self
.
dict
=
defaultdict
(
int
)
self
.
dict
.
setdefault
(
0
)
assets_dir
=
os
.
path
.
join
(
module_dir
,
"assets"
)
tokens_path
=
os
.
path
.
join
(
assets_dir
,
"tokens.txt"
)
word_id
=
0
with
open
(
tokens_path
)
as
fi
:
words
=
fi
.
readlines
()
words
=
map
(
str
.
strip
,
words
)
for
w
in
words
:
self
.
dict
[
w
]
=
word_id
word_id
+=
1
print
(
w
,
word_id
)
def
add_module_feed_list
(
self
,
feed_list
):
def
add_module_feed_list
(
self
,
feed_list
):
self
.
feed_list
=
feed_list
self
.
feed_list
=
feed_list
...
@@ -43,9 +128,6 @@ class Module(object):
...
@@ -43,9 +128,6 @@ class Module(object):
if
not
os
.
path
.
exists
(
path
):
if
not
os
.
path
.
exists
(
path
):
os
.
makedirs
(
path
)
os
.
makedirs
(
path
)
def
save_inference_module
(
feed_var_names
,
target_vars
,
executor
):
pass
class
ModuleImpl
(
object
):
class
ModuleImpl
(
object
):
def
get_signature_name
():
def
get_signature_name
():
...
@@ -53,10 +135,36 @@ class ModuleImpl(object):
...
@@ -53,10 +135,36 @@ class ModuleImpl(object):
class
ModuleDesc
(
object
):
class
ModuleDesc
(
object
):
def
__init__
(
self
,
input_list
,
output_list
):
def
__init__
(
self
):
self
.
input_list
=
input_sig
self
.
output_list
=
output_list
pass
pass
def
add_signature
(
input
,
output
):
@
staticmethod
def
_mkdir
(
path
):
if
not
os
.
path
.
exists
(
path
):
print
(
"mkdir"
,
path
)
os
.
makedirs
(
path
)
@
staticmethod
def
save_dict
(
path
,
word_dict
):
ModuleDesc
.
_mkdir
(
path
)
with
open
(
os
.
path
.
join
(
path
,
"tokens.txt"
),
"w"
)
as
fo
:
print
(
"tokens.txt path"
,
os
.
path
.
join
(
path
,
"tokens.txt"
))
dict_str
=
"
\n
"
.
join
(
word_dict
)
fo
.
write
(
dict_str
)
@
staticmethod
def
save_module_dict
(
module_path
,
word_dict
):
assets_path
=
os
.
path
.
join
(
module_path
,
"assets"
)
print
(
"save_module_dict"
,
assets_path
)
ModuleDesc
.
save_dict
(
assets_path
,
word_dict
)
pass
pass
if
__name__
==
"__main__"
:
module_link
=
"http://paddlehub.cdn.bcebos.com/word2vec/w2v_saved_inference_module.tar.gz"
m
=
Module
(
module_link
)
inputs
=
[[
"it"
,
"is"
,
"new"
],
[
"hello"
,
"world"
]]
#tensor = m._process_input(inputs)
#print(tensor)
result
=
m
(
inputs
)
print
(
result
)
paddle_hub/module_desc.proto
浏览文件 @
9dfd6e56
...
@@ -14,11 +14,21 @@
...
@@ -14,11 +14,21 @@
// =============================================================================
// =============================================================================
syntax
=
"proto3"
;
syntax
=
"proto3"
;
package
paddle_hub
package
paddle_hub
;
message
InputDesc
{
}
message
OutputDesc
{
bool
return_numpy
=
1
;
}
// A Hub Module is stored in a directory with a file 'paddlehub_module.pb'
// A Hub Module is stored in a directory with a file 'paddlehub_module.pb'
// containing a serialized protocol message of this type. The further contents
// containing a serialized protocol message of this type. The further contents
// of the directory depend on the storage format described by the message.
// of the directory depend on the storage format described by the message.
message
ModuleDesc
{
message
ModuleDesc
{
required
stirng
name
=
0
;
// PaddleHub module name
string
name
=
1
;
// PaddleHub module name
repeated
string
input_signature
}
}
paddle_hub/test_downloader.py
0 → 100644
浏览文件 @
9dfd6e56
# 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
downloader
as
dl
import
unittest
class
TestDownloader
(
unittest
.
TestCase
):
def
test_download
(
self
):
link
=
"http://paddlehub.bj.bcebos.com/word2vec/word2vec-dim16-simple-example-1.tar.gz"
module_path
=
dl
.
ownload_and_uncompress
(
link
)
if
__name__
==
"__main__"
:
unittest
.
main
()
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录