13template<
typename ModelType>
19 const auto&
get_cref()
const {
return model; };
21 Owner(ModelType&& m) : model(m),
index(std::type_index(typeid(ModelType))) {};
26template<
typename ModelType>
29 const ModelType& model;
32 const auto&
get_cref()
const {
return model; };
38 template<
class T>
struct tag{
using type=T;};
48template<
typename ModelPack>
70 return mp.get_cref().R(molefrac);
73 virtual double get_Arxy(
const int NT,
const int ND,
const double T,
const double rhomolar,
const EArrayd& molefrac)
const override{
74 return TDXDerivatives<
decltype(mp.get_cref()),
double,
EArrayd>::get_Ar(NT, ND, mp.get_cref(), T, rhomolar, molefrac);
78#define X(i,j) virtual double get_Ar ## i ## j(const double T, const double rho, const REArrayd& molefrac) const override { return TDXDerivatives<decltype(mp.get_cref()), double, EArrayd>::template get_Arxy<i,j>(mp.get_cref(), T, rho, molefrac); };
82#define X(i) virtual EArrayd get_Ar0 ## i ## n(const double T, const double rho, const REArrayd& molefrac) const override { auto vals = TDXDerivatives<decltype(mp.get_cref()), double, EArrayd>::template get_Ar0n<i>(mp.get_cref(), T, rho, molefrac); return Eigen::Map<Eigen::ArrayXd>(&(vals[0]), vals.size()); };
90 virtual std::map<int, double>
get_Bnvir(
const int Nderiv,
const double T,
const EArrayd& z)
const override {
96 virtual double get_dmBnvirdTm(
const int Nderiv,
const int NTderiv,
const double T,
const EArrayd& molefrac)
const override {
97 return VirialDerivatives<
decltype(mp.get_cref()),
double,
EArrayd>::get_dmBnvirdTm_runtime(Nderiv, NTderiv, mp.get_cref(), T, molefrac);
101 virtual double get_ATrhoXi(
const double T,
const int NT,
const double rhomolar,
const int ND,
const EArrayd& molefrac,
const int i,
const int NXi)
const override {
102 return TDXDerivatives<
decltype(mp.get_cref()),
double,
EArrayd>::get_ATrhoXi_runtime(mp.get_cref(), T, NT, rhomolar, ND, molefrac, i, NXi);
104 virtual double get_ATrhoXiXj(
const double T,
const int NT,
const double rhomolar,
const int ND,
const EArrayd& molefrac,
const int i,
const int NXi,
const int j,
const int NXj)
const override {
105 return TDXDerivatives<
decltype(mp.get_cref()),
double,
EArrayd>::get_ATrhoXiXj_runtime(mp.get_cref(), T, NT, rhomolar, ND, molefrac, i, NXi, j, NXj);
107 virtual double get_ATrhoXiXjXk(
const double T,
const int NT,
const double rhomolar,
const int ND,
const EArrayd& molefrac,
const int i,
const int NXi,
const int j,
const int NXj,
const int k,
const int NXk)
const override {
108 return TDXDerivatives<
decltype(mp.get_cref()),
double,
EArrayd>::get_ATrhoXiXjXk_runtime(mp.get_cref(), T, NT, rhomolar, ND, molefrac, i, NXi, j, NXj, k, NXk);
112 virtual double get_AtaudeltaXi(
const double tau,
const int NT,
const double delta,
const int ND,
const EArrayd& molefrac,
const int i,
const int NXi)
const override {
113 return TDXDerivatives<
decltype(mp.get_cref()),
double,
EArrayd>::get_AtaudeltaXi_runtime(mp.get_cref(), tau, NT, delta, ND, molefrac, i, NXi);
115 virtual double get_AtaudeltaXiXj(
const double tau,
const int NT,
const double delta,
const int ND,
const EArrayd& molefrac,
const int i,
const int NXi,
const int j,
const int NXj)
const override {
116 return TDXDerivatives<
decltype(mp.get_cref()),
double,
EArrayd>::get_AtaudeltaXiXj_runtime(mp.get_cref(), tau, NT, delta, ND, molefrac, i, NXi, j, NXj);
118 virtual double get_AtaudeltaXiXjXk(
const double tau,
const int NT,
const double delta,
const int ND,
const EArrayd& molefrac,
const int i,
const int NXi,
const int j,
const int NXj,
const int k,
const int NXk)
const override {
119 return TDXDerivatives<
decltype(mp.get_cref()),
double,
EArrayd>::get_AtaudeltaXiXjXk_runtime(mp.get_cref(), tau, NT, delta, ND, molefrac, i, NXi, j, NXj, k, NXk);
123#define X(f) virtual double f(const double T, const EArrayd& rhovec) const override { return IsochoricDerivatives<decltype(mp.get_cref()), double, EArrayd>::f(mp.get_cref(), T, rhovec); };
126#define X(f) virtual EArrayd f(const double T, const EArrayd& rhovec) const override { return IsochoricDerivatives<decltype(mp.get_cref()), double, EArrayd>::f(mp.get_cref(), T, rhovec); };
129#define X(f) virtual EMatrixd f(const double T, const EArrayd& rhovec) const override { return IsochoricDerivatives<decltype(mp.get_cref()), double, EArrayd>::f(mp.get_cref(), T, rhovec); };
132#define X(f) virtual std::tuple<double, Eigen::ArrayXd, Eigen::MatrixXd> f(const double T, const EArrayd& rhovec) const override { return IsochoricDerivatives<decltype(mp.get_cref()), double, EArrayd>::f(mp.get_cref(), T, rhovec); };
144template<
typename TemplatedModel>
auto view(
const TemplatedModel& tp){
148template<
typename TemplatedModel>
auto own(
const TemplatedModel&& tp){
149 Owner o(std::move(tp));
153template<
typename TemplatedModel>
auto make_owned(
const TemplatedModel& tmodel){
155 return std::unique_ptr<AbstractModel>(
own(std::move(tmodel)));
158template<
typename TemplatedModel>
auto make_cview(
const TemplatedModel& tmodel){
160 return std::unique_ptr<AbstractModel>(
view(tmodel));
168template<
typename ModelType>
176 if (mptr !=
nullptr){
179 else if (mptr2 !=
nullptr){
192template<
typename ModelType>
199 if (mptr2 !=
nullptr){
203 throw teqp::InvalidArgument(
"Unable to cast model to desired type; only the Owner ownership model is allowed");
Eigen::Array< double, Nderivsmax+1, Nderivsmax+1 > derivs
virtual ISOCHORIC_multimatrix_args Eigen::ArrayXd get_Psir_sigma_derivs(const double T, const EArrayd &rhovec, const EArrayd &v) const override
virtual double get_AtaudeltaXi(const double tau, const int NT, const double delta, const int ND, const EArrayd &molefrac, const int i, const int NXi) const override
const std::type_index & get_type_index() const override
virtual double get_dmBnvirdTm(const int Nderiv, const int NTderiv, const double T, const EArrayd &molefrac) const override
auto & get_ModelPack_ref()
virtual EArray33d get_deriv_mat2(const double T, double rho, const EArrayd &z) const override
virtual double get_AtaudeltaXiXjXk(const double tau, const int NT, const double delta, const int ND, const EArrayd &molefrac, const int i, const int NXi, const int j, const int NXj, const int k, const int NXk) const override
virtual double get_ATrhoXiXjXk(const double T, const int NT, const double rhomolar, const int ND, const EArrayd &molefrac, const int i, const int NXi, const int j, const int NXj, const int k, const int NXk) const override
virtual std::map< int, double > get_Bnvir(const int Nderiv, const double T, const EArrayd &z) const override
virtual double get_Arxy(const int NT, const int ND, const double T, const double rhomolar, const EArrayd &molefrac) const override
virtual double get_AtaudeltaXiXj(const double tau, const int NT, const double delta, const int ND, const EArrayd &molefrac, const int i, const int NXi, const int j, const int NXj) const override
virtual double get_R(const EArrayd &molefrac) const override
virtual AR0N_args double get_B2vir(const double T, const EArrayd &z) const override
virtual double get_B12vir(const double T, const EArrayd &z) const override
virtual double get_ATrhoXiXj(const double T, const int NT, const double rhomolar, const int ND, const EArrayd &molefrac, const int i, const int NXi, const int j, const int NXj) const override
DerivativeAdapter(internal::tag< T >, const T &&mp)
virtual double get_ATrhoXi(const double T, const int NT, const double rhomolar, const int ND, const EArrayd &molefrac, const int i, const int NXi) const override
const auto & get_ModelPack_cref() const
auto make_cview(const TemplatedModel &tmodel)
auto own(const TemplatedModel &&tp)
auto view(const TemplatedModel &tp)
ModelType & get_model_ref(AbstractModel *am)
Get a mutable reference to the model.
auto make_owned(const TemplatedModel &tmodel)
const ModelType & get_model_cref(const AbstractModel *am)
Get a const reference to the model that is being held in a DerivativeAdapter instance.
ConstViewer(ModelType &m)
const std::type_index index
const auto & get_cref() const
const auto & get_cref() const
const std::type_index index
#define ISOCHORIC_matrix_args
#define ISOCHORIC_double_args
Eigen::Array< double, 3, 3 > EArray33d
#define ISOCHORIC_multimatrix_args
#define ISOCHORIC_array_args
Eigen::ArrayX< double > EArrayd