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
b422f6a9
Unverified
Commit
b422f6a9
authored
Feb 25, 2020
by
雾雨魔理沙
Committed by
GitHub
Feb 25, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[WIP] Fixing an Infinite Loop case in UnmatchedChecker. (#4881)
* save * save * remove * remove cerr
parent
545f6ea3
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
28 additions
and
19 deletions
+28
-19
src/relay/pass/match_exhaustion.cc
+3
-19
tests/python/relay/test_pass_unmatched_cases.py
+25
-0
No files found.
src/relay/pass/match_exhaustion.cc
View file @
b422f6a9
...
...
@@ -168,8 +168,10 @@ Array<Pattern> ExpandWildcards(const Pattern& clause_pat,
const
IRModule
&
mod
)
{
if
(
auto
clause_ctor
=
clause_pat
.
as
<
PatternConstructorNode
>
())
{
return
ExpandWildcardsConstructor
(
GetRef
<
PatternConstructor
>
(
clause_ctor
),
cand
,
mod
);
}
else
if
(
auto
clause_tup
=
clause_pat
.
as
<
PatternTupleNode
>
())
{
return
ExpandWildcardsTuple
(
GetRef
<
PatternTuple
>
(
clause_tup
),
cand
,
mod
);
}
else
{
return
ExpandWildcardsTuple
(
Downcast
<
PatternTuple
>
(
clause_pat
),
cand
,
mod
)
;
return
{
cand
}
;
}
}
...
...
@@ -201,19 +203,10 @@ Array<Pattern> ExpandWildcardsConstructor(const PatternConstructor& clause_ctor,
// for constructors, we will expand the wildcards in any field that is an ADT.
Array
<
Array
<
Pattern
>>
values_by_field
;
for
(
size_t
i
=
0
;
i
<
ctor_cand
->
constructor
->
inputs
.
size
();
i
++
)
{
bool
subpattern
=
clause_ctor
->
patterns
[
i
].
as
<
PatternConstructorNode
>
()
||
clause_ctor
->
patterns
[
i
].
as
<
PatternTupleNode
>
();
// for non-ADT fields, we can only have a wildcard for the value.
if
(
!
subpattern
)
{
values_by_field
.
push_back
({
PatternWildcardNode
::
make
()});
}
else
{
// otherwise, recursively expand.
values_by_field
.
push_back
(
ExpandWildcards
(
clause_ctor
->
patterns
[
i
],
ctor_cand
->
patterns
[
i
],
mod
));
}
}
// generate new candidates using a cartesian product.
auto
all_subfields
=
CartesianProduct
(
values_by_field
);
...
...
@@ -243,19 +236,10 @@ Array<Pattern> ExpandWildcardsTuple(const PatternTuple& clause_tuple,
// for constructors, we will expand the wildcards in any field that is an ADT.
Array
<
Array
<
Pattern
>>
values_by_field
;
for
(
size_t
i
=
0
;
i
<
tuple_cand
->
patterns
.
size
();
i
++
)
{
bool
subpattern
=
clause_tuple
->
patterns
[
i
].
as
<
PatternConstructorNode
>
()
||
clause_tuple
->
patterns
[
i
].
as
<
PatternTupleNode
>
();
// for non-ADT fields, we can only have a wildcard for the value
if
(
!
subpattern
)
{
values_by_field
.
push_back
({
PatternWildcardNode
::
make
()});
}
else
{
// otherwise, recursively expand
values_by_field
.
push_back
(
ExpandWildcards
(
clause_tuple
->
patterns
[
i
],
tuple_cand
->
patterns
[
i
],
mod
));
}
}
// generate new candidates using a cartesian product
auto
all_subfields
=
CartesianProduct
(
values_by_field
);
...
...
tests/python/relay/test_pass_unmatched_cases.py
View file @
b422f6a9
...
...
@@ -19,6 +19,7 @@ import tvm
from
tvm
import
relay
from
tvm.relay.prelude
import
Prelude
from
tvm.relay.analysis
import
unmatched_cases
import
pytest
def
test_empty_match_block
():
# empty match block will not match anything, so it should return a wildcard pattern
...
...
@@ -273,3 +274,27 @@ def test_tuple_match():
clause
=
relay
.
Clause
(
relay
.
PatternTuple
([
relay
.
PatternVar
(
a
),
relay
.
PatternVar
(
b
)]),
a
+
b
)
x
=
relay
.
Match
(
relay
.
Tuple
([
relay
.
const
(
1
),
relay
.
const
(
1
)]),
[
clause
])
assert
len
(
unmatched_cases
(
x
))
==
0
def
test_inf_loop_case
():
code
=
"""
v0.0.4
type Arith[A] {
Zero,
Const(A),
Plus(Arith[A], Arith[A])
}
def @shallow_opt[A](
%
a: Arith[A]) -> Arith[A] {
match (
%
a) {
Plus(Zero,
%
r) =>
%
r,
Plus(
%
l, Zero) =>
%
l,
_ =>
%
a
}
}
"""
relay
.
fromtext
(
code
)
# fromtext parse the module, then checked it (which include strictness checking).
if
__name__
==
"__main__"
:
pytest
.
main
([
__file__
])
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