class ngraph::pass::low_precision::AddTransformation¶
Overview¶
AddTransformation propagates dequantization subtraction from one input branch to another and propagates dequantization multiplication from the same branch through Add operation. More…
#include <add.hpp>
class AddTransformation: public ngraph::pass::low_precision::EltwiseBaseTransformation
{
public:
// construction
AddTransformation(const Params& params = Params());
// methods
OPENVINO_RTTI("AddTransformation", "0");
virtual bool transform(
TransformationContext& context,
ngraph::pattern::Matcher& m
);
virtual bool canBeTransformed(
const TransformationContext& context,
std::shared_ptr<Node> layer
) const;
};
Inherited Members¶
public:
// typedefs
typedef DiscreteTypeInfo type_info_t;
// classes
class Params;
class PrecisionDetails;
// methods
bool get_property(const PassPropertyMask& prop_mask) const;
void set_name(const std::string& name);
std::string get_name() const;
void set_callback(const param_callback& callback);
virtual void set_pass_config(const std::shared_ptr<PassConfig>& pass_config);
std::shared_ptr<PassConfig> get_pass_config();
bool m_transformation_callback(const std::shared_ptr<const Node>& node);
bool transformation_callback(const std::shared_ptr<const Node>& node);
virtual const type_info_t& get_type_info() const = 0;
OPENVINO_RTTI("ov::pass::MatcherPass");
MatcherPass& operator = (const MatcherPass&);
bool apply(std::shared_ptr<ov::Node> node);
template <typename T, class... Args>
std::shared_ptr<T> register_new_node(Args&&... args);
template <typename T>
std::shared_ptr<T> register_new_node(const std::shared_ptr<T>& node);
std::shared_ptr<ov::Node> register_new_node_(const std::shared_ptr<ov::Node>& node);
const std::vector<std::shared_ptr<ov::Node>>& get_new_nodes();
void clear_new_nodes();
std::shared_ptr<pattern::Matcher> get_matcher();
virtual bool transform(
TransformationContext& context,
ngraph::pattern::Matcher& m
) = 0;
void setContext(TransformationContext \* context);
void setUpdatePrecisions(const bool updatePrecisions);
void setDefaultPrecisions(const std::vector<ngraph::element::Type>& defaultPrecisions);
virtual bool canBeTransformed(
const TransformationContext& context,
std::shared_ptr<Node> layer
) const;
bool canSubtractBeHandled(
const std::shared_ptr<Node>& op,
const FakeQuantizeDequantization& dequantization
) const;
virtual bool isQuantized(
const std::shared_ptr<const Node>& layer,
const std::vector<ngraph::element::Type>& defaultPrecisions
) const;
virtual bool isPrecisionPreserved(std::shared_ptr<Node> layer) const = 0;
static bool canBeTransformedStatic(
const std::shared_ptr<Node>& layer,
const std::vector<ngraph::element::Type>& defaultPrecisions = precision_set::int8_support
);
static PrecisionDetails getPrecisionDetails(
const size_t quantizationLevels,
const std::vector<float>& outputLowValues,
const std::vector<float>& outputHighValues
);
static PrecisionDetails getPrecisionDetails(const QuantizationDetails& quantizationDetails);
static bool isAsymmetricQuantization(
const std::shared_ptr<const Node>& node,
const std::vector<ngraph::element::Type>& defaultPrecisions = precision_set::int8_support
);
static DataPrecision getDataPrecision(
const std::shared_ptr<Node>& layer,
const QuantizationDetails& quantizationDetails,
const std::vector<element::Type>& requiredPrecisions
);
virtual bool canBeTransformed(
const TransformationContext& context,
std::shared_ptr<Node> layer
) const;
virtual bool isPrecisionPreserved(std::shared_ptr<Node> layer) const;
static bool isBroadcasted(const PartialShape& shape);
Detailed Documentation¶
AddTransformation propagates dequantization subtraction from one input branch to another and propagates dequantization multiplication from the same branch through Add operation.
For more details about the transformation, refer to AddTransformation page in the Inference Engine Developer Guide.