Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleSeg
提交
a448431b
P
PaddleSeg
项目概览
PaddlePaddle
/
PaddleSeg
通知
285
Star
8
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
53
列表
看板
标记
里程碑
合并请求
3
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleSeg
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
53
Issue
53
列表
看板
标记
里程碑
合并请求
3
合并请求
3
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
a448431b
编写于
8月 04, 2020
作者:
W
wuzewu
提交者:
GitHub
8月 04, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #329 from michaelowenliu/develop
上级
b1f48747
3bed6aa7
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
123 addition
and
0 deletion
+123
-0
dygraph/cvlibs/__init__.py
dygraph/cvlibs/__init__.py
+13
-0
dygraph/cvlibs/manager.py
dygraph/cvlibs/manager.py
+110
-0
未找到文件。
dygraph/cvlibs/__init__.py
0 → 100644
浏览文件 @
a448431b
# 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.
dygraph/cvlibs/manager.py
0 → 100644
浏览文件 @
a448431b
# -*- encoding: utf-8 -*-
# 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.
import
collections
import
inspect
class
ComponentManager
:
"""
Implement a manager class to add the new component properly.
The component can be added as either class or function type.
For example:
>>> model_manager = ComponentManager()
>>> class AlexNet: ...
>>> class ResNet: ...
>>> model_manager.add_component(AlexNet)
>>> model_manager.add_component(ResNet)
or pass a sequence alliteratively:
>>> model_manager.add_component([AlexNet, ResNet])
>>> print(model_manager.components_dict)
output: {'AlexNet': <class '__main__.AlexNet'>, 'ResNet': <class '__main__.ResNet'>}
Or an easier way, using it as a Python decorator, while just add it above the class declaration.
>>> model_manager = ComponentManager()
>>> @model_manager.add_component
>>> class AlexNet: ...
>>> @model_manager.add_component
>>> class ResNet: ...
>>> print(model_manager.components_dict)
output: {'AlexNet': <class '__main__.AlexNet'>, 'ResNet': <class '__main__.ResNet'>}
"""
def
__init__
(
self
):
self
.
_components_dict
=
dict
()
def
__len__
(
self
):
return
len
(
self
.
_components_dict
)
def
__repr__
(
self
):
return
"{}:{}"
.
format
(
self
.
__class__
.
__name__
,
list
(
self
.
_components_dict
.
keys
()))
def
__getitem__
(
self
,
item
):
if
item
not
in
self
.
_components_dict
.
keys
():
raise
KeyError
(
"{} does not exist in the current {}"
.
format
(
item
,
self
))
return
self
.
_components_dict
[
item
]
@
property
def
components_dict
(
self
):
return
self
.
_components_dict
def
_add_single_component
(
self
,
component
):
"""
Add a single component into the corresponding manager
Args:
component (function | class): a new component
Returns:
None
"""
# Currently only support class or function type
if
not
(
inspect
.
isclass
(
component
)
or
inspect
.
isfunction
(
component
)):
raise
TypeError
(
"Expect class/function type, but received {}"
.
format
(
type
(
component
)))
# Obtain the internal name of the component
component_name
=
component
.
__name__
# Check whether the component was added already
if
component_name
in
self
.
_components_dict
.
keys
():
raise
KeyError
(
"{} exists already!"
.
format
(
component_name
))
else
:
# Take the internal name of the component as its key
self
.
_components_dict
[
component_name
]
=
component
def
add_component
(
self
,
components
):
"""
Add component(s) into the corresponding manager
Args:
components (function | class | list | tuple): support three types of components
Returns:
None
"""
# Check whether the type is a sequence
if
isinstance
(
components
,
collections
.
Sequence
):
for
component
in
components
:
self
.
_add_single_component
(
component
)
else
:
component
=
components
self
.
_add_single_component
(
component
)
MODELS
=
ComponentManager
()
BACKBONES
=
ComponentManager
()
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录