tk::ctr namespace

Toolkit control, general purpose user input to internal data transfer.

Contents

Classes

struct KeywordInfo
Keyword information bundle.
struct HelpKw
Help bundle on a single keyword.
struct Info
Function object for filling a HelpFactory (std::map) with keywords and their associated information bundle.
class Error
Error options: outsource searches to base templated on enum type.
class MKLBetaMethod
MKLBetaMethod options: outsource searches to base templated on enum type.
class MKLGammaMethod
MKLGammaMethod options: outsource searches to base templated on enum type.
class MKLGaussianMethod
MKLGaussianMethod options: outsource searches to base templated on enum type.
class MKLGaussianMVMethod
MKLGaussianMVMethod options: outsource searches to base templated on enum type.
class MKLUniformMethod
MKLUniformMethod options: outsource searches to base templated on enum type.
class PDFCentering
PDFCentering options: outsource searches to base templated on enum type.
class PDFFile
PDFFileType options: outsource searches to base templated on enum type.
class PDFPolicy
PDFPolicy ptions: outsource searches to base templated on enum type.
class RNG
RNG options: outsource searches to base templated on enum type.
class RNGSSESeqLen
RNGSSESeqLen options: outsource searches to base templated on enum type.
class TxtFloatFormat
TxtFloatFormat options: outsource searches to base templated on enum type.
class UserTable
UserTable options: outsource searches to base templated on enum type.
struct Term
Term is a Moment of a quantity with a field ID to be ensemble averaged.
struct CaseInsensitiveCharLess
Case-insensitive character comparison functor.
struct PDFInfo
PDF information bundle.
struct ComponentVector
template<typename... Tags>
class ncomponents
Number of components storage.

Enums

enum class ErrorType: uint8_t { L2 =0, LINF }
Error types.
enum class MKLBetaMethodType: uint8_t { CJA, CJA_ACCURATE }
MKL beta random number generator method types.
enum class MKLGammaMethodType: uint8_t { GNORM, GNORM_ACCURATE }
MKL gamma random number generator method types.
enum class MKLGaussianMethodType: uint8_t { BOXMULLER, BOXMULLER2, ICDF }
MKL Gaussian random number generator method types.
enum class MKLGaussianMVMethodType: uint8_t { BOXMULLER, BOXMULLER2, ICDF }
MKL Gaussian random number generator method types.
enum class MKLUniformMethodType: uint8_t { STANDARD, ACCURATE }
MKL uniform random number generator method types.
enum class PDFCenteringType: uint8_t { ELEM =0, NODE }
PDF output file types.
enum class PDFFileType: uint8_t { TXT =0, GMSHTXT, GMSHBIN, EXODUSII }
PDF output file types.
enum class PDFPolicyType: uint8_t { OVERWRITE =0, MULTIPLE, EVOLUTION }
PDF output file policy types.
enum class RNGType: uint8_t { NO_RNG =0, RNGSSE_GM19, RNGSSE_GM29, RNGSSE_GM31, RNGSSE_GM55, RNGSSE_GM61, RNGSSE_GQ581, RNGSSE_GQ583, RNGSSE_GQ584, RNGSSE_MT19937, RNGSSE_LFSR113, RNGSSE_MRG32K3A, MKL_MCG31, MKL_R250, MKL_MRG32K3A, MKL_MCG59, MKL_WH, MKL_MT19937, MKL_MT2203, MKL_SFMT19937, MKL_SOBOL, MKL_NIEDERR, MKL_NONDETERM, R123_THREEFRY, R123_PHILOX }
Random number generator types.
enum class RNGLibType: uint8_t { NO_LIB =0, MKL, RNGSSE, PRAND, R123 }
Random number generator library types.
enum class RNGSSESeqLenType: uint8_t { SHORT, MEDIUM, LONG }
RNGSSE sequence length options.
enum class TxtFloatFormatType: uint8_t { DEFAULT =0, FIXED, SCIENTIFIC }
Txt floating-point format types.
enum class UserTableType: uint8_t { POSITION =0, VELOCITY, ACCELERATION }
Table types types.
enum class Moment: uint8_t { ORDINARY =0, CENTRAL }
Moment specifies which type of moment is computed for a quantity in a Term.

Typedefs

using HelpFactory = std::map<std::string, KeywordInfo>
A typedef for associating a keyword-string with its associated information stored in a KeywordInfo struct.
using RawRNGType = std::underlying_type_t<RNGType>
Enum class underlying type shortcut.
using RNGSSEParam = tk::TaggedTuple<brigand::list<tag::seed, kw::seed::info::expect::type, tag::seqlen, RNGSSESeqLenType>>
RNGSSE random number generator parameters storage.
using RNGSSEParameters = std::map<RNGType, RNGSSEParam>
RNGSSE parameters bundle associating RNG types and their parameters.
using RNGRandom123Param = tk::TaggedTuple<brigand::list<tag::seed, kw::seed::info::expect::type>>
Random123 random number generator parameters storage.
using RNGRandom123Parameters = std::map<RNGType, RNGRandom123Param>
Random123 parameters bundle associating RNG types and their parameters.
using RNGMKLParam = tk::TaggedTuple<brigand::list<tag::seed, kw::seed::info::expect::type, tag::uniform_method, MKLUniformMethodType, tag::gaussian_method, MKLGaussianMethodType, tag::gaussianmv_method, MKLGaussianMVMethodType, tag::beta_method, MKLBetaMethodType, tag::gamma_method, MKLGammaMethodType>>
MKL random number generator parameters storage.
using RNGMKLParameters = std::map<RNGType, RNGMKLParam>
MKL RNG parameters bundle associating RNG types and their parameters.
using Product = std::vector<Term>
Products are arbitrary number of Terms to be multiplied and ensemble averaged.
using Probability = std::vector<Term>
Probability density function (vector of sample space variables)
using ncomp_t = kw::ncomp::info::expect::type
Inherit type of number of components from keyword 'ncomp'.
using OffsetMap = std::map<char, ncomp_t, CaseInsensitiveCharLess>
Map associating offsets to dependent variables for systems.
using NcompMap = std::map<char, ncomp_t, CaseInsensitiveCharLess>
Map associating number of scalar components to dependent variables for systems.
template<typename... T>
using tagged_tuple_wrapper = typename tk::TaggedTuple<brigand::list<T...>>
Helper for converting a brigand::list to a tagged_tuple.
template<typename L>
using as_tagged_tuple = brigand::wrap<L, tagged_tuple_wrapper>
Helper for converting a brigand::list to a tagged_tuple.

Functions

void operator|(PUP::er& p, ErrorType& e)
Pack/Unpack ErrorType: forward overload to generic enum class packer.
void operator|(PUP::er& p, MKLBetaMethodType& e)
Pack/Unpack MKLBetaMethodType: forward overload to generic enum class packer.
void operator|(PUP::er& p, MKLGammaMethodType& e)
Pack/Unpack MKLGammaMethodType: forward overload to generic enum class packer.
void operator|(PUP::er& p, MKLGaussianMethodType& e)
Pack/Unpack MKLGaussianMethodType: forward overload to generic enum class packer.
void operator|(PUP::er& p, MKLGaussianMVMethodType& e)
Pack/Unpack MKLGaussianMVMethodType: forward overload to generic enum class packer.
void operator|(PUP::er& p, MKLUniformMethodType& e)
Pack/Unpack MKLGUniformMethodType: forward overload to generic enum class packer.
void operator|(PUP::er& p, PDFCenteringType& e)
Pack/Unpack PDFCenteringType: forward overload to generic enum class packer.
void operator|(PUP::er& p, PDFFileType& e)
Pack/Unpack PDFFileType: forward overload to generic enum class packer.
void operator|(PUP::er& p, PDFPolicyType& e)
Pack/Unpack PDFPolicyType: forward overload to generic enum class packer.
void operator|(PUP::er& p, RNGType& e)
Pack/Unpack RNGType: forward overload to generic enum class packer.
auto raw(RNGType r) -> RawRNGType constexpr
void operator|(PUP::er& p, RNGSSESeqLenType& e)
Pack/Unpack RNGSSESeqLenType: forward overload to generic enum class packer.
void operator|(PUP::er& p, TxtFloatFormatType& e)
Pack/Unpack TxtFloatFormatType: forward overload to generic enum class packer.
void operator|(PUP::er& p, UserTableType& e)
Pack/Unpack UserTableType: forward overload to generic enum class packer.
void pup(PUP::er& p, Term& t)
Pack/Unpack: Namespace-scope serialize Term object for Charm++.
static auto operator+(const std::string& lhs, const Term& term) -> std::string
Operator + for adding Term (var+field) to a std::string.
static auto operator+=(std::string& os, const Term& term) -> std::string&
Operator += for adding Term (var+field) to a std::string.
static auto operator<<(std::ostream& os, const Term& term) -> std::ostream&
Operator << for writing Term to output streams.
static auto operator+(const std::string& lhs, const Product& p) -> std::string
Operator + for adding products (var+field) to a std::string.
static auto operator<<(std::ostream& os, const Product& p) -> std::ostream&
Operator << for writing products to output streams.
static auto pdf(std::ostream& os, const std::vector<Term>& var, const std::vector<tk::real>& bin, const std::string& name, const std::vector<tk::real>& ext) -> std::ostream&
Function for writing PDF sample space variables to output streams.
static auto ordinary(const std::vector<ctr::Term>& vec) -> bool
Find out if a vector of Terms only contains ordinary moment terms.
static auto central(const std::vector<ctr::Term>& vec) -> bool
Find out if a vector of Terms contains any central moment terms.
template<std::size_t D>
auto pdfInfo(const std::vector<std::vector<tk::real>>& binsizes, const std::vector<std::string>& names, const std::vector<std::vector<tk::real>>& exts, const std::vector<Probability>& pdfs, tk::ctr::Moment m, std::size_t idx, std::uint64_t it, tk::real time) -> PDFInfo
Find PDF information, see tk::ctr::PDFInfo.
template<std::size_t D>
auto numPDF(const std::vector<std::vector<tk::real>>& binsizes, const std::vector<Probability>& pdfs, ctr::Moment m) -> std::size_t
static auto lookup(const Product& p, const std::map<Product, tk::real>& moments) -> tk::real
Lookup moment in moments map based on product key.
static auto mean(char var, kw::ncomp::info::expect::type c) -> Product
static auto covariance(char var1, kw::ncomp::info::expect::type c1, char var2, kw::ncomp::info::expect::type c2) -> Product
static auto variance(char var, kw::ncomp::info::expect::type c) -> Product
static auto cen3(char var, kw::ncomp::info::expect::type c) -> Product
static auto ord2(char var, kw::ncomp::info::expect::type c) -> Product

Enum documentation

enum class tk::ctr::Moment: uint8_t

Moment specifies which type of moment is computed for a quantity in a Term.

Enumerators
ORDINARY

Full variable.

CENTRAL

Fluctuation.

Typedef documentation

using tk::ctr::Product = std::vector<Term>

Products are arbitrary number of Terms to be multiplied and ensemble averaged.

An example is the scalar flux in x direction which needs two terms for ensemble averaging: (Y-<Y>) and (U-<U>), then the central moment is <yu> = <(Y-<Y>)(U-<U>)>, another example is the third mixed central moment of three scalars which needs three terms for ensemble averaging: (Y1-<Y1>), (Y2-<Y2>), and (Y3-<Y3>), then the central moment is <y1y2y3> = <(Y1-<Y1>)(Y2-<Y2>)(Y3-<Y3>)>.

using tk::ctr::OffsetMap = std::map<char, ncomp_t, CaseInsensitiveCharLess>

Map associating offsets to dependent variables for systems.

This map associates offsets of systems of differential equations in a larger data array storing dependent variables for all scalar components of a system of systems. These offsets are where a particular system starts and their field (or component) ids then can be used to access an individual scalar component based on theses offsets.

using tk::ctr::NcompMap = std::map<char, ncomp_t, CaseInsensitiveCharLess>

Map associating number of scalar components to dependent variables for systems.

This map associates the number of properties (scalar components) of systems of differential equations for all scalar components of a system of systems.

Function documentation

RawRNGType tk::ctr::raw(RNGType r) constexpr

Parameters
in RNG enum class value
Returns Enum class underlying value using static_cast

Return underlying type

void tk::ctr::pup(PUP::er& p, Term& t)

Pack/Unpack: Namespace-scope serialize Term object for Charm++.

Parameters
in/out Charm++'s PUP::er serializer object reference
in/out Term object reference

static std::string tk::ctr::operator+(const std::string& lhs, const Term& term)

Operator + for adding Term (var+field) to a std::string.

Parameters
lhs in std::string to add to
term in Term to add
Returns Updated std::string

static std::string& tk::ctr::operator+=(std::string& os, const Term& term)

Operator += for adding Term (var+field) to a std::string.

Parameters
os in/out std::string to add to
term in Term to add
Returns Updated std::string

static std::ostream& tk::ctr::operator<<(std::ostream& os, const Term& term)

Operator << for writing Term to output streams.

Parameters
os in/out Output stream to write to
term in Term to write
Returns Updated output stream

static std::string tk::ctr::operator+(const std::string& lhs, const Product& p)

Operator + for adding products (var+field) to a std::string.

Parameters
lhs in std::string to add to
in Product to add
Returns Updated std::string

static std::ostream& tk::ctr::operator<<(std::ostream& os, const Product& p)

Operator << for writing products to output streams.

Parameters
os in/out Output stream to write to
in Product, std::vector< Term >, to write
Returns Updated output stream

static std::ostream& tk::ctr::pdf(std::ostream& os, const std::vector<Term>& var, const std::vector<tk::real>& bin, const std::string& name, const std::vector<tk::real>& ext)

Function for writing PDF sample space variables to output streams.

Parameters
os in/out Output stream to write to
var in Vector of Terms to write
bin in Vector of PDF bin sizes
name in Name of PDF
ext in Vector of sample space extents
Returns Updated output stream

static bool tk::ctr::ordinary(const std::vector<ctr::Term>& vec)

Find out if a vector of Terms only contains ordinary moment terms.

Parameters
vec in Vector of Terms to check
Returns Boolean indicating if all terms are ordinary

If and only if all terms are ordinary, the vector of Terms is ordinary.

static bool tk::ctr::central(const std::vector<ctr::Term>& vec)

Find out if a vector of Terms contains any central moment terms.

Parameters
vec in Vector of Terms to check
Returns Boolean indicating of any term is central

If any term is central, the vector of Terms is central.

template<std::size_t D>
PDFInfo tk::ctr::pdfInfo(const std::vector<std::vector<tk::real>>& binsizes, const std::vector<std::string>& names, const std::vector<std::vector<tk::real>>& exts, const std::vector<Probability>& pdfs, tk::ctr::Moment m, std::size_t idx, std::uint64_t it, tk::real time)

Find PDF information, see tk::ctr::PDFInfo.

Parameters
binsizes in Vector of sample space bin sizes for multiple PDFs
names in Vector of PDF names
exts in Vector of sample space extents. Note: if the user did not specify extents for a PDF, the corresponding extents vector still exists but it is empty.
pdfs in Vector of PDFs
in ORDINARY or CENTRAL PDF we are looking for
idx in Index of the PDF within the list of matching (based on D and m) PDFs requested
it in Iteration count
time in Physical time
Returns The PDF metadata requested

Find PDF information given the sample space dimension (template argument D), ordinary or central PDF (m), and the index within the list of matching (based on D and m) PDFs requested (idx). This function must find the PDF, if it does not, it throws an exception.

template<std::size_t D>
std::size_t tk::ctr::numPDF(const std::vector<std::vector<tk::real>>& binsizes, const std::vector<Probability>& pdfs, ctr::Moment m)

Parameters
binsizes in Vector of vector of bin sizes (inner vector: a different entry for each sample space dimension for potentially multi-variate PDFs, outer vector: potentially multiple PDFs)
pdfs in Vector of PDFs
in ORDINARY or CENTRAL PDF we are looking for
Returns The number of PDFs matchin the criteria discussed above

Extract number of PDFs given sample space dimension

Count number of PDFs given the sample space dimension (template argument D) and whether the PDF is ordinary or central (m)

static Product tk::ctr::mean(char var, kw::ncomp::info::expect::type c)

Parameters
var in Variable
in Component number
Returns Constructed vector< Term > identifying the first ordinary moment (mean) of field (component) c of variable var

Construct mean

static Product tk::ctr::covariance(char var1, kw::ncomp::info::expect::type c1, char var2, kw::ncomp::info::expect::type c2)

Parameters
var1 in Variable 1
c1 in Component number 1
var2 in Variable 2
c2 in Component number 2
Returns Constructed vector< Term > identifying the first ordinary moment (mean) of field (component) c of variable var

Construct covariance

static Product tk::ctr::variance(char var, kw::ncomp::info::expect::type c)

Parameters
var in Variable
in Component number
Returns Constructed vector< Term > identifying the second central moment (variance) of field (component) c of variable var

Construct variance

static Product tk::ctr::cen3(char var, kw::ncomp::info::expect::type c)

Parameters
var in Variable
in Component number
Returns Constructed vector< Term > identifying the third central moment of field (component) c of variable var

Construct third central moment

static Product tk::ctr::ord2(char var, kw::ncomp::info::expect::type c)

Parameters
var in Variable
in Component number
Returns Constructed vector< Term > identifying the second ordinary moment of field (component) c of variable var

Construct second ordinary moment