Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Remove opset0 support and undesired passes from Interpreter backend #1469

Merged
Merged
Changes from 1 commit
Commits
Show all changes
133 commits
Select commit Hold shift + click to select a range
16e66e7
Move evaluate() interface from some OPs to Interpreter
Jun 17, 2020
8cdb2a2
commit
Aug 7, 2020
51e4d6e
Merge 'master' into evaluate_update
Aug 11, 2020
7a41458
Move shuffle channels reference to OP's evaluate
Aug 11, 2020
c0a43b6
Add some operations missed in evaluate_node
Aug 12, 2020
fa43065
Fix select references invocation from evaluate_node()
Aug 12, 2020
9cb9021
Activation refs (#2)
iefode Aug 17, 2020
8d225af
Merge upstream master
Aug 17, 2020
dc58f48
Rollback donwgrade passes delition
Aug 18, 2020
9a44221
Initial batch to space refs
Aug 21, 2020
4e0a3d4
Return opset1_upgrade
Aug 25, 2020
6c486cb
Merge upstreeam master
Aug 25, 2020
1e083c2
WIP: Add space to batch evaluate
Aug 26, 2020
af154ac
Fix space to batch
Aug 26, 2020
1776a53
add evaluates function in evaluates_map (#4)
antonzaycev96 Aug 26, 2020
19eabad
Merge branch 'update_evaluates' of github.com:mikhail-treskin/openvin…
Aug 26, 2020
41983a8
Add space to batch evaluate
Aug 26, 2020
dca1bba
Merge branch 'master' into update_evaluates
Aug 26, 2020
5a77ee2
Fix crop in batch to space references
Aug 27, 2020
a00a6b9
Remove vectors reallocation in evaluates for b2s and s2b
Aug 31, 2020
8e1a0e4
.
Sep 2, 2020
c57beab
Add SpaceToDepth evaluate
Sep 2, 2020
9e92e3b
Add depth to space evaluate
Sep 5, 2020
5794f2f
Remove code duplication depth to space evaluate
Sep 5, 2020
759f976
Fix some failed layer tests
Sep 5, 2020
d043403
merge upstream master
Sep 7, 2020
f80c325
Ngraph test (#3)
iefode Sep 7, 2020
3dab0d6
Enable cells refs in evaluate map
iefode Sep 8, 2020
1f42b8e
Fix some failed layer tests
Sep 10, 2020
7b06f04
Merge iefode/cells
Sep 10, 2020
f647cda
Merge upstreream/master
Sep 10, 2020
167073f
Some more fixes
Sep 10, 2020
d910235
Fix code style (#6)
iefode Sep 10, 2020
0ea28db
Merge branch 'update_evaluates' of github.com:mikhail-treskin/openvin…
Sep 10, 2020
fdd3c16
Tests (#7)
iefode Sep 15, 2020
4039a80
Fix one hot ref call
Sep 15, 2020
4eca370
Merge branch 'update_evaluates' of github.com:mikhail-treskin/openvin…
Sep 15, 2020
223f386
.
Sep 15, 2020
f0a5399
Select (#8)
iefode Sep 16, 2020
66425a3
Merge branch 'update_evaluates' of github.com:mikhail-treskin/openvin…
Sep 16, 2020
a5c32c1
ReverseSeq (#9)
iefode Sep 22, 2020
4660ca4
Merge branch 'update_evaluates' of github.com:mikhail-treskin/openvin…
Sep 22, 2020
7adf1c7
Add fake quantize reference
Sep 23, 2020
1bda367
Merge upstream master
Sep 23, 2020
631aa2f
Align convolution layer tests instantiations with updated definition
Sep 24, 2020
611ffdc
Disabled some failed LPT tests
Sep 28, 2020
7e5c5af
Merge branch 'master' into update_evaluates
Sep 28, 2020
c21484a
Disabled some failed LPT tests
Sep 28, 2020
86afce5
Remove undesired changes
Sep 28, 2020
1adbb2f
Update unit-test manifests + some code cleanup
Sep 28, 2020
dfa711d
Fix code style (#10)
iefode Sep 29, 2020
9938151
Normalize L2 refs support (from PR #2327)
Sep 29, 2020
d57c03e
Fix code style
Sep 29, 2020
cb96362
Apply review comments. Part 1 (#11)
iefode Oct 1, 2020
f37c347
Remove redundant reshape from shuffle_channels evaluate
Oct 1, 2020
7cd5ec6
Decompose GroupConvolution
Oct 6, 2020
0cf873b
[IE Ngraph] Fix some operation inheritance (#13)
iefode Oct 6, 2020
b6f95b8
Fix code style
Oct 6, 2020
ed8614f
[IE NGraph] Remove decompose op (#14)
iefode Oct 7, 2020
f8fc914
.
Oct 7, 2020
ecf96e5
Merge branch 'master' into update_evaluates
Oct 7, 2020
5233a09
Fix loosing control dependency in replace_node
Oct 7, 2020
1340aea
Fix loosing control dependency in replace_node
Oct 7, 2020
fc429b7
Merge branch 'master' into update_evaluates
Oct 8, 2020
1a47819
Fix code style
Oct 8, 2020
8480066
Fix FQ references build on windows
Oct 8, 2020
3463c9b
Merge remote-tracking branch 'origin/update_evaluates' into update_ev…
Oct 8, 2020
32dbaeb
Fix code style
Oct 8, 2020
a1a58ab
Apply comments (#15)
iefode Oct 8, 2020
d9092a8
Ci (#16)
iefode Oct 12, 2020
b83218a
Android fix (#17)
iefode Oct 12, 2020
6f301a9
fix failures
Oct 12, 2020
1fa4644
Fix code style
Oct 12, 2020
da4b5e3
Add (#18)
iefode Oct 12, 2020
7f66509
Merge branch 'master' into update_evaluates
Oct 12, 2020
c19bf49
Add in opset1 upgrade pass
Oct 12, 2020
e9729f3
Add in opset1 upgrade pass
Oct 12, 2020
083dcdb
Remove v0::Add, Reverted removing v0::Multiply (#19)
iefode Oct 13, 2020
83fc4c8
Remove overloaded math operators from PyNgraph
Oct 13, 2020
55ff773
Remove overloaded math operators from PyNgraph
Oct 13, 2020
f9760d8
Merge branch 'master' into update_evaluates
Oct 13, 2020
92c2c96
Fix gna tests (#20)
iefode Oct 13, 2020
620804f
Merge branch 'update_evaluates' of https://github.com/mikhail-treskin…
Oct 13, 2020
a9c338a
Merge upstream master
Oct 13, 2020
aec84b1
LRN Reference (#21)
iefode Oct 14, 2020
5b7afbd
Disable failed tests on ia32
Oct 14, 2020
b3cca60
Merge upstream master
Oct 14, 2020
0c892de
Remove redundant broadcast from MVN ref
Oct 14, 2020
58fb557
Merge branch 'update_evaluates' of https://github.com/mikhail-treskin…
Oct 14, 2020
fb1dc34
Fix missed GatherND in opset_int_tbl + code style
Oct 14, 2020
9389d24
Remove one extra temporary buffer from MVN ref
Oct 15, 2020
8e50854
Merge branch 'update_evaluates' of github.com:mikhail-treskin/openvin…
Oct 15, 2020
a5153c2
Merge master (#22)
iefode Oct 15, 2020
b3d514f
Merge remote-tracking branch 'upstream/master' into update_evaluates
Oct 15, 2020
d288aec
Merge remote-tracking branch 'upstream/master' into update_evaluates
iefode Oct 16, 2020
410f865
RegionYolo
iefode Oct 16, 2020
9d89220
Apply review comments
Oct 21, 2020
ed4e574
Merge remote-tracking branch 'upstream/master' into update_evaluates
Oct 21, 2020
cdbcbd2
Merge remote-tracking branch 'upstream/master' into update_evaluates
Oct 21, 2020
6f9a462
Merge remote-tracking branch 'origin/update_evaluates' into update_ev…
Oct 21, 2020
9ef2324
Apply code style
Oct 21, 2020
ba88b24
Apply comments
Oct 21, 2020
4c2e815
Merge branch 'update_evaluates' of github.com:mikhail-treskin/openvin…
Oct 21, 2020
5bf1ccb
Apply code style
Oct 21, 2020
061d97c
Fix RegionYolo evaluate redefinition
Oct 21, 2020
0435170
Removed defines from evaluates map
Oct 22, 2020
617ce58
Apply code style
Oct 22, 2020
ed8e562
Merge remote-tracking branch 'upstream/master' into update_evaluates
Oct 23, 2020
f116518
Fix MVN ref
Oct 23, 2020
c26efd3
Merge upstream master
Oct 29, 2020
13c5f14
rename select reference argument
Oct 30, 2020
1375188
Merge remote-tracking branch 'upstream/master' into update_evaluates
iefode Nov 2, 2020
941597d
Fix code style
iefode Nov 2, 2020
f6d2cc8
Merge remote-tracking branch 'upstream/master' into update_evaluates
iefode Nov 5, 2020
ad4d67e
Merge remote-tracking branch 'upstream/master' into update_evaluates
iefode Nov 24, 2020
18d52ed
Fix Fake Quantize references calculation (#24)
Nov 24, 2020
187fe80
Fix MVN ref
iefode Nov 24, 2020
015fe64
Fix MVN & adding NMS
iefode Nov 25, 2020
a798b60
Merge remote-tracking branch 'origin/update_evaluates' into update_ev…
iefode Nov 25, 2020
eb94ae7
Merge remote-tracking branch 'upstream/master' into update_evaluates
iefode Nov 25, 2020
4259a5b
Fix TI
iefode Nov 25, 2020
b32b601
Temporary relax comparison threshold for FQ SLT
Nov 27, 2020
7f8fd31
Fix GPU LPT Tests
Nov 27, 2020
fca0174
Merge remote-tracking branch 'upstream/master' into update_evaluates
Nov 27, 2020
9b3a687
Add explicit rounding mode seetting in FQ references
Nov 27, 2020
ed974ab
Merge remote-tracking branch 'upstream/master' into update_evaluates
Dec 1, 2020
70f603b
Apply code style
Dec 1, 2020
a7d897b
Rollback op_is test deletion
Dec 2, 2020
d93a4c7
Apply code style
Dec 2, 2020
de3987b
Merge remote-tracking branch 'upstream/master' into update_evaluates
Dec 2, 2020
282e54d
Merge remote-tracking branch 'upstream/master' into update_evaluates
Dec 3, 2020
9c23b70
Fix merge conflict resolving issues
Dec 3, 2020
0d84107
Apply code style
Dec 3, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Align convolution layer tests instantiations with updated definition
  • Loading branch information
Mikhail Treskin committed Sep 24, 2020
commit 631aa2ffd6647279827fe4a26a53bc7ab4fdf8f3
Original file line number Diff line number Diff line change
@@ -11,6 +11,7 @@
#include <ie_core.hpp>

#include <transformations/init_node_info.hpp>
#include "ngraph/pass/visualize_tree.hpp"

namespace LayerTestsDefinitions {

@@ -40,7 +41,8 @@ void FuseFakeQuantizeAndScaleShiftTransformation::SetUp() {
fakeQuantizeOnData);

ngraph::pass::InitNodeInfo().run_on_function(function);

auto p = ngraph::pass::VisualizeTree("graph.dot");
p.run_on_function(function);
EXPECT_EQ(1ul, function->get_output_size());
EXPECT_EQ(1ul, function->get_output_op(0)->get_input_size());
const std::string referenceOutputLayerName = function->get_output_op(0)->get_input_node_ptr(0)->get_friendly_name();
@@ -54,7 +56,6 @@ void FuseFakeQuantizeAndScaleShiftTransformation::validate(const std::string& re
InferenceEngine::details::LayerTransformation::Params params;
ngraph::builder::subgraph::FakeQuantizeOnData fakeQuantizeOnData;
std::tie(netPrecision, inputShape, targetDevice, params, fakeQuantizeOnData) = this->GetParam();

auto transformations = getLowPrecisionTransformations(params);
const InferenceEngine::CNNNetwork network = transform(transformations);

Original file line number Diff line number Diff line change
@@ -36,7 +36,6 @@ std::string BatchToSpaceLayerTest::getTestCaseName(const testing::TestParamInfo<
}

void BatchToSpaceLayerTest::SetUp() {
SetRefMode(LayerTestsUtils::RefMode::INTERPRETER_TRANSFORMATIONS);
std::vector<size_t> inputShape, blockShape, cropsBegin, cropsEnd;
InferenceEngine::Precision netPrecision;
std::tie(blockShape, cropsBegin, cropsEnd, inputShape, netPrecision, targetDevice) = this->GetParam();
Original file line number Diff line number Diff line change
@@ -36,7 +36,6 @@ std::string SpaceToBatchLayerTest::getTestCaseName(const testing::TestParamInfo<
}

void SpaceToBatchLayerTest::SetUp() {
SetRefMode(LayerTestsUtils::RefMode::INTERPRETER_TRANSFORMATIONS);
std::vector<size_t> inputShape, blockShape, padsBegin, padsEnd;
InferenceEngine::Precision inputPrecision, netPrecision;
std::tie(blockShape, padsBegin, padsEnd, inputShape, netPrecision, targetDevice) = this->GetParam();
Original file line number Diff line number Diff line change
@@ -175,13 +175,6 @@ std::vector<std::vector<std::uint8_t>> LayerTestsCommon::CalculateRefs() {
// reference inference on device with other options and nGraph function has to be implemented here
break;
}
case INTERPRETER_TRANSFORMATIONS: {
auto cloned_function = ngraph::clone_function(*function);

// todo: add functionality to configure the necessary transformations for each test separately
expectedOutputs = ngraph::helpers::interpreterFunction(cloned_function, referenceInputs, convertType);
break;
}
}

return expectedOutputs;
Original file line number Diff line number Diff line change
@@ -40,7 +40,6 @@ typedef std::tuple<

enum RefMode {
INTERPRETER,
INTERPRETER_TRANSFORMATIONS,
CONSTANT_FOLDING,
IE
};
@@ -67,6 +66,16 @@ class LayerTestsCommon : public CommonTestUtils::TestsCommon {

template<class T>
void Compare(const T *expected, const T *actual, std::size_t size, T threshold) {
std::cout << std::endl;
mikhail-treskin marked this conversation as resolved.
Show resolved Hide resolved
std::cout << "REFS" << std::endl;
for (std::size_t i = 0; i < size; ++i) {
std::cout << expected[i] << " ";
}
std::cout << std::endl;
std::cout << "ACTUAL" << std::endl;
for (std::size_t i = 0; i < size; ++i) {
std::cout << actual[i] << " ";
}
std::cout << std::endl;
for (std::size_t i = 0; i < size; ++i) {
const auto &ref = expected[i];
Original file line number Diff line number Diff line change
@@ -173,6 +173,7 @@ std::string LayerTransformation::toString(const InferenceEngine::details::LayerT
params.precisionsOnWeights << "_" <<
params.quantizedTensorAlignmentOnActivations;

std::cout << result.str() << std::endl;
return result.str();
}

Original file line number Diff line number Diff line change
@@ -31,41 +31,19 @@ namespace ngraph {
namespace reference {
std::vector<size_t> calc_broadcast_index_offset(const std::vector<size_t> &memory_offsets,
const std::vector<size_t> &broadcast_shape) {
std::vector<size_t> left_broadcastable_dims;
std::vector<size_t> right_broadcastable_dims;
for (size_t i = 0; i < broadcast_shape.size(); ++i) {
if (broadcast_shape[i] == 1) {
left_broadcastable_dims.push_back(i);
} else {
break;
}
}
for (size_t i = broadcast_shape.size(); i >= 0; ++i) {
if (broadcast_shape[i] == 1) {
right_broadcastable_dims.push_back(i);
} else {
break;
}
}
std::vector<size_t> broadcast_offsets;
for (size_t &i : left_broadcastable_dims) {
broadcast_offsets[i] = memory_offsets[i];
}
// TODO: handle right_bradcastable_dims properly
// for (size_t &i : right_broadcastable_dims) {
// broadcast_offsets[i] = memory_offsets[i];
// }
size_t right_bound = right_broadcastable_dims.empty() ? broadcast_shape.size() :
right_broadcastable_dims.back();
for (size_t i = left_broadcastable_dims.back() + 1; i < right_bound; ++i) {
std::vector<size_t> broadcast_offsets(broadcast_shape.size(), 0);
for (int i = broadcast_shape.size() - 2; i >= 0; --i) {
if (broadcast_shape[i] == 1) {
broadcast_offsets[i] = memory_offsets[i];
} else {
broadcast_offsets[i] = std::accumulate(broadcast_offsets.begin() + i,
broadcast_offsets.begin() + right_bound, 0,
broadcast_offsets.end(), 0,
std::plus<size_t>());
}
}
if (broadcast_shape.size() > 1 && broadcast_shape.back() == 1) {
broadcast_offsets[broadcast_offsets.size() - 1] = 1;
}
return broadcast_offsets;
}

@@ -100,33 +78,41 @@ namespace ngraph {

template<typename T>
void fake_quantize(const T *arg,
const T *in_low,
const T *in_high,
const T *out_low,
const T *out_high,
T *out,
T *in_low,
T *in_high,
T *out_low,
T *out_high,
Shape &arg_shape,
Shape &in_low_shape,
Shape &in_high_shape,
Shape &out_low_shape,
Shape &out_high_shape,
const Shape &arg_shape,
const Shape &_in_low_shape,
const Shape &_in_high_shape,
const Shape &_out_low_shape,
const Shape &_out_high_shape,
size_t levels
) {
Shape in_low_shape(_in_low_shape);
Shape in_high_shape(_in_high_shape);
Shape out_low_shape(_out_low_shape);
Shape out_high_shape(_out_high_shape);
std::vector<size_t> arg_memory_offsets(arg_shape.size(), 0);
for (size_t i = arg_shape.size() - 1; i >= 0; --i) {
arg_memory_offsets[i] = std::accumulate(arg_shape.begin() + i, arg_shape.end(), 1,
for (int i = arg_shape.size() - 2; i >= 0; i--) {
arg_memory_offsets[i] = std::accumulate(arg_shape.begin() + i + 1, arg_shape.end(), 1,
std::multiplies<size_t>());
}
align_shape_sizes(in_low_shape, arg_shape.size());
align_shape_sizes(in_high_shape, arg_shape.size());
align_shape_sizes(out_low_shape, arg_shape.size());
align_shape_sizes(out_high_shape, arg_shape.size());

std::vector<size_t> in_low_offsets, in_high_offsets, out_low_offsets;
std::vector<size_t> out_high_offsets = calc_broadcast_index_offset(arg_memory_offsets, out_high_shape);
bool in_low_trivial_broadcast, in_high_trivial_broadcast,
out_low_trivial_broadcast, out_high_trivial_broadcast = false;
bool in_low_aligned, in_high_aligned, out_low_aligned, out_high_aligned = false;
std::vector<size_t> in_low_offsets, in_high_offsets, out_low_offsets, out_high_offsets;
bool in_low_trivial_broadcast =false;
bool in_high_trivial_broadcast = false;
bool out_low_trivial_broadcast = false;
bool out_high_trivial_broadcast = false;
bool in_low_aligned = false;
bool in_high_aligned = false;
bool out_low_aligned = false;
bool out_high_aligned = false;

auto check_trivial_broadcast = [&arg_shape, &arg_memory_offsets](Shape &shape_to_check,
std::vector<size_t> &target_offsets,
@@ -148,7 +134,7 @@ namespace ngraph {
std::vector<size_t> current_dim(arg_shape.size(), 0);


auto get_value = [&current_dim](bool is_trivial_broadcast, bool is_aligned, T *data, size_t idx,
auto get_value = [&current_dim](bool is_trivial_broadcast, bool is_aligned, const T *data, size_t idx,
const std::vector<size_t> &offsets) {
T val;
if (is_aligned) {
@@ -163,20 +149,20 @@ namespace ngraph {
return val;
};
for (size_t i = 0; i < shape_size(arg_shape); ++i) {
T in_low_val = get_value(in_low_trivial_broadcast, in_low_aligned, in_low, in_low_offsets);
T in_high_val = get_value(in_high_trivial_broadcast, in_high_aligned, in_high, in_high_offsets);
T out_low_val = get_value(out_low_trivial_broadcast, out_low_aligned, out_low, out_low_offsets);
T out_high_val = get_value(out_high_trivial_broadcast, out_high_aligned, out_high, out_high_offsets);

T in_low_val = get_value(in_low_trivial_broadcast, in_low_aligned, in_low, i, in_low_offsets);
T in_high_val = get_value(in_high_trivial_broadcast, in_high_aligned, in_high, i, in_high_offsets);
T out_low_val = get_value(out_low_trivial_broadcast, out_low_aligned, out_low, i, out_low_offsets);
T out_high_val = get_value(out_high_trivial_broadcast, out_high_aligned, out_high, i, out_high_offsets);
if (arg[i] <= in_low_val) {
out[i] = std::roundf(out_low_val);
} else if (arg[i] > in_high[i]) {
out[i] = std::roundf(out_high_val);
out[i] = out_low_val;
} else if (arg[i] > in_high_val) {
out[i] = out_high_val;
} else {
const T value = std::roundf((arg[i] - in_low_val) / (in_high_val - in_low_val) * levels) /
levels * (out_high_val - out_low_val) + out_low_val;
out[i] = std::roundf(value);
out[i] = std::roundf((arg[i] - in_low_val) / (in_high_val - in_low_val) * (levels - 1)) /
(levels - 1) * (out_high_val - out_low_val) + out_low_val;
// out[i] = std::roundf(value);
}
increment_current_dim(current_dim, arg_shape, arg_shape.size() - 1);
}
}
}
Loading