aboutsummaryrefslogtreecommitdiff
path: root/src/runtime/CL/CLTuner.cpp
diff options
context:
space:
mode:
authorAnthony Barbier <anthony.barbier@arm.com>2018-02-28 13:47:58 +0000
committerAnthony Barbier <anthony.barbier@arm.com>2018-11-02 16:48:33 +0000
commit8b81195919eaab90a803fabae57ca05136e9430e (patch)
tree325798fd319f8091b18458127d3843b88c4d40af /src/runtime/CL/CLTuner.cpp
parentfadfc6d6737716891f543f61a529e984da9b0a8b (diff)
downloadComputeLibrary-8b81195919eaab90a803fabae57ca05136e9430e.tar.gz
COMPMID-978 Load/Store tuning data from file (Part2)
Change-Id: I1819f42c0e456673543b267d51f730b6e80a0ad9 Reviewed-on: https://eu-gerrit-1.euhpc.arm.com/122629 Reviewed-by: Robert Hughes <robert.hughes@arm.com> Tested-by: Jenkins <bsgcomp@arm.com> Reviewed-by: Georgios Pinitas <georgios.pinitas@arm.com>
Diffstat (limited to 'src/runtime/CL/CLTuner.cpp')
-rw-r--r--src/runtime/CL/CLTuner.cpp45
1 files changed, 16 insertions, 29 deletions
diff --git a/src/runtime/CL/CLTuner.cpp b/src/runtime/CL/CLTuner.cpp
index 29ddbea460..9fb9d1b396 100644
--- a/src/runtime/CL/CLTuner.cpp
+++ b/src/runtime/CL/CLTuner.cpp
@@ -99,6 +99,10 @@ void CLTuner::set_tune_new_kernels(bool tune_new_kernels)
{
_tune_new_kernels = tune_new_kernels;
}
+bool CLTuner::tune_new_kernels() const
+{
+ return _tune_new_kernels;
+}
void CLTuner::tune_kernel(ICLKernel &kernel)
{
@@ -246,15 +250,16 @@ void CLTuner::import_lws_table(const std::unordered_map<std::string, cl::NDRange
_lws_table = lws_table;
}
-const std::unordered_map<std::string, cl::NDRange> &CLTuner::export_lws_table() const
+const std::unordered_map<std::string, cl::NDRange> &CLTuner::lws_table() const
{
return _lws_table;
}
-CLFileTuner::CLFileTuner(std::string file_path, bool update_file, bool tune_new_kernels)
- : CLTuner(tune_new_kernels), filename(std::move(file_path)), _update_file(update_file)
+void CLTuner::load_from_file(const std::string &filename)
{
- std::ifstream fs(filename);
+ std::ifstream fs;
+ fs.exceptions(std::ifstream::failbit | std::ifstream::badbit);
+ fs.open(filename, std::ios::in);
if(fs.is_open())
{
std::string line;
@@ -264,24 +269,18 @@ CLFileTuner::CLFileTuner(std::string file_path, bool update_file, bool tune_new_
std::string token;
if(!std::getline(ss, token, ';'))
{
- continue;
+ ARM_COMPUTE_ERROR("Malformed row '%s' (Should be of the form 'kernel_id;lws[0];lws[1];lws[2]')", ss.str().c_str());
}
std::string kernel_id = token;
cl::NDRange lws(1, 1, 1);
- bool lws_is_valid = true;
for(int i = 0; i < 3; i++)
{
if(std::getline(ss, token, ';').fail())
{
- lws_is_valid = false;
- break;
+ ARM_COMPUTE_ERROR("Malformed row '%s' (Should be of the form 'kernel_id;lws[0];lws[1];lws[2]')", ss.str().c_str());
}
lws.get()[i] = support::cpp11::stoi(token);
}
- if(!lws_is_valid)
- {
- continue; // Skip this kernel
- }
// If all dimensions are 0: reset to NullRange (i.e nullptr)
if(lws[0] == 0 && lws[1] == 0 && lws[2] == 0)
@@ -294,26 +293,14 @@ CLFileTuner::CLFileTuner(std::string file_path, bool update_file, bool tune_new_
}
}
-void CLFileTuner::save_to_file() const
+void CLTuner::save_to_file(const std::string &filename) const
{
- const std::unordered_map<std::string, cl::NDRange> &table = export_lws_table();
- std::ofstream fs(filename);
- for(auto kernel_data : table)
+ std::ofstream fs;
+ fs.exceptions(std::ifstream::failbit | std::ifstream::badbit);
+ fs.open(filename, std::ios::out);
+ for(auto kernel_data : _lws_table)
{
fs << kernel_data.first << ";" << kernel_data.second[0] << ";" << kernel_data.second[1] << ";" << kernel_data.second[2] << std::endl;
}
fs.close();
}
-
-CLFileTuner::~CLFileTuner()
-{
- if(_update_file)
- {
- save_to_file();
- }
-}
-
-void CLFileTuner::set_update_file(bool update_file)
-{
- _update_file = update_file;
-}