xref: /aosp_15_r20/external/ComputeLibrary/arm_compute/runtime/CL/CLTuningParams.h (revision c217d954acce2dbc11938adb493fc0abd69584f3)
1*c217d954SCole Faust /*
2*c217d954SCole Faust  * Copyright (c) 2020-2022 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_CLTUNING_PARAMS_H
25*c217d954SCole Faust #define ARM_COMPUTE_CLTUNING_PARAMS_H
26*c217d954SCole Faust 
27*c217d954SCole Faust #include "arm_compute/core/CL/OpenCL.h"
28*c217d954SCole Faust #include "arm_compute/runtime/CL/CLTunerTypes.h"
29*c217d954SCole Faust #include "support/StringSupport.h"
30*c217d954SCole Faust 
31*c217d954SCole Faust #include <ostream>
32*c217d954SCole Faust 
33*c217d954SCole Faust namespace arm_compute
34*c217d954SCole Faust {
35*c217d954SCole Faust /**< OpenCL tuner parameters */
36*c217d954SCole Faust class CLTuningParams
37*c217d954SCole Faust {
38*c217d954SCole Faust public:
CLTuningParams(const CLTuningParams & tuning_params)39*c217d954SCole Faust     CLTuningParams(const CLTuningParams &tuning_params)
40*c217d954SCole Faust         : _lws(tuning_params._lws), _wbsm(tuning_params._wbsm)
41*c217d954SCole Faust     {
42*c217d954SCole Faust     }
43*c217d954SCole Faust 
44*c217d954SCole Faust     CLTuningParams(unsigned int lws_x = 0, unsigned int lws_y = 0, unsigned int lws_z = 0, int wbsm = 0)
_lws(lws_x,lws_y,lws_z)45*c217d954SCole Faust         : _lws(lws_x, lws_y, lws_z), _wbsm(wbsm)
46*c217d954SCole Faust     {
47*c217d954SCole Faust     }
48*c217d954SCole Faust     CLTuningParams(cl::NDRange lws, cl_int wbsm = 0)
_lws(lws)49*c217d954SCole Faust         : _lws(lws), _wbsm(wbsm)
50*c217d954SCole Faust     {
51*c217d954SCole Faust     }
52*c217d954SCole Faust 
CLTuningParams(cl_int wbsm)53*c217d954SCole Faust     CLTuningParams(cl_int wbsm)
54*c217d954SCole Faust         : CLTuningParams(cl::NullRange, wbsm)
55*c217d954SCole Faust     {
56*c217d954SCole Faust     }
57*c217d954SCole Faust     CLTuningParams& operator=(const CLTuningParams &other)
58*c217d954SCole Faust     {
59*c217d954SCole Faust         _lws = other._lws;
60*c217d954SCole Faust         _wbsm = other._wbsm;
61*c217d954SCole Faust         return *this;
62*c217d954SCole Faust     }
63*c217d954SCole Faust 
set_lws(cl::NDRange lws)64*c217d954SCole Faust     void set_lws(cl::NDRange lws)
65*c217d954SCole Faust     {
66*c217d954SCole Faust         _lws = lws;
67*c217d954SCole Faust     }
68*c217d954SCole Faust 
get_lws()69*c217d954SCole Faust     cl::NDRange get_lws() const
70*c217d954SCole Faust     {
71*c217d954SCole Faust         return _lws;
72*c217d954SCole Faust     }
73*c217d954SCole Faust 
set_wbsm(cl_int wbsm)74*c217d954SCole Faust     void set_wbsm(cl_int wbsm)
75*c217d954SCole Faust     {
76*c217d954SCole Faust         _wbsm = wbsm;
77*c217d954SCole Faust     }
78*c217d954SCole Faust 
get_wbsm()79*c217d954SCole Faust     cl_int get_wbsm() const
80*c217d954SCole Faust     {
81*c217d954SCole Faust         return _wbsm;
82*c217d954SCole Faust     }
83*c217d954SCole Faust 
to_string(CLTuningInfo tuning_info)84*c217d954SCole Faust     std::string to_string(CLTuningInfo tuning_info)
85*c217d954SCole Faust     {
86*c217d954SCole Faust         std::string tuning_params_string = "";
87*c217d954SCole Faust         tuning_params_string += ";" + support::cpp11::to_string(_lws[0]) + ";" + support::cpp11::to_string(_lws[1]) + ";" + support::cpp11::to_string(_lws[2]);
88*c217d954SCole Faust         if(tuning_info.tune_wbsm)
89*c217d954SCole Faust         {
90*c217d954SCole Faust             tuning_params_string += ";" + support::cpp11::to_string(_wbsm);
91*c217d954SCole Faust         }
92*c217d954SCole Faust         return tuning_params_string;
93*c217d954SCole Faust     }
94*c217d954SCole Faust 
from_string(CLTuningInfo tuning_info,std::string tuning_params_string)95*c217d954SCole Faust     bool from_string(CLTuningInfo tuning_info, std::string tuning_params_string)
96*c217d954SCole Faust     {
97*c217d954SCole Faust         std::replace(tuning_params_string.begin(), tuning_params_string.end(), ';', ' ');
98*c217d954SCole Faust         std::vector<std::string> array;
99*c217d954SCole Faust         std::stringstream        ss(tuning_params_string);
100*c217d954SCole Faust         std::string              temp;
101*c217d954SCole Faust         while(ss >> temp)
102*c217d954SCole Faust         {
103*c217d954SCole Faust             array.push_back(temp);
104*c217d954SCole Faust         }
105*c217d954SCole Faust         // Read 3 values for lws
106*c217d954SCole Faust         if(array.size() < 3)
107*c217d954SCole Faust         {
108*c217d954SCole Faust             return false;
109*c217d954SCole Faust         }
110*c217d954SCole Faust         const unsigned int lws_0 = support::cpp11::stoi(array[0]);
111*c217d954SCole Faust         const unsigned int lws_1 = support::cpp11::stoi(array[1]);
112*c217d954SCole Faust         const unsigned int lws_2 = support::cpp11::stoi(array[2]);
113*c217d954SCole Faust         if(lws_0 == 0 && lws_1 == 0 && lws_2 == 0)
114*c217d954SCole Faust         {
115*c217d954SCole Faust             // If lws values are 0, cl::NullRange has to be used
116*c217d954SCole Faust             // otherwise the lws object will be badly created
117*c217d954SCole Faust             _lws = cl::NullRange;
118*c217d954SCole Faust         }
119*c217d954SCole Faust         else
120*c217d954SCole Faust         {
121*c217d954SCole Faust             _lws = cl::NDRange(lws_0, lws_1, lws_2);
122*c217d954SCole Faust         }
123*c217d954SCole Faust         array.erase(array.begin(), array.begin() + 3);
124*c217d954SCole Faust         if(tuning_info.tune_wbsm)
125*c217d954SCole Faust         {
126*c217d954SCole Faust             if(array.size() < 1)
127*c217d954SCole Faust             {
128*c217d954SCole Faust                 return false;
129*c217d954SCole Faust             }
130*c217d954SCole Faust             _wbsm = support::cpp11::stoi(array[0]);
131*c217d954SCole Faust             array.erase(array.begin());
132*c217d954SCole Faust         }
133*c217d954SCole Faust         return true;
134*c217d954SCole Faust     }
135*c217d954SCole Faust 
136*c217d954SCole Faust private:
137*c217d954SCole Faust     cl::NDRange _lws;
138*c217d954SCole Faust     cl_int      _wbsm;
139*c217d954SCole Faust };
140*c217d954SCole Faust } // namespace arm_compute
141*c217d954SCole Faust #endif /*ARM_COMPUTE_CLTUNING_PARAMS_H */
142