17#include "../KernelGenerator.h"
18#include "../Validator.h"
25void Validator::visit(
const ir::operation::OneHot &) {
_supported =
true; }
27void KernelGenerator::visit(
const ir::operation::OneHot &node)
29 const auto output_idx{node.getOutputs().at(0)};
34 const auto depth = _ctx.
at(depth_idx).asScalar<int32_t>();
38 auto indices_tensor = _tensor_reg->getAclTensor(indices_idx);
39 auto onvalue_tensor = _tensor_reg->getAclTensor(onvalue_idx);
41 const size_t output_rank = _ctx.
at(output_idx).shape().rank();
42 int32_t axis = node.param().axis == -1 ? output_rank - 1 : node.param().axis;
51 std::unique_ptr<::arm_compute::IFunction> fn;
52 const auto &offvalue = _ctx.
at(offvalue_idx);
53 if (offvalue.isConstant())
55 fn = acl_common::generateLayer<arm_compute::CLOneHot>(
56 indices_tensor->handle(), onvalue_tensor->handle(),
output_tensor->handle(),
61 auto offvalue_tensor = _tensor_reg->getAclTensor(offvalue_idx);
62 fn = acl_common::generateLayer<arm_compute::CLOneHot>(
63 indices_tensor->handle(), onvalue_tensor->handle(), offvalue_tensor->handle(),
uint32_t value(void) const
std::unique_ptr< exec::IFunction > _return_fn
const Object & at(const Index &index) const
Get the object that is associated with the given index.
ARMComputeAxis ToARMComputeAxis(uint32_t rank, uint32_t axis)
void enableDimCorrection(IACLTensor *tensor)
arm_compute::PixelValue asPixelValue(const ir::Operand &operand)
std::unique_ptr< AclFunction > asAclFunction(std::unique_ptr<::arm_compute::IFunction > &&layer)
void disableDimCorrection(IACLTensor *tensor)