DPNP C++ backend kernel library 0.20.0dev0
Data Parallel Extension for NumPy*
Loading...
Searching...
No Matches
dot.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 dot_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 dot_event;
60 try {
61 dot_event = mkl_blas::column_major::dot(exec_q,
62 n, // size of the input vectors
63 x, // Pointer to vector x.
64 incx, // Stride of vector x.
65 y, // Pointer to vector y.
66 incy, // Stride of vector y.
67 res, // Pointer to result.
68 depends);
69 } catch (oneapi::mkl::exception const &e) {
70 error_msg
71 << "Unexpected MKL exception caught during dot() call:\nreason: "
72 << e.what();
73 is_exception_caught = true;
74 } catch (sycl::exception const &e) {
75 error_msg << "Unexpected SYCL exception caught during dot() call:\n"
76 << e.what();
77 is_exception_caught = true;
78 }
79
80 if (is_exception_caught) // an unexpected error occurs
81 {
82 throw std::runtime_error(error_msg.str());
83 }
84
85 return dot_event;
86}
87
88template <typename fnT, typename varT>
90{
91 fnT get()
92 {
94 return dot_impl<varT>;
95 }
96 else {
97 return nullptr;
98 }
99 }
100};
101} // namespace dpnp::extensions::blas
A factory to define pairs of supported types for which MKL BLAS library provides support in oneapi::m...