blob: 90f306a175fc99cc8bb61700b49e55e93cb129f9 [file] [log] [blame]
James Conroyaba90cd2020-11-06 16:28:18 +00001//
Mike Kelly7cbe7812023-07-25 17:37:33 +01002// Copyright © 2020-2023 Arm Ltd and Contributors. All rights reserved.
James Conroyaba90cd2020-11-06 16:28:18 +00003// SPDX-License-Identifier: MIT
4//
5
6#include "RefLogicalUnaryWorkload.hpp"
7
8#include "Decoders.hpp"
9#include "ElementwiseFunction.hpp"
10#include "Encoders.hpp"
11#include "RefWorkloadUtils.hpp"
12
13#include <Profiling.hpp>
14
15#include <armnn/TypesUtils.hpp>
16
17namespace armnn
18{
19
20RefLogicalUnaryWorkload::RefLogicalUnaryWorkload(const ElementwiseUnaryQueueDescriptor& desc,
21 const WorkloadInfo& info)
Finn Williams73c547d2022-02-15 20:47:34 +000022 : RefBaseWorkload<ElementwiseUnaryQueueDescriptor>(desc, info)
James Conroyaba90cd2020-11-06 16:28:18 +000023{}
24
Finn Williamsb8181f72021-04-07 10:23:21 +010025void RefLogicalUnaryWorkload::Execute() const
James Conroyaba90cd2020-11-06 16:28:18 +000026{
Finn Williamsb8181f72021-04-07 10:23:21 +010027 Execute(m_Data.m_Inputs, m_Data.m_Outputs);
James Conroyaba90cd2020-11-06 16:28:18 +000028}
29
Matthew Sloyan2d213a72022-06-30 17:13:04 +010030void RefLogicalUnaryWorkload::ExecuteAsync(ExecutionData& executionData)
Finn Williamsb8181f72021-04-07 10:23:21 +010031{
Matthew Sloyan2d213a72022-06-30 17:13:04 +010032 WorkingMemDescriptor* workingMemDescriptor = static_cast<WorkingMemDescriptor*>(executionData.m_Data);
33 Execute(workingMemDescriptor->m_Inputs, workingMemDescriptor->m_Outputs);
Finn Williamsb8181f72021-04-07 10:23:21 +010034}
35
36void RefLogicalUnaryWorkload::Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const
James Conroyaba90cd2020-11-06 16:28:18 +000037{
Mike Kelly7cbe7812023-07-25 17:37:33 +010038 ARMNN_SCOPED_PROFILING_EVENT_REF_NAME_GUID("RefLogicalUnaryWorkload_Execute");
James Conroyaba90cd2020-11-06 16:28:18 +000039
Finn Williamsb8181f72021-04-07 10:23:21 +010040 const TensorInfo& inputInfo = GetTensorInfo(inputs[0]);
41 const TensorInfo& outputInfo = GetTensorInfo(outputs[0]);
James Conroyaba90cd2020-11-06 16:28:18 +000042
43 const TensorShape& inShape = inputInfo.GetShape();
44 const TensorShape& outShape = outputInfo.GetShape();
45
Finn Williamsb8181f72021-04-07 10:23:21 +010046 std::unique_ptr<Decoder<InType>> input = MakeDecoder<InType>(inputInfo, inputs[0]->Map());
47 std::unique_ptr<Encoder<OutType>> output = MakeEncoder<OutType>(outputInfo, outputs[0]->Map());
James Conroyaba90cd2020-11-06 16:28:18 +000048
49 using NotFunction = LogicalUnaryFunction<std::logical_not<bool>>;
50
51 switch (m_Data.m_Parameters.m_Operation)
52 {
53 case UnaryOperation::LogicalNot:
54 {
Finn Williamsb8181f72021-04-07 10:23:21 +010055 NotFunction(inShape, outShape, *input, *output);
James Conroyaba90cd2020-11-06 16:28:18 +000056 break;
57 }
58 default:
59 {
60 throw InvalidArgumentException(std::string("Unsupported Logical Unary operation") +
61 GetUnaryOperationAsCString(m_Data.m_Parameters.m_Operation), CHECK_LOCATION());
62 }
63 }
64}
65
66} // namespace armnn