Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
T
tic
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wenyuanbo
tic
Commits
a8e6ee9b
Commit
a8e6ee9b
authored
Nov 15, 2019
by
ziyu-guo
Committed by
Yao Wang
Nov 15, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix inconsistent tag name (#4134)
parent
5b1ca85d
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
50 additions
and
2 deletions
+50
-2
tests/python/relay/test_op_level2.py
+48
-0
topi/python/topi/arm_cpu/depthwise_conv2d.py
+2
-2
No files found.
tests/python/relay/test_op_level2.py
View file @
a8e6ee9b
...
@@ -22,6 +22,7 @@ from tvm import autotvm
...
@@ -22,6 +22,7 @@ from tvm import autotvm
from
tvm
import
relay
from
tvm
import
relay
from
tvm.relay
import
transform
from
tvm.relay
import
transform
from
tvm.relay.testing
import
ctx_list
from
tvm.relay.testing
import
ctx_list
from
tvm.contrib
import
util
import
topi.testing
import
topi.testing
def
run_infer_type
(
expr
):
def
run_infer_type
(
expr
):
...
@@ -134,6 +135,46 @@ def test_conv2d_run():
...
@@ -134,6 +135,46 @@ def test_conv2d_run():
op_res1
=
intrp1
.
evaluate
(
func
)(
data
,
kernel
)
op_res1
=
intrp1
.
evaluate
(
func
)(
data
,
kernel
)
tvm
.
testing
.
assert_allclose
(
op_res1
.
asnumpy
(),
ref_res
,
rtol
=
1e-5
,
atol
=
1e-5
)
tvm
.
testing
.
assert_allclose
(
op_res1
.
asnumpy
(),
ref_res
,
rtol
=
1e-5
,
atol
=
1e-5
)
def
compile_test_conv2d_arm_cpu
(
dtype
,
out_dtype
,
scale
,
dshape
,
kshape
,
padding
=
(
1
,
1
),
groups
=
1
,
dilation
=
(
1
,
1
),
**
attrs
):
x
=
relay
.
var
(
"x"
,
shape
=
dshape
,
dtype
=
dtype
)
w
=
relay
.
var
(
"w"
,
dtype
=
dtype
)
y
=
relay
.
nn
.
conv2d
(
x
,
w
,
padding
=
padding
,
dilation
=
dilation
,
groups
=
groups
,
**
attrs
)
func
=
relay
.
Function
([
x
,
w
],
y
)
mod
=
tvm
.
relay
.
Module
()
mod
[
"main"
]
=
func
test_schedule
=
'{"i": ["llvm -device=arm_cpu", "topi_nn_depthwise_conv2d_nchw",
\
[["TENSOR", [1, 512, 32, 32], "float32"],
\
["TENSOR", [512, 1, 3, 3], "float32"],
\
[1, 1], [1, 1], [1, 1], "float32"], {},
\
["depthwise_conv2d_nchw", [1, 512, 32, 32, "float32"],
\
[512, 1, 3, 3, "float32"], [1, 1], [1, 1], [1, 1], "float32"],
\
{"i": 743640, "t": "contrib_spatial_pack", "c": null,
\
"e": [["tile_co", "sp", [512, 1]], ["tile_oh", "sp", [8, 1]],
\
["tile_ow", "sp", [1, 8]],
\
["reorder_0", "re", [0, 1, 2, 3, 4, 5, 8, 6, 7]],
\
["reorder_1", "re", [0, 1, 2, 3, 6, 4, 5]],
\
["ann_reduce", "an", ["unroll", "none"]],
\
["ann_spatial", "an", ["unroll", "unroll", "vec"]],
\
["data_pad_inline", "ot", 4], ["data_vec_inline", "ot", 1],
\
["conv_inline", "ot", 0]]}], "r": [[0.0002933163],
\
0, 3.1976189613342285, 1570811630.6058347], "v": 0.1}'
temp
=
util
.
tempdir
()
with
open
(
temp
.
relpath
(
"temp.log"
),
"w"
)
as
log_file
:
log_file
.
write
(
test_schedule
)
with
autotvm
.
apply_history_best
(
temp
.
relpath
(
"temp.log"
)):
with
relay
.
build_config
(
opt_level
=
3
):
print
(
'Compiling...'
)
graph_json
,
mod
,
params
=
tvm
.
relay
.
build
(
mod
,
target
=
"llvm -device=arm_cpu"
)
# depthwise conv2d
# depthwise conv2d
dshape
=
(
1
,
32
,
18
,
18
)
dshape
=
(
1
,
32
,
18
,
18
)
kshape
=
(
32
,
1
,
3
,
3
)
kshape
=
(
32
,
1
,
3
,
3
)
...
@@ -142,6 +183,13 @@ def test_conv2d_run():
...
@@ -142,6 +183,13 @@ def test_conv2d_run():
fref
=
lambda
x
,
w
:
topi
.
testing
.
depthwise_conv2d_python_nchw
(
fref
=
lambda
x
,
w
:
topi
.
testing
.
depthwise_conv2d_python_nchw
(
x
,
w
,
(
1
,
1
),
"SAME"
))
x
,
w
,
(
1
,
1
),
"SAME"
))
# depthwise conv2d for arm_cpu
dshape
=
(
1
,
512
,
32
,
32
)
kshape
=
(
512
,
1
,
3
,
3
)
compile_test_conv2d_arm_cpu
(
"float32"
,
"float32"
,
1
,
dshape
,
kshape
,
padding
=
(
1
,
1
),
channels
=
512
,
groups
=
512
,
kernel_size
=
(
3
,
3
))
# CUDA is disabled for 'direct' schedule:
# CUDA is disabled for 'direct' schedule:
# https://github.com/apache/incubator-tvm/pull/3070#issuecomment-486597553
# https://github.com/apache/incubator-tvm/pull/3070#issuecomment-486597553
# group conv2d
# group conv2d
...
...
topi/python/topi/arm_cpu/depthwise_conv2d.py
View file @
a8e6ee9b
...
@@ -134,7 +134,7 @@ def schedule_depthwise_conv2d_nchw_arm(cfg, outs):
...
@@ -134,7 +134,7 @@ def schedule_depthwise_conv2d_nchw_arm(cfg, outs):
data
=
data_pad
.
op
.
input_tensors
[
0
]
data
=
data_pad
.
op
.
input_tensors
[
0
]
_schedule
(
cfg
,
s
,
data
,
data_pad
,
kernel
,
output
)
_schedule
(
cfg
,
s
,
data
,
data_pad
,
kernel
,
output
)
if
op
.
tag
==
'spatial_depthwise_conv_nchw_output'
:
if
op
.
tag
==
'spatial_depthwise_conv
2d
_nchw_output'
:
output
=
op
.
output
(
0
)
output
=
op
.
output
(
0
)
conv
=
op
.
input_tensors
[
0
]
conv
=
op
.
input_tensors
[
0
]
data_vec
=
conv
.
op
.
input_tensors
[
0
]
data_vec
=
conv
.
op
.
input_tensors
[
0
]
...
@@ -316,7 +316,7 @@ def _decl_spatial_pack(cfg, data, kernel, strides, padding, dilation, out_dtype,
...
@@ -316,7 +316,7 @@ def _decl_spatial_pack(cfg, data, kernel, strides, padding, dilation, out_dtype,
conv
[
n
,
conv
[
n
,
idxdiv
(
co
,
VC
),
idxdiv
(
h
,
VH
),
idxdiv
(
w
,
VW
),
idxdiv
(
co
,
VC
),
idxdiv
(
h
,
VH
),
idxdiv
(
w
,
VW
),
idxmod
(
h
,
VH
),
idxmod
(
w
,
VW
),
idxmod
(
co
,
VC
)],
idxmod
(
h
,
VH
),
idxmod
(
w
,
VW
),
idxmod
(
co
,
VC
)],
name
=
'output_unpack'
,
tag
=
'spatial_depthwise_conv_nchw_output'
)
name
=
'output_unpack'
,
tag
=
'spatial_depthwise_conv
2d
_nchw_output'
)
return
output
return
output
def
_schedule_spatial_pack
(
cfg
,
s
,
data_vec
,
kernel_vec
,
def
_schedule_spatial_pack
(
cfg
,
s
,
data_vec
,
kernel_vec
,
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment