15#include <Kokkos_Core.hpp>
24
25
26
27
28
29
30
31
32
33
34
40 class ExtrapolationRule>
41class SplineEvaluatorND;
47 class... EvaluationDDim,
48 class... ExtrapolationRule>
49class SplineEvaluatorND<
52 detail::TypeSeq<BSplines...>,
53 detail::TypeSeq<EvaluationDDim...>,
54 detail::TypeSeq<ExtrapolationRule...>>
57 static constexpr std::size_t dimension =
sizeof...(BSplines);
59 using bsplines_ts = detail::TypeSeq<BSplines...>;
61 template <
class BSpline>
62 static constexpr std::size_t s_idx = ddc::type_seq_rank_v<BSpline, bsplines_ts>;
64 using evaluation_ddim_ts = detail::TypeSeq<EvaluationDDim...>;
65 using lower_extrap_rule_ts = detail::TypeSeq<
66 ddc::type_seq_element_t<2 * s_idx<BSplines>, detail::TypeSeq<ExtrapolationRule...>>...>;
67 using upper_extrap_rule_ts = detail::TypeSeq<
ddc::type_seq_element_t<
68 2 * s_idx<BSplines> + 1,
69 detail::TypeSeq<ExtrapolationRule...>>...>;
74 template <std::size_t I>
75 using continuous_dimension_type
76 =
ddc::type_seq_element_t<I, bsplines_ts>::continuous_dimension_type;
79 using exec_space = ExecSpace;
82 using memory_space = MemorySpace;
85 template <std::size_t I>
86 using evaluation_discrete_dimension_type =
ddc::type_seq_element_t<I, evaluation_ddim_ts>;
89 template <std::size_t I>
90 using bsplines_type =
ddc::type_seq_element_t<I, bsplines_ts>;
93
94
95
96
97 template <std::size_t... Dims>
98 using evaluation_domain_type =
ddc::
DiscreteDomain<evaluation_discrete_dimension_type<Dims>...>;
101
102
103
104
105 template <concepts::discrete_domain BatchedInterpolationDDom>
106 using batched_evaluation_domain_type = BatchedInterpolationDDom;
109
110
111
112
113 template <std::size_t... Dims>
117
118
119
120
121
122 template <concepts::discrete_domain BatchedInterpolationDDom>
123 using batch_domain_type
124 =
ddc::detail::convert_type_seq_to_discrete_domain_t<
ddc::type_seq_remove_t<
125 ddc::to_type_seq_t<BatchedInterpolationDDom>,
126 evaluation_ddim_ts>>;
129
130
131
132
133
134 template <concepts::discrete_domain BatchedInterpolationDDom>
135 using batched_spline_domain_type
136 =
ddc::detail::convert_type_seq_to_discrete_domain_t<
ddc::type_seq_replace_t<
137 ddc::to_type_seq_t<BatchedInterpolationDDom>,
142 template <std::size_t I>
143 using lower_extrapolation_rule_type =
ddc::type_seq_element_t<I, lower_extrap_rule_ts>;
146 template <std::size_t I>
147 using upper_extrapolation_rule_type =
ddc::type_seq_element_t<I, upper_extrap_rule_ts>;
150 cexa::tuple<
ddc::type_seq_element_t<s_idx<BSplines>, lower_extrap_rule_ts>...>
151 m_lower_extrap_rules;
152 cexa::tuple<
ddc::type_seq_element_t<s_idx<BSplines>, upper_extrap_rule_ts>...>
153 m_upper_extrap_rules;
157 sizeof...(BSplines) == dimension,
158 "Number of BSpline dims should be equal to the dimension");
160 sizeof...(EvaluationDDim) == dimension,
161 "Number of evaluation dims should be equal to the dimensions");
163 ddc::type_seq_size_v<lower_extrap_rule_ts> == dimension,
164 "Number of lower extrapolation rules should be equal to the dimension");
166 ddc::type_seq_size_v<upper_extrap_rule_ts> == dimension,
167 "Number of upper extrapolation rules should be equal to the dimension");
171 ddc::type_seq_element_t<s_idx<BSplines>, lower_extrap_rule_ts>,
173 == BSplines::is_periodic()
175 ddc::type_seq_element_t<s_idx<BSplines>, upper_extrap_rule_ts>,
177 typename BSplines::continuous_dimension_type>>
178 == BSplines::is_periodic())
180 "PeriodicExtrapolationRule has to be used if and only if dimension is periodic");
182 (std::is_invocable_r_v<
184 ddc::type_seq_element_t<s_idx<BSplines>, lower_extrap_rule_ts>,
185 ddc::Coordinate<
typename BSplines::continuous_dimension_type>,
189 Kokkos::layout_right,
192 "LowerExtrapolationRule::operator() has to be callable "
193 "with usual arguments.");
195 (std::is_invocable_r_v<
197 ddc::type_seq_element_t<s_idx<BSplines>, upper_extrap_rule_ts>,
198 ddc::Coordinate<
typename BSplines::continuous_dimension_type>,
202 Kokkos::layout_right,
205 "UpperExtrapolationRule::operator() has to be callable "
206 "with usual arguments.");
209
210
211
212
213
214
215 template <
class... ExtrapRules>
216 explicit SplineEvaluatorND(ExtrapRules
const&... extrap_rules)
219 (std::is_same_v<ExtrapRules, ExtrapolationRule> && ...),
220 "The type of the extrapolation rules passed to the constructor should be the same "
221 "as the ones passed as template argument to the class");
223 cexa::tuple<ExtrapRules...> extrap_rules_tuple(extrap_rules...);
225 = cexa::make_tuple(cexa::get<2 * s_idx<BSplines>>(extrap_rules_tuple)...);
227 = cexa::make_tuple(cexa::get<2 * s_idx<BSplines> + 1>(extrap_rules_tuple)...);
231
232
233
234
235 SplineEvaluatorND(SplineEvaluatorND
const& x) =
default;
238
239
240
241
242 SplineEvaluatorND(SplineEvaluatorND&& x) =
default;
245 ~SplineEvaluatorND() =
default;
248
249
250
251
252
253 SplineEvaluatorND& operator=(SplineEvaluatorND
const& x) =
default;
256
257
258
259
260
261 SplineEvaluatorND& operator=(SplineEvaluatorND&& x) =
default;
264
265
266
267
268
269
270
271
272 template <std::size_t I>
273 auto lower_extrapolation_rule()
const
275 return cexa::get<I>(m_lower_extrap_rules);
279
280
281
282
283
284
285
286
287 template <std::size_t I>
288 auto upper_extrapolation_rule()
const
290 return cexa::get<I>(m_upper_extrap_rules);
294
295
296
297
298
299
300
301
302
303
304
305 template <
class Layout,
class... CoordsDims>
306 KOKKOS_FUNCTION
double operator()(
307 ddc::Coordinate<CoordsDims...>
const& coord_eval,
312 memory_space>
const spline_coef)
const
314 return eval(coord_eval, spline_coef);
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
341 class BatchedInterpolationDDom,
344 ddc::
ChunkSpan<
double, BatchedInterpolationDDom, Layout1, memory_space>
const
347 ddc::Coordinate<CoordsDims...>
const,
348 BatchedInterpolationDDom,
350 memory_space>
const coords_eval,
353 batched_spline_domain_type<BatchedInterpolationDDom>,
355 memory_space>
const spline_coef)
const
358 evaluation_domain_type
const evaluation_domain(spline_eval.domain());
360 batch_domain_type<BatchedInterpolationDDom>
const batch_domain(coords_eval.domain());
362 ddc::parallel_for_each(
363 "ddc_splines_evaluate_Nd",
367 batch_domain_type<BatchedInterpolationDDom>::discrete_element_type
const
369 auto const spline_eval_ND = spline_eval[j];
370 auto const coords_eval_ND = coords_eval[j];
371 auto const spline_coef_ND = spline_coef[j];
372 ddc::device_for_each(
374 [&](evaluation_domain_type::discrete_element_type
const i) {
375 spline_eval_ND(i) = eval(coords_eval_ND(i), spline_coef_ND);
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395 template <
class Layout1,
class Layout2,
class BatchedInterpolationDDom>
397 ddc::
ChunkSpan<
double, BatchedInterpolationDDom, Layout1, memory_space>
const
401 batched_spline_domain_type<BatchedInterpolationDDom>,
403 memory_space>
const spline_coef)
const
406 evaluation_domain_type evaluation_domain(spline_eval.domain());
408 batch_domain_type<BatchedInterpolationDDom>
const batch_domain(spline_eval.domain());
410 ddc::parallel_for_each(
411 "ddc_splines_evaluate_Nd",
415 batch_domain_type<BatchedInterpolationDDom>::discrete_element_type
const
417 auto const spline_eval_ND = spline_eval[j];
418 auto const spline_coef_ND = spline_coef[j];
420 ddc::device_for_each(
422 [&](evaluation_domain_type::discrete_element_type
const i) {
423 ddc::Coordinate<
typename BSplines::continuous_dimension_type...>
424 coord_eval_ND(
ddc::coordinate(i));
425 spline_eval_ND(i) = eval(coord_eval_3D(i), spline_coef_ND);
431
432
433
434
435
436
437
438
439
440
441
442
443 template <
class DElem,
class Layout,
class... CoordsDims>
444 KOKKOS_FUNCTION
double deriv(
445 DElem
const& deriv_order,
446 ddc::Coordinate<CoordsDims...>
const& coord_eval,
451 memory_space>
const spline_coef)
const
453 static_assert(
ddc::is_discrete_element_v<DElem>);
455 return eval_no_bc(deriv_order, coord_eval, spline_coef);
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
484 class BatchedInterpolationDDom,
487 DElem
const& deriv_order,
488 ddc::
ChunkSpan<
double, BatchedInterpolationDDom, Layout1, memory_space>
const
491 ddc::Coordinate<CoordsDims...>
const,
492 BatchedInterpolationDDom,
494 memory_space>
const coords_eval,
497 batched_spline_domain_type<BatchedInterpolationDDom>,
499 memory_space>
const spline_coef)
const
501 static_assert(
ddc::is_discrete_element_v<DElem>);
504 evaluation_domain_type
const evaluation_domain(spline_eval.domain());
506 batch_domain_type<BatchedInterpolationDDom>
const batch_domain(spline_eval.domain());
508 ddc::parallel_for_each(
509 "ddc_splines_cross_differentiate_Nd",
513 batch_domain_type<BatchedInterpolationDDom>::discrete_element_type
const
515 auto const spline_eval_ND = spline_eval[j];
516 auto const coords_eval_ND = coords_eval[j];
517 auto const spline_coef_ND = spline_coef[j];
518 ddc::device_for_each(
520 [&](evaluation_domain_type::discrete_element_type
const i) {
521 spline_eval_ND(i) = eval_no_bc(
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544 template <
class DElem,
class Layout1,
class Layout2,
class BatchedInterpolationDDom>
546 DElem
const& deriv_order,
547 ddc::
ChunkSpan<
double, BatchedInterpolationDDom, Layout1, memory_space>
const
551 batched_spline_domain_type<BatchedInterpolationDDom>,
553 memory_space>
const spline_coef)
const
555 static_assert(is_discrete_element_v<DElem>);
558 evaluation_domain_type evaluation_domain(spline_eval.domain());
560 batch_domain_type<BatchedInterpolationDDom>
const batch_domain(spline_eval.domain());
562 ddc::parallel_for_each(
563 "ddc_splines_cross_differentiate_Nd",
567 batch_domain_type<BatchedInterpolationDDom>::discrete_element_type
const
569 auto const spline_eval_ND = spline_eval[j];
570 auto const spline_coef_ND = spline_coef[j];
571 ddc::device_for_each(
573 [&](evaluation_domain_type::discrete_element_type
const i) {
574 ddc::Coordinate<
typename BSplines::continuous_dimension_type...>
575 coord_eval_ND(
ddc::coordinate(i));
577 = eval_no_bc(deriv_order, coord_eval_ND, spline_coef_ND);
583
584
585
586
587
588
589
590
591
592
593
594
595 template <
class Layout1,
class Layout2,
class BatchedDDom,
class BatchedSplineDDom>
597 ddc::
ChunkSpan<
double, BatchedDDom, Layout1, memory_space>
const integrals,
598 ddc::
ChunkSpan<
double const, BatchedSplineDDom, Layout2, memory_space>
const
602 ddc::type_seq_contains_v<bsplines_ts, to_type_seq_t<BatchedSplineDDom>>,
603 "The spline coefficients domain must contain the bsplines dimensions");
605 std::is_same_v<batch_domain_type<BatchedDDom>, BatchedDDom>,
606 "The integrals domain must only contain the batch dimensions");
609 bsplines_domain_type
const bsplines_domain(spline_coef.domain());
611 batch_domain_type<BatchedDDom>
const batch_domain(integrals.domain());
612 auto values_alloc = cexa::make_tuple(
616 auto values = cexa::make_tuple(cexa::get<s_idx<BSplines>>(values_alloc).span_view()...);
617 (
ddc::integrals(exec_space(), cexa::get<s_idx<BSplines>>(values)), ...);
619 ddc::parallel_for_each(
620 "ddc_splines_integrate_bsplines",
623 KOKKOS_LAMBDA(batch_domain_type<BatchedDDom>::discrete_element_type
const j) {
625 ddc::device_for_each(
627 [&](bsplines_domain_type::discrete_element_type
const i) {
628 integrals(j) += spline_coef(i, j)
629 * (cexa::get<s_idx<BSplines>>(values)(
630 ddc::DiscreteElement<BSplines>(i))
637 template <std::size_t I,
class... CoordsDims>
638 KOKKOS_INLINE_FUNCTION
static void update_coord_eval(
ddc::Coordinate<CoordsDims...>& coord_eval)
640 using Dim = continuous_dimension_type<I>;
641 using bsplines_t = bsplines_type<I>;
643 if constexpr (bsplines_t::is_periodic()) {
644 if (
ddc::get<Dim>(coord_eval) <
ddc::discrete_space<bsplines_t>().rmin()
645 ||
ddc::get<Dim>(coord_eval) >
ddc::discrete_space<bsplines_t>().rmax()) {
646 ddc::get<Dim>(coord_eval) -= Kokkos::floor(
647 (
ddc::get<Dim>(coord_eval)
648 -
ddc::discrete_space<bsplines_t>().rmin())
649 /
ddc::discrete_space<bsplines_t>().length())
650 *
ddc::discrete_space<bsplines_t>().length();
655 template <std::size_t I,
class Layout,
class... CoordsDims>
656 KOKKOS_INLINE_FUNCTION
bool check_needs_extrapolation(
657 ddc::Coordinate<CoordsDims...> coord_eval,
662 memory_space>
const spline_coef,
665 if constexpr (!bsplines_type<I>::is_periodic()) {
666 if (
ddc::get<continuous_dimension_type<I>>(coord_eval)
667 <
ddc::discrete_space<bsplines_type<I>>().rmin()) {
668 res = cexa::get<I>(m_lower_extrap_rules)(coord_eval, spline_coef);
671 if (
ddc::get<continuous_dimension_type<I>>(coord_eval)
672 >
ddc::discrete_space<bsplines_type<I>>().rmax()) {
673 res = cexa::get<I>(m_upper_extrap_rules)(coord_eval, spline_coef);
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695 template <
class Layout,
class... CoordsDims>
696 KOKKOS_INLINE_FUNCTION
double eval(
697 ddc::Coordinate<CoordsDims...> coord_eval,
702 memory_space>
const spline_coef)
const
704 (update_coord_eval<s_idx<BSplines>>(coord_eval), ...);
708 bool const needs_extrapolation
709 = (... || check_needs_extrapolation<s_idx<BSplines>>(coord_eval, spline_coef, res));
711 if (needs_extrapolation) {
717 ddc::Coordinate<
typename BSplines::continuous_dimension_type...>(
718 ddc::get<
typename BSplines::continuous_dimension_type>(coord_eval)...),
722 template <
class BSplinesType,
class... DerivDims,
class CoordDim>
723 KOKKOS_INLINE_FUNCTION
static ddc::DiscreteElement<BSplinesType> get_jmin(
724 ddc::DiscreteElement<DerivDims...>
const& deriv_order,
725 Kokkos::mdspan<
double, Kokkos::extents<std::size_t, BSplinesType::degree() + 1>> vals,
726 ddc::Coordinate<CoordDim>
const& coord_eval)
728 using deriv_dim =
Deriv<
typename BSplinesType::continuous_dimension_type>;
729 using deriv_dims = detail::TypeSeq<DerivDims...>;
730 if constexpr (!in_tags_v<deriv_dim, deriv_dims>) {
731 return ddc::discrete_space<BSplinesType>().eval_basis(vals, coord_eval);
733 auto const order = deriv_order.
template uid<deriv_dim>();
734 KOKKOS_ASSERT(order > 0 && order <= BSplinesType::degree())
736 std::array<
double, (BSplinesType::degree() + 1) * (BSplinesType::degree() + 1)>
742 BSplinesType::degree() + 1,
743 Kokkos::dynamic_extent>>
const derivs(derivs_ptr.data(), order + 1);
745 auto jmin =
ddc::discrete_space<BSplinesType>()
746 .eval_basis_and_n_derivs(derivs, coord_eval, order);
748 for (std::size_t i = 0; i < BSplinesType::degree() + 1; ++i) {
749 vals[i] = DDC_MDSPAN_ACCESS_OP(derivs, i, order);
756 template <std::size_t N,
class Functor,
class... Is>
757 KOKKOS_INLINE_FUNCTION
static void for_each(
758 std::array<std::size_t, N>
const& bounds,
762 static constexpr std::size_t I =
sizeof...(Is);
763 if constexpr (I == N) {
764 f(std::array<std::size_t, N> {is...});
766 for (std::size_t i = 0; i < bounds[I]; ++i) {
767 for_each(bounds, f, is..., i);
773
774
775
776
777
778
779
780 template <
class... DerivDims,
class Layout,
class... CoordsDims>
781 KOKKOS_INLINE_FUNCTION
double eval_no_bc(
782 ddc::DiscreteElement<DerivDims...>
const& deriv_order,
783 ddc::Coordinate<CoordsDims...>
const& coord_eval,
788 memory_space>
const spline_coef)
const
794 ddc::detail::TypeSeq<
Deriv<continuous_dimension_type<s_idx<BSplines>>>...>>
796 "The only valid dimensions for deriv_order are Deriv<Dim1>, Deriv<Dim2>, ..., "
799 auto vals_ptr = cexa::make_tuple(std::array<
double, BSplines::degree() + 1> {}...);
800 auto const vals = cexa::make_tuple(
801 Kokkos::mdspan<
double, Kokkos::extents<std::size_t, BSplines::degree() + 1>>(
802 cexa::get<s_idx<BSplines>>(vals_ptr).data())...);
804 auto const jmin = cexa::make_tuple(
807 cexa::get<s_idx<BSplines>>(vals),
808 ddc::Coordinate<
typename BSplines::continuous_dimension_type>(
813 std::array<std::size_t, dimension> {(BSplines::degree() + 1)...},
814 [&](std::array<std::size_t, dimension> idx) {
816 ddc::DiscreteElement<BSplines...>(
817 (cexa::get<s_idx<BSplines>>(jmin)
818 + idx[s_idx<BSplines>])...))
819 * (cexa::get<s_idx<BSplines>>(vals)[idx[s_idx<BSplines>]] * ...);
friend class DiscreteDomain
KOKKOS_DEFAULTED_FUNCTION constexpr DiscreteElement()=default
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.
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 2D spline approximation of a function.
SplineBuilder2D(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 SplineBuilder2D acting on the interpolation domain contained in batched_interpolation_domain.
SplineBuilder2D & operator=(SplineBuilder2D const &x)=delete
Copy-assignment is deleted.
SplineBuilder2D(std::string const &label, 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 SplineBuilder2D acting on the interpolation domain contained in batched_interpolation_domain.
batch_domain_type< BatchedInterpolationDDom > batch_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the batch domain.
interpolation_domain_type interpolation_domain() const noexcept
Get the domain for the 2D interpolation mesh used by this class.
SplineBuilder2D(SplineBuilder2D &&x)=default
Move-constructs.
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.
SplineBuilder2D(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 SplineBuilder2D acting on interpolation_domain.
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_type1< BatchedInterpolationDDom >, Layout, memory_space > > derivs_min1=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1< BatchedInterpolationDDom >, Layout, memory_space > > derivs_max1=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type2< BatchedInterpolationDDom >, Layout, memory_space > > derivs_min2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type2< BatchedInterpolationDDom >, Layout, memory_space > > derivs_max2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_min2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_min2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_max2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_max2=std::nullopt) const
Compute a 2D spline approximation of a function.
~SplineBuilder2D()=default
Destructs.
SplineBuilder2D(std::string const &label, 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 SplineBuilder2D acting on interpolation_domain.
ddc::DiscreteDomain< bsplines_type1, bsplines_type2 > spline_domain() const noexcept
Get the 2D domain on which spline coefficients are defined.
SplineBuilder2D(SplineBuilder2D const &x)=delete
Copy-constructor is deleted.
BatchedInterpolationDDom batched_interpolation_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the whole domain representing interpolation points.
SplineBuilder2D & operator=(SplineBuilder2D &&x)=default
Move-assigns.
A class for creating a 3D spline approximation of a function.
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_type1< BatchedInterpolationDDom >, Layout, memory_space > > derivs_min1=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1< BatchedInterpolationDDom >, Layout, memory_space > > derivs_max1=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type2< BatchedInterpolationDDom >, Layout, memory_space > > derivs_min2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type2< BatchedInterpolationDDom >, Layout, memory_space > > derivs_max2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type3< BatchedInterpolationDDom >, Layout, memory_space > > derivs_min3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type3< BatchedInterpolationDDom >, Layout, memory_space > > derivs_max3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1_2< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_min2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1_2< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_min2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1_2< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_max2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1_2< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_max2=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type2_3< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min2_min3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type2_3< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max2_min3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type2_3< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min2_max3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type2_3< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max2_max3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1_3< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_min3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1_3< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_min3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1_3< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_max3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type1_3< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_max3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_min2_min3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_min2_min3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_max2_min3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_max2_min3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_min2_max3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_min2_max3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_min1_max2_max3=std::nullopt, std::optional< ddc::ChunkSpan< double const, batched_derivs_domain_type< BatchedInterpolationDDom >, Layout, memory_space > > mixed_derivs_max1_max2_max3=std::nullopt) const
Compute a 3D spline approximation of a function.
BatchedInterpolationDDom batched_interpolation_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the whole domain representing interpolation points.
SplineBuilder3D(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 SplineBuilder3D acting on interpolation_domain.
SplineBuilder3D(std::string label, 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 SplineBuilder3D acting on the interpolation domain contained in batched_interpolation_domain.
SplineBuilder3D & operator=(SplineBuilder3D &&x)=default
Move-assigns.
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_type1, bsplines_type2, bsplines_type3 > spline_domain() const noexcept
Get the 3D domain on which spline coefficients are defined.
batch_domain_type< BatchedInterpolationDDom > batch_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the batch domain.
interpolation_domain_type interpolation_domain() const noexcept
Get the domain for the 3D interpolation mesh used by this class.
~SplineBuilder3D()=default
Destructs.
SplineBuilder3D & operator=(SplineBuilder3D const &x)=delete
Copy-assignment is deleted.
SplineBuilder3D(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 SplineBuilder3D acting on the interpolation domain contained in batched_interpolation_domain.
SplineBuilder3D(std::string label, 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 SplineBuilder3D acting on interpolation_domain.
SplineBuilder3D(SplineBuilder3D const &x)=delete
Copy-constructor is deleted.
SplineBuilder3D(SplineBuilder3D &&x)=default
Move-constructs.
A class for creating a spline approximation of a function.
ddc::DiscreteDomain< bsplines_type > spline_domain() const noexcept
Get the 1D domain on which spline coefficients are defined.
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.
SplineBuilder(SplineBuilder const &x)=delete
Copy-constructor is deleted.
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_xmax_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the whole domain on which derivatives on upper boundary are defined.
static constexpr int s_nbe_xmin
The number of equations defining the closure relation at the lower bound.
static constexpr ddc::SplineBuilderClosure s_sbc_xmin
The closure relation implemented at the lower bound.
SplineBuilder(std::string label, 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.
batch_domain_type< BatchedInterpolationDDom > batch_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the batch domain.
SplineBuilder & operator=(SplineBuilder &&x)=default
Move-assigns.
static constexpr int s_nbe_xmax
The number of equations defining the closure relation at the upper bound.
static constexpr SplineSolver s_spline_solver
The SplineSolver giving the backend used to perform the spline approximation.
static constexpr ddc::SplineBuilderClosure s_sbc_xmax
The closure relation implemented at the upper bound.
BatchedInterpolationDDom batched_interpolation_domain(BatchedInterpolationDDom const &batched_interpolation_domain) const noexcept
Get the whole domain representing interpolation points.
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.
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.
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 bool s_odd
Indicates if the degree of the splines is odd or even.
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.
SplineBuilder(std::string label, 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.
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.
SplineBuilder(SplineBuilder &&x)=default
Move-constructs.
static constexpr int s_nbv_xmax
The number of input values defining the closure relation at the upper bound.
~SplineBuilder()=default
Destructs.
static constexpr int s_nbv_xmin
The number of input values defining the closure relation at the lower bound.
SplineBuilder & operator=(SplineBuilder const &x)=delete
Copy-assignment is deleted.
A class to evaluate, differentiate or integrate a 2D spline function.
void operator()(ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout2, memory_space > const spline_coef) const
Evaluate 2D spline function (described by its spline coefficients) on a mesh.
SplineEvaluator2D(SplineEvaluator2D &&x)=default
Move-constructs.
lower_extrapolation_rule_1_type lower_extrapolation_rule_dim_1() const
Get the lower extrapolation rule along the first dimension.
SplineEvaluator2D & operator=(SplineEvaluator2D const &x)=default
Copy-assigns.
void deriv(DElem const &deriv_order, ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< ddc::Coordinate< CoordsDims... > const, BatchedInterpolationDDom, Layout2, memory_space > const coords_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout3, memory_space > const spline_coef) const
Differentiate 2D spline function (described by its spline coefficients) on a mesh along the dimension...
SplineEvaluator2D(SplineEvaluator2D const &x)=default
Copy-constructs.
~SplineEvaluator2D()=default
Destructs.
KOKKOS_FUNCTION double deriv(DElem const &deriv_order, ddc::Coordinate< CoordsDims... > const &coord_eval, ddc::ChunkSpan< double const, spline_domain_type, Layout, memory_space > const spline_coef) const
Differentiate 2D spline function (described by its spline coefficients) at a given coordinate along t...
void deriv(DElem const &deriv_order, ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout2, memory_space > const spline_coef) const
Differentiate 2D spline function (described by its spline coefficients) on a mesh along the dimension...
void integrate(ddc::ChunkSpan< double, BatchedDDom, Layout1, memory_space > const integrals, ddc::ChunkSpan< double const, BatchedSplineDDom, Layout2, memory_space > const spline_coef) const
Perform batched 2D integrations of a spline function (described by its spline coefficients) along the...
upper_extrapolation_rule_2_type upper_extrapolation_rule_dim_2() const
Get the upper extrapolation rule along the second dimension.
upper_extrapolation_rule_1_type upper_extrapolation_rule_dim_1() const
Get the upper extrapolation rule along the first dimension.
lower_extrapolation_rule_2_type lower_extrapolation_rule_dim_2() const
Get the lower extrapolation rule along the second dimension.
SplineEvaluator2D & operator=(SplineEvaluator2D &&x)=default
Move-assigns.
KOKKOS_FUNCTION double operator()(ddc::Coordinate< CoordsDims... > const &coord_eval, ddc::ChunkSpan< double const, spline_domain_type, Layout, memory_space > const spline_coef) const
Evaluate 2D spline function (described by its spline coefficients) at a given coordinate.
void operator()(ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< ddc::Coordinate< CoordsDims... > const, BatchedInterpolationDDom, Layout2, memory_space > const coords_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout3, memory_space > const spline_coef) const
Evaluate 2D spline function (described by its spline coefficients) on a mesh.
SplineEvaluator2D(LowerExtrapolationRule1 const &lower_extrap_rule1, UpperExtrapolationRule1 const &upper_extrap_rule1, LowerExtrapolationRule2 const &lower_extrap_rule2, UpperExtrapolationRule2 const &upper_extrap_rule2)
Build a SplineEvaluator2D acting on batched_spline_domain.
A class to evaluate, differentiate or integrate a 3D spline function.
upper_extrapolation_rule_1_type upper_extrapolation_rule_dim_1() const
Get the upper extrapolation rule along the first dimension.
void deriv(DElem const &deriv_order, ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout2, memory_space > const spline_coef) const
Differentiate 3D spline function (described by its spline coefficients) on a mesh along the dimension...
void operator()(ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< ddc::Coordinate< CoordsDims... > const, BatchedInterpolationDDom, Layout2, memory_space > const coords_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout3, memory_space > const spline_coef) const
Evaluate 3D spline function (described by its spline coefficients) on a mesh.
SplineEvaluator3D & operator=(SplineEvaluator3D &&x)=default
Move-assigns.
upper_extrapolation_rule_3_type upper_extrapolation_rule_dim_3() const
Get the upper extrapolation rule along the third dimension.
SplineEvaluator3D(LowerExtrapolationRule1 const &lower_extrap_rule1, UpperExtrapolationRule1 const &upper_extrap_rule1, LowerExtrapolationRule2 const &lower_extrap_rule2, UpperExtrapolationRule2 const &upper_extrap_rule2, LowerExtrapolationRule3 const &lower_extrap_rule3, UpperExtrapolationRule3 const &upper_extrap_rule3)
Build a SplineEvaluator3D acting on batched_spline_domain.
~SplineEvaluator3D()=default
Destructs.
lower_extrapolation_rule_1_type lower_extrapolation_rule_dim_1() const
Get the lower extrapolation rule along the first dimension.
upper_extrapolation_rule_2_type upper_extrapolation_rule_dim_2() const
Get the upper extrapolation rule along the second dimension.
void deriv(DElem const &deriv_order, ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< ddc::Coordinate< CoordsDims... > const, BatchedInterpolationDDom, Layout2, memory_space > const coords_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout3, memory_space > const spline_coef) const
Differentiate 3D spline function (described by its spline coefficients) on a mesh along the dimension...
KOKKOS_FUNCTION double deriv(DElem const &deriv_order, ddc::Coordinate< CoordsDims... > const &coord_eval, ddc::ChunkSpan< double const, spline_domain_type, Layout, memory_space > const spline_coef) const
Differentiate 3D spline function (described by its spline coefficients) at a given coordinate along t...
SplineEvaluator3D(SplineEvaluator3D const &x)=default
Copy-constructs.
KOKKOS_FUNCTION double operator()(ddc::Coordinate< CoordsDims... > const &coord_eval, ddc::ChunkSpan< double const, spline_domain_type, Layout, memory_space > const spline_coef) const
Evaluate 3D spline function (described by its spline coefficients) at a given coordinate.
lower_extrapolation_rule_3_type lower_extrapolation_rule_dim_3() const
Get the lower extrapolation rule along the third dimension.
SplineEvaluator3D(SplineEvaluator3D &&x)=default
Move-constructs.
void integrate(ddc::ChunkSpan< double, BatchedDDom, Layout1, memory_space > const integrals, ddc::ChunkSpan< double const, BatchedSplineDDom, Layout2, memory_space > const spline_coef) const
Perform batched 3D integrations of a spline function (described by its spline coefficients) along the...
lower_extrapolation_rule_2_type lower_extrapolation_rule_dim_2() const
Get the lower extrapolation rule along the second dimension.
SplineEvaluator3D & operator=(SplineEvaluator3D const &x)=default
Copy-assigns.
void operator()(ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout2, memory_space > const spline_coef) const
Evaluate 3D spline function (described by its spline coefficients) on a mesh.
A class to evaluate, differentiate or integrate a spline function.
void operator()(ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< ddc::Coordinate< CoordsDims... > const, BatchedInterpolationDDom, Layout2, memory_space > const coords_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout3, memory_space > const spline_coef) const
Evaluate spline function (described by its spline coefficients) on a mesh.
upper_extrapolation_rule_type upper_extrapolation_rule() const
Get the upper extrapolation rule.
SplineEvaluator & operator=(SplineEvaluator const &x)=default
Copy-assigns.
SplineEvaluator & operator=(SplineEvaluator &&x)=default
Move-assigns.
SplineEvaluator(LowerExtrapolationRule const &lower_extrap_rule, UpperExtrapolationRule const &upper_extrap_rule)
Build a SplineEvaluator acting on batched_spline_domain.
lower_extrapolation_rule_type lower_extrapolation_rule() const
Get the lower extrapolation rule.
void deriv(DElem const &deriv_order, ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout2, memory_space > const spline_coef) const
Differentiate 1D spline function (described by its spline coefficients) on a mesh.
KOKKOS_FUNCTION double operator()(ddc::Coordinate< CoordsDims... > const &coord_eval, ddc::ChunkSpan< double const, spline_domain_type, Layout, memory_space > const spline_coef) const
Evaluate 1D spline function (described by its spline coefficients) at a given coordinate.
KOKKOS_FUNCTION double deriv(DElem const &deriv_order, ddc::Coordinate< CoordsDims... > const &coord_eval, ddc::ChunkSpan< double const, spline_domain_type, Layout, memory_space > const spline_coef) const
Differentiate 1D spline function (described by its spline coefficients) at a given coordinate.
SplineEvaluator(SplineEvaluator const &x)=default
Copy-constructs.
SplineEvaluator(SplineEvaluator &&x)=default
Move-constructs.
void deriv(DElem const &deriv_order, ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< ddc::Coordinate< CoordsDims... > const, BatchedInterpolationDDom, Layout2, memory_space > const coords_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout3, memory_space > const spline_coef) const
Differentiate 1D spline function (described by its spline coefficients) on a mesh.
void integrate(ddc::ChunkSpan< double, BatchedDDom, Layout1, memory_space > const integrals, ddc::ChunkSpan< double const, BatchedSplineDDom, Layout2, memory_space > const spline_coef) const
Perform batched 1D integrations of a spline function (described by its spline coefficients) along the...
void operator()(ddc::ChunkSpan< double, BatchedInterpolationDDom, Layout1, memory_space > const spline_eval, ddc::ChunkSpan< double const, batched_spline_domain_type< BatchedInterpolationDDom >, Layout2, memory_space > const spline_coef) const
Evaluate a spline function (described by its spline coefficients) on a mesh.
~SplineEvaluator()=default
Destructs.
#define DDC_BUILD_DEPRECATED_CODE
The top-level namespace of DDC.
constexpr bool is_uniform_bsplines_v
Indicates if a tag corresponds to uniform B-splines or not.
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 int n_boundary_equations(ddc::SplineBuilderClosure const sbc, std::size_t const degree)
Return the number of equations needed to describe a given closure relation.
constexpr bool is_non_uniform_bsplines_v
Indicates if a tag corresponds to non-uniform B-splines or not.
SplineBuilderClosure
An enum representing a spline closure relation.
@ HOMOGENEOUS_HERMITE
Homogeneous Hermite closure relation (derivatives are 0)
@ GREVILLE
Use Greville points instead of conditions on derivative for B-Spline interpolation.
@ HERMITE
Hermite closure relation.
@ PERIODIC
Periodic closure relation u(1)=u(n)
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.