From 618a835acc42e8bb54875744a85287efe6758a90 Mon Sep 17 00:00:00 2001 From: "yuan.xiong" Date: Tue, 3 Dec 2024 14:58:31 +0800 Subject: [PATCH] Change to skip mark reorder node (added for conv) in shape_of flow for quantized model Signed-off-by: yuan.xiong --- .../mark_shape_of_subgraphs.cpp | 33 ++++++++++++++++--- 1 file changed, 28 insertions(+), 5 deletions(-) diff --git a/src/plugins/intel_gpu/src/graph/graph_optimizer/mark_shape_of_subgraphs.cpp b/src/plugins/intel_gpu/src/graph/graph_optimizer/mark_shape_of_subgraphs.cpp index d7cfdc2ceb3278..a28ddb3d1b619a 100644 --- a/src/plugins/intel_gpu/src/graph/graph_optimizer/mark_shape_of_subgraphs.cpp +++ b/src/plugins/intel_gpu/src/graph/graph_optimizer/mark_shape_of_subgraphs.cpp @@ -2,7 +2,6 @@ // SPDX-License-Identifier: Apache-2.0 // -#include "broadcast_inst.h" #include "shape_of_inst.h" #include "read_value_inst.h" #include "reshape_inst.h" @@ -16,21 +15,45 @@ using namespace cldnn; +namespace { + bool conv_reorder_with_fake_quantize(program_node& node) { + if (!node.is_type()) { + return false; + } + + std::string dequantize_name = "DequantizationMultiply"; + for (auto& dependency : node.get_dependencies()) { + if (dependency.first->is_type()) { + auto& conv_deps = dependency.first->get_dependencies(); + + for (auto& conv_dep : conv_deps) { + if (conv_dep.first->id().find(dequantize_name) != std::string::npos) { + return true; + } + } + } + } + + return false; + } +} // namespace + void mark_shape_of_subgraphs::look_for_shape_of_subgraph(program_node& node) { if (node.is_type()) { mark_node(node); return; } + // skip mark_node for reorder node (after convolution node) for quantized model + if (conv_reorder_with_fake_quantize(node)) { + return; + } + // Check if all dependencies are constant or marked as a part of shape_of subgraph bool can_execute_in_subgraph = true; bool has_shape_of_subgraph_dep = false; for (auto& dependency : node.get_dependencies()) { if (dependency.first->is_in_shape_of_subgraph()) { - // skip mark_node for broadcast node if dependency node is shape_of - if (dependency.first->is_type() && node.is_type()) { - break; - } has_shape_of_subgraph_dep = true; } else if (!dependency.first->is_constant()) { can_execute_in_subgraph = false;