From a2f07c4aa9dffe9bf27545a825ab209f3768e63a Mon Sep 17 00:00:00 2001 From: Darrell Ross Date: Sun, 29 Jan 2017 17:03:20 -0800 Subject: [PATCH] Updates to Homework 3 code to allow forcing the use of hardcoded optimal values for work group sizes. --- hwk1/hwk1/OCLArgs.cpp | 2 +- hwk1/hwk1/homework3.cpp | 44 +++++++++++++++++++++++++++++++++++------ hwk1/hwk1/homework3.h | 5 +++++ 3 files changed, 44 insertions(+), 7 deletions(-) diff --git a/hwk1/hwk1/OCLArgs.cpp b/hwk1/hwk1/OCLArgs.cpp index a26eef0..2d533d9 100644 --- a/hwk1/hwk1/OCLArgs.cpp +++ b/hwk1/hwk1/OCLArgs.cpp @@ -364,7 +364,7 @@ int ocl_args_d_t::GetPlatformAndDeviceVersion(cl_platform_id platformId) // Execute the Kernel // @param[in] globalWorkSize size_t array of passed in constants to use -// @param[in] workSizeCount size of the globalWorkSize array +// @param[in] workSizeCount size of the globalWorkSize arraysize_t localWo cl_uint ocl_args_d_t::helper_ExecuteKernel(size_t *globalWorkSize, cl_uint workSizeCount, size_t* localWorkSize) { cl_int err = CL_SUCCESS; diff --git a/hwk1/hwk1/homework3.cpp b/hwk1/hwk1/homework3.cpp index 81eb695..22ad1d6 100644 --- a/hwk1/hwk1/homework3.cpp +++ b/hwk1/hwk1/homework3.cpp @@ -9,14 +9,17 @@ #include #include -/////////// HOMEWORK 2 +/////////// HOMEWORK 3 +bool USE_HARDCODED_LOCAL_WORKGROUP_SIZES = false; + namespace { const char* FILENAME = "homework3.cl"; + size_t* HARDCODED_LOCAL_WORKGROUP_SIZE = NULL; } HWK3Class::HWK3Class() - : GroupManager("Homework 2") + : GroupManager("Homework 3") { groups_ = GroupFactory(); @@ -31,6 +34,7 @@ std::map HWK3Class::GroupFactory() std::map pgs; ProblemGroup* InputControl = GroupManagerInputControlFactory(); + InputControl->problems_[InputControl->problems_.size()+1] = new Problem(&UseHardcodedLocalWorkgroupSizes, "Use Hardcoded Local Workgroup Sizes"); pgs[InputControl->GroupNum()] = InputControl; ProblemGroup* Homework3 = new ProblemGroup(1, "Homework 3"); @@ -44,6 +48,15 @@ std::map HWK3Class::GroupFactory() return pgs; } +///// Local Setting ///// +int UseHardcodedLocalWorkgroupSizes(ResultsStruct* results) +{ + std::cout << "Enter 1 to use hard coded work group sizes (currently " << USE_HARDCODED_LOCAL_WORKGROUP_SIZES << "): "; + unsigned int i = (unsigned int)USE_HARDCODED_LOCAL_WORKGROUP_SIZES; + std::cin >> i; + USE_HARDCODED_LOCAL_WORKGROUP_SIZES = (i == 1); + return 0; +} ////////////////// MATRIX POWER ///////////////// // Since MatrixPower and MatrixPower_Manual use identical input types, I use the exact same function call and just vary the KernelName @@ -101,8 +114,7 @@ int exCL_MatrixPower_Helper(ResultsStruct* results, const std::string& KernelNam ProfilerStruct profiler; profiler.Start(); size_t globalWorkSize[2] = { arrayWidth, arrayHeight }; -// size_t localWorkSize[2] = { 8, 4 }; - if (CL_SUCCESS != ocl.ExecuteKernel(globalWorkSize, 2)) + if (CL_SUCCESS != ocl.ExecuteKernel(globalWorkSize, 2, HARDCODED_LOCAL_WORKGROUP_SIZE)) return -1; profiler.Stop(); float runTime = profiler.Log(); @@ -163,11 +175,25 @@ int exCL_MatrixPower_Helper(ResultsStruct* results, const std::string& KernelNam int exCL_MatrixPower(ResultsStruct* results) { + // hard code work group size after finding optimal solution with KDF Sessions + // pow: {8,4} + size_t localWorkSize[2] = { 8, 4 }; + if (USE_HARDCODED_LOCAL_WORKGROUP_SIZES) + HARDCODED_LOCAL_WORKGROUP_SIZE = localWorkSize; + else + HARDCODED_LOCAL_WORKGROUP_SIZE = NULL; return exCL_MatrixPower_Helper(results, "elementwiseMatrixPower"); } int exCL_MatrixPower_Manual(ResultsStruct* results) { + // hard code work group size after finding optimal solution with KDF Sessions + // manual: {128,2,0} + size_t localWorkSize[2] = { 128, 2 }; + if (USE_HARDCODED_LOCAL_WORKGROUP_SIZES) + HARDCODED_LOCAL_WORKGROUP_SIZE = localWorkSize; + else + HARDCODED_LOCAL_WORKGROUP_SIZE = NULL; return exCL_MatrixPower_Helper(results, "elementwiseMatrixPower_Manual"); } @@ -259,8 +285,14 @@ int exCL_ProgressiveArraySum(ResultsStruct* results) ProfilerStruct profiler; profiler.Start(); size_t globalWorkSize[1] = { arrayWidth }; -// size_t localWorkSize[1] = { 256 }; - if (CL_SUCCESS != ocl.ExecuteKernel(globalWorkSize, 1)) + // hard code work group size after finding optimal solution with KDF Sessions + // progressive array sum: {64} + size_t localWorkSize[1] = { 64 }; + if (USE_HARDCODED_LOCAL_WORKGROUP_SIZES) + HARDCODED_LOCAL_WORKGROUP_SIZE = localWorkSize; + else + HARDCODED_LOCAL_WORKGROUP_SIZE = NULL; + if (CL_SUCCESS != ocl.ExecuteKernel(globalWorkSize, 1, HARDCODED_LOCAL_WORKGROUP_SIZE)) return -1; profiler.Stop(); float runTime = profiler.Log(); diff --git a/hwk1/hwk1/homework3.h b/hwk1/hwk1/homework3.h index c48405e..7573934 100644 --- a/hwk1/hwk1/homework3.h +++ b/hwk1/hwk1/homework3.h @@ -1,6 +1,8 @@ #pragma once #include "ProblemGroups.h" +extern bool USE_HARDCODED_LOCAL_WORKGROUP_SIZES; + class HWK3Class : public GroupManager { public: @@ -12,6 +14,9 @@ class HWK3Class : public GroupManager }; +///// Local Setting ///// +int UseHardcodedLocalWorkgroupSizes(ResultsStruct* results); + ///// MATRIX POWER ////// int exCL_MatrixPower_Helper(ResultsStruct* results, const std::string& KernelName); int exCL_MatrixPower(ResultsStruct* results);