Unverified Commit ad30e973 authored by Adam Procter's avatar Adam Procter Committed by GitHub

Merge pull request #2330 from NervanaSystems/krovatkin/rs_slice_heuristic

A simple heuristic for slice sinker
parents 2f180f90 2dc0c48f
...@@ -473,7 +473,21 @@ bool ngraph::pass::ReshapeSinking::run_on_function(std::shared_ptr<ngraph::Funct ...@@ -473,7 +473,21 @@ bool ngraph::pass::ReshapeSinking::run_on_function(std::shared_ptr<ngraph::Funct
} }
else if (auto slice = std::dynamic_pointer_cast<op::Slice>(n)) else if (auto slice = std::dynamic_pointer_cast<op::Slice>(n))
{ {
sink_slice(slice, reorders, reshapes_to_delete); // A heuristic. If Reshape has multiple slice users, if sunk
// it will be replicated by the number of its users
// TODO: we should have a pre-pass that looks at this kind of
// scenarios and marks some reshapes as too "toxic" to sink
// For now, this heuristic works really well.
// Note, get_users(*true*) which means we only care about
// live users of Reshape
if (slice->get_argument(0)->get_users(true).size() == 1)
{
sink_slice(slice, reorders, reshapes_to_delete);
}
else
{
materialize_shapes(n, reorders, reshapes_to_delete);
}
} }
else if (auto pad = std::dynamic_pointer_cast<op::Pad>(n)) else if (auto pad = std::dynamic_pointer_cast<op::Pad>(n))
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment