| [1337] | 1 | //
|
|---|
| 2 | // ********************************************************************
|
|---|
| 3 | // * License and Disclaimer *
|
|---|
| 4 | // * *
|
|---|
| 5 | // * The Geant4 software is copyright of the Copyright Holders of *
|
|---|
| 6 | // * the Geant4 Collaboration. It is provided under the terms and *
|
|---|
| 7 | // * conditions of the Geant4 Software License, included in the file *
|
|---|
| 8 | // * LICENSE and available at http://cern.ch/geant4/license . These *
|
|---|
| 9 | // * include a list of copyright holders. *
|
|---|
| 10 | // * *
|
|---|
| 11 | // * Neither the authors of this software system, nor their employing *
|
|---|
| 12 | // * institutes,nor the agencies providing financial support for this *
|
|---|
| 13 | // * work make any representation or warranty, express or implied, *
|
|---|
| 14 | // * regarding this software system or assume any liability for its *
|
|---|
| 15 | // * use. Please see the license in the file LICENSE and URL above *
|
|---|
| 16 | // * for the full disclaimer and the limitation of liability. *
|
|---|
| 17 | // * *
|
|---|
| 18 | // * This code implementation is the result of the scientific and *
|
|---|
| 19 | // * technical work of the GEANT4 collaboration. *
|
|---|
| 20 | // * By using, copying, modifying or distributing the software (or *
|
|---|
| 21 | // * any work based on the software) you agree to acknowledge its *
|
|---|
| 22 | // * use in resulting scientific publications, and indicate your *
|
|---|
| 23 | // * acceptance of all terms of the Geant4 Software license. *
|
|---|
| 24 | // ********************************************************************
|
|---|
| 25 | //
|
|---|
| 26 | // $Id: pyG4RotationMatrix.cc,v 1.4 2006/06/29 15:33:15 gunter Exp $
|
|---|
| 27 | // $Name: geant4-09-04-beta-01 $
|
|---|
| 28 | // ====================================================================
|
|---|
| 29 | // pyG4RotationMatrix.cc
|
|---|
| 30 | //
|
|---|
| 31 | // 2005 Q
|
|---|
| 32 | // ====================================================================
|
|---|
| 33 | #include <boost/python.hpp>
|
|---|
| 34 | #include "G4RotationMatrix.hh"
|
|---|
| 35 |
|
|---|
| 36 | using namespace boost::python;
|
|---|
| 37 |
|
|---|
| 38 | typedef G4RotationMatrix XXX; // ...
|
|---|
| 39 |
|
|---|
| 40 | // ====================================================================
|
|---|
| 41 | // thin wrappers
|
|---|
| 42 | // ====================================================================
|
|---|
| 43 | namespace pyG4RotationMatrix {
|
|---|
| 44 |
|
|---|
| 45 | XXX&(XXX::*f1_rotate)(G4double, const G4ThreeVector&)= &XXX::rotate;
|
|---|
| 46 | XXX&(XXX::*f2_rotate)(G4double, const G4ThreeVector*)= &XXX::rotate;
|
|---|
| 47 |
|
|---|
| 48 | };
|
|---|
| 49 |
|
|---|
| 50 | using namespace pyG4RotationMatrix;
|
|---|
| 51 |
|
|---|
| 52 | // ====================================================================
|
|---|
| 53 | // module definition
|
|---|
| 54 | // ====================================================================
|
|---|
| 55 | void export_G4RotationMatrix()
|
|---|
| 56 | {
|
|---|
| 57 | class_<G4RotationMatrix>("G4RotationMatrix", "rotation matrix")
|
|---|
| 58 | // constructors
|
|---|
| 59 | .def(init<const XXX&>())
|
|---|
| 60 |
|
|---|
| 61 | // property
|
|---|
| 62 | .add_property("xx", &XXX::xx)
|
|---|
| 63 | .add_property("xy", &XXX::xy)
|
|---|
| 64 | .add_property("xz", &XXX::xz)
|
|---|
| 65 | .add_property("yx", &XXX::yx)
|
|---|
| 66 | .add_property("yy", &XXX::yy)
|
|---|
| 67 | .add_property("yz", &XXX::yz)
|
|---|
| 68 | .add_property("zx", &XXX::zx)
|
|---|
| 69 | .add_property("zy", &XXX::zy)
|
|---|
| 70 | .add_property("zz", &XXX::zz)
|
|---|
| 71 | .def_readonly("IDENTITY", &XXX::IDENTITY)
|
|---|
| 72 |
|
|---|
| 73 | // methods
|
|---|
| 74 | .def("colX", &XXX::colX)
|
|---|
| 75 | .def("colY", &XXX::colY)
|
|---|
| 76 | .def("colZ", &XXX::colZ)
|
|---|
| 77 | .def("rowX", &XXX::rowX)
|
|---|
| 78 | .def("rowY", &XXX::rowY)
|
|---|
| 79 | .def("rowZ", &XXX::rowZ)
|
|---|
| 80 | .def("getPhi", &XXX::getPhi)
|
|---|
| 81 | .def("getTheta", &XXX::getTheta)
|
|---|
| 82 | .def("getPsi", &XXX::getPsi)
|
|---|
| 83 | .def("phi", &XXX::phi)
|
|---|
| 84 | .def("theta", &XXX::theta)
|
|---|
| 85 | .def("psi", &XXX::psi)
|
|---|
| 86 | .def("getDelta", &XXX::getDelta)
|
|---|
| 87 | .def("getAxis", &XXX::getAxis)
|
|---|
| 88 | .def("delta", &XXX::axis)
|
|---|
| 89 | .def("axis", &XXX::delta)
|
|---|
| 90 | .def("phiX", &XXX::phiX)
|
|---|
| 91 | .def("phiY", &XXX::phiY)
|
|---|
| 92 | .def("phiZ", &XXX::phiZ)
|
|---|
| 93 | .def("thetaX", &XXX::thetaX)
|
|---|
| 94 | .def("thetaY", &XXX::thetaY)
|
|---|
| 95 | .def("thetaZ", &XXX::thetaZ)
|
|---|
| 96 | .def("setPhi", &XXX::setPhi)
|
|---|
| 97 | .def("setTheta", &XXX::setTheta)
|
|---|
| 98 | .def("setPsi", &XXX::setPsi)
|
|---|
| 99 | .def("setAxis", &XXX::setAxis)
|
|---|
| 100 | .def("setDelta", &XXX::setDelta)
|
|---|
| 101 | .def("isIdentity", &XXX::isIdentity)
|
|---|
| 102 | .def("rotateX", &XXX::rotateX,
|
|---|
| 103 | return_value_policy<reference_existing_object>())
|
|---|
| 104 | .def("rotateY", &XXX::rotateY,
|
|---|
| 105 | return_value_policy<reference_existing_object>())
|
|---|
| 106 | .def("rotateZ", &XXX::rotateZ,
|
|---|
| 107 | return_value_policy<reference_existing_object>())
|
|---|
| 108 | .def("rotate", f1_rotate,
|
|---|
| 109 | return_value_policy<reference_existing_object>())
|
|---|
| 110 | .def("rotate", f2_rotate,
|
|---|
| 111 | return_value_policy<reference_existing_object>())
|
|---|
| 112 | .def("rotateAxes", &XXX::rotateAxes,
|
|---|
| 113 | return_value_policy<reference_existing_object>())
|
|---|
| 114 | .def("inverse", &XXX::inverse)
|
|---|
| 115 | .def("invert", &XXX::invert,
|
|---|
| 116 | return_value_policy<reference_existing_object>())
|
|---|
| 117 |
|
|---|
| 118 | // operators
|
|---|
| 119 | .def(self_ns::str(self))
|
|---|
| 120 | .def(self == self)
|
|---|
| 121 | .def(self != self)
|
|---|
| 122 | .def(self > self)
|
|---|
| 123 | .def(self < self)
|
|---|
| 124 | .def(self >= self)
|
|---|
| 125 | .def(self <= self)
|
|---|
| 126 | .def(self * self)
|
|---|
| 127 | .def(self * G4ThreeVector())
|
|---|
| 128 | .def(self *= self)
|
|---|
| 129 | ;
|
|---|
| 130 | }
|
|---|
| 131 |
|
|---|