diff options
author | Cedric Nugteren <web@cedricnugteren.nl> | 2017-04-10 22:54:14 +0200 |
---|---|---|
committer | Cedric Nugteren <web@cedricnugteren.nl> | 2017-04-10 22:54:14 +0200 |
commit | 6b625f8915ce0596d65187bd3a8eb47e91a0084e (patch) | |
tree | ed16d34e567e52667f74131ff09f0673619dd661 /test/routines/level2/xtrmv.hpp | |
parent | 22b3ea9256bd197da3cd320560c14e5f3bd7fb86 (diff) |
Added reference implementations for performance-testing against cuBLAS
Diffstat (limited to 'test/routines/level2/xtrmv.hpp')
-rw-r--r-- | test/routines/level2/xtrmv.hpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/test/routines/level2/xtrmv.hpp b/test/routines/level2/xtrmv.hpp index 7c97c966..a773b1ca 100644 --- a/test/routines/level2/xtrmv.hpp +++ b/test/routines/level2/xtrmv.hpp @@ -113,6 +113,20 @@ class TestXtrmv { } #endif + // Describes how to run the cuBLAS routine (for correctness/performance comparison) + #ifdef CLBLAST_REF_CUBLAS + static StatusCode RunReference3(const Arguments<T> &args, BuffersCUDA<T> &buffers, Queue &) { + auto status = cublasXtrmv(args.layout, + convertToCUBLAS(args.triangle), + convertToCUBLAS(args.a_transpose), + convertToCUBLAS(args.diagonal), + args.n, + buffers.a_mat, args.a_offset, args.a_ld, + buffers.x_vec, args.x_offset, args.x_inc); + if (status == CUBLAS_STATUS_SUCCESS) { return StatusCode::kSuccess; } else { return StatusCode::kUnknownError; } + } + #endif + // Describes how to download the results of the computation (more importantly: which buffer) static std::vector<T> DownloadResult(const Arguments<T> &args, Buffers<T> &buffers, Queue &queue) { std::vector<T> result(args.x_size, static_cast<T>(0)); |