OPAL (Object Oriented Parallel Accelerator Library) 2022.1
OPAL
|
#include <PyOpalObject.h>
Public Types | |
typedef PyOpalObject< C > | PyC |
typedef PyOpalObject< C > | PyC |
Public Member Functions | |
PyOpalObject () | |
PyOpalObject (std::shared_ptr< C > object) | |
PyOpalObject (const PyOpalObject< C > &rhs) | |
~PyOpalObject () | |
boost::python::class_< PyC > | make_class (const char *className) |
template<class PYCLASS > | |
void | addAttributes (PYCLASS &pyclass) |
template<class PYCLASS > | |
void | addExecute (PYCLASS &pyclass) |
template<class PYCLASS > | |
void | addRegister (PYCLASS &pyclass) |
template<class PYCLASS > | |
void | addGetOpalElement (PYCLASS &pyclass) |
template<class ValueType > | |
ValueType | dummyGet () const |
template<class ValueType > | |
void | dummySet (ValueType test) |
PyObject * | getAttribute (AttributeType type, std::string opalName) const |
void | setAttribute (AttributeType type, std::string opalName, PyObject *value) |
std::shared_ptr< C > | getOpalShared () |
PyOpalObject () | |
PyOpalObject (std::shared_ptr< C > object) | |
PyOpalObject (const PyOpalObject< C > &rhs) | |
~PyOpalObject () | |
boost::python::class_< PyC > | make_class (const char *className) |
template<class PYCLASS > | |
void | addAttributes (PYCLASS &pyclass) |
template<class PYCLASS > | |
void | addExecute (PYCLASS &pyclass) |
template<class PYCLASS > | |
void | addRegister (PYCLASS &pyclass) |
template<class PYCLASS > | |
void | addGetOpalName (PYCLASS &pyclass) |
template<class PYCLASS > | |
void | addSetOpalName (PYCLASS &pyclass) |
template<class PYCLASS > | |
void | addGetOpalElement (PYCLASS &pyclass) |
template<class PYCLASS > | |
void | addGetFieldValue (PYCLASS &pyclass, double distanceUnits, double timeUnits, double bfieldUnits, double efieldUnits) |
template<class ValueType > | |
ValueType | dummyGet () const |
template<class ValueType > | |
void | dummySet (ValueType test) |
PyObject * | getAttribute (AttributeType type, std::string opalName) const |
void | setAttribute (AttributeType type, std::string opalName, PyObject *value) |
std::shared_ptr< C > | getOpalShared () |
std::shared_ptr< C > | getOpalShared () const |
PyOpalObject () | |
PyOpalObject () | |
Protected Member Functions | |
std::string | getDocString (AttributeDef &def) |
std::string | getDocString (AttributeDef &def) |
Static Protected Member Functions | |
static void | execute (PyOpalObject< C > &pyobject) |
static void | registerObject (PyOpalObject< C > &pyobject) |
static boost::python::object | getPyOpalElement (PyOpalObject< C > &pyobject) |
static boost::python::object | getFieldValue (PyOpalObjectNS::PyOpalObject< C > &pyobject, double x, double y, double z, double t) |
static std::string | getOpalName (const PyOpalObject< C > &pyobject) |
static void | setOpalName (PyOpalObject< C > &pyobject, std::string name) |
static void | execute (PyOpalObject< C > &pyobject) |
static void | registerObject (PyOpalObject< C > &pyobject) |
static boost::python::object | getPyOpalElement (PyOpalObject< C > &pyobject) |
Protected Attributes | |
std::shared_ptr< C > | object_m |
Static Protected Attributes | |
static std::vector< AttributeDef > | attributes |
static std::string | classDocstring |
static bool | converterRegistered |
static double | distanceUnits_m = 1 |
static double | timeUnits_m = 1 |
static double | bfieldUnits_m = 1 |
static double | efieldUnits_m = 1 |
static const std::string | getFieldValueDocString |
PyOpalObject<C> is the basic wrapper class for Opal Objects
PyOpalObject<C> is a wrapper for an Opal Object C. Opal Attributes are implemented in python as properties (public member data). Some default method calls can be enabled in the concrete implementation by setting flags. Docstring can be enabled by setting classDocString.
element_m: pointer to the base element attributes: vector of attributes. The order of the vector is the order that attributes will appear in the docstring classDocString: overall docstring. docstrings on each property and method are added automatically by the framework.
property access is set up in make_class using add_property from boost::python. Normally, the "get" method can't take any data; this would mean that we can't pass an Attribute name for the OpalElement lookup. In order to get around this limitation, we have a "dummy" getter dummyGet. Then there is a "real" getter, which is hidden in the call policy for the property (a sort of pre- and post- decorator). We use PyOpalObjectGetProperty to hold the Attribute name and then dummyGet just tells PyElementGetProperty the address of the PyOpalObject. PyElementGetProperty does a postcall action to overwrite the return value with the "real" return value, based on the stored Attribute name.
Setters work in exactly the same way, except now we have dummySet and PyElementSetProperty to handle the interface.
The routine then looks like: python::boost calls dummyGet; dummyGet tells PyElementGetProperty pointer to PyOpalObject python::boost calls PyElementGetProperty.postcall PyElementGetProperty.postcall calls PyOpalObject->getAttribute; where getAttribute takes the name of the Attribute as a string. It's a bit of a faff.
Definition at line 119 of file PyOpalObject.h.
typedef PyOpalObject<C> PyOpal::PyOpalObjectNS::PyOpalObject< C >::PyC |
Definition at line 120 of file PyOpalObject.h.
typedef PyOpalObject<C> PyOpal::PyOpalObjectNS::PyOpalObject< C >::PyC |
Definition at line 121 of file PyOpalObject.h.
|
inline |
Default constructor
Definition at line 333 of file PyOpalObject.h.
|
inline |
Constructor taking the element as argument
Definition at line 124 of file PyOpalObject.h.
PyOpal::PyOpalObjectNS::PyOpalObject< C >::PyOpalObject | ( | const PyOpalObject< C > & | rhs | ) |
Copying is disabled
Definition at line 421 of file PyOpalObject.h.
|
inline |
Default destructor
Definition at line 128 of file PyOpalObject.h.
|
inline |
Default constructor
|
inline |
Constructor taking the element as argument
Definition at line 125 of file PyOpalObject.h.
PyOpal::PyOpalObjectNS::PyOpalObject< C >::PyOpalObject | ( | const PyOpalObject< C > & | rhs | ) |
Copying is disabled
|
inline |
Default destructor
Definition at line 129 of file PyOpalObject.h.
PyOpal::PyOpalObjectNS::PyOpalObject< OpalElement >::PyOpalObject | ( | ) |
PyOpal::PyOpalObjectNS::PyOpalObject< OpalElement >::PyOpalObject | ( | ) |
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addAttributes | ( | PYCLASS & | pyclass | ) |
Add attributes to the python class.
Definition at line 470 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::BOOL, PyOpal::PyOpalObjectNS::DOUBLE, PyOpal::PyOpalObjectNS::FLOATLIST, PyOpal::PyOpalObjectNS::INT, and PyOpal::PyOpalObjectNS::STRING.
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addAttributes | ( | PYCLASS & | pyclass | ) |
Add attributes to the python class.
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addExecute | ( | PYCLASS & | pyclass | ) |
Add an "execute" method to the python class (e.g. if it is an ACTION)
Definition at line 450 of file PyOpalObject.h.
Referenced by PyOpal::PyDistributionNS::BOOST_PYTHON_MODULE(), and PyOpal::PyTrackRunNS::BOOST_PYTHON_MODULE().
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addExecute | ( | PYCLASS & | pyclass | ) |
Add an "execute" method to the python class (e.g. if it is an ACTION)
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addGetFieldValue | ( | PYCLASS & | pyclass, |
double | distanceUnits, | ||
double | timeUnits, | ||
double | bfieldUnits, | ||
double | efieldUnits | ||
) |
Add a "get_field_value" method to the python class (for elements that expose a field)
It is encouraged to expose the field map for field-type objects, for user to check that the field is as expected.
Note that conversion factors for units in distance, time, bfield and efield should be provided - the OPAL unit system should be exposed to user (see OPAL docs for current recommendation). Opal will call element->apply(R*distanceUnits, P, t*timeUnits, Efield, Bfield) and return Efield*efieldUnits, BField*bfield units.
Definition at line 643 of file PyOpalObject.h.
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addGetOpalElement | ( | PYCLASS & | pyclass | ) |
Add a "get_opal_element" method to the python class (to overload as an PyOpalElement)
Definition at line 462 of file PyOpalObject.h.
Referenced by PyOpal::PyLineNS::BOOST_PYTHON_MODULE(), PyOpal::PyOpalLocalCartesianOffset::BOOST_PYTHON_MODULE(), PyOpal::PyRingDefinition::BOOST_PYTHON_MODULE(), and PyOpal::PyVerticalFFAMagnet::BOOST_PYTHON_MODULE().
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addGetOpalElement | ( | PYCLASS & | pyclass | ) |
Add a "get_opal_element" method to the python class (to overload as a PyOpalElement)
This is required for OpalElement objects, in order that they can be used in a OPAL line object (for setting up beamlines having multiple elements). In general, if C is an OpalElement, developer should call addGetOpalElement in the module setup function.
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addGetOpalName | ( | PYCLASS & | pyclass | ) |
Add a get_opal_name method to the python class (to get the opal internal string that uniquely identifies the object)
Definition at line 625 of file PyOpalObject.h.
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addRegister | ( | PYCLASS & | pyclass | ) |
Add a "register" method to the python class (to register against opal global data header)
Definition at line 456 of file PyOpalObject.h.
Referenced by PyOpal::PyBeamNS::BOOST_PYTHON_MODULE().
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addRegister | ( | PYCLASS & | pyclass | ) |
Add a "register" method to the python class (to register against opal global data object)
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::addSetOpalName | ( | PYCLASS & | pyclass | ) |
Add a set_opal_name method to the python class (to set the opal internal string that uniquely identifies the object)
Definition at line 631 of file PyOpalObject.h.
|
inline |
dummyGet sets the object ptr for PyOpalObjectGetProperty but doesn't actually do the get(...)
Definition at line 162 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObjectGetProperty< C >::setObject().
|
inline |
dummyGet sets the object ptr for PyOpalObjectGetProperty but doesn't actually do the get(...)
Definition at line 205 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObjectGetProperty< C >::setObject().
|
inline |
dummySet sets the element ptr for PyOpalObjectSetProperty but doesn't actually do the set(...)
Definition at line 168 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObjectSetProperty< C >::setObject().
|
inline |
dummySet sets the element ptr for PyOpalObjectSetProperty but doesn't actually do the set(...)
|
staticprotected |
Definition at line 296 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObject< C >::getOpalShared().
|
staticprotected |
PyObject * PyOpal::PyOpalObjectNS::PyOpalObject< C >::getAttribute | ( | AttributeType | type, |
std::string | opalName | ||
) | const |
Get the value of an attribute
It is an error if the Attribute does not exist (throws OpalException)
Definition at line 336 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::attributeName, PyOpal::PyOpalObjectNS::BOOL, PyOpal::PyOpalObjectNS::DOUBLE, PyOpal::PyOpalObjectNS::FLOATLIST, Attributes::getBool(), Attributes::getReal(), Attributes::getRealArray(), Attributes::getString(), PyOpal::PyOpalObjectNS::INT, and PyOpal::PyOpalObjectNS::STRING.
PyObject * PyOpal::PyOpalObjectNS::PyOpalObject< C >::getAttribute | ( | AttributeType | type, |
std::string | opalName | ||
) | const |
Get the value of an attribute
It is an error if the Attribute does not exist (throws OpalException)
|
protected |
pointer to the element Generates a docstring from the attribute
Definition at line 425 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::attributeName, PyOpal::PyOpalObjectNS::AttributeDef::docString_m, Attribute::getHelp(), PyOpal::PyOpalObjectNS::AttributeDef::opalName_m, PyOpal::PyOpalObjectNS::AttributeDef::pyName_m, and PyOpal::PyOpalObjectNS::AttributeDef::type_m.
|
protected |
pointer to the element Generates a docstring from the attribute
|
staticprotected |
Definition at line 271 of file PyOpalObject.h.
References Component::apply(), PyOpal::PyOpalObjectNS::PyOpalObject< C >::getOpalShared(), and Attrib::Distribution::R.
|
staticprotected |
Definition at line 377 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObject< C >::getOpalShared().
|
inline |
Returns the Opal Object from the PyOpalObject
Definition at line 190 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObject< C >::object_m.
Referenced by PyOpal::PyOpalObjectNS::PyOpalObject< C >::execute(), PyOpal::PyTrackRunNS::executeWrapper(), PyOpal::PyTrackCmdNS::executeWrapper(), PyOpal::PyOpalObjectNS::getFieldValue(), PyOpal::PyOpalObjectNS::PyOpalObject< C >::getFieldValue(), PyOpal::PyOpalObjectNS::PyOpalObject< C >::getOpalName(), PyOpal::PyOpalObjectNS::PyOpalObject< C >::getPyOpalElement(), PyOpal::PyDistributionNS::registerDistribution(), PyOpal::PyOpalObjectNS::PyOpalObject< C >::registerObject(), PyOpal::PyLine_< C >::setElement(), and PyOpal::PyOpalObjectNS::PyOpalObject< C >::setOpalName().
|
inline |
Returns the Opal Object from the PyOpalObject
Definition at line 233 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObject< C >::object_m.
|
inline |
Returns the Opal Object from the PyOpalObject (const version)
Definition at line 236 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObject< C >::object_m.
|
staticprotected |
Definition at line 315 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObject< C >::getOpalShared().
|
staticprotected |
|
inline |
This is the basic method to make a class. It should normally be called when the module is declared, BOOST_PYTHON_MODULE.
Note that while in principle this could be static, in the end we need an instance of C so that we can access the docString from the attribute.
Definition at line 439 of file PyOpalObject.h.
Referenced by PyOpal::PyBeamNS::BOOST_PYTHON_MODULE(), PyOpal::PyDistributionNS::BOOST_PYTHON_MODULE(), PyOpal::PyOpalLocalCartesianOffset::BOOST_PYTHON_MODULE(), PyOpal::PyOpalElement::BOOST_PYTHON_MODULE(), PyOpal::PyRingDefinition::BOOST_PYTHON_MODULE(), PyOpal::PyTrackRunNS::BOOST_PYTHON_MODULE(), PyOpal::PyTrackCmdNS::BOOST_PYTHON_MODULE(), and PyOpal::PyVerticalFFAMagnet::BOOST_PYTHON_MODULE().
|
inline |
This is the basic method to make a class. It should normally be called when the module is declared, BOOST_PYTHON_MODULE.
Note that while in principle this could be static, in the end we need an instance of C so that we can access the docString from the attribute.
|
staticprotected |
Definition at line 302 of file PyOpalObject.h.
References OpalData::define(), OpalData::getInstance(), and PyOpal::PyOpalObjectNS::PyOpalObject< C >::getOpalShared().
|
staticprotected |
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::setAttribute | ( | AttributeType | type, |
std::string | opalName, | ||
PyObject * | value | ||
) |
Set the value of an attribute
Definition at line 384 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::attributeName, PyOpal::PyOpalObjectNS::BOOL, PyOpal::PyOpalObjectNS::DOUBLE, PyOpal::PyOpalObjectNS::FLOATLIST, PyOpal::PyOpalObjectNS::INT, Attributes::setBool(), Attributes::setReal(), Attributes::setRealArray(), Attributes::setString(), and PyOpal::PyOpalObjectNS::STRING.
void PyOpal::PyOpalObjectNS::PyOpalObject< C >::setAttribute | ( | AttributeType | type, |
std::string | opalName, | ||
PyObject * | value | ||
) |
Set the value of an attribute
|
staticprotected |
Definition at line 383 of file PyOpalObject.h.
References PyOpal::PyOpalObjectNS::PyOpalObject< C >::getOpalShared(), and name.
|
staticprotected |
Definition at line 193 of file PyOpalObject.h.
|
staticprotected |
Definition at line 258 of file PyOpalObject.h.
|
staticprotected |
class data (attributes)
Definition at line 194 of file PyOpalObject.h.
|
staticprotected |
class docstring
Definition at line 195 of file PyOpalObject.h.
|
staticprotected |
Definition at line 256 of file PyOpalObject.h.
|
staticprotected |
Definition at line 259 of file PyOpalObject.h.
|
staticprotected |
Definition at line 260 of file PyOpalObject.h.
|
protected |
set to true if the converter has been registered
Definition at line 196 of file PyOpalObject.h.
Referenced by PyOpal::PyOpalObjectNS::PyOpalObject< C >::getOpalShared().
|
staticprotected |
Definition at line 257 of file PyOpalObject.h.