xref: /aosp_15_r20/external/ComputeLibrary/tests/datasets/ThresholdDataset.h (revision c217d954acce2dbc11938adb493fc0abd69584f3)
1*c217d954SCole Faust /*
2*c217d954SCole Faust  * Copyright (c) 2017 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_THRESHOLD_DATASET
25*c217d954SCole Faust #define ARM_COMPUTE_TEST_THRESHOLD_DATASET
26*c217d954SCole Faust 
27*c217d954SCole Faust #include "utils/TypePrinter.h"
28*c217d954SCole Faust 
29*c217d954SCole Faust #include "arm_compute/core/Types.h"
30*c217d954SCole Faust 
31*c217d954SCole Faust namespace arm_compute
32*c217d954SCole Faust {
33*c217d954SCole Faust namespace test
34*c217d954SCole Faust {
35*c217d954SCole Faust namespace datasets
36*c217d954SCole Faust {
37*c217d954SCole Faust class ThresholdDataset
38*c217d954SCole Faust {
39*c217d954SCole Faust public:
40*c217d954SCole Faust     using type = std::tuple<uint8_t, uint8_t, uint8_t, ThresholdType, uint8_t>;
41*c217d954SCole Faust 
42*c217d954SCole Faust     struct iterator
43*c217d954SCole Faust     {
iteratoriterator44*c217d954SCole Faust         iterator(std::vector<uint8_t>::const_iterator       threshold_it,
45*c217d954SCole Faust                  std::vector<uint8_t>::const_iterator       false_value_it,
46*c217d954SCole Faust                  std::vector<uint8_t>::const_iterator       true_value_it,
47*c217d954SCole Faust                  std::vector<ThresholdType>::const_iterator type_it,
48*c217d954SCole Faust                  std::vector<uint8_t>::const_iterator       upper_it)
49*c217d954SCole Faust             : _threshold_it{ std::move(threshold_it) },
50*c217d954SCole Faust               _false_value_it{ std::move(false_value_it) },
51*c217d954SCole Faust               _true_value_it{ std::move(true_value_it) },
52*c217d954SCole Faust               _type_it{ std::move(type_it) },
53*c217d954SCole Faust               _upper_it{ std::move(upper_it) }
54*c217d954SCole Faust         {
55*c217d954SCole Faust         }
56*c217d954SCole Faust 
descriptioniterator57*c217d954SCole Faust         std::string description() const
58*c217d954SCole Faust         {
59*c217d954SCole Faust             std::stringstream description;
60*c217d954SCole Faust             description << "Threshold=" << static_cast<unsigned>(*_threshold_it) << ":";
61*c217d954SCole Faust             description << "FalseValue_=" << std::boolalpha << static_cast<unsigned>(*_false_value_it) << ":";
62*c217d954SCole Faust             description << "TrueValue=" << std::boolalpha << static_cast<unsigned>(*_true_value_it) << ":";
63*c217d954SCole Faust             description << "Type=" << ((*_type_it == ThresholdType::BINARY) ? "binary" : "range") << ":";
64*c217d954SCole Faust             description << "Upper=" << static_cast<unsigned>(*_upper_it);
65*c217d954SCole Faust 
66*c217d954SCole Faust             return description.str();
67*c217d954SCole Faust         }
68*c217d954SCole Faust 
69*c217d954SCole Faust         ThresholdDataset::type operator*() const
70*c217d954SCole Faust         {
71*c217d954SCole Faust             return std::make_tuple(*_threshold_it, *_false_value_it, *_true_value_it, *_type_it, *_upper_it);
72*c217d954SCole Faust         }
73*c217d954SCole Faust 
74*c217d954SCole Faust         iterator &operator++()
75*c217d954SCole Faust         {
76*c217d954SCole Faust             ++_threshold_it;
77*c217d954SCole Faust             ++_false_value_it;
78*c217d954SCole Faust             ++_true_value_it;
79*c217d954SCole Faust             ++_type_it;
80*c217d954SCole Faust             ++_upper_it;
81*c217d954SCole Faust 
82*c217d954SCole Faust             return *this;
83*c217d954SCole Faust         }
84*c217d954SCole Faust 
85*c217d954SCole Faust     private:
86*c217d954SCole Faust         std::vector<uint8_t>::const_iterator       _threshold_it;
87*c217d954SCole Faust         std::vector<uint8_t>::const_iterator       _false_value_it;
88*c217d954SCole Faust         std::vector<uint8_t>::const_iterator       _true_value_it;
89*c217d954SCole Faust         std::vector<ThresholdType>::const_iterator _type_it;
90*c217d954SCole Faust         std::vector<uint8_t>::const_iterator       _upper_it;
91*c217d954SCole Faust     };
92*c217d954SCole Faust 
begin()93*c217d954SCole Faust     iterator begin() const
94*c217d954SCole Faust     {
95*c217d954SCole Faust         return iterator(_thresholds.begin(), _false_values.begin(), _true_values.begin(), _types.begin(), _uppers.begin());
96*c217d954SCole Faust     }
97*c217d954SCole Faust 
size()98*c217d954SCole Faust     int size() const
99*c217d954SCole Faust     {
100*c217d954SCole Faust         return std::min(_thresholds.size(), std::min(_false_values.size(), std::min(_true_values.size(), std::min(_types.size(), _uppers.size()))));
101*c217d954SCole Faust     }
102*c217d954SCole Faust 
add_config(uint8_t threshold,uint8_t false_value,uint8_t true_value,ThresholdType threshold_type,uint8_t upper)103*c217d954SCole Faust     void add_config(uint8_t threshold, uint8_t false_value, uint8_t true_value, ThresholdType threshold_type, uint8_t upper)
104*c217d954SCole Faust     {
105*c217d954SCole Faust         _thresholds.emplace_back(std::move(threshold));
106*c217d954SCole Faust         _false_values.emplace_back(std::move(false_value));
107*c217d954SCole Faust         _true_values.emplace_back(std::move(true_value));
108*c217d954SCole Faust         _types.emplace_back(std::move(threshold_type));
109*c217d954SCole Faust         _uppers.emplace_back(std::move(upper));
110*c217d954SCole Faust     }
111*c217d954SCole Faust 
112*c217d954SCole Faust protected:
113*c217d954SCole Faust     ThresholdDataset()                    = default;
114*c217d954SCole Faust     ThresholdDataset(ThresholdDataset &&) = default;
115*c217d954SCole Faust 
116*c217d954SCole Faust private:
117*c217d954SCole Faust     std::vector<uint8_t>       _thresholds{};
118*c217d954SCole Faust     std::vector<uint8_t>       _false_values{};
119*c217d954SCole Faust     std::vector<uint8_t>       _true_values{};
120*c217d954SCole Faust     std::vector<ThresholdType> _types{};
121*c217d954SCole Faust     std::vector<uint8_t>       _uppers{};
122*c217d954SCole Faust };
123*c217d954SCole Faust 
124*c217d954SCole Faust class MixedThresholdDataset final : public ThresholdDataset
125*c217d954SCole Faust {
126*c217d954SCole Faust public:
MixedThresholdDataset()127*c217d954SCole Faust     MixedThresholdDataset()
128*c217d954SCole Faust     {
129*c217d954SCole Faust         add_config(10U, 25U, 3U, ThresholdType::BINARY, 0U);
130*c217d954SCole Faust         add_config(20U, 1U, 0U, ThresholdType::BINARY, 0U);
131*c217d954SCole Faust         add_config(30U, 1U, 0U, ThresholdType::RANGE, 100U);
132*c217d954SCole Faust         add_config(100U, 1U, 0U, ThresholdType::RANGE, 200U);
133*c217d954SCole Faust     }
134*c217d954SCole Faust };
135*c217d954SCole Faust } // namespace datasets
136*c217d954SCole Faust } // namespace test
137*c217d954SCole Faust } // namespace arm_compute
138*c217d954SCole Faust #endif /* ARM_COMPUTE_TEST_THRESHOLD_DATASET */
139