cMHN 1.1
C++ library for learning MHNs with pRC
Loading...
Searching...
No Matches
reduce.hpp
Go to the documentation of this file.
1// SPDX-License-Identifier: BSD-2-Clause
2
3#ifndef pRC_CORE_TENSOR_FUNCTIONS_REDUCE_H
4#define pRC_CORE_TENSOR_FUNCTIONS_REDUCE_H
5
9
10namespace pRC
11{
12 template<class F, Index... Is>
13 struct Reduce;
14
15 template<class F, Index... Is, class X, class R = RemoveReference<X>,
17 If<IsSatisfied<(sizeof...(Is) <= typename R::Dimension())>> = 0,
18 If<IsUnique<Constant<Index, Is>...>> = 0,
19 If<IsSatisfied<(max(Is...) < typename R::Dimension())>> = 0,
22 If<IsInvocable<F, decltype(F::template Identity<typename R::Type>()),
23 E>> = 0>
24 static inline constexpr auto reduce(X &&a)
25 {
28 using Sizes = decltype(chip<Is...>(typename R::Sizes()));
29
30 return TensorViews::Reduce<T, Sizes, F,
31 decltype(sort(Sequence<Index, Is...>())), V>(view(forward<X>(a)));
32 }
33
34 template<class F, class X, class R = RemoveReference<X>,
35 If<IsTensorish<R>> = 0, If<IsInvocable<View, X>> = 0,
36 class E = ResultOf<X, typename R::Subscripts>,
37 If<IsInvocable<F, E, E>> = 0,
38 If<IsInvocable<F, decltype(F::template Identity<typename R::Type>()),
39 E>> = 0>
40 static inline constexpr auto reduce(X &&a)
41 {
42 if constexpr(typename R::Dimension() == 0)
43 {
44 return view(forward<X>(a));
45 }
46 else
47 {
48 return expand(makeSeries<Index, typename R::Dimension{}>(),
49 [&a](auto const... seq)
50 {
51 return reduce<F, seq...>(forward<X>(a));
52 });
53 }
54 }
55
56 template<class F, Index... Is, class X, class R = RemoveReference<X>,
58 If<IsInvocable<Reduce<F, Is...>, X &>> = 0>
59 static inline constexpr auto reduce(X &&a)
60 {
61 return eval(reduce<F, Is...>(a));
62 }
63}
64#endif // pRC_CORE_TENSOR_FUNCTIONS_REDUCE_H
Definition sequence.hpp:56
Definition sequence.hpp:34
Definition reduce.hpp:14
pRC::Float<> T
Definition externs_nonTT.hpp:1
Definition cholesky.hpp:18
static constexpr X eval(X &&a)
Definition eval.hpp:11
static constexpr auto reduce(Sequence< T, I1, I2, Is... > const)
Definition sequence.hpp:416
static constexpr auto makeConstantSequence()
Definition sequence.hpp:402
Size Index
Definition type_traits.hpp:21
static constexpr X view(X &&a)
Definition view.hpp:12
std::enable_if_t< B{}, int > If
Definition type_traits.hpp:68
Constant< Bool, B > IsSatisfied
Definition type_traits.hpp:71
static constexpr void sort(C const &compare, T &a, Size const k=T::size(), Size const d=0)
Definition sort.hpp:15
Sequence< Size, Ns... > Sizes
Definition type_traits.hpp:238
static constexpr auto makeSeries()
Definition sequence.hpp:351
RemoveConst< RemoveReference< T > > RemoveConstReference
Definition type_traits.hpp:62
static constexpr auto chip(Sequence< T, Is... > const)
Definition sequence.hpp:551
static constexpr decltype(auto) expand(Sequence< T, Seq... > const, F &&f, Xs &&...args)
Definition sequence.hpp:344
std::is_invocable< F, Args... > IsInvocable
Definition type_traits.hpp:134
static constexpr X max(X &&a)
Definition max.hpp:13