Newer
Older
Ian Bell
committed
#include "pybind11_wrapper.hpp"
#include "teqp/algorithms/critical_tracing.hpp"
// The implementation of each prototype are in separate files to move the compilation into
// multiple compilation units so that multiple processors can be used
// at the same time to carry out the compilation
//
// This speeds up things a lot on linux, but not much in MSVC
Ian Bell
committed
void add_vdW(py::module &m);
void add_PCSAFT(py::module& m);
void add_CPA(py::module& m);
void add_multifluid(py::module& m);
void add_multifluid_mutant(py::module& m);
void add_multifluid_mutant_invariant(py::module& m);
/// Instantiate "instances" of models (really wrapped Python versions of the models), and then attach all derivative methods
void init_teqp(py::module& m) {
Ian Bell
committed
add_vdW(m);
add_PCSAFT(m);
add_CPA(m);
add_multifluid(m);
add_multifluid_mutant(m);
add_multifluid_mutant_invariant(m);
// The options class for critical tracer, not tied to a particular model
py::class_<TCABOptions>(m, "TCABOptions")
.def(py::init<>())
.def_readwrite("abs_err", &TCABOptions::abs_err)
.def_readwrite("rel_err", &TCABOptions::rel_err)
.def_readwrite("init_dt", &TCABOptions::init_dt)
Ian Bell
committed
.def_readwrite("max_dt", &TCABOptions::max_dt)
.def_readwrite("max_step_count", &TCABOptions::max_step_count)
.def_readwrite("integration_order", &TCABOptions::integration_order)
;
// The options class for isotherm tracer, not tied to a particular model
py::class_<TVLEOptions>(m, "TVLEOptions")
.def(py::init<>())
.def_readwrite("abs_err", &TVLEOptions::abs_err)
.def_readwrite("rel_err", &TVLEOptions::rel_err)
.def_readwrite("init_dt", &TVLEOptions::init_dt)
.def_readwrite("max_dt", &TVLEOptions::max_dt)
.def_readwrite("max_steps", &TVLEOptions::max_steps)
.def_readwrite("integration_order", &TVLEOptions::integration_order)
;
// Some functions for timing overhead of interface
m.def("___mysummer", [](const double &c, const Eigen::ArrayXd &x) { return c*x.sum(); });
using RAX = Eigen::Ref<Eigen::ArrayXd>;
using namespace pybind11::literals; // for "arg"_a
m.def("___mysummerref", [](const double& c, const RAX x) { return c * x.sum(); }, "c"_a, "x"_a.noconvert());
m.def("___myadder", [](const double& c, const double& d) { return c+d; });
}
PYBIND11_MODULE(teqp, m) {
m.doc() = "TEQP: Templated Equation of State Package";
m.attr("__version__") = TEQPVERSION;