DPNP C++ backend kernel library 0.20.0dev0
Data Parallel Extension for NumPy*
Loading...
Searching...
No Matches
dpnp_utils.hpp
1//*****************************************************************************
2// Copyright (c) 2016, 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#ifndef BACKEND_UTILS_H // Cython compatibility
31#define BACKEND_UTILS_H
32
33#include <complex>
34#include <iostream>
35#include <stdexcept>
36#include <string>
37#include <type_traits>
38#include <vector>
39
40#include <sycl/sycl.hpp>
41
42#include <dpnp_iface_fptr.hpp>
43
48#ifndef __SYCL_COMPILER_VECTOR_ABS_CHANGED
49#define __SYCL_COMPILER_VECTOR_ABS_CHANGED 20230503L
50#endif
51
55#ifndef __INTEL_MKL_2023_0_0_VERSION_REQUIRED
56#define __INTEL_MKL_2023_0_0_VERSION_REQUIRED 20230000
57#endif
58
76template <typename T>
77static inline void validate_type_for_device(const sycl::device &d)
78{
79 if constexpr (std::is_same_v<T, double>) {
80 if (!d.has(sycl::aspect::fp64)) {
81 throw std::runtime_error("Device " +
82 d.get_info<sycl::info::device::name>() +
83 " does not support type 'double'");
84 }
85 }
86 else if constexpr (std::is_same_v<T, std::complex<double>>) {
87 if (!d.has(sycl::aspect::fp64)) {
88 throw std::runtime_error(
89 "Device " + d.get_info<sycl::info::device::name>() +
90 " does not support type 'complex<double>'");
91 }
92 }
93 else if constexpr (std::is_same_v<T, sycl::half>) {
94 if (!d.has(sycl::aspect::fp16)) {
95 throw std::runtime_error("Device " +
96 d.get_info<sycl::info::device::name>() +
97 " does not support type 'half'");
98 }
99 }
100}
101
112template <typename T>
113static inline void validate_type_for_device(const sycl::queue &q)
114{
115 validate_type_for_device<T>(q.get_device());
116}
117
126template <typename T>
127std::ostream &operator<<(std::ostream &out, const std::vector<T> &vec)
128{
129 std::string delimiter;
130 out << "{";
131 // std::copy(vec.begin(), vec.end(), std::ostream_iterator<T>(out, ", "));
132 // out << "\b\b}"; // last two 'backspaces' needs to eliminate last
133 // delimiter. ex: {2, 3, 4, }
134 for (auto &elem : vec) {
135 out << delimiter << elem;
136 if (delimiter.empty()) {
137 delimiter.assign(", ");
138 }
139 }
140 out << "}";
141
142 return out;
143}
144
154template <typename T>
155std::ostream &operator<<(std::ostream &out, DPNPFuncType elem)
156{
157 out << static_cast<size_t>(elem);
158
159 return out;
160}
161
162#endif // BACKEND_UTILS_H
DPNPFuncType
Template types which are used in this interface.
std::ostream & operator<<(std::ostream &out, const std::vector< T > &vec)
print std::vector to std::ostream.