13 {
return V(i, j, k); }
16 std::string array_with_unit_tostring(
const A& V)
18 std::ostringstream os;
24 std::string array_with_unit_unit_get(
const A& V)
26 return V.units.name();
30 void array_with_unit_unit_set(
A& V, std::string& Unit_name)
32 V.units =
Unit(Unit_name);
40 .def(luabind::constructor<
const blitz::Array<double, 1>&,
41 const std::string&>())
44 &array_with_unit_unit_get<awud1>,
45 &array_with_unit_unit_set<awud1>)
46 .def(
"__call", &awu_double_1d_read)
47 .def(
"__tostring", &array_with_unit_tostring<awud1>)
51 .
def(luabind::constructor<const
blitz::Array<
double, 2>&,
52 const
std::
string&>())
53 .def_readwrite("
value", &awud2::value)
55 &array_with_unit_unit_get<awud2>,
56 &array_with_unit_unit_set<awud2>)
57 .
def("__call", &awu_double_2d_read)
58 .
def("__tostring", &array_with_unit_tostring<awud2>)
62 .
def(luabind::constructor<const
blitz::Array<
double, 3>&,
63 const
std::
string&>())
64 .def_readwrite("value", &awud3::value)
66 &array_with_unit_unit_get<awud3>,
67 &array_with_unit_unit_set<awud3>)
68 .
def("__call", &awu_double_3d_read)
69 .
def("__tostring", &array_with_unit_tostring<awud3>)
Apply value function to a blitz array.
const Unit A("A", 1.0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0)
#define REGISTER_LUA_CLASS_NAME(X, Y)
We frequently have a double with units associated with it.
Libraries such as boost::units allow unit handling where we know the units at compile time...
Contains classes to abstract away details in various Spurr Radiative Transfer software.
#define REGISTER_LUA_END()
def(luabind::constructor< int >()) .def("rows"
double value(const FullPhysics::AutoDerivative< double > &Ad)