DPNP C++ backend kernel library 0.20.0dev0
Data Parallel Extension for NumPy*
Loading...
Searching...
No Matches
getrf.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 <oneapi/mkl.hpp>
32#include <sycl/sycl.hpp>
33
34#include <dpctl4pybind11.hpp>
35
36namespace dpnp::extensions::lapack
37{
38extern std::pair<sycl::event, sycl::event>
39 getrf(sycl::queue &exec_q,
40 const dpctl::tensor::usm_ndarray &a_array,
41 const dpctl::tensor::usm_ndarray &ipiv_array,
42 py::list dev_info,
43 const std::vector<sycl::event> &depends = {});
44
45extern std::pair<sycl::event, sycl::event>
46 getrf_batch(sycl::queue &exec_q,
47 const dpctl::tensor::usm_ndarray &a_array,
48 const dpctl::tensor::usm_ndarray &ipiv_array,
49 py::list dev_info,
50 std::int64_t m,
51 std::int64_t n,
52 std::int64_t stride_a,
53 std::int64_t stride_ipiv,
54 std::int64_t batch_size,
55 const std::vector<sycl::event> &depends = {});
56
57extern void init_getrf_dispatch_vector(void);
58extern void init_getrf_batch_dispatch_vector(void);
59} // namespace dpnp::extensions::lapack