Alexandria  2.27.0
SDC-CH common library for the Euclid project
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
InverseCumulative.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 MATHUTILS_INV_CUMULATIVE_H
20 #define MATHUTILS_INV_CUMULATIVE_H
21 
23 #include <vector>
24 
25 namespace Euclid {
26 namespace MathUtils {
27 
38 template <typename TKnot, typename E = void>
40 public:
50 
56  TKnot operator()(double p) const;
57 };
58 
59 } // namespace MathUtils
60 } // namespace Euclid
61 
62 #define INVERSE_CUMULATIVE_IMPL
64 #undef INVERSE_CUMULATIVE_IMPL
65 
66 #endif // MATHUTILS_INV_CUMULATIVE_H
TKnot operator()(double p) const
STL class.
InverseCumulative(std::vector< TKnot > knots, std::vector< double > pdf)