itom 1.1.0
|
00001 /* ******************************************************************** 00002 itom software 00003 URL: http://www.uni-stuttgart.de/ito 00004 Copyright (C) 2013, Institut fuer Technische Optik (ITO), 00005 Universitaet Stuttgart, Germany 00006 00007 This file is part of itom. 00008 00009 itom is free software; you can redistribute it and/or modify it 00010 under the terms of the GNU Library General Public Licence as published by 00011 the Free Software Foundation; either version 2 of the Licence, or (at 00012 your option) any later version. 00013 00014 itom is distributed in the hope that it will be useful, but 00015 WITHOUT ANY WARRANTY; without even the implied warranty of 00016 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library 00017 General Public Licence for more details. 00018 00019 You should have received a copy of the GNU Library General Public License 00020 along with itom. If not, see <http://www.gnu.org/licenses/>. 00021 *********************************************************************** */ 00022 00023 #ifndef PYTHONDATAOBJECT 00024 #define PYTHONDATAOBJECT 00025 00026 /* includes */ 00027 #include <string> 00028 #ifndef Q_MOC_RUN 00029 #define PY_ARRAY_UNIQUE_SYMBOL itom_ARRAY_API //see numpy help ::array api :: Miscellaneous :: Importing the api (this line must before including global.h) 00030 #define NO_IMPORT_ARRAY 00031 00032 //#define NPY_NO_DEPRECATED_API 0x00000007 //see comment in pythonNpDataObject.cpp 00033 //python 00034 // see http://vtk.org/gitweb?p=VTK.git;a=commitdiff;h=7f3f750596a105d48ea84ebfe1b1c4ca03e0bab3 00035 #if (defined _DEBUG) && (!defined linux) 00036 #undef _DEBUG 00037 #if (defined linux) | (defined CMAKE) 00038 #include "Python.h" 00039 #include "numpy/arrayobject.h" 00040 #else 00041 #include "Python.h" 00042 #include "../Lib/site-packages/numpy/core/include/numpy/arrayobject.h" //for numpy arrays 00043 #endif 00044 #define _DEBUG 00045 #else 00046 #ifdef linux 00047 #include "Python.h" 00048 #include "numpy/arrayobject.h" 00049 #else 00050 #include "Python.h" 00051 #include "../Lib/site-packages/numpy/core/include/numpy/arrayobject.h" //for numpy arrays 00052 #endif 00053 #endif 00054 #endif 00055 00056 #include "../../DataObject/dataobj.h" 00057 #include <qobject.h> 00058 00059 namespace ito 00060 { 00061 class PythonDataObject 00062 { 00063 00064 public: 00065 00066 //------------------------------------------------------------------------------------------------- 00067 // typedefs 00068 //------------------------------------------------------------------------------------------------- 00069 typedef struct 00070 { 00071 PyObject_HEAD 00072 DataObject* dataObject; 00073 PyObject* base; 00074 } 00075 PyDataObject; 00076 00077 00078 00079 typedef struct 00080 { 00081 char *name; 00082 int typeno; 00083 } 00084 PyDataObjectTypes; 00085 00086 #define PyDataObject_Check(op) PyObject_TypeCheck(op, &PythonDataObject::PyDataObjectType) 00087 00088 static inline void PyDataObject_SetBase( PyDataObject *op, PyObject *base ) 00089 { 00090 PyObject* x = op->base; 00091 Py_XINCREF(base); 00092 op->base = base; 00093 Py_XDECREF(x); 00094 } 00095 00096 //------------------------------------------------------------------------------------------------- 00097 // constructor, deconstructor, alloc, dellaoc 00098 //------------------------------------------------------------------------------------------------- 00099 00100 static void PyDataObject_dealloc(PyDataObject *self); 00101 static PyObject *PyDataObject_new(PyTypeObject *type, PyObject *args, PyObject *kwds); 00102 static int PyDataObject_init(PyDataObject *self, PyObject *args, PyObject *kwds); 00103 00104 static int copyNpDataObjTags2DataObj(PyObject* npDataObject, DataObject* dataObj); 00105 static int parsePyObject2StdString(PyObject* pyObj, std::string &str); 00106 00107 //------------------------------------------------------------------------------------------------- 00108 // general members 00109 //------------------------------------------------------------------------------------------------- 00110 static PyObject *PyDataObject_name(PyDataObject *self); 00111 00112 static PyObject* PyDataObject_repr(PyDataObject *self); 00113 00114 static PyObject* PyDataObject_data(PyDataObject *self); 00115 static PyObject* PyDataObject_conj(PyDataObject *self); 00116 static PyObject* PyDataObject_conjugate(PyDataObject *self); 00117 static PyObject* PyDataObject_adj(PyDataObject *self); 00118 static PyObject* PyDataObject_adjugate(PyDataObject *self); 00119 static PyObject* PyDataObject_trans(PyDataObject *self); 00120 static PyObject* PyDataObject_copy(PyDataObject *self, PyObject* args); 00121 static PyObject* PyDataObject_astype(PyDataObject *self, PyObject* args, PyObject* kwds); 00122 static PyObject* PyDataObject_normalize(PyDataObject *self, PyObject* args, PyObject* kwds); 00123 static PyObject* PyDataObject_size(PyDataObject *self, PyObject* args); 00124 static PyObject* PyDataObject_makeContinuous(PyDataObject *self); 00125 static PyObject* PyDataObject_locateROI(PyDataObject *self); 00126 static PyObject* PyDataObject_adjustROI(PyDataObject *self, PyObject* args); 00127 static PyObject* PyDataObject_squeeze(PyDataObject *self, PyObject* args); 00128 00129 static PyObject* PyDataObject_mul(PyDataObject *self, PyObject *args); 00130 static PyObject* PyDataObject_div(PyDataObject *self, PyObject *args); 00131 00132 static PyObject* PyDataObject_reshape(PyDataObject *self, PyObject *args); 00133 00134 // Get / Set metadata / objecttags 00135 static PyObject* PyDataObj_SetAxisOffset(PyDataObject *self, PyObject *args); 00136 static PyObject* PyDataObj_SetAxisScale(PyDataObject *self, PyObject *args); 00137 static PyObject* PyDataObj_SetAxisDescription(PyDataObject *self, PyObject *args); 00138 static PyObject* PyDataObj_SetAxisUnit(PyDataObject *self, PyObject *args); 00139 00140 static PyObject* PyDataObj_SetTag(PyDataObject *self, PyObject *args); 00141 static PyObject* PyDataObj_DeleteTag(PyDataObject *self, PyObject *args); 00142 static PyObject* PyDataObj_TagExists(PyDataObject *self, PyObject *args); 00143 static PyObject* PyDataObj_GetTagListSize(PyDataObject *self); 00144 static PyObject* PyDataObj_AddToProtocol(PyDataObject *self, PyObject *args); 00145 00146 // end tags 00147 00148 static PyObject* PyDataObject_RichCompare(PyDataObject *self, PyObject *other, int cmp_op); 00149 00150 static PyGetSetDef PyDataObject_getseters[]; 00151 static PyObject* PyDataObj_GetDims(PyDataObject *self, void *closure); 00152 static PyObject* PyDataObj_GetType(PyDataObject *self, void *closure); 00153 static PyObject* PyDataObj_GetShape(PyDataObject *self, void *closure); 00154 static PyObject* PyDataObj_GetContinuous(PyDataObject *self, void *closure); 00155 00156 static PyObject* PyDataObject_getTagDict(PyDataObject *self, void *clousure); 00157 00158 static PyObject* PyDataObject_getTags(PyDataObject *self, void *closure); 00159 static int PyDataObject_setTags(PyDataObject *self, PyObject *value, void *closure); 00160 static PyObject* PyDataObject_getAxisScales(PyDataObject *self, void *closure); 00161 static int PyDataObject_setAxisScales(PyDataObject *self, PyObject *value, void *closure); 00162 static PyObject* PyDataObject_getAxisOffsets(PyDataObject *self, void *closure); 00163 static int PyDataObject_setAxisOffsets(PyDataObject *self, PyObject *value, void *closure); 00164 static PyObject* PyDataObject_getAxisDescriptions(PyDataObject *self, void *closure); 00165 static int PyDataObject_setAxisDescriptions(PyDataObject *self, PyObject *value, void *closure); 00166 static PyObject* PyDataObject_getAxisUnits(PyDataObject *self, void *closure); 00167 static int PyDataObject_setAxisUnits(PyDataObject *self, PyObject *value, void *closure); 00168 static PyObject* PyDataObject_getValueUnit(PyDataObject *self, void *closure); 00169 static int PyDataObject_setValueUnit(PyDataObject *self, PyObject *value, void *closure); 00170 static PyObject* PyDataObject_getValueDescription(PyDataObject *self, void *closure); 00171 static int PyDataObject_setValueDescription(PyDataObject *self, PyObject *value, void *closure); 00172 static PyObject* PyDataObject_getValueScale(PyDataObject *self, void *closure); 00173 static PyObject* PyDataObject_getValueOffset(PyDataObject *self, void *closure); 00174 00175 static int PyDataObject_setXYRotationalMatrix(PyDataObject *self, PyObject *value, void *closure); 00176 static PyObject* PyDataObject_getXYRotationalMatrix(PyDataObject *self, void *closure); 00177 00178 static PyObject* PyDataObject_getValue(PyDataObject *self, void *closure); 00179 static int PyDataObject_setValue(PyDataObject *self, PyObject *value, void *closure); 00180 00181 static PyObject* PyDataObj_Array_StructGet(PyDataObject *self); 00182 static PyObject* PyDataObj_Array_Interface(PyDataObject *self); 00183 static PyObject* PyDataObj_Array_(PyDataObject *self, PyObject *args); 00184 00185 static PyObject* PyDataObj_ToList(PyDataObject *self); 00186 static PyObject* PyDataObj_At(ito::DataObject *dataObj, unsigned int *idx); 00187 static PyObject* PyDataObj_At(ito::DataObject *dataObj, int continuousIdx); 00188 static PyObject* PyDataObj_ToListRecursive(ito::DataObject *dataObj, unsigned int *currentIdx, int iterationIndex); 00189 00190 00191 static void PyDataObj_Capsule_Destructor(PyObject* capsule); //called if capsule (dataObject exported by __array__struct_) is destroyed 00192 00193 static PyObject* PyDataObj_Reduce(PyDataObject *self, PyObject *args); 00194 static PyObject* PyDataObj_SetState(PyDataObject *self, PyObject *args); 00195 00196 //------------------------------------------------------------------------------------------------- 00197 // number protocol 00198 // 00199 // python note: Binary and ternary functions must check the type of all their operands, and implement 00200 // the necessary conversions (at least one of the operands is an instance of the defined type). 00201 // If the operation is not defined for the given operands, binary and ternary functions must return 00202 // Py_NotImplemented, if another error occurred they must return NULL and set an exception. 00203 //------------------------------------------------------------------------------------------------- 00204 static PyObject* PyDataObj_nbAdd(PyObject* o1, PyObject* o2); 00205 static PyObject* PyDataObj_nbSubtract(PyObject* o1, PyObject* o2); 00206 static PyObject* PyDataObj_nbMultiply(PyObject* o1, PyObject* o2); 00207 static PyObject* PyDataObj_nbRemainder(PyObject* o1, PyObject* o2); 00208 static PyObject* PyDataObj_nbDivmod(PyObject* o1, PyObject* o2); 00209 static PyObject* PyDataObj_nbPower(PyObject* o1, PyObject* o2, PyObject* o3); 00210 static PyObject* PyDataObj_nbNegative(PyObject* o1); 00211 static PyObject* PyDataObj_nbPositive(PyObject* o1); 00212 static PyObject* PyDataObj_nbAbsolute(PyObject* o1); 00213 static PyObject* PyDataObj_nbInvert(PyObject* o1); 00214 static PyObject* PyDataObj_nbLshift(PyObject* o1, PyObject* o2); 00215 static PyObject* PyDataObj_nbRshift(PyObject* o1, PyObject* o2); 00216 static PyObject* PyDataObj_nbAnd(PyObject* o1, PyObject* o2); 00217 static PyObject* PyDataObj_nbXor(PyObject* o1, PyObject* o2); 00218 static PyObject* PyDataObj_nbOr(PyObject* o1, PyObject* o2); 00219 00220 static PyObject* PyDataObj_nbInplaceAdd(PyObject* o1, PyObject* o2); 00221 static PyObject* PyDataObj_nbInplaceSubtract(PyObject* o1, PyObject* o2); 00222 static PyObject* PyDataObj_nbInplaceMultiply(PyObject* o1, PyObject* o2); 00223 static PyObject* PyDataObj_nbInplaceRemainder(PyObject* o1, PyObject* o2); 00224 static PyObject* PyDataObj_nbInplacePower(PyObject* o1, PyObject* o2, PyObject* o3); 00225 static PyObject* PyDataObj_nbInplaceLshift(PyObject* o1, PyObject* o2); 00226 static PyObject* PyDataObj_nbInplaceRshift(PyObject* o1, PyObject* o2); 00227 static PyObject* PyDataObj_nbInplaceAnd(PyObject* o1, PyObject* o2); 00228 static PyObject* PyDataObj_nbInplaceXor(PyObject* o1, PyObject* o2); 00229 static PyObject* PyDataObj_nbInplaceOr(PyObject* o1, PyObject* o2); 00230 00231 //------------------------------------------------------------------------------------------------- 00232 // iterator protocol 00233 //------------------------------------------------------------------------------------------------- 00234 static PyObject* PyDataObj_getiter(PyDataObject* self); //getiterfunc tp_iter; 00235 00236 00237 //------------------------------------------------------------------------------------------------- 00238 // mapping protocol 00239 //------------------------------------------------------------------------------------------------- 00240 static int PyDataObj_mappingLength(PyDataObject* self); 00241 static PyObject* PyDataObj_mappingGetElem(PyDataObject* self, PyObject* key); 00242 static int PyDataObj_mappingSetElem(PyDataObject* self, PyObject* key, PyObject* value); 00243 00244 //------------------------------------------------------------------------------------------------- 00245 // type structures 00246 //------------------------------------------------------------------------------------------------- 00247 static PyMemberDef PyDataObject_members[]; 00248 static PyMethodDef PyDataObject_methods[]; 00249 static PyTypeObject PyDataObjectType; 00250 static PyModuleDef PyDataObjectModule; 00251 00252 static PyNumberMethods PyDataObject_numberProtocol; 00253 static PyMappingMethods PyDataObject_mappingProtocol; 00254 00255 //------------------------------------------------------------------------------------------------- 00256 // helper methods 00257 //------------------------------------------------------------------------------------------------- 00258 static RetVal PyDataObj_ParseCreateArgs(PyObject *args, PyObject *kwds, int &typeno, std::vector<unsigned int> &dims, unsigned char &continuous); 00259 00260 static PyDataObjectTypes PyDataObject_types[]; 00261 static int typeNameToNumber(const char *name); 00262 static char* typeNumberToName(int typeno); 00263 00264 static PyDataObject* createEmptyPyDataObject(); 00265 00266 static bool checkPyDataObject(int number, PyObject* o1 = NULL, PyObject* o2 = NULL, PyObject* o3 = NULL); 00267 00268 static RetVal parseTypeNumber(int typeno, char &typekind, int &itemsize); 00269 static int parseTypeNumberInverse(char typekind, int itemsize); 00270 static int getTypenumOfCompatibleType(char typekind, int itemsize); 00271 00272 //------------------------------------------------------------------------------------------------- 00273 // static type methods 00274 //------------------------------------------------------------------------------------------------- 00275 //static PyObject* PyDataObj_StaticArange(PyDataObject *self, PyObject *args); 00276 static PyObject* PyDataObj_StaticZeros(PyObject *self, PyObject *args, PyObject *kwds); 00277 static PyObject* PyDataObj_StaticOnes(PyObject *self, PyObject *args, PyObject *kwds); 00278 static PyObject* PyDataObj_StaticRand(PyObject *self, PyObject *args, PyObject *kwds); 00279 static PyObject* PyDataObj_StaticRandN(PyObject *self, PyObject *args, PyObject *kwds); 00280 static PyObject* PyDataObj_StaticEye(PyObject *self, PyObject *args /*, PyObject *kwds*/); 00281 00282 00283 //################################################################################################# 00284 // ITERATOR METHODS 00285 //################################################################################################# 00286 00287 typedef struct 00288 { 00289 PyObject_HEAD 00290 ito::DObjConstIterator it; 00291 ito::DObjConstIterator itEnd; 00292 Py_ssize_t len; 00293 PyObject* base; 00294 } 00295 PyDataObjectIter; 00296 00297 //------------------------------------------------------------------------------------------------- 00298 // constructor, deconstructor, alloc, dellaoc 00299 //------------------------------------------------------------------------------------------------- 00300 00301 static void PyDataObjectIter_dealloc(PyDataObjectIter *self); 00302 static PyObject *PyDataObjectIter_new(PyTypeObject *type, PyObject *args, PyObject *kwds); 00303 static int PyDataObjectIter_init(PyDataObjectIter *self, PyObject *args, PyObject *kwds); 00304 00305 static PyObject* PyDataObjectIter_iternext(PyDataObjectIter* self); 00306 static PyObject* PyDataObjectIter_len(PyDataObjectIter* self); 00307 00308 //------------------------------------------------------------------------------------------------- 00309 // type structures 00310 //------------------------------------------------------------------------------------------------- 00311 static PyMethodDef PyDataObjectIter_methods[]; 00312 static PyTypeObject PyDataObjectIterType; 00313 00314 00315 00316 }; 00317 00318 } //end namespace ito 00319 00320 #endif