Alexandria  2.22.0
Please provide a description of the project.
Operations.h
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2012-2021 Euclid Science Ground Segment
3  *
4  * This library is free software; you can redistribute it and/or modify it under
5  * the terms of the GNU Lesser General Public License as published by the Free
6  * Software Foundation; either version 3.0 of the License, or (at your option)
7  * any later version.
8  *
9  * This library is distributed in the hope that it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
11  * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
12  * details.
13  *
14  * You should have received a copy of the GNU Lesser General Public License
15  * along with this library; if not, write to the Free Software Foundation, Inc.,
16  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17  */
18 
19 #ifndef ALEXANDRIA_NDARRAY_OPERATIONS_H
20 #define ALEXANDRIA_NDARRAY_OPERATIONS_H
21 
22 #include "NdArray/NdArray.h"
23 
24 namespace Euclid {
25 namespace NdArray {
26 
39 
45 template <typename T>
46 T sum(const NdArray<T>& array);
47 
57 template <typename T>
58 NdArray<T> sum(const NdArray<T>& array, int axis);
59 
72 template <typename T, typename Iterator>
73 NdArray<T> trapz(const NdArray<T>& array, const Iterator kbegin, const Iterator kend, int axis);
74 
84 template <typename T>
86 
96 template <typename T>
98 
108 template <typename T>
109 void sort(NdArray<T>& array, const std::vector<std::string>& attrs);
110 
111 } // namespace NdArray
112 } // namespace Euclid
113 
114 #define NDARRAY_OPS_IMPL
116 #undef NDARRAY_OPS_IMPL
117 
118 #endif // ALEXANDRIA_NDARRAY_OPERATIONS_H
std::vector< std::size_t > argmax(const NdArray< T > &array)
std::vector< std::size_t > argmin(const NdArray< T > &array)
void sort(NdArray< T > &array, const std::vector< std::string > &attrs)
T sum(const NdArray< T > &array)
std::vector< std::size_t > unravel_index(std::size_t index, const std::vector< std::size_t > &shape)
Definition: Operations.cpp:24
NdArray< T > trapz(const NdArray< T > &array, const Iterator kbegin, const Iterator kend, int axis)