Commit 62e6f628 authored by Amy Zhuang's avatar Amy Zhuang Committed by Scott Cyphers

Fix a bug in rotate_blocked_md. (#3710)

Enable in place rotation for Reshape for blocked data format.
parent 454ba5ed
...@@ -1325,6 +1325,12 @@ memory::desc runtime::cpu::mkldnn_utils::rotate_blocked_md(const memory::desc& i ...@@ -1325,6 +1325,12 @@ memory::desc runtime::cpu::mkldnn_utils::rotate_blocked_md(const memory::desc& i
md.data_type = in.data.data_type; md.data_type = in.data.data_type;
md.format_desc.blocking.inner_nblks = in.data.format_desc.blocking.inner_nblks; md.format_desc.blocking.inner_nblks = in.data.format_desc.blocking.inner_nblks;
AxisVector inverse_axis_order(in.data.ndims);
for (size_t i = 0; i < in.data.ndims; i++)
{
inverse_axis_order[axis_order[i]] = i;
}
for (size_t i = 0; i < in.data.ndims; i++) for (size_t i = 0; i < in.data.ndims; i++)
{ {
md.padded_dims[i] = in.data.padded_dims[axis_order[i]]; md.padded_dims[i] = in.data.padded_dims[axis_order[i]];
...@@ -1337,7 +1343,7 @@ memory::desc runtime::cpu::mkldnn_utils::rotate_blocked_md(const memory::desc& i ...@@ -1337,7 +1343,7 @@ memory::desc runtime::cpu::mkldnn_utils::rotate_blocked_md(const memory::desc& i
{ {
md.format_desc.blocking.inner_blks[i] = in.data.format_desc.blocking.inner_blks[i]; md.format_desc.blocking.inner_blks[i] = in.data.format_desc.blocking.inner_blks[i];
md.format_desc.blocking.inner_idxs[i] = md.format_desc.blocking.inner_idxs[i] =
axis_order[in.data.format_desc.blocking.inner_idxs[i]]; inverse_axis_order[in.data.format_desc.blocking.inner_idxs[i]];
} }
md.offset0 = in.data.offset0; md.offset0 = in.data.offset0;
......
...@@ -1896,12 +1896,7 @@ namespace ngraph ...@@ -1896,12 +1896,7 @@ namespace ngraph
if (input_shape[axis_order[i]] != output_shape[i]) if (input_shape[axis_order[i]] != output_shape[i])
return false; return false;
} }
#if MKLDNN_VERSION_MAJOR >= 1
if (mkldnn_utils::is_mkldnn_desc_blocked_data_format(md))
{
return false;
}
#endif
return true; return true;
} }
......
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