diff options
author | Cedric Nugteren <web@cedricnugteren.nl> | 2017-08-30 19:17:17 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-08-30 19:17:17 +0200 |
commit | 6e95752054edc6bf49430ec40355d2aea691c32a (patch) | |
tree | d0027323a9f45ea4fd2a82bb029f5ba9d58adf44 /test/performance | |
parent | da28cc5e9315729bc7f9078f1ae43ac68740ec87 (diff) | |
parent | 161fd8514d75d61045e1683e091f1851656c28da (diff) |
Merge pull request #184 from CNugteren/im_to_col
im2col
Diffstat (limited to 'test/performance')
-rw-r--r-- | test/performance/client.cpp | 26 | ||||
-rw-r--r-- | test/performance/routines/levelx/xim2col.cpp | 33 |
2 files changed, 58 insertions, 1 deletions
diff --git a/test/performance/client.cpp b/test/performance/client.cpp index dc98ffbd..076481f7 100644 --- a/test/performance/client.cpp +++ b/test/performance/client.cpp @@ -93,7 +93,7 @@ Arguments<U> Client<T,U>::ParseArguments(int argc, char *argv[], const size_t le if (o == kArgAPOffset) { args.ap_offset= GetArgument(command_line_args, help, kArgAPOffset, size_t{0}); } // Scalar result arguments - if (o == kArgDotOffset) { args.dot_offset = GetArgument(command_line_args, help, kArgDotOffset, size_t{0}); } + if (o == kArgDotOffset) { args.dot_offset = GetArgument(command_line_args, help, kArgDotOffset, size_t{0}); } if (o == kArgNrm2Offset) { args.nrm2_offset = GetArgument(command_line_args, help, kArgNrm2Offset, size_t{0}); } if (o == kArgAsumOffset) { args.asum_offset = GetArgument(command_line_args, help, kArgAsumOffset, size_t{0}); } if (o == kArgImaxOffset) { args.imax_offset = GetArgument(command_line_args, help, kArgImaxOffset, size_t{0}); } @@ -104,6 +104,19 @@ Arguments<U> Client<T,U>::ParseArguments(int argc, char *argv[], const size_t le // Scalar values if (o == kArgAlpha) { args.alpha = GetArgument(command_line_args, help, kArgAlpha, GetScalar<U>()); } if (o == kArgBeta) { args.beta = GetArgument(command_line_args, help, kArgBeta, GetScalar<U>()); } + + // Arguments for im2col + if (o == kArgChannels) { args.channels = GetArgument(command_line_args, help, kArgChannels, size_t{64}); } + if (o == kArgHeight) { args.height = GetArgument(command_line_args, help, kArgHeight, size_t{64}); } + if (o == kArgWidth) { args.width = GetArgument(command_line_args, help, kArgWidth, size_t{64}); } + if (o == kArgKernelH) { args.kernel_h = GetArgument(command_line_args, help, kArgKernelH, size_t{3}); } + if (o == kArgKernelW) { args.kernel_w = GetArgument(command_line_args, help, kArgKernelW, size_t{3}); } + if (o == kArgPadH) { args.pad_h = GetArgument(command_line_args, help, kArgPadH, size_t{0}); } + if (o == kArgPadW) { args.pad_w = GetArgument(command_line_args, help, kArgPadW, size_t{0}); } + if (o == kArgStrideH) { args.stride_h = GetArgument(command_line_args, help, kArgStrideH, size_t{1}); } + if (o == kArgStrideW) { args.stride_w = GetArgument(command_line_args, help, kArgStrideW, size_t{1}); } + if (o == kArgDilationH) { args.dilation_h = GetArgument(command_line_args, help, kArgDilationH, size_t{1}); } + if (o == kArgDilationW) { args.dilation_w = GetArgument(command_line_args, help, kArgDilationW, size_t{1}); } } // These are the options common to all routines @@ -379,6 +392,17 @@ void Client<T,U>::PrintTableRow(const Arguments<U>& args, else if (o == kArgAsumOffset){integers.push_back(args.asum_offset); } else if (o == kArgImaxOffset){integers.push_back(args.imax_offset); } else if (o == kArgBatchCount){integers.push_back(args.batch_count); } + else if (o == kArgChannels) {integers.push_back(args.channels); } + else if (o == kArgHeight) {integers.push_back(args.height); } + else if (o == kArgWidth) {integers.push_back(args.width); } + else if (o == kArgKernelH) {integers.push_back(args.kernel_h); } + else if (o == kArgKernelW) {integers.push_back(args.kernel_w); } + else if (o == kArgPadH) {integers.push_back(args.pad_h); } + else if (o == kArgPadW) {integers.push_back(args.pad_w); } + else if (o == kArgStrideH) {integers.push_back(args.stride_h); } + else if (o == kArgStrideW) {integers.push_back(args.stride_w); } + else if (o == kArgDilationH) {integers.push_back(args.dilation_h); } + else if (o == kArgDilationW) {integers.push_back(args.dilation_w); } } auto strings = std::vector<std::string>{}; for (auto &o: options_) { diff --git a/test/performance/routines/levelx/xim2col.cpp b/test/performance/routines/levelx/xim2col.cpp new file mode 100644 index 00000000..30e224f8 --- /dev/null +++ b/test/performance/routines/levelx/xim2col.cpp @@ -0,0 +1,33 @@ + +// ================================================================================================= +// This file is part of the CLBlast project. The project is licensed under Apache Version 2.0. This +// project loosely follows the Google C++ styleguide and uses a tab-size of two spaces and a max- +// width of 100 characters per line. +// +// Author(s): +// Cedric Nugteren <www.cedricnugteren.nl> +// +// ================================================================================================= + +#include "test/performance/client.hpp" +#include "test/routines/levelx/xim2col.hpp" + +// Main function (not within the clblast namespace) +int main(int argc, char *argv[]) { + const auto command_line_args = clblast::RetrieveCommandLineArguments(argc, argv); + switch(clblast::GetPrecision(command_line_args, clblast::Precision::kSingle)) { + case clblast::Precision::kHalf: + clblast::RunClient<clblast::TestXim2col<clblast::half>, clblast::half, clblast::half>(argc, argv); break; + case clblast::Precision::kSingle: + clblast::RunClient<clblast::TestXim2col<float>, float, float>(argc, argv); break; + case clblast::Precision::kDouble: + clblast::RunClient<clblast::TestXim2col<double>, double, double>(argc, argv); break; + case clblast::Precision::kComplexSingle: + clblast::RunClient<clblast::TestXim2col<clblast::float2>, clblast::float2, clblast::float2>(argc, argv); break; + case clblast::Precision::kComplexDouble: + clblast::RunClient<clblast::TestXim2col<clblast::double2>, clblast::double2, clblast::double2>(argc, argv); break; + } + return 0; +} + +// ================================================================================================= |