Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
Paddle
提交
45f8b9d0
P
Paddle
项目概览
PaddlePaddle
/
Paddle
1 年多 前同步成功
通知
2302
Star
20931
Fork
5422
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1423
列表
看板
标记
里程碑
合并请求
543
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1,423
Issue
1,423
列表
看板
标记
里程碑
合并请求
543
合并请求
543
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
45f8b9d0
编写于
6月 11, 2021
作者:
Z
zhiboniu
提交者:
GitHub
6月 11, 2021
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update 2.0 public api in vision (#33307)
* update 2.0 public api in vision * fix some flake8 errors
上级
9567cbd7
变更
25
隐藏空白更改
内联
并排
Showing
25 changed file
with
236 addition
and
119 deletion
+236
-119
python/paddle/hapi/callbacks.py
python/paddle/hapi/callbacks.py
+5
-5
python/paddle/hapi/model.py
python/paddle/hapi/model.py
+34
-25
python/paddle/metric/metrics.py
python/paddle/metric/metrics.py
+1
-1
python/paddle/tests/test_callback_visualdl.py
python/paddle/tests/test_callback_visualdl.py
+1
-1
python/paddle/vision/__init__.py
python/paddle/vision/__init__.py
+50
-13
python/paddle/vision/datasets/__init__.py
python/paddle/vision/datasets/__init__.py
+18
-16
python/paddle/vision/datasets/cifar.py
python/paddle/vision/datasets/cifar.py
+1
-1
python/paddle/vision/datasets/flowers.py
python/paddle/vision/datasets/flowers.py
+1
-1
python/paddle/vision/datasets/folder.py
python/paddle/vision/datasets/folder.py
+1
-1
python/paddle/vision/datasets/mnist.py
python/paddle/vision/datasets/mnist.py
+1
-1
python/paddle/vision/datasets/voc2012.py
python/paddle/vision/datasets/voc2012.py
+1
-1
python/paddle/vision/image.py
python/paddle/vision/image.py
+1
-1
python/paddle/vision/models/__init__.py
python/paddle/vision/models/__init__.py
+34
-16
python/paddle/vision/models/lenet.py
python/paddle/vision/models/lenet.py
+1
-1
python/paddle/vision/models/mobilenetv1.py
python/paddle/vision/models/mobilenetv1.py
+1
-1
python/paddle/vision/models/mobilenetv2.py
python/paddle/vision/models/mobilenetv2.py
+1
-1
python/paddle/vision/models/resnet.py
python/paddle/vision/models/resnet.py
+1
-3
python/paddle/vision/models/vgg.py
python/paddle/vision/models/vgg.py
+1
-7
python/paddle/vision/ops.py
python/paddle/vision/ops.py
+6
-2
python/paddle/vision/transforms/__init__.py
python/paddle/vision/transforms/__init__.py
+66
-7
python/paddle/vision/transforms/functional.py
python/paddle/vision/transforms/functional.py
+1
-5
python/paddle/vision/transforms/functional_cv2.py
python/paddle/vision/transforms/functional_cv2.py
+3
-1
python/paddle/vision/transforms/functional_pil.py
python/paddle/vision/transforms/functional_pil.py
+3
-1
python/paddle/vision/transforms/functional_tensor.py
python/paddle/vision/transforms/functional_tensor.py
+2
-0
python/paddle/vision/transforms/transforms.py
python/paddle/vision/transforms/transforms.py
+1
-7
未找到文件。
python/paddle/hapi/callbacks.py
浏览文件 @
45f8b9d0
...
@@ -324,7 +324,7 @@ class ProgBarLogger(Callback):
...
@@ -324,7 +324,7 @@ class ProgBarLogger(Callback):
])
])
train_dataset = MNIST(mode='train', transform=transform)
train_dataset = MNIST(mode='train', transform=transform)
lenet = paddle.vision.LeNet()
lenet = paddle.vision.
models.
LeNet()
model = paddle.Model(lenet,
model = paddle.Model(lenet,
inputs, labels)
inputs, labels)
...
@@ -554,7 +554,7 @@ class ModelCheckpoint(Callback):
...
@@ -554,7 +554,7 @@ class ModelCheckpoint(Callback):
])
])
train_dataset = MNIST(mode='train', transform=transform)
train_dataset = MNIST(mode='train', transform=transform)
lenet = paddle.vision.LeNet()
lenet = paddle.vision.
models.
LeNet()
model = paddle.Model(lenet,
model = paddle.Model(lenet,
inputs, labels)
inputs, labels)
...
@@ -614,7 +614,7 @@ class LRScheduler(Callback):
...
@@ -614,7 +614,7 @@ class LRScheduler(Callback):
])
])
train_dataset = paddle.vision.datasets.MNIST(mode='train', transform=transform)
train_dataset = paddle.vision.datasets.MNIST(mode='train', transform=transform)
lenet = paddle.vision.LeNet()
lenet = paddle.vision.
models.
LeNet()
model = paddle.Model(lenet,
model = paddle.Model(lenet,
inputs, labels)
inputs, labels)
...
@@ -630,7 +630,7 @@ class LRScheduler(Callback):
...
@@ -630,7 +630,7 @@ class LRScheduler(Callback):
boundaries=boundaries, values=values)
boundaries=boundaries, values=values)
learning_rate = paddle.optimizer.lr.LinearWarmup(
learning_rate = paddle.optimizer.lr.LinearWarmup(
learning_rate=learning_rate,
learning_rate=learning_rate,
warmup_steps=wamup_
epoch
s,
warmup_steps=wamup_
step
s,
start_lr=base_lr / 5.,
start_lr=base_lr / 5.,
end_lr=base_lr,
end_lr=base_lr,
verbose=True)
verbose=True)
...
@@ -856,7 +856,7 @@ class VisualDL(Callback):
...
@@ -856,7 +856,7 @@ class VisualDL(Callback):
train_dataset = paddle.vision.datasets.MNIST(mode='train', transform=transform)
train_dataset = paddle.vision.datasets.MNIST(mode='train', transform=transform)
eval_dataset = paddle.vision.datasets.MNIST(mode='test', transform=transform)
eval_dataset = paddle.vision.datasets.MNIST(mode='test', transform=transform)
net = paddle.vision.LeNet()
net = paddle.vision.
models.
LeNet()
model = paddle.Model(net, inputs, labels)
model = paddle.Model(net, inputs, labels)
optim = paddle.optimizer.Adam(0.001, parameters=net.parameters())
optim = paddle.optimizer.Adam(0.001, parameters=net.parameters())
...
...
python/paddle/hapi/model.py
浏览文件 @
45f8b9d0
...
@@ -30,20 +30,28 @@ from collections import Iterable
...
@@ -30,20 +30,28 @@ from collections import Iterable
import
paddle
import
paddle
from
paddle
import
fluid
from
paddle
import
fluid
from
paddle.fluid
import
core
from
paddle.fluid
import
core
from
paddle.fluid.framework
import
in_dygraph_mode
,
Variable
,
ParamBase
,
_current_expected_place
from
paddle.fluid.framework
import
in_dygraph_mode
from
paddle.fluid.framework
import
in_dygraph_mode
,
Variable
,
_get_paddle_place
from
paddle.fluid.framework
import
Variable
from
paddle.fluid.framework
import
ParamBase
from
paddle.fluid.framework
import
_current_expected_place
from
paddle.fluid.framework
import
_get_paddle_place
from
paddle.fluid.framework
import
_current_expected_place
as
_get_device
from
paddle.fluid.framework
import
_current_expected_place
as
_get_device
from
paddle.fluid.executor
import
global_scope
from
paddle.fluid.executor
import
global_scope
from
paddle.fluid.io
import
is_belong_to_optimizer
from
paddle.fluid.io
import
is_belong_to_optimizer
from
paddle.fluid.dygraph.base
import
to_variable
from
paddle.fluid.dygraph.base
import
to_variable
from
paddle.fluid.dygraph.parallel
import
ParallelEnv
from
paddle.fluid.dygraph.parallel
import
ParallelEnv
from
paddle.fluid.dygraph.dygraph_to_static.program_translator
import
ProgramTranslator
,
FunctionSpec
from
paddle.fluid.dygraph.dygraph_to_static.program_translator
import
ProgramTranslator
from
paddle.fluid.dygraph.io
import
INFER_MODEL_SUFFIX
,
INFER_PARAMS_SUFFIX
from
paddle.fluid.dygraph.dygraph_to_static.program_translator
import
FunctionSpec
from
paddle.fluid.dygraph.io
import
INFER_MODEL_SUFFIX
from
paddle.fluid.dygraph.io
import
INFER_PARAMS_SUFFIX
from
paddle.fluid.layers.utils
import
flatten
from
paddle.fluid.layers.utils
import
flatten
from
paddle.fluid.layers
import
collective
from
paddle.fluid.layers
import
collective
from
paddle.io
import
DataLoader
,
Dataset
,
DistributedBatchSampler
from
paddle.io
import
DataLoader
from
paddle.fluid.executor
import
scope_guard
,
Executor
from
paddle.io
import
Dataset
from
paddle.io
import
DistributedBatchSampler
from
paddle.fluid.executor
import
scope_guard
from
paddle.fluid.executor
import
Executor
from
paddle.fluid.dygraph.layers
import
Layer
from
paddle.fluid.dygraph.layers
import
Layer
from
paddle.metric
import
Metric
from
paddle.metric
import
Metric
from
paddle.static
import
InputSpec
as
Input
from
paddle.static
import
InputSpec
as
Input
...
@@ -166,7 +174,6 @@ def init_communicator(program, rank, nranks, wait_port, current_endpoint,
...
@@ -166,7 +174,6 @@ def init_communicator(program, rank, nranks, wait_port, current_endpoint,
name
=
unique_name
.
generate
(
'hccl_id'
),
name
=
unique_name
.
generate
(
'hccl_id'
),
persistable
=
True
,
persistable
=
True
,
type
=
core
.
VarDesc
.
VarType
.
RAW
)
type
=
core
.
VarDesc
.
VarType
.
RAW
)
endpoint_to_index_map
=
{
e
:
idx
for
idx
,
e
in
enumerate
(
endpoints
)}
block
.
append_op
(
block
.
append_op
(
type
=
'c_gen_hccl_id'
,
type
=
'c_gen_hccl_id'
,
inputs
=
{},
inputs
=
{},
...
@@ -710,10 +717,10 @@ class DynamicGraphAdapter(object):
...
@@ -710,10 +717,10 @@ class DynamicGraphAdapter(object):
enable
=
self
.
_amp_level
!=
'O0'
,
**
self
.
_amp_custom_lists
):
enable
=
self
.
_amp_level
!=
'O0'
,
**
self
.
_amp_custom_lists
):
if
self
.
_nranks
>
1
:
if
self
.
_nranks
>
1
:
outputs
=
self
.
ddp_model
.
forward
(
outputs
=
self
.
ddp_model
.
forward
(
*
[
to_variable
(
x
)
for
x
in
inputs
])
*
[
to_variable
(
x
)
for
x
in
inputs
])
else
:
else
:
outputs
=
self
.
model
.
network
.
forward
(
outputs
=
self
.
model
.
network
.
forward
(
*
[
to_variable
(
x
)
for
x
in
inputs
])
*
[
to_variable
(
x
)
for
x
in
inputs
])
losses
=
self
.
model
.
_loss
(
*
(
to_list
(
outputs
)
+
labels
))
losses
=
self
.
model
.
_loss
(
*
(
to_list
(
outputs
)
+
labels
))
losses
=
to_list
(
losses
)
losses
=
to_list
(
losses
)
...
@@ -732,7 +739,7 @@ class DynamicGraphAdapter(object):
...
@@ -732,7 +739,7 @@ class DynamicGraphAdapter(object):
metrics
=
[]
metrics
=
[]
for
metric
in
self
.
model
.
_metrics
:
for
metric
in
self
.
model
.
_metrics
:
metric_outs
=
metric
.
compute
(
*
(
to_list
(
outputs
)
+
labels
))
metric_outs
=
metric
.
compute
(
*
(
to_list
(
outputs
)
+
labels
))
m
=
metric
.
update
(
*
[
to_numpy
(
m
)
for
m
in
to_list
(
metric_outs
)])
m
=
metric
.
update
(
*
[
to_numpy
(
m
)
for
m
in
to_list
(
metric_outs
)])
metrics
.
append
(
m
)
metrics
.
append
(
m
)
return
([
to_numpy
(
l
)
for
l
in
losses
],
metrics
)
\
return
([
to_numpy
(
l
)
for
l
in
losses
],
metrics
)
\
...
@@ -746,7 +753,7 @@ class DynamicGraphAdapter(object):
...
@@ -746,7 +753,7 @@ class DynamicGraphAdapter(object):
labels
=
labels
or
[]
labels
=
labels
or
[]
labels
=
[
to_variable
(
l
)
for
l
in
to_list
(
labels
)]
labels
=
[
to_variable
(
l
)
for
l
in
to_list
(
labels
)]
outputs
=
self
.
model
.
network
.
forward
(
*
[
to_variable
(
x
)
for
x
in
inputs
])
outputs
=
self
.
model
.
network
.
forward
(
*
[
to_variable
(
x
)
for
x
in
inputs
])
if
self
.
model
.
_loss
:
if
self
.
model
.
_loss
:
losses
=
self
.
model
.
_loss
(
*
(
to_list
(
outputs
)
+
labels
))
losses
=
self
.
model
.
_loss
(
*
(
to_list
(
outputs
)
+
labels
))
losses
=
to_list
(
losses
)
losses
=
to_list
(
losses
)
...
@@ -777,7 +784,7 @@ class DynamicGraphAdapter(object):
...
@@ -777,7 +784,7 @@ class DynamicGraphAdapter(object):
self
.
_merge_count
[
self
.
mode
+
'_batch'
]
=
samples
self
.
_merge_count
[
self
.
mode
+
'_batch'
]
=
samples
metric_outs
=
metric
.
compute
(
*
(
to_list
(
outputs
)
+
labels
))
metric_outs
=
metric
.
compute
(
*
(
to_list
(
outputs
)
+
labels
))
m
=
metric
.
update
(
*
[
to_numpy
(
m
)
for
m
in
to_list
(
metric_outs
)])
m
=
metric
.
update
(
*
[
to_numpy
(
m
)
for
m
in
to_list
(
metric_outs
)])
metrics
.
append
(
m
)
metrics
.
append
(
m
)
if
self
.
model
.
_loss
and
len
(
metrics
):
if
self
.
model
.
_loss
and
len
(
metrics
):
...
@@ -1363,8 +1370,9 @@ class Model(object):
...
@@ -1363,8 +1370,9 @@ class Model(object):
# pure float16 training has some restricts now
# pure float16 training has some restricts now
if
self
.
_adapter
.
_amp_level
==
"O2"
:
if
self
.
_adapter
.
_amp_level
==
"O2"
:
if
in_dygraph_mode
():
if
in_dygraph_mode
():
warnings
.
warn
(
"Pure float16 training is not supported in dygraph mode now, "
\
warnings
.
warn
(
"and it will be supported in future version."
)
"Pure float16 training is not supported in dygraph mode now, and it will be supported in future version."
)
else
:
else
:
# grad clip is not supported in pure fp16 training now
# grad clip is not supported in pure fp16 training now
assert
self
.
_optimizer
.
_grad_clip
is
None
,
\
assert
self
.
_optimizer
.
_grad_clip
is
None
,
\
...
@@ -1398,8 +1406,7 @@ class Model(object):
...
@@ -1398,8 +1406,7 @@ class Model(object):
if
'use_pure_fp16'
in
amp_configs
:
if
'use_pure_fp16'
in
amp_configs
:
raise
ValueError
(
raise
ValueError
(
"''use_pure_fp16' is an invalid parameter, "
"'use_pure_fp16' is an invalid parameter, the level of mixed precision training only depends on 'O1' or 'O2'."
"the level of mixed precision training only depends on 'O1' or 'O2'."
)
)
_check_pure_fp16_configs
()
_check_pure_fp16_configs
()
...
@@ -1427,9 +1434,8 @@ class Model(object):
...
@@ -1427,9 +1434,8 @@ class Model(object):
}
}
if
amp_config_key_set
-
accepted_param_set
:
if
amp_config_key_set
-
accepted_param_set
:
raise
ValueError
(
raise
ValueError
(
"Except for 'level', the keys of 'amp_configs' must be accepted by mixed precision APIs, "
"Except for 'level', the keys of 'amp_configs' must be accepted by mixed precision APIs, but {} could not be recognized."
.
"but {} could not be recognized."
.
format
(
format
(
tuple
(
amp_config_key_set
-
accepted_param_set
)))
tuple
(
amp_config_key_set
-
accepted_param_set
)))
if
'use_fp16_guard'
in
amp_config_key_set
:
if
'use_fp16_guard'
in
amp_config_key_set
:
if
in_dygraph_mode
():
if
in_dygraph_mode
():
...
@@ -1501,8 +1507,9 @@ class Model(object):
...
@@ -1501,8 +1507,9 @@ class Model(object):
self
.
_optimizer
=
optimizer
self
.
_optimizer
=
optimizer
if
loss
is
not
None
:
if
loss
is
not
None
:
if
not
isinstance
(
loss
,
paddle
.
nn
.
Layer
)
and
not
callable
(
loss
):
if
not
isinstance
(
loss
,
paddle
.
nn
.
Layer
)
and
not
callable
(
loss
):
raise
TypeError
(
"'loss' must be sub classes of "
\
raise
TypeError
(
"`paddle.nn.Layer` or any callable function."
)
"'loss' must be sub classes of `paddle.nn.Layer` or any callable function."
)
self
.
_loss
=
loss
self
.
_loss
=
loss
metrics
=
metrics
or
[]
metrics
=
metrics
or
[]
...
@@ -2080,7 +2087,7 @@ class Model(object):
...
@@ -2080,7 +2087,7 @@ class Model(object):
input = InputSpec([None, 1, 28, 28], 'float32', 'image')
input = InputSpec([None, 1, 28, 28], 'float32', 'image')
label = InputSpec([None, 1], 'int64', 'label')
label = InputSpec([None, 1], 'int64', 'label')
model = paddle.Model(paddle.vision.LeNet(),
model = paddle.Model(paddle.vision.
models.
LeNet(),
input, label)
input, label)
optim = paddle.optimizer.Adam(
optim = paddle.optimizer.Adam(
learning_rate=0.001, parameters=model.parameters())
learning_rate=0.001, parameters=model.parameters())
...
@@ -2122,9 +2129,11 @@ class Model(object):
...
@@ -2122,9 +2129,11 @@ class Model(object):
else
:
else
:
out_specs
=
to_list
(
specs
)
out_specs
=
to_list
(
specs
)
elif
isinstance
(
specs
,
dict
):
elif
isinstance
(
specs
,
dict
):
assert
is_input
==
False
assert
is_input
is
False
out_specs
=
[
specs
[
n
]
\
out_specs
=
[
for
n
in
extract_args
(
self
.
network
.
forward
)
if
n
!=
'self'
]
specs
[
n
]
for
n
in
extract_args
(
self
.
network
.
forward
)
if
n
!=
'self'
]
else
:
else
:
out_specs
=
to_list
(
specs
)
out_specs
=
to_list
(
specs
)
# Note: checks each element has specificed `name`.
# Note: checks each element has specificed `name`.
...
...
python/paddle/metric/metrics.py
浏览文件 @
45f8b9d0
...
@@ -222,7 +222,7 @@ class Accuracy(Metric):
...
@@ -222,7 +222,7 @@ class Accuracy(Metric):
transform = T.Compose([T.Transpose(), T.Normalize([127.5], [127.5])])
transform = T.Compose([T.Transpose(), T.Normalize([127.5], [127.5])])
train_dataset = MNIST(mode='train', transform=transform)
train_dataset = MNIST(mode='train', transform=transform)
model = paddle.Model(paddle.vision.LeNet(), input, label)
model = paddle.Model(paddle.vision.
models.
LeNet(), input, label)
optim = paddle.optimizer.Adam(
optim = paddle.optimizer.Adam(
learning_rate=0.001, parameters=model.parameters())
learning_rate=0.001, parameters=model.parameters())
model.prepare(
model.prepare(
...
...
python/paddle/tests/test_callback_visualdl.py
浏览文件 @
45f8b9d0
...
@@ -55,7 +55,7 @@ class TestCallbacks(unittest.TestCase):
...
@@ -55,7 +55,7 @@ class TestCallbacks(unittest.TestCase):
train_dataset
=
MnistDataset
(
mode
=
'train'
,
transform
=
transform
)
train_dataset
=
MnistDataset
(
mode
=
'train'
,
transform
=
transform
)
eval_dataset
=
MnistDataset
(
mode
=
'test'
,
transform
=
transform
)
eval_dataset
=
MnistDataset
(
mode
=
'test'
,
transform
=
transform
)
net
=
paddle
.
vision
.
LeNet
()
net
=
paddle
.
vision
.
models
.
LeNet
()
model
=
paddle
.
Model
(
net
,
inputs
,
labels
)
model
=
paddle
.
Model
(
net
,
inputs
,
labels
)
optim
=
paddle
.
optimizer
.
Adam
(
0.001
,
parameters
=
net
.
parameters
())
optim
=
paddle
.
optimizer
.
Adam
(
0.001
,
parameters
=
net
.
parameters
())
...
...
python/paddle/vision/__init__.py
浏览文件 @
45f8b9d0
...
@@ -11,22 +11,59 @@
...
@@ -11,22 +11,59 @@
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# See the License for the specific language governing permissions and
# limitations under the License.
# limitations under the License.
import
paddle
import
paddle.nn
as
nn
from
.
import
models
# noqa: F401
from
.
import
transforms
# noqa: F401
from
.
import
datasets
# noqa: F401
from
.
import
ops
# noqa: F401
from
.image
import
set_image_backend
# noqa: F401
from
.image
import
get_image_backend
# noqa: F401
from
.image
import
image_load
# noqa: F401
from
.models
import
LeNet
as
models_LeNet
import
paddle.utils.deprecated
as
deprecated
from
.
import
models
__all__
=
[
#noqa
from
.models
import
*
'set_image_backend'
,
'get_image_backend'
,
'image_load'
]
from
.
import
transforms
from
.transforms
import
*
from
.
import
datasets
class
LeNet
(
models_LeNet
):
from
.datasets
import
*
"""LeNet model from
`"LeCun Y, Bottou L, Bengio Y, et al. Gradient-based learning applied to document recognition[J]. Proceedings of the IEEE, 1998, 86(11): 2278-2324.`_
from
.
import
image
Args:
from
.image
import
*
num_classes (int): output dim of last fc layer. If num_classes <=0, last fc layer
will not be defined. Default: 10.
from
.
import
ops
Examples:
.. code-block:: python
__all__
=
models
.
__all__
\
from paddle.vision.models import LeNet
+
transforms
.
__all__
\
+
datasets
.
__all__
\
model = LeNet()
+
image
.
__all__
"""
@
deprecated
(
since
=
"2.0.0"
,
update_to
=
"paddle.vision.models.LeNet"
,
level
=
1
,
reason
=
"Please use new API in models, paddle.vision.LeNet will be removed in future"
)
def
__init__
(
self
,
num_classes
=
10
):
super
(
LeNet
,
self
).
__init__
(
num_classes
=
10
)
self
.
num_classes
=
num_classes
self
.
features
=
nn
.
Sequential
(
nn
.
Conv2D
(
1
,
6
,
3
,
stride
=
1
,
padding
=
1
),
nn
.
ReLU
(),
nn
.
MaxPool2D
(
2
,
2
),
nn
.
Conv2D
(
6
,
16
,
5
,
stride
=
1
,
padding
=
0
),
nn
.
ReLU
(),
nn
.
MaxPool2D
(
2
,
2
))
if
num_classes
>
0
:
self
.
fc
=
nn
.
Sequential
(
nn
.
Linear
(
400
,
120
),
nn
.
Linear
(
120
,
84
),
nn
.
Linear
(
84
,
num_classes
))
python/paddle/vision/datasets/__init__.py
浏览文件 @
45f8b9d0
...
@@ -12,20 +12,22 @@
...
@@ -12,20 +12,22 @@
# See the License for the specific language governing permissions and
# See the License for the specific language governing permissions and
# limitations under the License.
# limitations under the License.
from
.
import
folder
from
.folder
import
DatasetFolder
# noqa: F401
from
.
import
mnist
from
.folder
import
ImageFolder
# noqa: F401
from
.
import
flowers
from
.mnist
import
MNIST
# noqa: F401
from
.
import
cifar
from
.mnist
import
FashionMNIST
# noqa: F401
from
.
import
voc2012
from
.flowers
import
Flowers
# noqa: F401
from
.cifar
import
Cifar10
# noqa: F401
from
.cifar
import
Cifar100
# noqa: F401
from
.voc2012
import
VOC2012
# noqa: F401
from
.folder
import
*
__all__
=
[
#noqa
from
.mnist
import
*
'DatasetFolder'
from
.flowers
import
*
'ImageFolder'
,
from
.cifar
import
*
'MNIST'
,
from
.voc2012
import
*
'FashionMNIST'
,
'Flowers'
,
__all__
=
folder
.
__all__
\
'Cifar10'
,
+
mnist
.
__all__
\
'Cifar100'
,
+
flowers
.
__all__
\
'VOC2012'
+
cifar
.
__all__
\
]
+
voc2012
.
__all__
python/paddle/vision/datasets/cifar.py
浏览文件 @
45f8b9d0
...
@@ -24,7 +24,7 @@ import paddle
...
@@ -24,7 +24,7 @@ import paddle
from
paddle.io
import
Dataset
from
paddle.io
import
Dataset
from
paddle.dataset.common
import
_check_exists_and_download
from
paddle.dataset.common
import
_check_exists_and_download
__all__
=
[
'Cifar10'
,
'Cifar100'
]
__all__
=
[]
URL_PREFIX
=
'https://dataset.bj.bcebos.com/cifar/'
URL_PREFIX
=
'https://dataset.bj.bcebos.com/cifar/'
CIFAR10_URL
=
URL_PREFIX
+
'cifar-10-python.tar.gz'
CIFAR10_URL
=
URL_PREFIX
+
'cifar-10-python.tar.gz'
...
...
python/paddle/vision/datasets/flowers.py
浏览文件 @
45f8b9d0
...
@@ -25,7 +25,7 @@ from paddle.io import Dataset
...
@@ -25,7 +25,7 @@ from paddle.io import Dataset
from
paddle.utils
import
try_import
from
paddle.utils
import
try_import
from
paddle.dataset.common
import
_check_exists_and_download
from
paddle.dataset.common
import
_check_exists_and_download
__all__
=
[
"Flowers"
]
__all__
=
[]
DATA_URL
=
'http://paddlemodels.bj.bcebos.com/flowers/102flowers.tgz'
DATA_URL
=
'http://paddlemodels.bj.bcebos.com/flowers/102flowers.tgz'
LABEL_URL
=
'http://paddlemodels.bj.bcebos.com/flowers/imagelabels.mat'
LABEL_URL
=
'http://paddlemodels.bj.bcebos.com/flowers/imagelabels.mat'
...
...
python/paddle/vision/datasets/folder.py
浏览文件 @
45f8b9d0
...
@@ -20,7 +20,7 @@ import paddle
...
@@ -20,7 +20,7 @@ import paddle
from
paddle.io
import
Dataset
from
paddle.io
import
Dataset
from
paddle.utils
import
try_import
from
paddle.utils
import
try_import
__all__
=
[
"DatasetFolder"
,
"ImageFolder"
]
__all__
=
[]
def
has_valid_extension
(
filename
,
extensions
):
def
has_valid_extension
(
filename
,
extensions
):
...
...
python/paddle/vision/datasets/mnist.py
浏览文件 @
45f8b9d0
...
@@ -24,7 +24,7 @@ import paddle
...
@@ -24,7 +24,7 @@ import paddle
from
paddle.io
import
Dataset
from
paddle.io
import
Dataset
from
paddle.dataset.common
import
_check_exists_and_download
from
paddle.dataset.common
import
_check_exists_and_download
__all__
=
[
"MNIST"
,
"FashionMNIST"
]
__all__
=
[]
class
MNIST
(
Dataset
):
class
MNIST
(
Dataset
):
...
...
python/paddle/vision/datasets/voc2012.py
浏览文件 @
45f8b9d0
...
@@ -23,7 +23,7 @@ import paddle
...
@@ -23,7 +23,7 @@ import paddle
from
paddle.io
import
Dataset
from
paddle.io
import
Dataset
from
paddle.dataset.common
import
_check_exists_and_download
from
paddle.dataset.common
import
_check_exists_and_download
__all__
=
[
"VOC2012"
]
__all__
=
[]
VOC_URL
=
'https://dataset.bj.bcebos.com/voc/VOCtrainval_11-May-2012.tar'
VOC_URL
=
'https://dataset.bj.bcebos.com/voc/VOCtrainval_11-May-2012.tar'
...
...
python/paddle/vision/image.py
浏览文件 @
45f8b9d0
...
@@ -15,7 +15,7 @@
...
@@ -15,7 +15,7 @@
from
PIL
import
Image
from
PIL
import
Image
from
paddle.utils
import
try_import
from
paddle.utils
import
try_import
__all__
=
[
'set_image_backend'
,
'get_image_backend'
,
'image_load'
]
__all__
=
[]
_image_backend
=
'pil'
_image_backend
=
'pil'
...
...
python/paddle/vision/models/__init__.py
浏览文件 @
45f8b9d0
...
@@ -12,20 +12,38 @@
...
@@ -12,20 +12,38 @@
#See the License for the specific language governing permissions and
#See the License for the specific language governing permissions and
#limitations under the License.
#limitations under the License.
from
.
import
resnet
from
.resnet
import
ResNet
# noqa: F401
from
.
import
vgg
from
.resnet
import
resnet18
# noqa: F401
from
.
import
mobilenetv1
from
.resnet
import
resnet34
# noqa: F401
from
.
import
mobilenetv2
from
.resnet
import
resnet50
# noqa: F401
from
.
import
lenet
from
.resnet
import
resnet101
# noqa: F401
from
.resnet
import
resnet152
# noqa: F401
from
.mobilenetv1
import
MobileNetV1
# noqa: F401
from
.mobilenetv1
import
mobilenet_v1
# noqa: F401
from
.mobilenetv2
import
MobileNetV2
# noqa: F401
from
.mobilenetv2
import
mobilenet_v2
# noqa: F401
from
.vgg
import
VGG
# noqa: F401
from
.vgg
import
vgg11
# noqa: F401
from
.vgg
import
vgg13
# noqa: F401
from
.vgg
import
vgg16
# noqa: F401
from
.vgg
import
vgg19
# noqa: F401
from
.lenet
import
LeNet
# noqa: F401
from
.resnet
import
*
__all__
=
[
#noqa
from
.mobilenetv1
import
*
'ResNet'
,
from
.mobilenetv2
import
*
'resnet18'
,
from
.vgg
import
*
'resnet34'
,
from
.lenet
import
*
'resnet50'
,
'resnet101'
,
__all__
=
resnet
.
__all__
\
'resnet152'
,
+
vgg
.
__all__
\
'VGG'
,
+
mobilenetv1
.
__all__
\
'vgg11'
,
+
mobilenetv2
.
__all__
\
'vgg13'
,
+
lenet
.
__all__
'vgg16'
,
'vgg19'
,
'MobileNetV1'
,
'mobilenet_v1'
,
'MobileNetV2'
,
'mobilenet_v2'
,
'LeNet'
]
python/paddle/vision/models/lenet.py
浏览文件 @
45f8b9d0
...
@@ -15,7 +15,7 @@
...
@@ -15,7 +15,7 @@
import
paddle
import
paddle
import
paddle.nn
as
nn
import
paddle.nn
as
nn
__all__
=
[
'LeNet'
]
__all__
=
[]
class
LeNet
(
nn
.
Layer
):
class
LeNet
(
nn
.
Layer
):
...
...
python/paddle/vision/models/mobilenetv1.py
浏览文件 @
45f8b9d0
...
@@ -17,7 +17,7 @@ import paddle.nn as nn
...
@@ -17,7 +17,7 @@ import paddle.nn as nn
from
paddle.utils.download
import
get_weights_path_from_url
from
paddle.utils.download
import
get_weights_path_from_url
__all__
=
[
'MobileNetV1'
,
'mobilenet_v1'
]
__all__
=
[]
model_urls
=
{
model_urls
=
{
'mobilenetv1_1.0'
:
'mobilenetv1_1.0'
:
...
...
python/paddle/vision/models/mobilenetv2.py
浏览文件 @
45f8b9d0
...
@@ -20,7 +20,7 @@ import paddle.nn.functional as F
...
@@ -20,7 +20,7 @@ import paddle.nn.functional as F
from
paddle.utils.download
import
get_weights_path_from_url
from
paddle.utils.download
import
get_weights_path_from_url
__all__
=
[
'MobileNetV2'
,
'mobilenet_v2'
]
__all__
=
[]
model_urls
=
{
model_urls
=
{
'mobilenetv2_1.0'
:
'mobilenetv2_1.0'
:
...
...
python/paddle/vision/models/resnet.py
浏览文件 @
45f8b9d0
...
@@ -20,9 +20,7 @@ import paddle.nn as nn
...
@@ -20,9 +20,7 @@ import paddle.nn as nn
from
paddle.utils.download
import
get_weights_path_from_url
from
paddle.utils.download
import
get_weights_path_from_url
__all__
=
[
__all__
=
[]
'ResNet'
,
'resnet18'
,
'resnet34'
,
'resnet50'
,
'resnet101'
,
'resnet152'
]
model_urls
=
{
model_urls
=
{
'resnet18'
:
(
'https://paddle-hapi.bj.bcebos.com/models/resnet18.pdparams'
,
'resnet18'
:
(
'https://paddle-hapi.bj.bcebos.com/models/resnet18.pdparams'
,
...
...
python/paddle/vision/models/vgg.py
浏览文件 @
45f8b9d0
...
@@ -17,13 +17,7 @@ import paddle.nn as nn
...
@@ -17,13 +17,7 @@ import paddle.nn as nn
from
paddle.utils.download
import
get_weights_path_from_url
from
paddle.utils.download
import
get_weights_path_from_url
__all__
=
[
__all__
=
[]
'VGG'
,
'vgg11'
,
'vgg13'
,
'vgg16'
,
'vgg19'
,
]
model_urls
=
{
model_urls
=
{
'vgg16'
:
(
'https://paddle-hapi.bj.bcebos.com/models/vgg16.pdparams'
,
'vgg16'
:
(
'https://paddle-hapi.bj.bcebos.com/models/vgg16.pdparams'
,
...
...
python/paddle/vision/ops.py
浏览文件 @
45f8b9d0
...
@@ -22,8 +22,12 @@ from ..fluid.initializer import Normal
...
@@ -22,8 +22,12 @@ from ..fluid.initializer import Normal
from
paddle.common_ops_import
import
*
from
paddle.common_ops_import
import
*
__all__
=
[
__all__
=
[
#noqa
'yolo_loss'
,
'yolo_box'
,
'deform_conv2d'
,
'DeformConv2D'
,
'read_file'
,
'yolo_loss'
,
'yolo_box'
,
'deform_conv2d'
,
'DeformConv2D'
,
'read_file'
,
'decode_jpeg'
'decode_jpeg'
]
]
...
...
python/paddle/vision/transforms/__init__.py
浏览文件 @
45f8b9d0
...
@@ -12,11 +12,70 @@
...
@@ -12,11 +12,70 @@
# See the License for the specific language governing permissions and
# See the License for the specific language governing permissions and
# limitations under the License.
# limitations under the License.
from
.
import
transforms
from
.transforms
import
BaseTransform
# noqa: F401
from
.
import
functional
from
.transforms
import
Compose
# noqa: F401
from
.transforms
import
Resize
# noqa: F401
from
.transforms
import
RandomResizedCrop
# noqa: F401
from
.transforms
import
CenterCrop
# noqa: F401
from
.transforms
import
RandomHorizontalFlip
# noqa: F401
from
.transforms
import
RandomVerticalFlip
# noqa: F401
from
.transforms
import
Transpose
# noqa: F401
from
.transforms
import
Normalize
# noqa: F401
from
.transforms
import
BrightnessTransform
# noqa: F401
from
.transforms
import
SaturationTransform
# noqa: F401
from
.transforms
import
ContrastTransform
# noqa: F401
from
.transforms
import
HueTransform
# noqa: F401
from
.transforms
import
ColorJitter
# noqa: F401
from
.transforms
import
RandomCrop
# noqa: F401
from
.transforms
import
Pad
# noqa: F401
from
.transforms
import
RandomRotation
# noqa: F401
from
.transforms
import
Grayscale
# noqa: F401
from
.transforms
import
ToTensor
# noqa: F401
from
.functional
import
to_tensor
# noqa: F401
from
.functional
import
hflip
# noqa: F401
from
.functional
import
vflip
# noqa: F401
from
.functional
import
resize
# noqa: F401
from
.functional
import
pad
# noqa: F401
from
.functional
import
rotate
# noqa: F401
from
.functional
import
to_grayscale
# noqa: F401
from
.functional
import
crop
# noqa: F401
from
.functional
import
center_crop
# noqa: F401
from
.functional
import
adjust_brightness
# noqa: F401
from
.functional
import
adjust_contrast
# noqa: F401
from
.functional
import
adjust_hue
# noqa: F401
from
.functional
import
normalize
# noqa: F401
from
.transforms
import
*
__all__
=
[
#noqa
from
.functional
import
*
'BaseTransform'
,
'Compose'
,
__all__
=
transforms
.
__all__
\
'Resize'
,
+
functional
.
__all__
'RandomResizedCrop'
,
'CenterCrop'
,
'RandomHorizontalFlip'
,
'RandomVerticalFlip'
,
'Transpose'
,
'Normalize'
,
'BrightnessTransform'
,
'SaturationTransform'
,
'ContrastTransform'
,
'HueTransform'
,
'ColorJitter'
,
'RandomCrop'
,
'Pad'
,
'RandomRotation'
,
'Grayscale'
,
'ToTensor'
,
'to_tensor'
,
'hflip'
,
'vflip'
,
'resize'
,
'pad'
,
'rotate'
,
'to_grayscale'
,
'crop'
,
'center_crop'
,
'adjust_brightness'
,
'adjust_contrast'
,
'adjust_hue'
,
'normalize'
]
python/paddle/vision/transforms/functional.py
浏览文件 @
45f8b9d0
...
@@ -29,11 +29,7 @@ from . import functional_pil as F_pil
...
@@ -29,11 +29,7 @@ from . import functional_pil as F_pil
from
.
import
functional_cv2
as
F_cv2
from
.
import
functional_cv2
as
F_cv2
from
.
import
functional_tensor
as
F_t
from
.
import
functional_tensor
as
F_t
__all__
=
[
__all__
=
[]
'to_tensor'
,
'hflip'
,
'vflip'
,
'resize'
,
'pad'
,
'rotate'
,
'to_grayscale'
,
'crop'
,
'center_crop'
,
'adjust_brightness'
,
'adjust_contrast'
,
'adjust_hue'
,
'normalize'
]
def
_is_pil_image
(
img
):
def
_is_pil_image
(
img
):
...
...
python/paddle/vision/transforms/functional_cv2.py
浏览文件 @
45f8b9d0
...
@@ -33,6 +33,8 @@ else:
...
@@ -33,6 +33,8 @@ else:
Sequence
=
collections
.
abc
.
Sequence
Sequence
=
collections
.
abc
.
Sequence
Iterable
=
collections
.
abc
.
Iterable
Iterable
=
collections
.
abc
.
Iterable
__all__
=
[]
def
to_tensor
(
pic
,
data_format
=
'CHW'
):
def
to_tensor
(
pic
,
data_format
=
'CHW'
):
"""Converts a ``numpy.ndarray`` to paddle.Tensor.
"""Converts a ``numpy.ndarray`` to paddle.Tensor.
...
@@ -49,7 +51,7 @@ def to_tensor(pic, data_format='CHW'):
...
@@ -49,7 +51,7 @@ def to_tensor(pic, data_format='CHW'):
"""
"""
if
not
data_forma
t
in
[
'CHW'
,
'HWC'
]:
if
data_format
no
t
in
[
'CHW'
,
'HWC'
]:
raise
ValueError
(
'data_format should be CHW or HWC. Got {}'
.
format
(
raise
ValueError
(
'data_format should be CHW or HWC. Got {}'
.
format
(
data_format
))
data_format
))
...
...
python/paddle/vision/transforms/functional_pil.py
浏览文件 @
45f8b9d0
...
@@ -41,6 +41,8 @@ _pil_interp_from_str = {
...
@@ -41,6 +41,8 @@ _pil_interp_from_str = {
'hamming'
:
Image
.
HAMMING
'hamming'
:
Image
.
HAMMING
}
}
__all__
=
[]
def
to_tensor
(
pic
,
data_format
=
'CHW'
):
def
to_tensor
(
pic
,
data_format
=
'CHW'
):
"""Converts a ``PIL.Image`` to paddle.Tensor.
"""Converts a ``PIL.Image`` to paddle.Tensor.
...
@@ -57,7 +59,7 @@ def to_tensor(pic, data_format='CHW'):
...
@@ -57,7 +59,7 @@ def to_tensor(pic, data_format='CHW'):
"""
"""
if
not
data_forma
t
in
[
'CHW'
,
'HWC'
]:
if
data_format
no
t
in
[
'CHW'
,
'HWC'
]:
raise
ValueError
(
'data_format should be CHW or HWC. Got {}'
.
format
(
raise
ValueError
(
'data_format should be CHW or HWC. Got {}'
.
format
(
data_format
))
data_format
))
...
...
python/paddle/vision/transforms/functional_tensor.py
浏览文件 @
45f8b9d0
...
@@ -23,6 +23,8 @@ import paddle.nn.functional as F
...
@@ -23,6 +23,8 @@ import paddle.nn.functional as F
import
sys
import
sys
import
collections
import
collections
__all__
=
[]
def
_assert_image_tensor
(
img
,
data_format
):
def
_assert_image_tensor
(
img
,
data_format
):
if
not
isinstance
(
if
not
isinstance
(
...
...
python/paddle/vision/transforms/transforms.py
浏览文件 @
45f8b9d0
...
@@ -35,13 +35,7 @@ else:
...
@@ -35,13 +35,7 @@ else:
Sequence
=
collections
.
abc
.
Sequence
Sequence
=
collections
.
abc
.
Sequence
Iterable
=
collections
.
abc
.
Iterable
Iterable
=
collections
.
abc
.
Iterable
__all__
=
[
__all__
=
[]
"BaseTransform"
,
"Compose"
,
"Resize"
,
"RandomResizedCrop"
,
"CenterCrop"
,
"RandomHorizontalFlip"
,
"RandomVerticalFlip"
,
"Transpose"
,
"Normalize"
,
"BrightnessTransform"
,
"SaturationTransform"
,
"ContrastTransform"
,
"HueTransform"
,
"ColorJitter"
,
"RandomCrop"
,
"Pad"
,
"RandomRotation"
,
"Grayscale"
,
"ToTensor"
]
def
_get_image_size
(
img
):
def
_get_image_size
(
img
):
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录