Reaktoro  v2.11.0
A unified framework for modeling chemically reactive systems
LagrangeInterpolator.hpp
1 // Reaktoro is a unified framework for modeling chemically reactive systems.
2 //
3 // Copyright © 2014-2024 Allan Leal
4 //
5 // This library is free software; you can redistribute it and/or
6 // modify it under the terms of the GNU Lesser General Public
7 // License as published by the Free Software Foundation; either
8 // version 2.1 of the License, or (at your option) any later version.
9 //
10 // This library is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 // Lesser General Public License for more details.
14 //
15 // You should have received a copy of the GNU Lesser General Public License
16 // along with this library. If not, see <http://www.gnu.org/licenses/>.
17 
18 #pragma once
19 
20 // C++ includes
21 #include <vector>
22 
23 namespace Reaktoro {
24 
27 {
28 public:
31 
36  LagrangeInterpolator(const std::vector<double>& xp, const std::vector<double>& yp, unsigned order = 1);
37 
39  auto operator()(double x) const -> double;
40 
41 private:
43  std::vector<double> xi;
44 
46  std::vector<double> yi;
47 
49  unsigned order;
50 };
51 
52 } // namespace Reaktoro
A class used to calculate interpolation of data in one dimension in any order.
Definition: LagrangeInterpolator.hpp:27
LagrangeInterpolator(const std::vector< double > &xp, const std::vector< double > &yp, unsigned order=1)
Construct a LagrangeInterpolator instance.
auto operator()(double x) const -> double
Return the interpolation of at a given coordinate .
LagrangeInterpolator()
Construct a default LagrangeInterpolator instance.
The namespace containing all components of the Reaktoro library.
Definition: Algorithms.hpp:29