Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
magicwindyyd
mindspore
提交
0c519882
M
mindspore
项目概览
magicwindyyd
/
mindspore
与 Fork 源项目一致
Fork自
MindSpore / mindspore
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
mindspore
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
0c519882
编写于
6月 27, 2020
作者:
Y
yanghaitao1
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
optimize fastrcnn training process
上级
122a9310
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
14 addition
and
18 deletion
+14
-18
model_zoo/faster_rcnn/src/dataset.py
model_zoo/faster_rcnn/src/dataset.py
+14
-18
未找到文件。
model_zoo/faster_rcnn/src/dataset.py
浏览文件 @
0c519882
...
...
@@ -318,10 +318,6 @@ def preprocess_fn(image, box, is_training):
else
:
input_data
=
resize_column
(
*
input_data
)
photo
=
(
np
.
random
.
rand
()
<
config
.
photo_ratio
)
if
photo
:
input_data
=
photo_crop_column
(
*
input_data
)
input_data
=
image_bgr_rgb
(
*
input_data
)
output_data
=
input_data
...
...
@@ -432,19 +428,19 @@ def data_to_mindrecord_byte_image(dataset="coco", is_training=True, prefix="fast
writer
.
write_raw_data
([
row
])
writer
.
commit
()
def
create_fasterrcnn_dataset
(
mindrecord_file
,
batch_size
=
2
,
repeat_num
=
12
,
device_num
=
1
,
rank_id
=
0
,
is_training
=
True
,
num_parallel_workers
=
8
):
is_training
=
True
,
num_parallel_workers
=
4
):
"""Creatr FasterRcnn dataset with MindDataset."""
ds
=
de
.
MindDataset
(
mindrecord_file
,
columns_list
=
[
"image"
,
"annotation"
],
num_shards
=
device_num
,
shard_id
=
rank_id
,
num_parallel_workers
=
num_parallel_workers
,
shuffle
=
is_training
)
num_parallel_workers
=
1
,
shuffle
=
is_training
)
decode
=
C
.
Decode
()
ds
=
ds
.
map
(
input_columns
=
[
"image"
],
operations
=
decode
)
ds
=
ds
.
map
(
input_columns
=
[
"image"
],
operations
=
decode
,
num_parallel_workers
=
1
)
compose_map_func
=
(
lambda
image
,
annotation
:
preprocess_fn
(
image
,
annotation
,
is_training
))
hwc_to_chw
=
C
.
HWC2CHW
()
normalize_op
=
C
.
Normalize
((
123.675
,
116.28
,
103.53
),
(
58.395
,
57.12
,
57.375
))
horizontally_op
=
C
.
RandomHorizontalFlip
(
1
)
type_cast0
=
CC
.
TypeCast
(
mstype
.
float32
)
type_cast1
=
CC
.
TypeCast
(
mstype
.
float16
)
type_cast2
=
CC
.
TypeCast
(
mstype
.
int32
)
type_cast3
=
CC
.
TypeCast
(
mstype
.
bool_
)
...
...
@@ -453,17 +449,18 @@ def create_fasterrcnn_dataset(mindrecord_file, batch_size=2, repeat_num=12, devi
ds
=
ds
.
map
(
input_columns
=
[
"image"
,
"annotation"
],
output_columns
=
[
"image"
,
"image_shape"
,
"box"
,
"label"
,
"valid_num"
],
columns_order
=
[
"image"
,
"image_shape"
,
"box"
,
"label"
,
"valid_num"
],
operations
=
compose_map_func
,
num_parallel_workers
=
4
)
ds
=
ds
.
map
(
input_columns
=
[
"image"
],
operations
=
[
normalize_op
,
type_cast0
],
num_parallel_workers
=
num_parallel_workers
)
operations
=
compose_map_func
,
num_parallel_workers
=
num_parallel_workers
)
flip
=
(
np
.
random
.
rand
()
<
config
.
flip_ratio
)
if
flip
:
ds
=
ds
.
map
(
input_columns
=
[
"image"
],
operations
=
[
horizontally_op
],
num_parallel_workers
=
num_parallel_workers
)
ds
=
ds
.
map
(
input_columns
=
[
"image"
],
operations
=
[
normalize_op
,
horizontally_op
,
hwc_to_chw
,
type_cast1
],
num_parallel_workers
=
24
)
ds
=
ds
.
map
(
input_columns
=
[
"image"
,
"image_shape"
,
"box"
,
"label"
,
"valid_num"
],
operations
=
flipped_generation
,
num_parallel_workers
=
4
)
operations
=
flipped_generation
,
num_parallel_workers
=
num_parallel_workers
)
else
:
ds
=
ds
.
map
(
input_columns
=
[
"image"
],
operations
=
[
normalize_op
,
hwc_to_chw
,
type_cast1
],
num_parallel_workers
=
24
)
else
:
ds
=
ds
.
map
(
input_columns
=
[
"image"
,
"annotation"
],
output_columns
=
[
"image"
,
"image_shape"
,
"box"
,
"label"
,
"valid_num"
],
...
...
@@ -471,11 +468,10 @@ def create_fasterrcnn_dataset(mindrecord_file, batch_size=2, repeat_num=12, devi
operations
=
compose_map_func
,
num_parallel_workers
=
num_parallel_workers
)
ds
=
ds
.
map
(
input_columns
=
[
"image"
],
operations
=
[
normalize_op
,
type_cast0
],
num_parallel_workers
=
num_parallel_workers
)
ds
=
ds
.
map
(
input_columns
=
[
"image"
],
operations
=
[
normalize_op
,
hwc_to_chw
,
type_cast1
],
num_parallel_workers
=
24
)
# transpose_column from python to c
ds
=
ds
.
map
(
input_columns
=
[
"image"
],
operations
=
[
hwc_to_chw
,
type_cast1
])
ds
=
ds
.
map
(
input_columns
=
[
"image_shape"
],
operations
=
[
type_cast1
])
ds
=
ds
.
map
(
input_columns
=
[
"box"
],
operations
=
[
type_cast1
])
ds
=
ds
.
map
(
input_columns
=
[
"label"
],
operations
=
[
type_cast2
])
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录