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

Update MarkDequantization transformation #27406

Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
dffcd9b
Make KeepConstPrecision attribute copyable
itikhono Nov 5, 2024
1a50a8d
Merge remote-tracking branch 'upstream/master' into itikhono/bug_fix/…
itikhono Nov 8, 2024
52e2e30
Merge remote-tracking branch 'upstream/master' into itikhono/bug_fix/…
itikhono Nov 12, 2024
2143e7e
Merge remote-tracking branch 'upstream/master' into itikhono/bug_fix/…
itikhono Nov 13, 2024
7555a9e
update mark dequantization transformation
itikhono Nov 13, 2024
5f237eb
add transformation callback
itikhono Nov 13, 2024
0dfabd9
try to fix a warning
itikhono Nov 13, 2024
865fd4c
revert KeepConstPrecision change
itikhono Nov 13, 2024
7cd9c24
Merge branch 'itikhono/bug_fix/keep_const_precision_attr' of https://…
itikhono Nov 14, 2024
fa6b0ec
align the current behavior with the previous implementation
itikhono Nov 15, 2024
1202ab2
fix tests
itikhono Nov 15, 2024
c93f7a7
add precision check
itikhono Nov 17, 2024
e7d7c5f
Merge branch 'master' into itikhono/bug_fix/keep_const_precision_attr
itikhono Nov 17, 2024
189153f
fix issue on gpu, docs, refactoring
itikhono Nov 19, 2024
48b5694
Merge branch 'master' into itikhono/bug_fix/keep_const_precision_attr
itikhono Nov 19, 2024
06f1c22
remove the dq model pass, leave the separate matchers only
itikhono Nov 19, 2024
1c7a72e
fix Opattern::op::Or logic
itikhono Nov 21, 2024
416d610
fixed the marking on gpu
itikhono Nov 21, 2024
7f2e1de
Merge branch 'master' into itikhono/bug_fix/keep_const_precision_attr
itikhono Nov 26, 2024
553f2b6
resolve review comments
itikhono Nov 30, 2024
570e84f
Merge branch 'itikhono/bug_fix/keep_const_precision_attr' of
itikhono Nov 30, 2024
6853a63
Merge branch 'master' into itikhono/bug_fix/keep_const_precision_attr
itikhono Nov 30, 2024
d2786b7
Merge branch 'master' into itikhono/bug_fix/keep_const_precision_attr
itikhono Dec 11, 2024
3944b9e
Merge branch 'master' into itikhono/bug_fix/keep_const_precision_attr
itikhono Dec 13, 2024
6d6749b
codestyle
itikhono Dec 13, 2024
ad10166
Merge branch 'master' into itikhono/bug_fix/keep_const_precision_attr
itikhono Dec 16, 2024
b4b3513
fix a warning
itikhono Dec 16, 2024
1fc379b
Merge branch 'itikhono/bug_fix/keep_const_precision_attr' of https://…
itikhono Dec 16, 2024
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
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,41 @@
#include "transformations/rt_info/keep_const_precision.hpp"

#include "common_test_utils/ov_test_utils.hpp"
#include "transformations/convert_precision.hpp"

using namespace ov;

TEST_F(TransformationTestsF, KeepConstPrecision) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we also compare nodes' rt_info in this test?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

done
but it looks like the rt_info comparison doesn't work, the same with other tests, I will double check

{
auto lp_const = std::make_shared<opset10::Constant>(element::u4, Shape{27}, 1);

const auto target_shape = std::make_shared<opset10::Constant>(ov::element::i64, ov::Shape{3}, 3);
auto reshape = std::make_shared<opset10::Reshape>(lp_const, target_shape, false);

auto second_convert = std::make_shared<opset10::Convert>(reshape, element::f32);
auto zero_point = opset10::Constant::create(element::f32, Shape{}, {127});
auto subtract = std::make_shared<opset10::Subtract>(second_convert, zero_point);
auto scale = opset10::Constant::create(element::f32, Shape{}, {0.2});
auto multiply = std::make_shared<opset10::Multiply>(subtract, scale);
auto stub_op = std::make_shared<opset10::Relu>(multiply);
model = std::make_shared<Model>(stub_op, ParameterVector{});
}
manager.register_pass<pass::MarkDequantizationSubgraph>(element::TypeVector{element::u4});
manager.register_pass<pass::ConstantFolding>();
manager.register_pass<pass::ConvertPrecision>(ov::element::u4, ov::element::u8, type_to_fuse_map{}, false, false);
manager.register_pass<pass::Serialize>("keep_const_precision.xml", "keep_const_precision.bin");
itikhono marked this conversation as resolved.
Show resolved Hide resolved
{
auto lp_const = std::make_shared<opset10::Constant>(element::u4, Shape{3, 3, 3}, 1);
auto second_convert = std::make_shared<opset10::Convert>(lp_const, element::f32);
auto zero_point = opset10::Constant::create(element::f32, Shape{}, {127});
auto subtract = std::make_shared<opset10::Subtract>(second_convert, zero_point);
auto scale = opset10::Constant::create(element::f32, Shape{}, {0.2});
auto multiply = std::make_shared<opset10::Multiply>(subtract, scale);
auto stub_op = std::make_shared<opset10::Relu>(multiply);
model_ref = std::make_shared<Model>(stub_op, ParameterVector{});
}
}

TEST_F(TransformationTestsF, MarkDequantizationSubgraphTransformation) {
// Input graph:
//
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,10 +26,6 @@ class TRANSFORMATIONS_API KeepConstPrecision : public RuntimeAttribute {
OPENVINO_RTTI("keep_const_precision", "0");

KeepConstPrecision() = default;

bool is_copyable() const override {
return false;
}
v-Golubev marked this conversation as resolved.
Show resolved Hide resolved
};

} // namespace ov
Loading