Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleHub
提交
6669e041
P
PaddleHub
项目概览
PaddlePaddle
/
PaddleHub
大约 2 年 前同步成功
通知
285
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看板
提交
6669e041
编写于
12月 18, 2019
作者:
W
wuzewu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add module v2
上级
5797e613
变更
6
展开全部
显示空白变更内容
内联
并排
Showing
6 changed file
with
346 addition
and
367 deletion
+346
-367
paddlehub/__init__.py
paddlehub/__init__.py
+1
-1
paddlehub/commands/run.py
paddlehub/commands/run.py
+10
-10
paddlehub/module/check_info.proto
paddlehub/module/check_info.proto
+3
-2
paddlehub/module/check_info_pb2.py
paddlehub/module/check_info_pb2.py
+26
-11
paddlehub/module/checker.py
paddlehub/module/checker.py
+23
-13
paddlehub/module/module.py
paddlehub/module/module.py
+283
-330
未找到文件。
paddlehub/__init__.py
浏览文件 @
6669e041
...
@@ -38,7 +38,7 @@ from .common.logger import logger
...
@@ -38,7 +38,7 @@ from .common.logger import logger
from
.common.paddle_helper
import
connect_program
from
.common.paddle_helper
import
connect_program
from
.common.hub_server
import
default_hub_server
from
.common.hub_server
import
default_hub_server
from
.module.module
import
Module
,
create_module
from
.module.module
import
Module
from
.module.base_processor
import
BaseProcessor
from
.module.base_processor
import
BaseProcessor
from
.module.signature
import
Signature
,
create_signature
from
.module.signature
import
Signature
,
create_signature
from
.module.manager
import
default_module_manager
from
.module.manager
import
default_module_manager
...
...
paddlehub/commands/run.py
浏览文件 @
6669e041
...
@@ -71,10 +71,10 @@ class RunCommand(BaseCommand):
...
@@ -71,10 +71,10 @@ class RunCommand(BaseCommand):
if
not
result
:
if
not
result
:
return
None
return
None
return
hub
.
Module
(
module_dir
=
module_dir
)
return
hub
.
Module
(
directory
=
module_dir
[
0
]
)
def
add_module_config_arg
(
self
):
def
add_module_config_arg
(
self
):
configs
=
self
.
module
.
processor
.
configs
()
configs
=
self
.
module
.
configs
()
for
config
in
configs
:
for
config
in
configs
:
if
not
config
[
"dest"
].
startswith
(
"--"
):
if
not
config
[
"dest"
].
startswith
(
"--"
):
config
[
"dest"
]
=
"--%s"
%
config
[
"dest"
]
config
[
"dest"
]
=
"--%s"
%
config
[
"dest"
]
...
@@ -104,8 +104,8 @@ class RunCommand(BaseCommand):
...
@@ -104,8 +104,8 @@ class RunCommand(BaseCommand):
def
add_module_input_arg
(
self
):
def
add_module_input_arg
(
self
):
module_type
=
self
.
module
.
type
.
lower
()
module_type
=
self
.
module
.
type
.
lower
()
expect_data_format
=
self
.
module
.
processor
.
data_format
(
expect_data_format
=
self
.
module
.
data_format
(
self
.
module
.
default_signature
.
name
)
self
.
module
.
default_signature
)
self
.
arg_input_group
.
add_argument
(
self
.
arg_input_group
.
add_argument
(
'--input_file'
,
'--input_file'
,
type
=
str
,
type
=
str
,
...
@@ -144,15 +144,15 @@ class RunCommand(BaseCommand):
...
@@ -144,15 +144,15 @@ class RunCommand(BaseCommand):
if
self
.
args
.
config
:
if
self
.
args
.
config
:
yaml_config
=
yaml_parser
.
parse
(
self
.
args
.
config
)
yaml_config
=
yaml_parser
.
parse
(
self
.
args
.
config
)
module_config
=
yaml_config
.
get
(
"config"
,
{})
module_config
=
yaml_config
.
get
(
"config"
,
{})
for
_config
in
self
.
module
.
processor
.
configs
():
for
_config
in
self
.
module
.
configs
():
key
=
_config
[
'dest'
]
key
=
_config
[
'dest'
]
module_config
[
key
]
=
self
.
args
.
__dict__
[
key
]
module_config
[
key
]
=
self
.
args
.
__dict__
[
key
]
return
module_config
return
module_config
def
get_data
(
self
):
def
get_data
(
self
):
module_type
=
self
.
module
.
type
.
lower
()
module_type
=
self
.
module
.
type
.
lower
()
expect_data_format
=
self
.
module
.
processor
.
data_format
(
expect_data_format
=
self
.
module
.
data_format
(
self
.
module
.
default_signature
.
name
)
self
.
module
.
default_signature
)
input_data
=
{}
input_data
=
{}
if
len
(
expect_data_format
)
==
1
:
if
len
(
expect_data_format
)
==
1
:
key
=
list
(
expect_data_format
.
keys
())[
0
]
key
=
list
(
expect_data_format
.
keys
())[
0
]
...
@@ -176,8 +176,8 @@ class RunCommand(BaseCommand):
...
@@ -176,8 +176,8 @@ class RunCommand(BaseCommand):
return
input_data
return
input_data
def
check_data
(
self
,
data
):
def
check_data
(
self
,
data
):
expect_data_format
=
self
.
module
.
processor
.
data_format
(
expect_data_format
=
self
.
module
.
data_format
(
self
.
module
.
default_signature
.
name
)
self
.
module
.
default_signature
)
if
len
(
data
.
keys
())
!=
len
(
expect_data_format
.
keys
()):
if
len
(
data
.
keys
())
!=
len
(
expect_data_format
.
keys
()):
print
(
print
(
...
@@ -260,7 +260,7 @@ class RunCommand(BaseCommand):
...
@@ -260,7 +260,7 @@ class RunCommand(BaseCommand):
return
False
return
False
results
=
self
.
module
(
results
=
self
.
module
(
sign_name
=
self
.
module
.
default_signature
.
name
,
sign_name
=
self
.
module
.
default_signature
,
data
=
data
,
data
=
data
,
use_gpu
=
self
.
args
.
use_gpu
,
use_gpu
=
self
.
args
.
use_gpu
,
batch_size
=
self
.
args
.
batch_size
,
batch_size
=
self
.
args
.
batch_size
,
...
...
paddlehub/module/check_info.proto
浏览文件 @
6669e041
...
@@ -50,6 +50,7 @@ message CheckInfo {
...
@@ -50,6 +50,7 @@ message CheckInfo {
string
paddle_version
=
1
;
string
paddle_version
=
1
;
string
hub_version
=
2
;
string
hub_version
=
2
;
string
module_proto_version
=
3
;
string
module_proto_version
=
3
;
repeated
FileInfo
file_infos
=
4
;
string
module_code_version
=
4
;
repeated
Requires
requires
=
5
;
repeated
FileInfo
file_infos
=
5
;
repeated
Requires
requires
=
6
;
};
};
paddlehub/module/check_info_pb2.py
浏览文件 @
6669e041
#coding:utf-8
# Generated by the protocol buffer compiler. DO NOT EDIT!
# Generated by the protocol buffer compiler. DO NOT EDIT!
# source: check_info.proto
# source: check_info.proto
...
@@ -19,7 +18,7 @@ DESCRIPTOR = _descriptor.FileDescriptor(
...
@@ -19,7 +18,7 @@ DESCRIPTOR = _descriptor.FileDescriptor(
package
=
'paddlehub.module.checkinfo'
,
package
=
'paddlehub.module.checkinfo'
,
syntax
=
'proto3'
,
syntax
=
'proto3'
,
serialized_pb
=
_b
(
serialized_pb
=
_b
(
'
\n\x10\x63
heck_info.proto
\x12\x1a
paddlehub.module.checkinfo
\"\x85\x01\n\x08\x46
ileInfo
\x12\x11\n\t
file_name
\x18\x01
\x01
(
\t\x12\x33\n\x04
type
\x18\x02
\x01
(
\x0e\x32
%.paddlehub.module.checkinfo.FILE_TYPE
\x12\x0f\n\x07
is_need
\x18\x03
\x01
(
\x08\x12\x0b\n\x03
md5
\x18\x04
\x01
(
\t\x12\x13\n\x0b\x64\x65
scription
\x18\x05
\x01
(
\t\"\x84\x01\n\x08
Requires
\x12
>
\n\x0c
require_type
\x18\x01
\x01
(
\x0e\x32
(.paddlehub.module.checkinfo.REQUIRE_TYPE
\x12\x0f\n\x07
version
\x18\x02
\x01
(
\t\x12\x12\n\n
great_than
\x18\x03
\x01
(
\x08\x12\x13\n\x0b\x64\x65
scription
\x18\x04
\x01
(
\t\"\x
c8\x01\n\t
CheckInfo
\x12\x16\n\x0e
paddle_version
\x18\x01
\x01
(
\t\x12\x13\n\x0b
hub_version
\x18\x02
\x01
(
\t\x12\x1c\n\x14
module_proto_version
\x18\x03
\x01
(
\t\x12\x38\n\n
file_infos
\x18\x04
\x03
(
\x0b\x32
$.paddlehub.module.checkinfo.FileInfo
\x12\x36\n\x08
requires
\x18\x05
\x03
(
\x0b\x32
$.paddlehub.module.checkinfo.Requires*
\x1e\n\t
FILE_TYPE
\x12\x08\n\x04\x46
ILE
\x10\x00\x12\x07\n\x03\x44
IR
\x10\x01
*[
\n\x0c
REQUIRE_TYPE
\x12\x12\n\x0e
PYTHON_PACKAGE
\x10\x00\x12\x0e\n\n
HUB_MODULE
\x10\x01\x12\n\n\x06
SYSTEM
\x10\x02\x12\x0b\n\x07\x43
OMMAND
\x10\x03\x12\x0e\n\n
PY_VERSION
\x10\x04\x42\x02
H
\x03\x62\x06
proto3'
'
\n\x10\x63
heck_info.proto
\x12\x1a
paddlehub.module.checkinfo
\"\x85\x01\n\x08\x46
ileInfo
\x12\x11\n\t
file_name
\x18\x01
\x01
(
\t\x12\x33\n\x04
type
\x18\x02
\x01
(
\x0e\x32
%.paddlehub.module.checkinfo.FILE_TYPE
\x12\x0f\n\x07
is_need
\x18\x03
\x01
(
\x08\x12\x0b\n\x03
md5
\x18\x04
\x01
(
\t\x12\x13\n\x0b\x64\x65
scription
\x18\x05
\x01
(
\t\"\x84\x01\n\x08
Requires
\x12
>
\n\x0c
require_type
\x18\x01
\x01
(
\x0e\x32
(.paddlehub.module.checkinfo.REQUIRE_TYPE
\x12\x0f\n\x07
version
\x18\x02
\x01
(
\t\x12\x12\n\n
great_than
\x18\x03
\x01
(
\x08\x12\x13\n\x0b\x64\x65
scription
\x18\x04
\x01
(
\t\"\x
e5\x01\n\t
CheckInfo
\x12\x16\n\x0e
paddle_version
\x18\x01
\x01
(
\t\x12\x13\n\x0b
hub_version
\x18\x02
\x01
(
\t\x12\x1c\n\x14
module_proto_version
\x18\x03
\x01
(
\t\x12\x1b\n\x13
module_code_version
\x18\x04
\x01
(
\t\x12\x38\n\n
file_infos
\x18\x05
\x03
(
\x0b\x32
$.paddlehub.module.checkinfo.FileInfo
\x12\x36\n\x08
requires
\x18\x06
\x03
(
\x0b\x32
$.paddlehub.module.checkinfo.Requires*
\x1e\n\t
FILE_TYPE
\x12\x08\n\x04\x46
ILE
\x10\x00\x12\x07\n\x03\x44
IR
\x10\x01
*[
\n\x0c
REQUIRE_TYPE
\x12\x12\n\x0e
PYTHON_PACKAGE
\x10\x00\x12\x0e\n\n
HUB_MODULE
\x10\x01\x12\n\n\x06
SYSTEM
\x10\x02\x12\x0b\n\x07\x43
OMMAND
\x10\x03\x12\x0e\n\n
PY_VERSION
\x10\x04\x42\x02
H
\x03\x62\x06
proto3'
))
))
_sym_db
.
RegisterFileDescriptor
(
DESCRIPTOR
)
_sym_db
.
RegisterFileDescriptor
(
DESCRIPTOR
)
...
@@ -36,8 +35,8 @@ _FILE_TYPE = _descriptor.EnumDescriptor(
...
@@ -36,8 +35,8 @@ _FILE_TYPE = _descriptor.EnumDescriptor(
],
],
containing_type
=
None
,
containing_type
=
None
,
options
=
None
,
options
=
None
,
serialized_start
=
5
22
,
serialized_start
=
5
51
,
serialized_end
=
5
52
,
serialized_end
=
5
81
,
)
)
_sym_db
.
RegisterEnumDescriptor
(
_FILE_TYPE
)
_sym_db
.
RegisterEnumDescriptor
(
_FILE_TYPE
)
...
@@ -61,8 +60,8 @@ _REQUIRE_TYPE = _descriptor.EnumDescriptor(
...
@@ -61,8 +60,8 @@ _REQUIRE_TYPE = _descriptor.EnumDescriptor(
],
],
containing_type
=
None
,
containing_type
=
None
,
options
=
None
,
options
=
None
,
serialized_start
=
5
54
,
serialized_start
=
5
83
,
serialized_end
=
6
45
,
serialized_end
=
6
74
,
)
)
_sym_db
.
RegisterEnumDescriptor
(
_REQUIRE_TYPE
)
_sym_db
.
RegisterEnumDescriptor
(
_REQUIRE_TYPE
)
...
@@ -316,10 +315,26 @@ _CHECKINFO = _descriptor.Descriptor(
...
@@ -316,10 +315,26 @@ _CHECKINFO = _descriptor.Descriptor(
extension_scope
=
None
,
extension_scope
=
None
,
options
=
None
),
options
=
None
),
_descriptor
.
FieldDescriptor
(
_descriptor
.
FieldDescriptor
(
name
=
'
file_infos
'
,
name
=
'
module_code_version
'
,
full_name
=
'paddlehub.module.checkinfo.CheckInfo.
file_infos
'
,
full_name
=
'paddlehub.module.checkinfo.CheckInfo.
module_code_version
'
,
index
=
3
,
index
=
3
,
number
=
4
,
number
=
4
,
type
=
9
,
cpp_type
=
9
,
label
=
1
,
has_default_value
=
False
,
default_value
=
_b
(
""
).
decode
(
'utf-8'
),
message_type
=
None
,
enum_type
=
None
,
containing_type
=
None
,
is_extension
=
False
,
extension_scope
=
None
,
options
=
None
),
_descriptor
.
FieldDescriptor
(
name
=
'file_infos'
,
full_name
=
'paddlehub.module.checkinfo.CheckInfo.file_infos'
,
index
=
4
,
number
=
5
,
type
=
11
,
type
=
11
,
cpp_type
=
10
,
cpp_type
=
10
,
label
=
3
,
label
=
3
,
...
@@ -334,8 +349,8 @@ _CHECKINFO = _descriptor.Descriptor(
...
@@ -334,8 +349,8 @@ _CHECKINFO = _descriptor.Descriptor(
_descriptor
.
FieldDescriptor
(
_descriptor
.
FieldDescriptor
(
name
=
'requires'
,
name
=
'requires'
,
full_name
=
'paddlehub.module.checkinfo.CheckInfo.requires'
,
full_name
=
'paddlehub.module.checkinfo.CheckInfo.requires'
,
index
=
4
,
index
=
5
,
number
=
5
,
number
=
6
,
type
=
11
,
type
=
11
,
cpp_type
=
10
,
cpp_type
=
10
,
label
=
3
,
label
=
3
,
...
@@ -357,7 +372,7 @@ _CHECKINFO = _descriptor.Descriptor(
...
@@ -357,7 +372,7 @@ _CHECKINFO = _descriptor.Descriptor(
extension_ranges
=
[],
extension_ranges
=
[],
oneofs
=
[],
oneofs
=
[],
serialized_start
=
320
,
serialized_start
=
320
,
serialized_end
=
5
20
,
serialized_end
=
5
49
,
)
)
_FILEINFO
.
fields_by_name
[
'type'
].
enum_type
=
_FILE_TYPE
_FILEINFO
.
fields_by_name
[
'type'
].
enum_type
=
_FILE_TYPE
...
...
paddlehub/module/checker.py
浏览文件 @
6669e041
...
@@ -32,20 +32,22 @@ FILE_SEP = "/"
...
@@ -32,20 +32,22 @@ FILE_SEP = "/"
class
ModuleChecker
(
object
):
class
ModuleChecker
(
object
):
def
__init__
(
self
,
module_path
):
def
__init__
(
self
,
directory
):
self
.
module_path
=
module_path
self
.
_directory
=
directory
self
.
_pb_path
=
os
.
path
.
join
(
self
.
directory
,
CHECK_INFO_PB_FILENAME
)
def
generate_check_info
(
self
):
def
generate_check_info
(
self
):
check_info
=
check_info_pb2
.
CheckInfo
()
check_info
=
check_info_pb2
.
CheckInfo
()
check_info
.
paddle_version
=
paddle
.
__version__
check_info
.
paddle_version
=
paddle
.
__version__
check_info
.
hub_version
=
hub_version
check_info
.
hub_version
=
hub_version
check_info
.
module_proto_version
=
module_proto_version
check_info
.
module_proto_version
=
module_proto_version
check_info
.
module_code_version
=
"v2"
file_infos
=
check_info
.
file_infos
file_infos
=
check_info
.
file_infos
file_list
=
[
file
for
file
in
os
.
listdir
(
self
.
module_path
)]
file_list
=
[
file
for
file
in
os
.
listdir
(
self
.
directory
)]
while
file_list
:
while
file_list
:
file
=
file_list
[
0
]
file
=
file_list
[
0
]
file_list
=
file_list
[
1
:]
file_list
=
file_list
[
1
:]
abs_path
=
os
.
path
.
join
(
self
.
module_path
,
file
)
abs_path
=
os
.
path
.
join
(
self
.
directory
,
file
)
if
os
.
path
.
isdir
(
abs_path
):
if
os
.
path
.
isdir
(
abs_path
):
for
sub_file
in
os
.
listdir
(
abs_path
):
for
sub_file
in
os
.
listdir
(
abs_path
):
sub_file
=
os
.
path
.
join
(
file
,
sub_file
)
sub_file
=
os
.
path
.
join
(
file
,
sub_file
)
...
@@ -62,9 +64,12 @@ class ModuleChecker(object):
...
@@ -62,9 +64,12 @@ class ModuleChecker(object):
file_info
.
type
=
check_info_pb2
.
FILE
file_info
.
type
=
check_info_pb2
.
FILE
file_info
.
is_need
=
True
file_info
.
is_need
=
True
with
open
(
os
.
path
.
join
(
self
.
module_path
,
CHECK_INFO_PB_FILENAME
),
with
open
(
self
.
pb_path
,
"wb"
)
as
file
:
"wb"
)
as
fi
:
file
.
write
(
check_info
.
SerializeToString
())
fi
.
write
(
check_info
.
SerializeToString
())
@
property
def
module_code_version
(
self
):
return
self
.
check_info
.
module_code_version
@
property
@
property
def
module_proto_version
(
self
):
def
module_proto_version
(
self
):
...
@@ -82,20 +87,25 @@ class ModuleChecker(object):
...
@@ -82,20 +87,25 @@ class ModuleChecker(object):
def
file_infos
(
self
):
def
file_infos
(
self
):
return
self
.
check_info
.
file_infos
return
self
.
check_info
.
file_infos
@
property
def
directory
(
self
):
return
self
.
_directory
@
property
def
pb_path
(
self
):
return
self
.
_pb_path
def
check
(
self
):
def
check
(
self
):
result
=
True
result
=
True
self
.
check_info_pb_path
=
os
.
path
.
join
(
self
.
module_path
,
CHECK_INFO_PB_FILENAME
)
if
not
(
os
.
path
.
exists
(
self
.
check_info_pb_path
)
if
not
(
os
.
path
.
exists
(
self
.
pb_path
)
or
os
.
path
.
isfile
(
self
.
pb_path
)):
or
os
.
path
.
isfile
(
self
.
check_info_pb_path
)):
logger
.
warning
(
logger
.
warning
(
"This module lacks core file %s"
%
CHECK_INFO_PB_FILENAME
)
"This module lacks core file %s"
%
CHECK_INFO_PB_FILENAME
)
result
=
False
result
=
False
self
.
check_info
=
check_info_pb2
.
CheckInfo
()
self
.
check_info
=
check_info_pb2
.
CheckInfo
()
try
:
try
:
with
open
(
self
.
check_info_
pb_path
,
"rb"
)
as
fi
:
with
open
(
self
.
pb_path
,
"rb"
)
as
fi
:
pb_string
=
fi
.
read
()
pb_string
=
fi
.
read
()
result
=
self
.
check_info
.
ParseFromString
(
pb_string
)
result
=
self
.
check_info
.
ParseFromString
(
pb_string
)
if
len
(
pb_string
)
==
0
or
(
result
is
not
None
if
len
(
pb_string
)
==
0
or
(
result
is
not
None
...
@@ -182,7 +192,7 @@ class ModuleChecker(object):
...
@@ -182,7 +192,7 @@ class ModuleChecker(object):
for
file_info
in
self
.
file_infos
:
for
file_info
in
self
.
file_infos
:
file_type
=
file_info
.
type
file_type
=
file_info
.
type
file_path
=
file_info
.
file_name
.
replace
(
FILE_SEP
,
os
.
sep
)
file_path
=
file_info
.
file_name
.
replace
(
FILE_SEP
,
os
.
sep
)
file_path
=
os
.
path
.
join
(
self
.
module_path
,
file_path
)
file_path
=
os
.
path
.
join
(
self
.
directory
,
file_path
)
if
not
os
.
path
.
exists
(
file_path
):
if
not
os
.
path
.
exists
(
file_path
):
if
file_info
.
is_need
:
if
file_info
.
is_need
:
logger
.
warning
(
logger
.
warning
(
...
...
paddlehub/module/module.py
浏览文件 @
6669e041
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录