3#ifndef pRC_CORE_TENSOR_FUNCTIONS_REDUCE_H
4#define pRC_CORE_TENSOR_FUNCTIONS_REDUCE_H
17 If<
IsSatisfied<(
sizeof...(Is) <=
typename R::Dimension())>> = 0,
18 If<IsUnique<Constant<Index, Is>...>> = 0,
24 static inline constexpr auto reduce(
X &&a)
28 using Sizes =
decltype(
chip<
Is...>(
typename R::Sizes()));
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>()),
40 static inline constexpr auto reduce(
X &&a)
42 if constexpr(
typename R::Dimension() == 0)
44 return view(forward<X>(a));
49 [&a](
auto const...
seq)
59 static inline constexpr auto reduce(
X &&a)
Definition sequence.hpp:56
Definition sequence.hpp:34
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