13#ifndef CD_LOOKUPTABLEIMPLEM_H
14#define CD_LOOKUPTABLEIMPLEM_H
25#include <CD_NamespaceHeader.H>
27template <
typename T,
size_t N,
typename I>
33template <
typename T,
size_t N,
typename I>
38 m_grid =
std::make_tuple(LookupTable::Spacing::Uniform, 0, -1.0, -1.0, -1.0);
39 m_rangeStrategyLo = LookupTable::OutOfRangeStrategy::Constant;
40 m_rangeStrategyHi = LookupTable::OutOfRangeStrategy::Constant;
43 m_structuredData.clear();
46template <
typename T,
size_t N,
typename I>
47template <
typename...
Ts>
53 m_rawData.emplace_back(
arr);
56template <
typename T,
size_t N,
typename I>
60 m_rawData.emplace_back(
x);
63template <
typename T,
size_t N,
typename I>
67 for (
auto&
r : m_rawData) {
74 for (
auto&
r : m_structuredData) {
91template <
typename T,
size_t N,
typename I>
96 for (
auto&
r : m_rawData) {
100 for (
auto&
r : m_structuredData) {
109template <
typename T,
size_t N,
typename I>
115 for (
const auto&
xy : m_rawData) {
124template <
typename T,
size_t N,
typename I>
131template <
typename T,
size_t N,
typename I>
138template <
typename T,
size_t N,
typename I>
158 return X1[i] < X2[i];
172 case LookupTable::Spacing::Uniform: {
181 case LookupTable::Spacing::Exponential: {
182 if (
xmin <= std::numeric_limits<T>::min()) {
203 m_structuredData.clear();
208 while (
curRow < m_rawData.size() - 1) {
216 const auto t = (
x -
x1) / (
x2 -
x1);
220 for (
size_t i = 0;
i <=
N;
i++) {
224 m_structuredData.emplace_back(
interpRow);
238template <
typename T,
size_t N,
typename I>
245template <
typename T,
size_t N,
typename I>
249 return (m_structuredData);
252template <
typename T,
size_t N,
typename I>
259template <
typename T,
size_t N,
typename I>
263 return (m_structuredData);
266template <
typename T,
size_t N,
typename I>
270 this->writeToFile(
a_file, m_rawData);
273template <
typename T,
size_t N,
typename I>
277 this->writeToFile(
a_file, m_structuredData);
280template <
typename T,
size_t N,
typename I>
287template <
typename T,
size_t N,
typename I>
291 this->outputData(
a_ostream, m_structuredData);
294template <
typename T,
size_t N,
typename I>
300 for (
const auto& c :
r) {
307template <
typename T,
size_t N,
typename I>
326template <
typename T,
size_t N,
typename I>
337 case LookupTable::Spacing::Uniform: {
342 case LookupTable::Spacing::Exponential: {
348 throw std::runtime_error(
"LookupTable1D<T,N,I>::getIndexLo - logic bust (unsupported table spacing system)");
355template <
typename T,
size_t N,
typename I>
360 throw std::runtime_error(
"LookupTable1D<T, N, I>::interpolate(array) but need to call 'prepareTable first'");
370 switch (m_rangeStrategyLo) {
371 case LookupTable::OutOfRangeStrategy::Constant: {
372 ret = m_structuredData.front();
376 case LookupTable::OutOfRangeStrategy::Interpolate: {
380 ret = m_structuredData.front();
382 for (
size_t i = 0;
i <
N + 1;
i++) {
383 const T slope = (m_structuredData[1][
i] - m_structuredData[0][
i]) /
diffDx;
391 throw std::runtime_error(
"LookupTable1D<T, N, I>::interpolate(array) unsupported range strategy at low end");
398 switch (m_rangeStrategyHi) {
399 case LookupTable::OutOfRangeStrategy::Constant: {
400 ret = m_structuredData.back();
404 case LookupTable::OutOfRangeStrategy::Interpolate: {
405 const size_t& size = m_structuredData.size();
410 ret = m_structuredData.back();
412 for (
size_t i = 0;
i <
N + 1;
i++) {
413 const T slope = (m_structuredData[size - 1][
i] - m_structuredData[size - 2][
i]) /
diffDx;
421 throw std::runtime_error(
"LookupTable1D<T, N, I>::interpolate(array) unsupported range strategy at low end");
428 const size_t idx = this->getIndexLo(
a_x);
433 ret = m_structuredData[
idx];
435 for (
size_t i = 0;
i <
N + 1;
i++) {
445template <
typename T,
size_t N,
typename I>
453template <
typename T,
size_t N,
typename I>
454template <
size_t M,
typename...
Ts>
458 static_assert(
M <=
N,
"LookupTable1D<T, N,I>::slice must have have 'M <= N'");
464 for (
const auto&
r : m_rawData) {
467 for (
size_t i = 0;
i <
M + 1;
i++) {
477#include <CD_NamespaceFooter.H>
Declaration of a lookup table in one independent variable.
OutOfRangeStrategy
Strategy for obtaining data when requesting data that is out of range. We can use either constant (i....
Definition CD_LookupTable.H:33
Spacing
Enum for classifying the coordinate system.
Definition CD_LookupTable.H:42
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
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
void setRangeStrategyHi(const LookupTable::OutOfRangeStrategy &a_strategy) noexcept
Set the out-of-range strategy on the high end.
Definition CD_LookupTable1DImplem.H:133
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
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
TracerParticleSolver()
Default constructor.
Definition CD_TracerParticleSolverImplem.H:26