10#include <Kokkos_Core.hpp>
12namespace ddc::detail {
15
16
17
18
19
20template <
class ExecSpace>
21class SplinesLinearProblem
25 using MultiRHS = Kokkos::View<
double**, Kokkos::LayoutRight,
typename ExecSpace::memory_space>;
31 explicit SplinesLinearProblem(std::size_t size);
34 SplinesLinearProblem(SplinesLinearProblem
const& x) =
delete;
36 SplinesLinearProblem(SplinesLinearProblem&& x) =
delete;
39 virtual ~SplinesLinearProblem();
41 SplinesLinearProblem& operator=(SplinesLinearProblem
const& x) =
delete;
43 SplinesLinearProblem& operator=(SplinesLinearProblem&& x) =
delete;
46
47
48
49
50
51
52
53 virtual double get_element(std::size_t i, std::size_t j)
const = 0;
56
57
58
59
60
61
62 virtual void set_element(std::size_t i, std::size_t j,
double aij) = 0;
65
66
67 virtual void setup_solver() = 0;
70
71
72
73
74
75 virtual void solve(MultiRHS b,
bool transpose)
const = 0;
78
79
80
81
82 std::size_t size()
const;
85
86
87
88
89
90
91 std::size_t required_number_of_rhs_rows()
const;
94 virtual std::size_t impl_required_number_of_rhs_rows()
const;
98
99
100
101
102
103
104
105template <
class ExecSpace>
106std::ostream& operator<<(std::ostream& os, SplinesLinearProblem<ExecSpace>
const& linear_problem);
108#if defined(KOKKOS_ENABLE_SERIAL
)
109extern template class SplinesLinearProblem<Kokkos::Serial>;
110extern template std::ostream& operator<<(
112 SplinesLinearProblem<Kokkos::Serial>
const& linear_problem);
114#if defined(KOKKOS_ENABLE_OPENMP)
115extern template class SplinesLinearProblem<Kokkos::OpenMP>;
116extern template std::ostream& operator<<(
118 SplinesLinearProblem<Kokkos::OpenMP>
const& linear_problem);
120#if defined(KOKKOS_ENABLE_CUDA)
121extern template class SplinesLinearProblem<Kokkos::Cuda>;
122extern template std::ostream& operator<<(
124 SplinesLinearProblem<Kokkos::Cuda>
const& linear_problem);
126#if defined(KOKKOS_ENABLE_HIP)
127extern template class SplinesLinearProblem<Kokkos::HIP>;
128extern template std::ostream& operator<<(
130 SplinesLinearProblem<Kokkos::HIP>
const& linear_problem);
132#if defined(KOKKOS_ENABLE_SYCL)
133extern template class SplinesLinearProblem<Kokkos::SYCL>;
134extern template std::ostream& operator<<(
136 SplinesLinearProblem<Kokkos::SYCL>
const& linear_problem);
friend class DiscreteDomain
KOKKOS_FUNCTION constexpr bool operator!=(DiscreteVector< OTags... > const &rhs) const noexcept
A class which provides helper functions to initialise the Greville points from a B-Spline definition.
static ddc::DiscreteDomain< Sampling > get_domain()
Get the domain which gives us access to all of the Greville points.
static auto get_sampling()
Get the UniformPointSampling defining the Greville points.
Helper class for the initialisation of the mesh of interpolation points.
static auto get_sampling()
Get the sampling of interpolation points.
static ddc::DiscreteDomain< Sampling > get_domain()
Get the domain which can be used to access the interpolation points in the sampling.
A class for creating a spline approximation of a function.
batched_derivs_domain_type< BatchedInterpolationDDom > batched_derivs_xmax_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the whole domain on which derivatives on upper boundary are defined.
static constexpr SplineSolver s_spline_solver
The SplineSolver giving the backend used to perform the spline approximation.
batch_domain_type< BatchedInterpolationDDom > batch_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the batch domain.
std::tuple< ddc::Chunk< double, ddc::DiscreteDomain< ddc::Deriv< typename InterpolationDDim::continuous_dimension_type > >, ddc::KokkosAllocator< double, OutMemorySpace > >, ddc::Chunk< double, ddc::DiscreteDomain< InterpolationDDim >, ddc::KokkosAllocator< double, OutMemorySpace > >, ddc::Chunk< double, ddc::DiscreteDomain< ddc::Deriv< typename InterpolationDDim::continuous_dimension_type > >, ddc::KokkosAllocator< double, OutMemorySpace > > > quadrature_coefficients() const
Compute the quadrature coefficients associated to the b-splines used by this SplineBuilder.
SplineBuilder & operator=(SplineBuilder const &x)=delete
Copy-assignment is deleted.
SplineBuilder(SplineBuilder &&x)=default
Move-constructs.
SplineBuilder(interpolation_domain_type const &interpolation_domain, std::optional< std::size_t > cols_per_chunk=std::nullopt, std::optional< unsigned int > preconditioner_max_block_size=std::nullopt)
Build a SplineBuilder acting on interpolation_domain.
static constexpr ddc::BoundCond s_bc_xmin
The boundary condition implemented at the lower bound.
static constexpr int s_nbc_xmin
The number of equations defining the boundary condition at the lower bound.
SplineBuilder & operator=(SplineBuilder &&x)=default
Move-assigns.
BatchedInterpolationDDom batched_interpolation_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the whole domain representing interpolation points.
SplineBuilder(SplineBuilder const &x)=delete
Copy-constructor is deleted.
SplineBuilder(BatchedInterpolationDDom const &batched_interpolation_domain, std::optional< std::size_t > cols_per_chunk=std::nullopt, std::optional< unsigned int > preconditioner_max_block_size=std::nullopt)
Build a SplineBuilder acting on the interpolation domain contained by batched_interpolation_domain.
static constexpr bool s_odd
Indicates if the degree of the splines is odd or even.
interpolation_domain_type interpolation_domain() const noexcept
Get the domain for the 1D interpolation mesh used by this class.
batched_derivs_domain_type< BatchedInterpolationDDom > batched_derivs_xmin_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the whole domain on which derivatives on lower boundary are defined.
static constexpr ddc::BoundCond s_bc_xmax
The boundary condition implemented at the upper bound.
static constexpr int s_nbc_xmax
The number of equations defining the boundary condition at the upper bound.
void operator()(ddc::ChunkSpan< double, batched_spline_domain_type< BatchedInterpolationDDom >, Layout, memory_space > spline, ddc::ChunkSpan< double const, BatchedInterpolationDDom, Layout, memory_space > vals, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > derivs_xmin=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > derivs_xmax=std::nullopt) const
Compute a spline approximation of a function.
batched_spline_domain_type< BatchedInterpolationDDom > batched_spline_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the whole domain on which spline coefficients are defined.
ddc::DiscreteDomain< bsplines_type > spline_domain() const noexcept
Get the 1D domain on which spline coefficients are defined.
~SplineBuilder()=default
Destructs.
The top-level namespace of DDC.
constexpr int n_boundary_equations(ddc::BoundCond const bc, std::size_t const degree)
Return the number of equations needed to describe a given boundary condition.
constexpr bool is_uniform_bsplines_v
Indicates if a tag corresponds to uniform B-splines or not.
BoundCond
An enum representing a spline boundary condition.
@ GREVILLE
Use Greville points instead of conditions on derivative for B-Spline interpolation.
@ HERMITE
Hermite boundary condition.
@ PERIODIC
Periodic boundary condition u(1)=u(n)
ddc::ChunkSpan< double, ddc::DiscreteDomain< DDim >, Layout, MemorySpace > integrals(ExecSpace const &execution_space, ddc::ChunkSpan< double, ddc::DiscreteDomain< DDim >, Layout, MemorySpace > int_vals)
Compute the integrals of the B-splines.
SplineSolver
An enum determining the backend solver of a SplineBuilder or SplineBuilder2d.
@ LAPACK
Enum member to identify the LAPACK-based solver (direct method)
@ GINKGO
Enum member to identify the Ginkgo-based solver (iterative method)
constexpr bool is_non_uniform_bsplines_v
Indicates if a tag corresponds to non-uniform B-splines or not.
A templated struct representing a discrete dimension storing the derivatives of a function along a co...
If the type DDim is a B-spline, defines type to the discrete dimension of the associated knots.