31 #include <boost/python.hpp>
35 using namespace boost::python;
36 using namespace CLHEP;
43 namespace pyG4ThreeVector {
93 using namespace pyG4ThreeVector;
100 class_<G4ThreeVector>(
"G4ThreeVector",
"general 3-vector")
102 .def(init<G4double>())
103 .def(init<G4double, G4double>())
104 .def(init<G4double, G4double, G4double>())
105 .def(init<const XXX&>())
108 .add_property(
"x", &
XXX::x, &XXX::setX)
109 .add_property(
"y", &
XXX::y, &XXX::setY)
110 .add_property(
"z", &
XXX::z, &XXX::setZ)
115 .def(
"mag", &XXX::mag)
116 .def(
"mag2", &XXX::mag2)
119 .def(
"setMag", &XXX::setMag)
120 .def(
"setPerp", &XXX::setPerp)
121 .def(
"setCylTheta", &XXX::setCylTheta)
124 .def(
"unit", &XXX::unit)
125 .def(
"orthogonal", &XXX::orthogonal)
126 .def(
"dot", &XXX::dot)
128 .def(
"pseudoRapidity", &XXX::pseudoRapidity)
129 .def(
"setEta", &XXX::setEta)
130 .def(
"setCylEta",&XXX::setCylEta)
131 .def(
"setRThetaPhi", &XXX::setRThetaPhi)
132 .def(
"setREtaPhi", &XXX::setREtaPhi)
133 .def(
"setRhoPhiZ", &XXX::setRhoPhiZ)
134 .def(
"setRhoPhiEta", &XXX::setRhoPhiEta)
135 .def(
"getX", &XXX::getX)
136 .def(
"getY", &XXX::getY)
137 .def(
"getZ", &XXX::getZ)
138 .def(
"getR", &XXX::getR)
142 .def(
"rho", &XXX::rho)
143 .def(
"getRho", &XXX::getRho)
144 .def(
"getEta", &XXX::getEta)
145 .def(
"setR", &XXX::setR)
146 .def(
"setRho", &XXX::setRho)
148 .def(
"diff2", &XXX::diff2)
150 .staticmethod(
"setTolerance")
152 .staticmethod(
"getTolerance")
154 .def(
"isParallel", &XXX::isParallel, f_isParallel())
155 .def(
"isOrthogonal", &XXX::isOrthogonal, f_isOrthogonal())
156 .def(
"howParallel", &XXX::howParallel)
157 .def(
"howOrthogonal", &XXX::howOrthogonal)
158 .def(
"beta", &XXX::beta)
159 .def(
"gamma", &XXX::gamma)
160 .def(
"deltaPhi", &XXX::deltaPhi)
161 .def(
"coLinearRapidity", &XXX::coLinearRapidity)
185 return_value_policy<reference_existing_object>())
187 return_value_policy<reference_existing_object>())
189 return_value_policy<reference_existing_object>())
190 .def(
"rotateUz", &XXX::rotateUz,
191 return_value_policy<reference_existing_object>())
193 return_value_policy<reference_existing_object>())
195 return_value_policy<reference_existing_object>())
197 return_value_policy<reference_existing_object>())
199 return_value_policy<reference_existing_object>())
202 .def(self_ns::str(
self))