Files
ANSLibs/OpenVINO/runtime/include/openvino/op/embeddingbag_packed.hpp

49 lines
2.0 KiB
C++

// Copyright (C) 2018-2025 Intel Corporation
// SPDX-License-Identifier: Apache-2.0
//
#pragma once
#include "openvino/core/axis_set.hpp"
#include "openvino/op/util/embeddingbag_packed_base.hpp"
#include "openvino/op/util/index_reduction.hpp"
namespace ov {
namespace op {
namespace v15 {
/// \brief Returns embeddings for given indices
/// \ingroup ov_ops_cpp_api
class OPENVINO_API EmbeddingBagPacked : public util::EmbeddingBagPackedBase {
public:
OPENVINO_OP("EmbeddingBagPacked", "opset15", util::EmbeddingBagPackedBase);
/// \brief Constructs a EmbeddingBagPacked operation.
EmbeddingBagPacked() = default;
/// \brief Constructs a EmbeddingBagPacked operation.
///
/// EmbeddingBagPacked constructs an output tensor by replacing every index in a
/// given
/// input tensor with a row (from the weights matrix) at that index
///
/// \param emb_table Tensor containing the embedding lookup table of the module of
/// shape [num_emb, emb_dim1, emb_dim2, ...] and of type T
/// \param indices Tensor of shape `[batch, indices_per_bag]` and of type *T_IND*.
/// Required.
/// \param per_sample_weights tensor of the same shape as indices and of type T.
/// Each value in this tensor are multiplied with each
/// value pooled from embedding table for each index. Optional.
/// \param reduction enum to select algorithm used to perform reduction of elements in bag. Optional.
EmbeddingBagPacked(const Output<Node>& emb_table,
const Output<Node>& indices,
const Output<Node>& per_sample_weights,
const Reduction& reduction = Reduction::SUM);
EmbeddingBagPacked(const Output<Node>& emb_table,
const Output<Node>& indices,
const Reduction& reduction = Reduction::SUM);
std::shared_ptr<Node> clone_with_new_inputs(const OutputVector& new_args) const override;
};
} // namespace v15
} // namespace op
} // namespace ov