1*89c4ff92SAndroid Build Coastguard Worker //
2*89c4ff92SAndroid Build Coastguard Worker // Copyright © 2021, 2023 Arm Ltd and Contributors. All rights reserved.
3*89c4ff92SAndroid Build Coastguard Worker // SPDX-License-Identifier: MIT
4*89c4ff92SAndroid Build Coastguard Worker //
5*89c4ff92SAndroid Build Coastguard Worker
6*89c4ff92SAndroid Build Coastguard Worker #include "PreluTestHelper.hpp"
7*89c4ff92SAndroid Build Coastguard Worker
8*89c4ff92SAndroid Build Coastguard Worker #include <armnn_delegate.hpp>
9*89c4ff92SAndroid Build Coastguard Worker
10*89c4ff92SAndroid Build Coastguard Worker #include <flatbuffers/flatbuffers.h>
11*89c4ff92SAndroid Build Coastguard Worker #include <tensorflow/lite/interpreter.h>
12*89c4ff92SAndroid Build Coastguard Worker #include <tensorflow/lite/kernels/register.h>
13*89c4ff92SAndroid Build Coastguard Worker #include <tensorflow/lite/model.h>
14*89c4ff92SAndroid Build Coastguard Worker #include <schema_generated.h>
15*89c4ff92SAndroid Build Coastguard Worker #include <tensorflow/lite/version.h>
16*89c4ff92SAndroid Build Coastguard Worker
17*89c4ff92SAndroid Build Coastguard Worker #include <doctest/doctest.h>
18*89c4ff92SAndroid Build Coastguard Worker
19*89c4ff92SAndroid Build Coastguard Worker namespace armnnDelegate {
20*89c4ff92SAndroid Build Coastguard Worker
PreluFloatSimpleTest(std::vector<armnn::BackendId> & backends,bool isAlphaConst,bool isDynamicOutput=false)21*89c4ff92SAndroid Build Coastguard Worker void PreluFloatSimpleTest(std::vector <armnn::BackendId>& backends, bool isAlphaConst, bool isDynamicOutput = false)
22*89c4ff92SAndroid Build Coastguard Worker {
23*89c4ff92SAndroid Build Coastguard Worker std::vector<int32_t> inputShape { 1, 2, 3 };
24*89c4ff92SAndroid Build Coastguard Worker std::vector<int32_t> alphaShape { 1 };
25*89c4ff92SAndroid Build Coastguard Worker std::vector<int32_t> outputShape { 1, 2, 3 };
26*89c4ff92SAndroid Build Coastguard Worker
27*89c4ff92SAndroid Build Coastguard Worker if (isDynamicOutput)
28*89c4ff92SAndroid Build Coastguard Worker {
29*89c4ff92SAndroid Build Coastguard Worker outputShape.clear();
30*89c4ff92SAndroid Build Coastguard Worker }
31*89c4ff92SAndroid Build Coastguard Worker
32*89c4ff92SAndroid Build Coastguard Worker std::vector<float> inputData = { -14.f, 2.f, 0.f, 1.f, -5.f, 14.f };
33*89c4ff92SAndroid Build Coastguard Worker std::vector<float> alphaData = { 0.5f };
34*89c4ff92SAndroid Build Coastguard Worker std::vector<float> expectedOutput = { -7.f, 2.f, 0.f, 1.f, -2.5f, 14.f };
35*89c4ff92SAndroid Build Coastguard Worker
36*89c4ff92SAndroid Build Coastguard Worker PreluTest(tflite::BuiltinOperator_PRELU,
37*89c4ff92SAndroid Build Coastguard Worker ::tflite::TensorType_FLOAT32,
38*89c4ff92SAndroid Build Coastguard Worker backends,
39*89c4ff92SAndroid Build Coastguard Worker inputShape,
40*89c4ff92SAndroid Build Coastguard Worker alphaShape,
41*89c4ff92SAndroid Build Coastguard Worker outputShape,
42*89c4ff92SAndroid Build Coastguard Worker inputData,
43*89c4ff92SAndroid Build Coastguard Worker alphaData,
44*89c4ff92SAndroid Build Coastguard Worker expectedOutput,
45*89c4ff92SAndroid Build Coastguard Worker isAlphaConst);
46*89c4ff92SAndroid Build Coastguard Worker }
47*89c4ff92SAndroid Build Coastguard Worker
48*89c4ff92SAndroid Build Coastguard Worker TEST_SUITE("Prelu_CpuRefTests")
49*89c4ff92SAndroid Build Coastguard Worker {
50*89c4ff92SAndroid Build Coastguard Worker
51*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleConstTest_CpuRef_Test")
52*89c4ff92SAndroid Build Coastguard Worker {
53*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::CpuRef };
54*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, true);
55*89c4ff92SAndroid Build Coastguard Worker }
56*89c4ff92SAndroid Build Coastguard Worker
57*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleTest_CpuRef_Test")
58*89c4ff92SAndroid Build Coastguard Worker {
59*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::CpuRef };
60*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, false);
61*89c4ff92SAndroid Build Coastguard Worker }
62*89c4ff92SAndroid Build Coastguard Worker
63*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleConstDynamicTest_CpuRef_Test")
64*89c4ff92SAndroid Build Coastguard Worker {
65*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::CpuRef };
66*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, true, true);
67*89c4ff92SAndroid Build Coastguard Worker }
68*89c4ff92SAndroid Build Coastguard Worker
69*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleDynamicTest_CpuRef_Test")
70*89c4ff92SAndroid Build Coastguard Worker {
71*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::CpuRef };
72*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, false, true);
73*89c4ff92SAndroid Build Coastguard Worker }
74*89c4ff92SAndroid Build Coastguard Worker
75*89c4ff92SAndroid Build Coastguard Worker } // TEST_SUITE("Prelu_CpuRefTests")
76*89c4ff92SAndroid Build Coastguard Worker
77*89c4ff92SAndroid Build Coastguard Worker TEST_SUITE("Prelu_CpuAccTests")
78*89c4ff92SAndroid Build Coastguard Worker {
79*89c4ff92SAndroid Build Coastguard Worker
80*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleConstTest_CpuAcc_Test")
81*89c4ff92SAndroid Build Coastguard Worker {
82*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::CpuAcc };
83*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, true);
84*89c4ff92SAndroid Build Coastguard Worker }
85*89c4ff92SAndroid Build Coastguard Worker
86*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleTest_CpuAcc_Test")
87*89c4ff92SAndroid Build Coastguard Worker {
88*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::CpuAcc };
89*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, false);
90*89c4ff92SAndroid Build Coastguard Worker }
91*89c4ff92SAndroid Build Coastguard Worker
92*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleConstDynamicTest_CpuAcc_Test")
93*89c4ff92SAndroid Build Coastguard Worker {
94*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::CpuAcc };
95*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, true, true);
96*89c4ff92SAndroid Build Coastguard Worker }
97*89c4ff92SAndroid Build Coastguard Worker
98*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleDynamicTest_CpuAcc_Test")
99*89c4ff92SAndroid Build Coastguard Worker {
100*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::CpuAcc };
101*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, false, true);
102*89c4ff92SAndroid Build Coastguard Worker }
103*89c4ff92SAndroid Build Coastguard Worker
104*89c4ff92SAndroid Build Coastguard Worker } // TEST_SUITE("Prelu_CpuAccTests")
105*89c4ff92SAndroid Build Coastguard Worker
106*89c4ff92SAndroid Build Coastguard Worker TEST_SUITE("Prelu_GpuAccTests")
107*89c4ff92SAndroid Build Coastguard Worker {
108*89c4ff92SAndroid Build Coastguard Worker
109*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleConstTest_GpuAcc_Test")
110*89c4ff92SAndroid Build Coastguard Worker {
111*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::GpuAcc };
112*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, true);
113*89c4ff92SAndroid Build Coastguard Worker }
114*89c4ff92SAndroid Build Coastguard Worker
115*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleTest_GpuAcc_Test")
116*89c4ff92SAndroid Build Coastguard Worker {
117*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::GpuAcc };
118*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, false);
119*89c4ff92SAndroid Build Coastguard Worker }
120*89c4ff92SAndroid Build Coastguard Worker
121*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleConstDynamicTest_GpuAcc_Test")
122*89c4ff92SAndroid Build Coastguard Worker {
123*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::GpuAcc };
124*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, true, true);
125*89c4ff92SAndroid Build Coastguard Worker }
126*89c4ff92SAndroid Build Coastguard Worker
127*89c4ff92SAndroid Build Coastguard Worker TEST_CASE ("PreluFp32SimpleDynamicTest_GpuAcc_Test")
128*89c4ff92SAndroid Build Coastguard Worker {
129*89c4ff92SAndroid Build Coastguard Worker std::vector<armnn::BackendId> backends = { armnn::Compute::GpuAcc };
130*89c4ff92SAndroid Build Coastguard Worker PreluFloatSimpleTest(backends, false, true);
131*89c4ff92SAndroid Build Coastguard Worker }
132*89c4ff92SAndroid Build Coastguard Worker
133*89c4ff92SAndroid Build Coastguard Worker } // TEST_SUITE("Prelu_GpuAccTests")
134*89c4ff92SAndroid Build Coastguard Worker
135*89c4ff92SAndroid Build Coastguard Worker }