xref: /aosp_15_r20/external/ComputeLibrary/tests/datasets/LSTMLayerDataset.h (revision c217d954acce2dbc11938adb493fc0abd69584f3)
1*c217d954SCole Faust /*
2*c217d954SCole Faust  * Copyright (c) 2018 Arm Limited.
3*c217d954SCole Faust  *
4*c217d954SCole Faust  * SPDX-License-Identifier: MIT
5*c217d954SCole Faust  *
6*c217d954SCole Faust  * Permission is hereby granted, free of charge, to any person obtaining a copy
7*c217d954SCole Faust  * of this software and associated documentation files (the "Software"), to
8*c217d954SCole Faust  * deal in the Software without restriction, including without limitation the
9*c217d954SCole Faust  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10*c217d954SCole Faust  * sell copies of the Software, and to permit persons to whom the Software is
11*c217d954SCole Faust  * furnished to do so, subject to the following conditions:
12*c217d954SCole Faust  *
13*c217d954SCole Faust  * The above copyright notice and this permission notice shall be included in all
14*c217d954SCole Faust  * copies or substantial portions of the Software.
15*c217d954SCole Faust  *
16*c217d954SCole Faust  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*c217d954SCole Faust  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*c217d954SCole Faust  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19*c217d954SCole Faust  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*c217d954SCole Faust  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21*c217d954SCole Faust  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22*c217d954SCole Faust  * SOFTWARE.
23*c217d954SCole Faust  */
24*c217d954SCole Faust #ifndef ARM_COMPUTE_TEST_LSTM_LAYER_DATASET
25*c217d954SCole Faust #define ARM_COMPUTE_TEST_LSTM_LAYER_DATASET
26*c217d954SCole Faust 
27*c217d954SCole Faust #include "utils/TypePrinter.h"
28*c217d954SCole Faust 
29*c217d954SCole Faust #include "arm_compute/core/TensorShape.h"
30*c217d954SCole Faust #include "arm_compute/core/Types.h"
31*c217d954SCole Faust 
32*c217d954SCole Faust namespace arm_compute
33*c217d954SCole Faust {
34*c217d954SCole Faust namespace test
35*c217d954SCole Faust {
36*c217d954SCole Faust namespace datasets
37*c217d954SCole Faust {
38*c217d954SCole Faust class LSTMLayerDataset
39*c217d954SCole Faust {
40*c217d954SCole Faust public:
41*c217d954SCole Faust     using type = std::tuple<TensorShape, TensorShape, TensorShape, TensorShape, TensorShape, TensorShape, TensorShape, ActivationLayerInfo, float, float>;
42*c217d954SCole Faust 
43*c217d954SCole Faust     struct iterator
44*c217d954SCole Faust     {
iteratoriterator45*c217d954SCole Faust         iterator(std::vector<TensorShape>::const_iterator         src_it,
46*c217d954SCole Faust                  std::vector<TensorShape>::const_iterator         input_weights_it,
47*c217d954SCole Faust                  std::vector<TensorShape>::const_iterator         recurrent_weights_it,
48*c217d954SCole Faust                  std::vector<TensorShape>::const_iterator         cells_bias_it,
49*c217d954SCole Faust                  std::vector<TensorShape>::const_iterator         output_cell_it,
50*c217d954SCole Faust                  std::vector<TensorShape>::const_iterator         dst_it,
51*c217d954SCole Faust                  std::vector<TensorShape>::const_iterator         scratch_it,
52*c217d954SCole Faust                  std::vector<ActivationLayerInfo>::const_iterator infos_it,
53*c217d954SCole Faust                  std::vector<float>::const_iterator               cell_threshold_it,
54*c217d954SCole Faust                  std::vector<float>::const_iterator               projection_threshold_it)
55*c217d954SCole Faust             : _src_it{ std::move(src_it) },
56*c217d954SCole Faust               _input_weights_it{ std::move(input_weights_it) },
57*c217d954SCole Faust               _recurrent_weights_it{ std::move(recurrent_weights_it) },
58*c217d954SCole Faust               _cells_bias_it{ std::move(cells_bias_it) },
59*c217d954SCole Faust               _output_cell_it{ std::move(output_cell_it) },
60*c217d954SCole Faust               _dst_it{ std::move(dst_it) },
61*c217d954SCole Faust               _scratch_it{ std::move(scratch_it) },
62*c217d954SCole Faust               _infos_it{ std::move(infos_it) },
63*c217d954SCole Faust               _cell_threshold_it{ std::move(cell_threshold_it) },
64*c217d954SCole Faust               _projection_threshold_it{ std::move(projection_threshold_it) }
65*c217d954SCole Faust         {
66*c217d954SCole Faust         }
67*c217d954SCole Faust 
descriptioniterator68*c217d954SCole Faust         std::string description() const
69*c217d954SCole Faust         {
70*c217d954SCole Faust             std::stringstream description;
71*c217d954SCole Faust             description << "In=" << *_src_it << ":";
72*c217d954SCole Faust             description << "InputWeights=" << *_input_weights_it << ":";
73*c217d954SCole Faust             description << "RecurrentWeights=" << *_recurrent_weights_it << ":";
74*c217d954SCole Faust             description << "Biases=" << *_cells_bias_it << ":";
75*c217d954SCole Faust             description << "Scratch=" << *_scratch_it << ":";
76*c217d954SCole Faust             description << "Out=" << *_dst_it;
77*c217d954SCole Faust             return description.str();
78*c217d954SCole Faust         }
79*c217d954SCole Faust 
80*c217d954SCole Faust         LSTMLayerDataset::type operator*() const
81*c217d954SCole Faust         {
82*c217d954SCole Faust             return std::make_tuple(*_src_it, *_input_weights_it, *_recurrent_weights_it, *_cells_bias_it, *_output_cell_it, *_dst_it, *_scratch_it, *_infos_it, *_cell_threshold_it, *_projection_threshold_it);
83*c217d954SCole Faust         }
84*c217d954SCole Faust 
85*c217d954SCole Faust         iterator &operator++()
86*c217d954SCole Faust         {
87*c217d954SCole Faust             ++_src_it;
88*c217d954SCole Faust             ++_input_weights_it;
89*c217d954SCole Faust             ++_recurrent_weights_it;
90*c217d954SCole Faust             ++_cells_bias_it;
91*c217d954SCole Faust             ++_output_cell_it;
92*c217d954SCole Faust             ++_dst_it;
93*c217d954SCole Faust             ++_scratch_it;
94*c217d954SCole Faust             ++_infos_it;
95*c217d954SCole Faust             ++_cell_threshold_it;
96*c217d954SCole Faust             ++_projection_threshold_it;
97*c217d954SCole Faust 
98*c217d954SCole Faust             return *this;
99*c217d954SCole Faust         }
100*c217d954SCole Faust 
101*c217d954SCole Faust     private:
102*c217d954SCole Faust         std::vector<TensorShape>::const_iterator         _src_it;
103*c217d954SCole Faust         std::vector<TensorShape>::const_iterator         _input_weights_it;
104*c217d954SCole Faust         std::vector<TensorShape>::const_iterator         _recurrent_weights_it;
105*c217d954SCole Faust         std::vector<TensorShape>::const_iterator         _cells_bias_it;
106*c217d954SCole Faust         std::vector<TensorShape>::const_iterator         _output_cell_it;
107*c217d954SCole Faust         std::vector<TensorShape>::const_iterator         _dst_it;
108*c217d954SCole Faust         std::vector<TensorShape>::const_iterator         _scratch_it;
109*c217d954SCole Faust         std::vector<ActivationLayerInfo>::const_iterator _infos_it;
110*c217d954SCole Faust         std::vector<float>::const_iterator               _cell_threshold_it;
111*c217d954SCole Faust         std::vector<float>::const_iterator               _projection_threshold_it;
112*c217d954SCole Faust     };
113*c217d954SCole Faust 
begin()114*c217d954SCole Faust     iterator begin() const
115*c217d954SCole Faust     {
116*c217d954SCole Faust         return iterator(_src_shapes.begin(), _input_weights_shapes.begin(), _recurrent_weights_shapes.begin(), _cell_bias_shapes.begin(), _output_cell_shapes.begin(), _dst_shapes.begin(),
117*c217d954SCole Faust                         _scratch_shapes.begin(), _infos.begin(), _cell_threshold.begin(), _projection_threshold.begin());
118*c217d954SCole Faust     }
119*c217d954SCole Faust 
size()120*c217d954SCole Faust     int size() const
121*c217d954SCole Faust     {
122*c217d954SCole Faust         return std::min(_src_shapes.size(), std::min(_input_weights_shapes.size(), std::min(_recurrent_weights_shapes.size(), std::min(_cell_bias_shapes.size(), std::min(_output_cell_shapes.size(),
123*c217d954SCole Faust                                                                                             std::min(_dst_shapes.size(), std::min(_scratch_shapes.size(), std::min(_cell_threshold.size(), std::min(_projection_threshold.size(), _infos.size())))))))));
124*c217d954SCole Faust     }
125*c217d954SCole Faust 
add_config(TensorShape src,TensorShape input_weights,TensorShape recurrent_weights,TensorShape cell_bias_weights,TensorShape output_cell_state,TensorShape dst,TensorShape scratch,ActivationLayerInfo info,float cell_threshold,float projection_threshold)126*c217d954SCole Faust     void add_config(TensorShape src, TensorShape input_weights, TensorShape recurrent_weights, TensorShape cell_bias_weights, TensorShape output_cell_state, TensorShape dst, TensorShape scratch,
127*c217d954SCole Faust                     ActivationLayerInfo info, float cell_threshold, float projection_threshold)
128*c217d954SCole Faust     {
129*c217d954SCole Faust         _src_shapes.emplace_back(std::move(src));
130*c217d954SCole Faust         _input_weights_shapes.emplace_back(std::move(input_weights));
131*c217d954SCole Faust         _recurrent_weights_shapes.emplace_back(std::move(recurrent_weights));
132*c217d954SCole Faust         _cell_bias_shapes.emplace_back(std::move(cell_bias_weights));
133*c217d954SCole Faust         _output_cell_shapes.emplace_back(std::move(output_cell_state));
134*c217d954SCole Faust         _dst_shapes.emplace_back(std::move(dst));
135*c217d954SCole Faust         _scratch_shapes.emplace_back(std::move(scratch));
136*c217d954SCole Faust         _infos.emplace_back(std::move(info));
137*c217d954SCole Faust         _cell_threshold.emplace_back(std::move(cell_threshold));
138*c217d954SCole Faust         _projection_threshold.emplace_back(std::move(projection_threshold));
139*c217d954SCole Faust     }
140*c217d954SCole Faust 
141*c217d954SCole Faust protected:
142*c217d954SCole Faust     LSTMLayerDataset()                    = default;
143*c217d954SCole Faust     LSTMLayerDataset(LSTMLayerDataset &&) = default;
144*c217d954SCole Faust 
145*c217d954SCole Faust private:
146*c217d954SCole Faust     std::vector<TensorShape>         _src_shapes{};
147*c217d954SCole Faust     std::vector<TensorShape>         _input_weights_shapes{};
148*c217d954SCole Faust     std::vector<TensorShape>         _recurrent_weights_shapes{};
149*c217d954SCole Faust     std::vector<TensorShape>         _cell_bias_shapes{};
150*c217d954SCole Faust     std::vector<TensorShape>         _output_cell_shapes{};
151*c217d954SCole Faust     std::vector<TensorShape>         _dst_shapes{};
152*c217d954SCole Faust     std::vector<TensorShape>         _scratch_shapes{};
153*c217d954SCole Faust     std::vector<ActivationLayerInfo> _infos{};
154*c217d954SCole Faust     std::vector<float>               _cell_threshold{};
155*c217d954SCole Faust     std::vector<float>               _projection_threshold{};
156*c217d954SCole Faust };
157*c217d954SCole Faust 
158*c217d954SCole Faust class SmallLSTMLayerDataset final : public LSTMLayerDataset
159*c217d954SCole Faust {
160*c217d954SCole Faust public:
SmallLSTMLayerDataset()161*c217d954SCole Faust     SmallLSTMLayerDataset()
162*c217d954SCole Faust     {
163*c217d954SCole Faust         add_config(TensorShape(8U), TensorShape(8U, 16U), TensorShape(16U, 16U), TensorShape(16U), TensorShape(16U), TensorShape(16U), TensorShape(64U),
164*c217d954SCole Faust                    ActivationLayerInfo(ActivationLayerInfo::ActivationFunction::RELU), 0.05f, 0.93f);
165*c217d954SCole Faust         add_config(TensorShape(8U, 2U), TensorShape(8U, 16U), TensorShape(16U, 16U), TensorShape(16U), TensorShape(16U, 2U), TensorShape(16U, 2U), TensorShape(64U, 2U),
166*c217d954SCole Faust                    ActivationLayerInfo(ActivationLayerInfo::ActivationFunction::RELU), 0.05f, 0.93f);
167*c217d954SCole Faust         add_config(TensorShape(8U, 2U), TensorShape(8U, 16U), TensorShape(16U, 16U), TensorShape(16U), TensorShape(16U, 2U), TensorShape(16U, 2U), TensorShape(48U, 2U),
168*c217d954SCole Faust                    ActivationLayerInfo(ActivationLayerInfo::ActivationFunction::RELU), 0.05f, 0.93f);
169*c217d954SCole Faust     }
170*c217d954SCole Faust };
171*c217d954SCole Faust 
172*c217d954SCole Faust } // namespace datasets
173*c217d954SCole Faust } // namespace test
174*c217d954SCole Faust } // namespace arm_compute
175*c217d954SCole Faust #endif /* ARM_COMPUTE_TEST_LSTM_LAYER_DATASET */
176