chombo-discharge
Loading...
Searching...
No Matches
CD_LookupTable1D.H
Go to the documentation of this file.
1/*
2 * SPDX-FileCopyrightText: 2021-2026 SINTEF Energy Research
3 *
4 * SPDX-License-Identifier: GPL-3.0-or-later
5 */
6
13#ifndef CD_LOOKUPTABLE1D_H
14#define CD_LOOKUPTABLE1D_H
15
16// Std includes
17#include <iostream>
18#include <vector>
19#include <array>
20#include <type_traits>
21
22// Our includes
23#include <CD_LookupTable.H>
24#include <CD_NamespaceHeader.H>
25
32{
33public:
34 static_assert(N >= 1, "LookupTable1D<N> must have N >= 1");
35
39 LookupTable1D() noexcept;
40
45
49 inline void
51
58 template <size_t M, typename... Ts>
61
67 inline void
69
74 inline void
75 addData(const std::array<T, N + 1>& x) noexcept;
76
84 inline void
85 swap(size_t a_columnOne, size_t a_columnTwo) noexcept;
86
91 template <size_t K>
92 inline void
94
103 inline void
105
110 inline void
111 setRangeStrategyLo(const LookupTable::OutOfRangeStrategy& a_strategy) noexcept;
112
117 inline void
118 setRangeStrategyHi(const LookupTable::OutOfRangeStrategy& a_strategy) noexcept;
119
126 inline void
127 prepareTable(const size_t& a_independentVariable, const size_t& a_numPoints, const LookupTable::Spacing& a_spacing);
128
134 template <size_t K>
135 inline T
137
143 inline std::array<T, N + 1>
145
150 inline std::vector<std::array<T, N + 1>>&
152
157 inline std::vector<std::array<T, N + 1>>&
159
164 inline const std::vector<std::array<T, N + 1>>&
166
171 inline const std::vector<std::array<T, N + 1>>&
173
178 inline void
180
185 inline void
187
192 inline void
194
199 inline void
201
207
211 LookupTable::OutOfRangeStrategy m_rangeStrategyLo;
212
216 LookupTable::OutOfRangeStrategy m_rangeStrategyHi;
217
221 std::tuple<LookupTable::Spacing, size_t, T, T, T> m_grid;
222
227
232
238 inline void
240
246 inline void
248
254 inline size_t
256};
257
258#include <CD_NamespaceFooter.H>
259
261
262#endif
Declaration of a lookup table in one independent variable.
Declaration of a table for looking up coefficients etc.
Class for interpolation of f = f(x) data in one independent variable x.
Definition CD_LookupTable1D.H:32
LookupTable::OutOfRangeStrategy m_rangeStrategyLo
Out-of-range strategy on low end.
Definition CD_LookupTable1D.H:211
std::vector< std::array< T, N+1 > > m_rawData
Raw data.
Definition CD_LookupTable1D.H:226
std::vector< std::array< T, N+1 > > m_structuredData
Structured data. This is populated when calling prepareTable.
Definition CD_LookupTable1D.H:231
std::vector< std::array< T, N+1 > > & getStructuredData() noexcept
Access function for structured data.
Definition CD_LookupTable1DImplem.H:247
T interpolate(const T &a_x) const
Interpolation function for specific dependent variable K.
Definition CD_LookupTable1DImplem.H:448
void addData(const Ts &... x) noexcept
Add entry.
Definition CD_LookupTable1DImplem.H:49
bool m_isGood
Check if data can be interpolated.
Definition CD_LookupTable1D.H:206
void swap(size_t a_columnOne, size_t a_columnTwo) noexcept
Utility function for swapping columns.
Definition CD_LookupTable1DImplem.H:65
void setRangeStrategyLo(const LookupTable::OutOfRangeStrategy &a_strategy) noexcept
Set the out-of-range strategy on the low end.
Definition CD_LookupTable1DImplem.H:126
void truncate(const T &a_min, const T &a_max, size_t a_column) noexcept
Utility function for truncating raw data along one of the variables (either dependent or independent)...
Definition CD_LookupTable1DImplem.H:111
size_t getIndexLo(const T &a_x) const
Get the lower index that brackets the input variable between two data points in the structured grid.
Definition CD_LookupTable1DImplem.H:328
LookupTable::OutOfRangeStrategy m_rangeStrategyHi
Out-of-range strategy on high end.
Definition CD_LookupTable1D.H:216
void setRangeStrategyHi(const LookupTable::OutOfRangeStrategy &a_strategy) noexcept
Set the out-of-range strategy on the high end.
Definition CD_LookupTable1DImplem.H:133
virtual ~LookupTable1D() noexcept=default
Destructor (does nothing).
LookupTable1D() noexcept
Default constructor. Creates a table without any entries.
Definition CD_LookupTable1DImplem.H:28
void writeRawData(const std::string &a_file) const noexcept
Dump raw table data to file.
Definition CD_LookupTable1DImplem.H:268
void outputStructuredData(std::ostream &a_ostream=std::cout) const noexcept
Dump structured table data to file.
Definition CD_LookupTable1DImplem.H:289
void reset() noexcept
Reset everything.
Definition CD_LookupTable1DImplem.H:35
void outputRawData(std::ostream &a_ostream=std::cout) const noexcept
Dump raw table data to output stream.
Definition CD_LookupTable1DImplem.H:282
void prepareTable(const size_t &a_independentVariable, const size_t &a_numPoints, const LookupTable::Spacing &a_spacing)
Turn the raw data into uniform data for fast lookup.
Definition CD_LookupTable1DImplem.H:140
void scale(const T &a_scale) noexcept
Utility function which scales one of the columns (either dependent or independent variable)
Definition CD_LookupTable1DImplem.H:94
void writeToFile(const std::string &a_file, const std::vector< std::array< T, N+1 > > &a_data) const noexcept
Utility function for outputting data to a file.
Definition CD_LookupTable1DImplem.H:309
void writeStructuredData(const std::string &a_file) const noexcept
Dump structured table data to file.
Definition CD_LookupTable1DImplem.H:275
LookupTable1D< T, M, I > slice(const Ts &... a_columns) const noexcept
Slice this table, keeping only the user-specified columns.
Definition CD_LookupTable1DImplem.H:456
std::tuple< LookupTable::Spacing, size_t, T, T, T > m_grid
Underlying 1D grid. This is populated when calling prepareTable.
Definition CD_LookupTable1D.H:221
void outputData(std::ostream &a_ostream, const std::vector< std::array< T, N+1 > > &a_data) const noexcept
Utility function for outputting data.
Definition CD_LookupTable1DImplem.H:296
std::vector< std::array< T, N+1 > > & getRawData() noexcept
Access function for raw data.
Definition CD_LookupTable1DImplem.H:240
Base class for a tracer particle solver. This solver can advance particles in a pre-defined velocity ...
Definition CD_TracerParticleSolver.H:38