DPNP C++ backend kernel library 0.20.0dev0
Data Parallel Extension for NumPy*
Loading...
Searching...
No Matches
dotu.hpp
1//*****************************************************************************
2// Copyright (c) 2024, Intel Corporation
3// All rights reserved.
4//
5// Redistribution and use in source and binary forms, with or without
6// modification, are permitted provided that the following conditions are met:
7// - Redistributions of source code must retain the above copyright notice,
8// this list of conditions and the following disclaimer.
9// - Redistributions in binary form must reproduce the above copyright notice,
10// this list of conditions and the following disclaimer in the documentation
11// and/or other materials provided with the distribution.
12// - Neither the name of the copyright holder nor the names of its contributors
13// may be used to endorse or promote products derived from this software
14// without specific prior written permission.
15//
16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
26// THE POSSIBILITY OF SUCH DAMAGE.
27//*****************************************************************************
28
29#pragma once
30
31#include <stdexcept>
32
33#include "dot_common.hpp"
34
35namespace dpnp::extensions::blas
36{
37namespace mkl_blas = oneapi::mkl::blas;
38namespace type_utils = dpctl::tensor::type_utils;
39
40template <typename T>
41static sycl::event dotu_impl(sycl::queue &exec_q,
42 const std::int64_t n,
43 const char *vectorX,
44 const std::int64_t incx,
45 const char *vectorY,
46 const std::int64_t incy,
47 char *result,
48 const std::vector<sycl::event> &depends)
49{
50 type_utils::validate_type_for_device<T>(exec_q);
51
52 const T *x = reinterpret_cast<const T *>(vectorX);
53 const T *y = reinterpret_cast<const T *>(vectorY);
54 T *res = reinterpret_cast<T *>(result);
55
56 std::stringstream error_msg;
57 bool is_exception_caught = false;
58
59 sycl::event dotu_event;
60 try {
61 dotu_event =
62 mkl_blas::column_major::dotu(exec_q,
63 n, // size of the input vectors
64 x, // Pointer to vector x.
65 incx, // Stride of vector x.
66 y, // Pointer to vector y.
67 incy, // Stride of vector y.
68 res, // Pointer to result.
69 depends);
70 } catch (oneapi::mkl::exception const &e) {
71 error_msg
72 << "Unexpected MKL exception caught during dotu() call:\nreason: "
73 << e.what();
74 is_exception_caught = true;
75 } catch (sycl::exception const &e) {
76 error_msg << "Unexpected SYCL exception caught during dotu() call:\n"
77 << e.what();
78 is_exception_caught = true;
79 }
80
81 if (is_exception_caught) // an unexpected error occurs
82 {
83 throw std::runtime_error(error_msg.str());
84 }
85
86 return dotu_event;
87}
88
89template <typename fnT, typename varT>
91{
92 fnT get()
93 {
95 return dotu_impl<varT>;
96 }
97 else {
98 return nullptr;
99 }
100 }
101};
102} // namespace dpnp::extensions::blas
A factory to define pairs of supported types for which MKL BLAS library provides support in oneapi::m...