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
47#ifndef __INTEL_MKL_2023_0_0_VERSION_REQUIRED
48#define __INTEL_MKL_2023_0_0_VERSION_REQUIRED 20230000
49#endif
50
68template <typename T>
69static inline void validate_type_for_device(const sycl::device &d)
70{
71 if constexpr (std::is_same_v<T, double>) {
72 if (!d.has(sycl::aspect::fp64)) {
73 throw std::runtime_error("Device " +
74 d.get_info<sycl::info::device::name>() +
75 " does not support type 'double'");
76 }
77 }
78 else if constexpr (std::is_same_v<T, std::complex<double>>) {
79 if (!d.has(sycl::aspect::fp64)) {
80 throw std::runtime_error(
81 "Device " + d.get_info<sycl::info::device::name>() +
82 " does not support type 'complex<double>'");
83 }
84 }
85 else if constexpr (std::is_same_v<T, sycl::half>) {
86 if (!d.has(sycl::aspect::fp16)) {
87 throw std::runtime_error("Device " +
88 d.get_info<sycl::info::device::name>() +
89 " does not support type 'half'");
90 }
91 }
92}
93
104template <typename T>
105static inline void validate_type_for_device(const sycl::queue &q)
106{
107 validate_type_for_device<T>(q.get_device());
108}
109
118template <typename T>
119std::ostream &operator<<(std::ostream &out, const std::vector<T> &vec)
120{
121 std::string delimiter;
122 out << "{";
123 // std::copy(vec.begin(), vec.end(), std::ostream_iterator<T>(out, ", "));
124 // out << "\b\b}"; // last two 'backspaces' needs to eliminate last
125 // delimiter. ex: {2, 3, 4, }
126 for (auto &elem : vec) {
127 out << delimiter << elem;
128 if (delimiter.empty()) {
129 delimiter.assign(", ");
130 }
131 }
132 out << "}";
133
134 return out;
135}
136
146template <typename T>
147std::ostream &operator<<(std::ostream &out, DPNPFuncType elem)
148{
149 out << static_cast<size_t>(elem);
150
151 return out;
152}
153
154#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.