/* Generated by Cython 0.17.4 on Fri May 17 18:38:19 2013 */ #define PY_SSIZE_T_CLEAN #include "Python.h" #ifndef Py_PYTHON_H #error Python headers needed to compile C extensions, please install development version of Python. #elif PY_VERSION_HEX < 0x02040000 #error Cython requires Python 2.4+. #else #include /* For offsetof */ #ifndef offsetof #define offsetof(type, member) ( (size_t) & ((type*)0) -> member ) #endif #if !defined(WIN32) && !defined(MS_WINDOWS) #ifndef __stdcall #define __stdcall #endif #ifndef __cdecl #define __cdecl #endif #ifndef __fastcall #define __fastcall #endif #endif #ifndef DL_IMPORT #define DL_IMPORT(t) t #endif #ifndef DL_EXPORT #define DL_EXPORT(t) t #endif #ifndef PY_LONG_LONG #define PY_LONG_LONG LONG_LONG #endif #ifndef Py_HUGE_VAL #define Py_HUGE_VAL HUGE_VAL #endif #ifdef PYPY_VERSION #define CYTHON_COMPILING_IN_PYPY 1 #define CYTHON_COMPILING_IN_CPYTHON 0 #else #define CYTHON_COMPILING_IN_PYPY 0 #define CYTHON_COMPILING_IN_CPYTHON 1 #endif #if PY_VERSION_HEX < 0x02050000 typedef int Py_ssize_t; #define PY_SSIZE_T_MAX INT_MAX #define PY_SSIZE_T_MIN INT_MIN #define PY_FORMAT_SIZE_T "" #define CYTHON_FORMAT_SSIZE_T "" #define PyInt_FromSsize_t(z) PyInt_FromLong(z) #define PyInt_AsSsize_t(o) __Pyx_PyInt_AsInt(o) #define PyNumber_Index(o) ((PyNumber_Check(o) && !PyFloat_Check(o)) ? PyNumber_Int(o) : \ (PyErr_Format(PyExc_TypeError, \ "expected index value, got %.200s", Py_TYPE(o)->tp_name), \ (PyObject*)0)) #define __Pyx_PyIndex_Check(o) (PyNumber_Check(o) && !PyFloat_Check(o) && \ !PyComplex_Check(o)) #define PyIndex_Check __Pyx_PyIndex_Check #define PyErr_WarnEx(category, message, stacklevel) PyErr_Warn(category, message) #define __PYX_BUILD_PY_SSIZE_T "i" #else #define __PYX_BUILD_PY_SSIZE_T "n" #define CYTHON_FORMAT_SSIZE_T "z" #define __Pyx_PyIndex_Check PyIndex_Check #endif #if PY_VERSION_HEX < 0x02060000 #define Py_REFCNT(ob) (((PyObject*)(ob))->ob_refcnt) #define Py_TYPE(ob) (((PyObject*)(ob))->ob_type) #define Py_SIZE(ob) (((PyVarObject*)(ob))->ob_size) #define PyVarObject_HEAD_INIT(type, size) \ PyObject_HEAD_INIT(type) size, #define PyType_Modified(t) typedef struct { void *buf; PyObject *obj; Py_ssize_t len; Py_ssize_t itemsize; int readonly; int ndim; char *format; Py_ssize_t *shape; Py_ssize_t *strides; Py_ssize_t *suboffsets; void *internal; } Py_buffer; #define PyBUF_SIMPLE 0 #define PyBUF_WRITABLE 0x0001 #define PyBUF_FORMAT 0x0004 #define PyBUF_ND 0x0008 #define PyBUF_STRIDES (0x0010 | PyBUF_ND) #define PyBUF_C_CONTIGUOUS (0x0020 | PyBUF_STRIDES) #define PyBUF_F_CONTIGUOUS (0x0040 | PyBUF_STRIDES) #define PyBUF_ANY_CONTIGUOUS (0x0080 | PyBUF_STRIDES) #define PyBUF_INDIRECT (0x0100 | PyBUF_STRIDES) #define PyBUF_RECORDS (PyBUF_STRIDES | PyBUF_FORMAT | PyBUF_WRITABLE) #define PyBUF_FULL (PyBUF_INDIRECT | PyBUF_FORMAT | PyBUF_WRITABLE) typedef int (*getbufferproc)(PyObject *, Py_buffer *, int); typedef void (*releasebufferproc)(PyObject *, Py_buffer *); #endif #if PY_MAJOR_VERSION < 3 #define __Pyx_BUILTIN_MODULE_NAME "__builtin__" #define __Pyx_PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) \ PyCode_New(a, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) #else #define __Pyx_BUILTIN_MODULE_NAME "builtins" #define __Pyx_PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) \ PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) #endif #if PY_MAJOR_VERSION < 3 && PY_MINOR_VERSION < 6 #define PyUnicode_FromString(s) PyUnicode_Decode(s, strlen(s), "UTF-8", "strict") #endif #if PY_MAJOR_VERSION >= 3 #define Py_TPFLAGS_CHECKTYPES 0 #define Py_TPFLAGS_HAVE_INDEX 0 #endif #if (PY_VERSION_HEX < 0x02060000) || (PY_MAJOR_VERSION >= 3) #define Py_TPFLAGS_HAVE_NEWBUFFER 0 #endif #if PY_VERSION_HEX > 0x03030000 && defined(PyUnicode_KIND) #define CYTHON_PEP393_ENABLED 1 #define __Pyx_PyUnicode_READY(op) (likely(PyUnicode_IS_READY(op)) ? \ 0 : _PyUnicode_Ready((PyObject *)(op))) #define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_LENGTH(u) #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_READ_CHAR(u, i) #define __Pyx_PyUnicode_READ(k, d, i) PyUnicode_READ(k, d, i) #else #define CYTHON_PEP393_ENABLED 0 #define __Pyx_PyUnicode_READY(op) (0) #define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_SIZE(u) #define __Pyx_PyUnicode_READ_CHAR(u, i) ((Py_UCS4)(PyUnicode_AS_UNICODE(u)[i])) #define __Pyx_PyUnicode_READ(k, d, i) ((k=k), (Py_UCS4)(((Py_UNICODE*)d)[i])) #endif #if PY_MAJOR_VERSION >= 3 #define PyBaseString_Type PyUnicode_Type #define PyStringObject PyUnicodeObject #define PyString_Type PyUnicode_Type #define PyString_Check PyUnicode_Check #define PyString_CheckExact PyUnicode_CheckExact #endif #if PY_VERSION_HEX < 0x02060000 #define PyBytesObject PyStringObject #define PyBytes_Type PyString_Type #define PyBytes_Check PyString_Check #define PyBytes_CheckExact PyString_CheckExact #define PyBytes_FromString PyString_FromString #define PyBytes_FromStringAndSize PyString_FromStringAndSize #define PyBytes_FromFormat PyString_FromFormat #define PyBytes_DecodeEscape PyString_DecodeEscape #define PyBytes_AsString PyString_AsString #define PyBytes_AsStringAndSize PyString_AsStringAndSize #define PyBytes_Size PyString_Size #define PyBytes_AS_STRING PyString_AS_STRING #define PyBytes_GET_SIZE PyString_GET_SIZE #define PyBytes_Repr PyString_Repr #define PyBytes_Concat PyString_Concat #define PyBytes_ConcatAndDel PyString_ConcatAndDel #endif #if PY_VERSION_HEX < 0x02060000 #define PySet_Check(obj) PyObject_TypeCheck(obj, &PySet_Type) #define PyFrozenSet_Check(obj) PyObject_TypeCheck(obj, &PyFrozenSet_Type) #endif #ifndef PySet_CheckExact #define PySet_CheckExact(obj) (Py_TYPE(obj) == &PySet_Type) #endif #define __Pyx_TypeCheck(obj, type) PyObject_TypeCheck(obj, (PyTypeObject *)type) #if PY_MAJOR_VERSION >= 3 #define PyIntObject PyLongObject #define PyInt_Type PyLong_Type #define PyInt_Check(op) PyLong_Check(op) #define PyInt_CheckExact(op) PyLong_CheckExact(op) #define PyInt_FromString PyLong_FromString #define PyInt_FromUnicode PyLong_FromUnicode #define PyInt_FromLong PyLong_FromLong #define PyInt_FromSize_t PyLong_FromSize_t #define PyInt_FromSsize_t PyLong_FromSsize_t #define PyInt_AsLong PyLong_AsLong #define PyInt_AS_LONG PyLong_AS_LONG #define PyInt_AsSsize_t PyLong_AsSsize_t #define PyInt_AsUnsignedLongMask PyLong_AsUnsignedLongMask #define PyInt_AsUnsignedLongLongMask PyLong_AsUnsignedLongLongMask #endif #if PY_MAJOR_VERSION >= 3 #define PyBoolObject PyLongObject #endif #if PY_VERSION_HEX < 0x03020000 typedef long Py_hash_t; #define __Pyx_PyInt_FromHash_t PyInt_FromLong #define __Pyx_PyInt_AsHash_t PyInt_AsLong #else #define __Pyx_PyInt_FromHash_t PyInt_FromSsize_t #define __Pyx_PyInt_AsHash_t PyInt_AsSsize_t #endif #if (PY_MAJOR_VERSION < 3) || (PY_VERSION_HEX >= 0x03010300) #define __Pyx_PySequence_GetSlice(obj, a, b) PySequence_GetSlice(obj, a, b) #define __Pyx_PySequence_SetSlice(obj, a, b, value) PySequence_SetSlice(obj, a, b, value) #define __Pyx_PySequence_DelSlice(obj, a, b) PySequence_DelSlice(obj, a, b) #else #define __Pyx_PySequence_GetSlice(obj, a, b) (unlikely(!(obj)) ? \ (PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), (PyObject*)0) : \ (likely((obj)->ob_type->tp_as_mapping) ? (PySequence_GetSlice(obj, a, b)) : \ (PyErr_Format(PyExc_TypeError, "'%.200s' object is unsliceable", (obj)->ob_type->tp_name), (PyObject*)0))) #define __Pyx_PySequence_SetSlice(obj, a, b, value) (unlikely(!(obj)) ? \ (PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), -1) : \ (likely((obj)->ob_type->tp_as_mapping) ? (PySequence_SetSlice(obj, a, b, value)) : \ (PyErr_Format(PyExc_TypeError, "'%.200s' object doesn't support slice assignment", (obj)->ob_type->tp_name), -1))) #define __Pyx_PySequence_DelSlice(obj, a, b) (unlikely(!(obj)) ? \ (PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), -1) : \ (likely((obj)->ob_type->tp_as_mapping) ? (PySequence_DelSlice(obj, a, b)) : \ (PyErr_Format(PyExc_TypeError, "'%.200s' object doesn't support slice deletion", (obj)->ob_type->tp_name), -1))) #endif #if PY_MAJOR_VERSION >= 3 #define PyMethod_New(func, self, klass) ((self) ? PyMethod_New(func, self) : PyInstanceMethod_New(func)) #endif #if PY_VERSION_HEX < 0x02050000 #define __Pyx_GetAttrString(o,n) PyObject_GetAttrString((o),((char *)(n))) #define __Pyx_SetAttrString(o,n,a) PyObject_SetAttrString((o),((char *)(n)),(a)) #define __Pyx_DelAttrString(o,n) PyObject_DelAttrString((o),((char *)(n))) #else #define __Pyx_GetAttrString(o,n) PyObject_GetAttrString((o),(n)) #define __Pyx_SetAttrString(o,n,a) PyObject_SetAttrString((o),(n),(a)) #define __Pyx_DelAttrString(o,n) PyObject_DelAttrString((o),(n)) #endif #if PY_VERSION_HEX < 0x02050000 #define __Pyx_NAMESTR(n) ((char *)(n)) #define __Pyx_DOCSTR(n) ((char *)(n)) #else #define __Pyx_NAMESTR(n) (n) #define __Pyx_DOCSTR(n) (n) #endif #if PY_MAJOR_VERSION >= 3 #define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y) #define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y) #else #define __Pyx_PyNumber_Divide(x,y) PyNumber_Divide(x,y) #define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceDivide(x,y) #endif #ifndef __PYX_EXTERN_C #ifdef __cplusplus #define __PYX_EXTERN_C extern "C" #else #define __PYX_EXTERN_C extern #endif #endif #if defined(WIN32) || defined(MS_WINDOWS) #define _USE_MATH_DEFINES #endif #include #define __PYX_HAVE__tables__indexesextension #define __PYX_HAVE_API__tables__indexesextension #include "stdio.h" #include "stdlib.h" #include "numpy/arrayobject.h" #include "numpy/ufuncobject.h" #include "time.h" #include "hdf5.h" #include "H5ATTR.h" #include "H5ARRAY.h" #include "utils.h" #include "typeconv.h" #include "blosc_filter.h" #include "H5ARRAY-opt.h" #include "idx-opt.h" #ifdef _OPENMP #include #endif /* _OPENMP */ #ifdef PYREX_WITHOUT_ASSERTIONS #define CYTHON_WITHOUT_ASSERTIONS #endif /* inline attribute */ #ifndef CYTHON_INLINE #if defined(__GNUC__) #define CYTHON_INLINE __inline__ #elif defined(_MSC_VER) #define CYTHON_INLINE __inline #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L #define CYTHON_INLINE inline #else #define CYTHON_INLINE #endif #endif /* unused attribute */ #ifndef CYTHON_UNUSED # if defined(__GNUC__) # if !(defined(__cplusplus)) || (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4)) # define CYTHON_UNUSED __attribute__ ((__unused__)) # else # define CYTHON_UNUSED # endif # elif defined(__ICC) || (defined(__INTEL_COMPILER) && !defined(_MSC_VER)) # define CYTHON_UNUSED __attribute__ ((__unused__)) # else # define CYTHON_UNUSED # endif #endif typedef struct {PyObject **p; char *s; const long n; const char* encoding; const char is_unicode; const char is_str; const char intern; } __Pyx_StringTabEntry; /*proto*/ /* Type Conversion Predeclarations */ #define __Pyx_PyBytes_FromUString(s) PyBytes_FromString((char*)s) #define __Pyx_PyBytes_AsUString(s) ((unsigned char*) PyBytes_AsString(s)) #define __Pyx_Owned_Py_None(b) (Py_INCREF(Py_None), Py_None) #define __Pyx_PyBool_FromLong(b) ((b) ? (Py_INCREF(Py_True), Py_True) : (Py_INCREF(Py_False), Py_False)) static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*); static CYTHON_INLINE PyObject* __Pyx_PyNumber_Int(PyObject* x); static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*); static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t); static CYTHON_INLINE size_t __Pyx_PyInt_AsSize_t(PyObject*); #if CYTHON_COMPILING_IN_CPYTHON #define __pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x)) #else #define __pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x) #endif #define __pyx_PyFloat_AsFloat(x) ((float) __pyx_PyFloat_AsDouble(x)) #ifdef __GNUC__ /* Test for GCC > 2.95 */ #if __GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95)) #define likely(x) __builtin_expect(!!(x), 1) #define unlikely(x) __builtin_expect(!!(x), 0) #else /* __GNUC__ > 2 ... */ #define likely(x) (x) #define unlikely(x) (x) #endif /* __GNUC__ > 2 ... */ #else /* __GNUC__ */ #define likely(x) (x) #define unlikely(x) (x) #endif /* __GNUC__ */ static PyObject *__pyx_m; static PyObject *__pyx_b; static PyObject *__pyx_empty_tuple; static PyObject *__pyx_empty_bytes; static int __pyx_lineno; static int __pyx_clineno = 0; static const char * __pyx_cfilenm= __FILE__; static const char *__pyx_filename; #if !defined(CYTHON_CCOMPLEX) #if defined(__cplusplus) #define CYTHON_CCOMPLEX 1 #elif defined(_Complex_I) #define CYTHON_CCOMPLEX 1 #else #define CYTHON_CCOMPLEX 0 #endif #endif #if CYTHON_CCOMPLEX #ifdef __cplusplus #include #else #include #endif #endif #if CYTHON_CCOMPLEX && !defined(__cplusplus) && defined(__sun__) && defined(__GNUC__) #undef _Complex_I #define _Complex_I 1.0fj #endif static const char *__pyx_f[] = { "indexesextension.pyx", "numpy.pxd", "type.pxd", "hdf5extension.pxd", "lrucacheextension.pxd", }; /* "numpy.pxd":723 * # in Cython to enable them only on the right systems. * * ctypedef npy_int8 int8_t # <<<<<<<<<<<<<< * ctypedef npy_int16 int16_t * ctypedef npy_int32 int32_t */ typedef npy_int8 __pyx_t_5numpy_int8_t; /* "numpy.pxd":724 * * ctypedef npy_int8 int8_t * ctypedef npy_int16 int16_t # <<<<<<<<<<<<<< * ctypedef npy_int32 int32_t * ctypedef npy_int64 int64_t */ typedef npy_int16 __pyx_t_5numpy_int16_t; /* "numpy.pxd":725 * ctypedef npy_int8 int8_t * ctypedef npy_int16 int16_t * ctypedef npy_int32 int32_t # <<<<<<<<<<<<<< * ctypedef npy_int64 int64_t * #ctypedef npy_int96 int96_t */ typedef npy_int32 __pyx_t_5numpy_int32_t; /* "numpy.pxd":726 * ctypedef npy_int16 int16_t * ctypedef npy_int32 int32_t * ctypedef npy_int64 int64_t # <<<<<<<<<<<<<< * #ctypedef npy_int96 int96_t * #ctypedef npy_int128 int128_t */ typedef npy_int64 __pyx_t_5numpy_int64_t; /* "numpy.pxd":730 * #ctypedef npy_int128 int128_t * * ctypedef npy_uint8 uint8_t # <<<<<<<<<<<<<< * ctypedef npy_uint16 uint16_t * ctypedef npy_uint32 uint32_t */ typedef npy_uint8 __pyx_t_5numpy_uint8_t; /* "numpy.pxd":731 * * ctypedef npy_uint8 uint8_t * ctypedef npy_uint16 uint16_t # <<<<<<<<<<<<<< * ctypedef npy_uint32 uint32_t * ctypedef npy_uint64 uint64_t */ typedef npy_uint16 __pyx_t_5numpy_uint16_t; /* "numpy.pxd":732 * ctypedef npy_uint8 uint8_t * ctypedef npy_uint16 uint16_t * ctypedef npy_uint32 uint32_t # <<<<<<<<<<<<<< * ctypedef npy_uint64 uint64_t * #ctypedef npy_uint96 uint96_t */ typedef npy_uint32 __pyx_t_5numpy_uint32_t; /* "numpy.pxd":733 * ctypedef npy_uint16 uint16_t * ctypedef npy_uint32 uint32_t * ctypedef npy_uint64 uint64_t # <<<<<<<<<<<<<< * #ctypedef npy_uint96 uint96_t * #ctypedef npy_uint128 uint128_t */ typedef npy_uint64 __pyx_t_5numpy_uint64_t; /* "numpy.pxd":737 * #ctypedef npy_uint128 uint128_t * * ctypedef npy_float32 float32_t # <<<<<<<<<<<<<< * ctypedef npy_float64 float64_t * #ctypedef npy_float80 float80_t */ typedef npy_float32 __pyx_t_5numpy_float32_t; /* "numpy.pxd":738 * * ctypedef npy_float32 float32_t * ctypedef npy_float64 float64_t # <<<<<<<<<<<<<< * #ctypedef npy_float80 float80_t * #ctypedef npy_float128 float128_t */ typedef npy_float64 __pyx_t_5numpy_float64_t; /* "numpy.pxd":747 * # The int types are mapped a bit surprising -- * # numpy.int corresponds to 'l' and numpy.long to 'q' * ctypedef npy_long int_t # <<<<<<<<<<<<<< * ctypedef npy_longlong long_t * ctypedef npy_longlong longlong_t */ typedef npy_long __pyx_t_5numpy_int_t; /* "numpy.pxd":748 * # numpy.int corresponds to 'l' and numpy.long to 'q' * ctypedef npy_long int_t * ctypedef npy_longlong long_t # <<<<<<<<<<<<<< * ctypedef npy_longlong longlong_t * */ typedef npy_longlong __pyx_t_5numpy_long_t; /* "numpy.pxd":749 * ctypedef npy_long int_t * ctypedef npy_longlong long_t * ctypedef npy_longlong longlong_t # <<<<<<<<<<<<<< * * ctypedef npy_ulong uint_t */ typedef npy_longlong __pyx_t_5numpy_longlong_t; /* "numpy.pxd":751 * ctypedef npy_longlong longlong_t * * ctypedef npy_ulong uint_t # <<<<<<<<<<<<<< * ctypedef npy_ulonglong ulong_t * ctypedef npy_ulonglong ulonglong_t */ typedef npy_ulong __pyx_t_5numpy_uint_t; /* "numpy.pxd":752 * * ctypedef npy_ulong uint_t * ctypedef npy_ulonglong ulong_t # <<<<<<<<<<<<<< * ctypedef npy_ulonglong ulonglong_t * */ typedef npy_ulonglong __pyx_t_5numpy_ulong_t; /* "numpy.pxd":753 * ctypedef npy_ulong uint_t * ctypedef npy_ulonglong ulong_t * ctypedef npy_ulonglong ulonglong_t # <<<<<<<<<<<<<< * * ctypedef npy_intp intp_t */ typedef npy_ulonglong __pyx_t_5numpy_ulonglong_t; /* "numpy.pxd":755 * ctypedef npy_ulonglong ulonglong_t * * ctypedef npy_intp intp_t # <<<<<<<<<<<<<< * ctypedef npy_uintp uintp_t * */ typedef npy_intp __pyx_t_5numpy_intp_t; /* "numpy.pxd":756 * * ctypedef npy_intp intp_t * ctypedef npy_uintp uintp_t # <<<<<<<<<<<<<< * * ctypedef npy_double float_t */ typedef npy_uintp __pyx_t_5numpy_uintp_t; /* "numpy.pxd":758 * ctypedef npy_uintp uintp_t * * ctypedef npy_double float_t # <<<<<<<<<<<<<< * ctypedef npy_double double_t * ctypedef npy_longdouble longdouble_t */ typedef npy_double __pyx_t_5numpy_float_t; /* "numpy.pxd":759 * * ctypedef npy_double float_t * ctypedef npy_double double_t # <<<<<<<<<<<<<< * ctypedef npy_longdouble longdouble_t * */ typedef npy_double __pyx_t_5numpy_double_t; /* "numpy.pxd":760 * ctypedef npy_double float_t * ctypedef npy_double double_t * ctypedef npy_longdouble longdouble_t # <<<<<<<<<<<<<< * * ctypedef npy_cfloat cfloat_t */ typedef npy_longdouble __pyx_t_5numpy_longdouble_t; /* "tables/indexesextension.pyx":44 * npy_longdouble) * * ctypedef npy_uint16 npy_float16 # <<<<<<<<<<<<<< * * from definitions cimport hid_t, herr_t, hsize_t, H5Screate_simple, H5Sclose */ typedef npy_uint16 __pyx_t_6tables_16indexesextension_npy_float16; #if CYTHON_CCOMPLEX #ifdef __cplusplus typedef ::std::complex< float > __pyx_t_float_complex; #else typedef float _Complex __pyx_t_float_complex; #endif #else typedef struct { float real, imag; } __pyx_t_float_complex; #endif #if CYTHON_CCOMPLEX #ifdef __cplusplus typedef ::std::complex< double > __pyx_t_double_complex; #else typedef double _Complex __pyx_t_double_complex; #endif #else typedef struct { double real, imag; } __pyx_t_double_complex; #endif /*--- Type declarations ---*/ struct __pyx_obj_6tables_13hdf5extension_Node; struct __pyx_obj_6tables_13hdf5extension_Leaf; struct __pyx_obj_6tables_13hdf5extension_Array; struct __pyx_obj_6tables_16indexesextension_LastRowArray; struct __pyx_obj_6tables_17lrucacheextension_BaseCache; struct __pyx_obj_6tables_17lrucacheextension_ObjectCache; struct __pyx_obj_6tables_16indexesextension_Index; struct __pyx_obj_6tables_17lrucacheextension_NodeCache; struct __pyx_obj_6tables_17lrucacheextension_ObjectNode; struct __pyx_obj_6tables_17lrucacheextension_NumCache; struct __pyx_obj_6tables_16indexesextension_CacheArray; struct __pyx_obj_6tables_16indexesextension_IndexArray; /* "numpy.pxd":762 * ctypedef npy_longdouble longdouble_t * * ctypedef npy_cfloat cfloat_t # <<<<<<<<<<<<<< * ctypedef npy_cdouble cdouble_t * ctypedef npy_clongdouble clongdouble_t */ typedef npy_cfloat __pyx_t_5numpy_cfloat_t; /* "numpy.pxd":763 * * ctypedef npy_cfloat cfloat_t * ctypedef npy_cdouble cdouble_t # <<<<<<<<<<<<<< * ctypedef npy_clongdouble clongdouble_t * */ typedef npy_cdouble __pyx_t_5numpy_cdouble_t; /* "numpy.pxd":764 * ctypedef npy_cfloat cfloat_t * ctypedef npy_cdouble cdouble_t * ctypedef npy_clongdouble clongdouble_t # <<<<<<<<<<<<<< * * ctypedef npy_cdouble complex_t */ typedef npy_clongdouble __pyx_t_5numpy_clongdouble_t; /* "numpy.pxd":766 * ctypedef npy_clongdouble clongdouble_t * * ctypedef npy_cdouble complex_t # <<<<<<<<<<<<<< * * cdef inline object PyArray_MultiIterNew1(a): */ typedef npy_cdouble __pyx_t_5numpy_complex_t; /* "hdf5extension.pxd":18 * * # Declaration of instance variables for shared classes * cdef class Node: # <<<<<<<<<<<<<< * cdef object name * cdef hid_t parent_id */ struct __pyx_obj_6tables_13hdf5extension_Node { PyObject_HEAD PyObject *name; hid_t parent_id; }; /* "hdf5extension.pxd":22 * cdef hid_t parent_id * * cdef class Leaf(Node): # <<<<<<<<<<<<<< * cdef hid_t dataset_id * cdef hid_t type_id */ struct __pyx_obj_6tables_13hdf5extension_Leaf { struct __pyx_obj_6tables_13hdf5extension_Node __pyx_base; struct __pyx_vtabstruct_6tables_13hdf5extension_Leaf *__pyx_vtab; hid_t dataset_id; hid_t type_id; hid_t base_type_id; hid_t disk_type_id; hsize_t *dims; }; /* "hdf5extension.pxd":31 * cdef _convert_time64(self, ndarray nparr, int sense) * * cdef class Array(Leaf): # <<<<<<<<<<<<<< * cdef int rank * cdef hsize_t *maxdims */ struct __pyx_obj_6tables_13hdf5extension_Array { struct __pyx_obj_6tables_13hdf5extension_Leaf __pyx_base; int rank; hsize_t *maxdims; hsize_t *dims_chunk; }; /* "tables/indexesextension.pyx":1018 * * * cdef class LastRowArray(Array): # <<<<<<<<<<<<<< * """ * Container for keeping sorted and indices values of last rows of an index. */ struct __pyx_obj_6tables_16indexesextension_LastRowArray { struct __pyx_obj_6tables_13hdf5extension_Array __pyx_base; }; /* "lrucacheextension.pxd":26 * * # Base class for other caches * cdef class BaseCache: # <<<<<<<<<<<<<< * cdef int iscachedisabled, incsetcount * cdef long setcount, getcount, containscount */ struct __pyx_obj_6tables_17lrucacheextension_BaseCache { PyObject_HEAD struct __pyx_vtabstruct_6tables_17lrucacheextension_BaseCache *__pyx_vtab; int iscachedisabled; int incsetcount; long setcount; long getcount; long containscount; long disablecyclecount; long disableeverycycles; long enablecyclecount; long enableeverycycles; double nprobes; double hitratio; long seqn_; long nextslot; long nslots; long *ratimes; double lowesthr; PyArrayObject *atimes; PyObject *name; }; /* "lrucacheextension.pxd":49 * * # The ObjectCache class is useful for general python objects * cdef class ObjectCache(BaseCache): # <<<<<<<<<<<<<< * cdef long maxcachesize, cachesize, maxobjsize * cdef long *rsizes */ struct __pyx_obj_6tables_17lrucacheextension_ObjectCache { struct __pyx_obj_6tables_17lrucacheextension_BaseCache __pyx_base; long maxcachesize; long cachesize; long maxobjsize; long *rsizes; PyArrayObject *sizes; PyObject *__pyx___list; PyObject *__pyx___dict; struct __pyx_obj_6tables_17lrucacheextension_ObjectNode *mrunode; }; /* "tables/indexesextension.pyx":192 * * * cdef class Index: # <<<<<<<<<<<<<< * pass * */ struct __pyx_obj_6tables_16indexesextension_Index { PyObject_HEAD }; /* "lrucacheextension.pxd":17 * # Declaration of instance variables for shared classes * # The NodeCache class is useful for caching general objects (like Nodes). * cdef class NodeCache: # <<<<<<<<<<<<<< * cdef long nextslot, nslots * cdef object nodes, paths */ struct __pyx_obj_6tables_17lrucacheextension_NodeCache { PyObject_HEAD struct __pyx_vtabstruct_6tables_17lrucacheextension_NodeCache *__pyx_vtab; long nextslot; long nslots; PyObject *nodes; PyObject *paths; }; /* "lrucacheextension.pxd":43 * * # Helper class for ObjectCache * cdef class ObjectNode: # <<<<<<<<<<<<<< * cdef object key, obj * cdef long nslot */ struct __pyx_obj_6tables_17lrucacheextension_ObjectNode { PyObject_HEAD PyObject *key; PyObject *obj; long nslot; }; /* "lrucacheextension.pxd":64 * * # The NumCache class is useful for caching numerical data in an efficient way * cdef class NumCache(BaseCache): # <<<<<<<<<<<<<< * cdef long itemsize, slotsize * cdef ndarray cacheobj, keys */ struct __pyx_obj_6tables_17lrucacheextension_NumCache { struct __pyx_obj_6tables_17lrucacheextension_BaseCache __pyx_base; long itemsize; long slotsize; PyArrayObject *cacheobj; PyArrayObject *keys; void *rcache; PY_LONG_LONG *rkeys; PyObject *__pyx___dict; }; /* "tables/indexesextension.pyx":196 * * * cdef class CacheArray(Array): # <<<<<<<<<<<<<< * """Container for keeping index caches of 1st and 2nd level.""" * */ struct __pyx_obj_6tables_16indexesextension_CacheArray { struct __pyx_obj_6tables_13hdf5extension_Array __pyx_base; hid_t mem_space_id; }; /* "tables/indexesextension.pyx":226 * * * cdef class IndexArray(Array): # <<<<<<<<<<<<<< * """Container for keeping sorted and indices values.""" * */ struct __pyx_obj_6tables_16indexesextension_IndexArray { struct __pyx_obj_6tables_13hdf5extension_Array __pyx_base; void *rbufst; void *rbufln; void *rbufrv; void *rbufbc; void *rbuflb; hid_t mem_space_id; int l_chunksize; int l_slicesize; int nbounds; int indsize; struct __pyx_obj_6tables_16indexesextension_CacheArray *bounds_ext; struct __pyx_obj_6tables_17lrucacheextension_NumCache *boundscache; struct __pyx_obj_6tables_17lrucacheextension_NumCache *sortedcache; PyArrayObject *bufferbc; PyArrayObject *bufferlb; }; /* "lrucacheextension.pxd":17 * # Declaration of instance variables for shared classes * # The NodeCache class is useful for caching general objects (like Nodes). * cdef class NodeCache: # <<<<<<<<<<<<<< * cdef long nextslot, nslots * cdef object nodes, paths */ struct __pyx_vtabstruct_6tables_17lrucacheextension_NodeCache { PyObject *(*setitem)(struct __pyx_obj_6tables_17lrucacheextension_NodeCache *, PyObject *, PyObject *); long (*getslot)(struct __pyx_obj_6tables_17lrucacheextension_NodeCache *, PyObject *); PyObject *(*cpop)(struct __pyx_obj_6tables_17lrucacheextension_NodeCache *, PyObject *); }; static struct __pyx_vtabstruct_6tables_17lrucacheextension_NodeCache *__pyx_vtabptr_6tables_17lrucacheextension_NodeCache; /* "lrucacheextension.pxd":26 * * # Base class for other caches * cdef class BaseCache: # <<<<<<<<<<<<<< * cdef int iscachedisabled, incsetcount * cdef long setcount, getcount, containscount */ struct __pyx_vtabstruct_6tables_17lrucacheextension_BaseCache { int (*checkhitratio)(struct __pyx_obj_6tables_17lrucacheextension_BaseCache *); int (*couldenablecache_)(struct __pyx_obj_6tables_17lrucacheextension_BaseCache *); long (*incseqn)(struct __pyx_obj_6tables_17lrucacheextension_BaseCache *); }; static struct __pyx_vtabstruct_6tables_17lrucacheextension_BaseCache *__pyx_vtabptr_6tables_17lrucacheextension_BaseCache; /* "lrucacheextension.pxd":49 * * # The ObjectCache class is useful for general python objects * cdef class ObjectCache(BaseCache): # <<<<<<<<<<<<<< * cdef long maxcachesize, cachesize, maxobjsize * cdef long *rsizes */ struct __pyx_vtabstruct_6tables_17lrucacheextension_ObjectCache { struct __pyx_vtabstruct_6tables_17lrucacheextension_BaseCache __pyx_base; PyObject *(*removeslot_)(struct __pyx_obj_6tables_17lrucacheextension_ObjectCache *, long); PyObject *(*clearcache_)(struct __pyx_obj_6tables_17lrucacheextension_ObjectCache *); PyObject *(*updateslot_)(struct __pyx_obj_6tables_17lrucacheextension_ObjectCache *, long, long, PyObject *, PyObject *); long (*setitem_)(struct __pyx_obj_6tables_17lrucacheextension_ObjectCache *, PyObject *, PyObject *, long); long (*getslot_)(struct __pyx_obj_6tables_17lrucacheextension_ObjectCache *, PyObject *); PyObject *(*getitem_)(struct __pyx_obj_6tables_17lrucacheextension_ObjectCache *, long); }; static struct __pyx_vtabstruct_6tables_17lrucacheextension_ObjectCache *__pyx_vtabptr_6tables_17lrucacheextension_ObjectCache; /* "hdf5extension.pxd":22 * cdef hid_t parent_id * * cdef class Leaf(Node): # <<<<<<<<<<<<<< * cdef hid_t dataset_id * cdef hid_t type_id */ struct __pyx_vtabstruct_6tables_13hdf5extension_Leaf { PyObject *(*_get_type_ids)(struct __pyx_obj_6tables_13hdf5extension_Leaf *); PyObject *(*_convert_time64)(struct __pyx_obj_6tables_13hdf5extension_Leaf *, PyArrayObject *, int); }; static struct __pyx_vtabstruct_6tables_13hdf5extension_Leaf *__pyx_vtabptr_6tables_13hdf5extension_Leaf; /* "hdf5extension.pxd":31 * cdef _convert_time64(self, ndarray nparr, int sense) * * cdef class Array(Leaf): # <<<<<<<<<<<<<< * cdef int rank * cdef hsize_t *maxdims */ struct __pyx_vtabstruct_6tables_13hdf5extension_Array { struct __pyx_vtabstruct_6tables_13hdf5extension_Leaf __pyx_base; }; static struct __pyx_vtabstruct_6tables_13hdf5extension_Array *__pyx_vtabptr_6tables_13hdf5extension_Array; /* "tables/indexesextension.pyx":196 * * * cdef class CacheArray(Array): # <<<<<<<<<<<<<< * """Container for keeping index caches of 1st and 2nd level.""" * */ struct __pyx_vtabstruct_6tables_16indexesextension_CacheArray { struct __pyx_vtabstruct_6tables_13hdf5extension_Array __pyx_base; PyObject *(*initread)(struct __pyx_obj_6tables_16indexesextension_CacheArray *, int); PyObject *(*read_slice)(struct __pyx_obj_6tables_16indexesextension_CacheArray *, hsize_t, hsize_t, hsize_t, void *); }; static struct __pyx_vtabstruct_6tables_16indexesextension_CacheArray *__pyx_vtabptr_6tables_16indexesextension_CacheArray; /* "tables/indexesextension.pyx":226 * * * cdef class IndexArray(Array): # <<<<<<<<<<<<<< * """Container for keeping sorted and indices values.""" * */ struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray { struct __pyx_vtabstruct_6tables_13hdf5extension_Array __pyx_base; void *(*_g_read_sorted_slice)(struct __pyx_obj_6tables_16indexesextension_IndexArray *, hsize_t, hsize_t, hsize_t); void *(*get_lru_bounds)(struct __pyx_obj_6tables_16indexesextension_IndexArray *, int, int); void *(*get_lru_sorted)(struct __pyx_obj_6tables_16indexesextension_IndexArray *, int, int, int, int); }; static struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *__pyx_vtabptr_6tables_16indexesextension_IndexArray; /* "lrucacheextension.pxd":64 * * # The NumCache class is useful for caching numerical data in an efficient way * cdef class NumCache(BaseCache): # <<<<<<<<<<<<<< * cdef long itemsize, slotsize * cdef ndarray cacheobj, keys */ struct __pyx_vtabstruct_6tables_17lrucacheextension_NumCache { struct __pyx_vtabstruct_6tables_17lrucacheextension_BaseCache __pyx_base; void *(*getaddrslot_)(struct __pyx_obj_6tables_17lrucacheextension_NumCache *, long); long (*setitem_)(struct __pyx_obj_6tables_17lrucacheextension_NumCache *, PY_LONG_LONG, void *, long); long (*setitem1_)(struct __pyx_obj_6tables_17lrucacheextension_NumCache *, PY_LONG_LONG); long (*getslot_)(struct __pyx_obj_6tables_17lrucacheextension_NumCache *, PY_LONG_LONG); PyObject *(*getitem_)(struct __pyx_obj_6tables_17lrucacheextension_NumCache *, long, void *, long); void *(*getitem1_)(struct __pyx_obj_6tables_17lrucacheextension_NumCache *, long); }; static struct __pyx_vtabstruct_6tables_17lrucacheextension_NumCache *__pyx_vtabptr_6tables_17lrucacheextension_NumCache; /* "tables/indexesextension.pyx":1018 * * * cdef class LastRowArray(Array): # <<<<<<<<<<<<<< * """ * Container for keeping sorted and indices values of last rows of an index. */ struct __pyx_vtabstruct_6tables_16indexesextension_LastRowArray { struct __pyx_vtabstruct_6tables_13hdf5extension_Array __pyx_base; }; static struct __pyx_vtabstruct_6tables_16indexesextension_LastRowArray *__pyx_vtabptr_6tables_16indexesextension_LastRowArray; #ifndef CYTHON_REFNANNY #define CYTHON_REFNANNY 0 #endif #if CYTHON_REFNANNY typedef struct { void (*INCREF)(void*, PyObject*, int); void (*DECREF)(void*, PyObject*, int); void (*GOTREF)(void*, PyObject*, int); void (*GIVEREF)(void*, PyObject*, int); void* (*SetupContext)(const char*, int, const char*); void (*FinishContext)(void**); } __Pyx_RefNannyAPIStruct; static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL; static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname); /*proto*/ #define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL; #ifdef WITH_THREAD #define __Pyx_RefNannySetupContext(name, acquire_gil) \ if (acquire_gil) { \ PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure(); \ __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__); \ PyGILState_Release(__pyx_gilstate_save); \ } else { \ __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__); \ } #else #define __Pyx_RefNannySetupContext(name, acquire_gil) \ __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__) #endif #define __Pyx_RefNannyFinishContext() \ __Pyx_RefNanny->FinishContext(&__pyx_refnanny) #define __Pyx_INCREF(r) __Pyx_RefNanny->INCREF(__pyx_refnanny, (PyObject *)(r), __LINE__) #define __Pyx_DECREF(r) __Pyx_RefNanny->DECREF(__pyx_refnanny, (PyObject *)(r), __LINE__) #define __Pyx_GOTREF(r) __Pyx_RefNanny->GOTREF(__pyx_refnanny, (PyObject *)(r), __LINE__) #define __Pyx_GIVEREF(r) __Pyx_RefNanny->GIVEREF(__pyx_refnanny, (PyObject *)(r), __LINE__) #define __Pyx_XINCREF(r) do { if((r) != NULL) {__Pyx_INCREF(r); }} while(0) #define __Pyx_XDECREF(r) do { if((r) != NULL) {__Pyx_DECREF(r); }} while(0) #define __Pyx_XGOTREF(r) do { if((r) != NULL) {__Pyx_GOTREF(r); }} while(0) #define __Pyx_XGIVEREF(r) do { if((r) != NULL) {__Pyx_GIVEREF(r);}} while(0) #else #define __Pyx_RefNannyDeclarations #define __Pyx_RefNannySetupContext(name, acquire_gil) #define __Pyx_RefNannyFinishContext() #define __Pyx_INCREF(r) Py_INCREF(r) #define __Pyx_DECREF(r) Py_DECREF(r) #define __Pyx_GOTREF(r) #define __Pyx_GIVEREF(r) #define __Pyx_XINCREF(r) Py_XINCREF(r) #define __Pyx_XDECREF(r) Py_XDECREF(r) #define __Pyx_XGOTREF(r) #define __Pyx_XGIVEREF(r) #endif /* CYTHON_REFNANNY */ #define __Pyx_CLEAR(r) do { PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);} while(0) #define __Pyx_XCLEAR(r) do { if((r) != NULL) {PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);}} while(0) static PyObject *__Pyx_GetName(PyObject *dict, PyObject *name); /*proto*/ static void __Pyx_RaiseArgtupleInvalid(const char* func_name, int exact, Py_ssize_t num_min, Py_ssize_t num_max, Py_ssize_t num_found); /*proto*/ static void __Pyx_RaiseDoubleKeywordsError(const char* func_name, PyObject* kw_name); /*proto*/ static int __Pyx_ParseOptionalKeywords(PyObject *kwds, PyObject **argnames[], \ PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args, \ const char* function_name); /*proto*/ static int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed, const char *name, int exact); /*proto*/ static CYTHON_INLINE void __Pyx_ErrRestore(PyObject *type, PyObject *value, PyObject *tb); /*proto*/ static CYTHON_INLINE void __Pyx_ErrFetch(PyObject **type, PyObject **value, PyObject **tb); /*proto*/ static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause); /*proto*/ static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type); /*proto*/ static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j) { PyObject *r; if (!j) return NULL; r = PyObject_GetItem(o, j); Py_DECREF(j); return r; } #define __Pyx_GetItemInt_List(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \ __Pyx_GetItemInt_List_Fast(o, i) : \ __Pyx_GetItemInt_Generic(o, to_py_func(i))) static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i) { #if CYTHON_COMPILING_IN_CPYTHON if (likely((0 <= i) & (i < PyList_GET_SIZE(o)))) { PyObject *r = PyList_GET_ITEM(o, i); Py_INCREF(r); return r; } else if ((-PyList_GET_SIZE(o) <= i) & (i < 0)) { PyObject *r = PyList_GET_ITEM(o, PyList_GET_SIZE(o) + i); Py_INCREF(r); return r; } return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i)); #else return PySequence_GetItem(o, i); #endif } #define __Pyx_GetItemInt_Tuple(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \ __Pyx_GetItemInt_Tuple_Fast(o, i) : \ __Pyx_GetItemInt_Generic(o, to_py_func(i))) static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i) { #if CYTHON_COMPILING_IN_CPYTHON if (likely((0 <= i) & (i < PyTuple_GET_SIZE(o)))) { PyObject *r = PyTuple_GET_ITEM(o, i); Py_INCREF(r); return r; } else if ((-PyTuple_GET_SIZE(o) <= i) & (i < 0)) { PyObject *r = PyTuple_GET_ITEM(o, PyTuple_GET_SIZE(o) + i); Py_INCREF(r); return r; } return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i)); #else return PySequence_GetItem(o, i); #endif } #define __Pyx_GetItemInt(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \ __Pyx_GetItemInt_Fast(o, i) : \ __Pyx_GetItemInt_Generic(o, to_py_func(i))) static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i) { #if CYTHON_COMPILING_IN_CPYTHON if (PyList_CheckExact(o)) { Py_ssize_t n = (likely(i >= 0)) ? i : i + PyList_GET_SIZE(o); if (likely((n >= 0) & (n < PyList_GET_SIZE(o)))) { PyObject *r = PyList_GET_ITEM(o, n); Py_INCREF(r); return r; } } else if (PyTuple_CheckExact(o)) { Py_ssize_t n = (likely(i >= 0)) ? i : i + PyTuple_GET_SIZE(o); if (likely((n >= 0) & (n < PyTuple_GET_SIZE(o)))) { PyObject *r = PyTuple_GET_ITEM(o, n); Py_INCREF(r); return r; } } else { /* inlined PySequence_GetItem() */ PySequenceMethods *m = Py_TYPE(o)->tp_as_sequence; if (likely(m && m->sq_item)) { if (unlikely(i < 0) && likely(m->sq_length)) { Py_ssize_t l = m->sq_length(o); if (unlikely(l < 0)) return NULL; i += l; } return m->sq_item(o, i); } } #else if (PySequence_Check(o)) { return PySequence_GetItem(o, i); } #endif return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i)); } static CYTHON_INLINE int __Pyx_PySequence_Contains(PyObject* item, PyObject* seq, int eq) { int result = PySequence_Contains(seq, item); return unlikely(result < 0) ? result : (result == (eq == Py_EQ)); } static CYTHON_INLINE long __Pyx_div_long(long, long); /* proto */ static CYTHON_INLINE int __Pyx_div_int(int, int); /* proto */ #define UNARY_NEG_WOULD_OVERFLOW(x) (((x) < 0) & ((unsigned long)(x) == 0-(unsigned long)(x))) static CYTHON_INLINE void __Pyx_RaiseTooManyValuesError(Py_ssize_t expected); static CYTHON_INLINE void __Pyx_RaiseNeedMoreValuesError(Py_ssize_t index); static CYTHON_INLINE void __Pyx_RaiseNoneNotIterableError(void); static CYTHON_INLINE int __Pyx_IterFinish(void); /*proto*/ static int __Pyx_IternextUnpackEndCheck(PyObject *retval, Py_ssize_t expected); /*proto*/ static void __Pyx_call_next_tp_dealloc(PyObject* obj, destructor current_tp_dealloc); static int __Pyx_call_next_tp_traverse(PyObject* obj, visitproc v, void *a, traverseproc current_tp_traverse); static void __Pyx_call_next_tp_clear(PyObject* obj, inquiry current_tp_dealloc); static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, long level); /*proto*/ static CYTHON_INLINE void __Pyx_RaiseImportError(PyObject *name); static CYTHON_INLINE hsize_t __Pyx_PyInt_from_py_hsize_t(PyObject *); static CYTHON_INLINE npy_uint32 __Pyx_PyInt_from_py_npy_uint32(PyObject *); static CYTHON_INLINE npy_int64 __Pyx_PyInt_from_py_npy_int64(PyObject *); static CYTHON_INLINE npy_uint64 __Pyx_PyInt_from_py_npy_uint64(PyObject *); static CYTHON_INLINE Py_intptr_t __Pyx_PyInt_from_py_Py_intptr_t(PyObject *); #ifndef __PYX_FORCE_INIT_THREADS #define __PYX_FORCE_INIT_THREADS 0 #endif #if CYTHON_CCOMPLEX #ifdef __cplusplus #define __Pyx_CREAL(z) ((z).real()) #define __Pyx_CIMAG(z) ((z).imag()) #else #define __Pyx_CREAL(z) (__real__(z)) #define __Pyx_CIMAG(z) (__imag__(z)) #endif #else #define __Pyx_CREAL(z) ((z).real) #define __Pyx_CIMAG(z) ((z).imag) #endif #if defined(_WIN32) && defined(__cplusplus) && CYTHON_CCOMPLEX #define __Pyx_SET_CREAL(z,x) ((z).real(x)) #define __Pyx_SET_CIMAG(z,y) ((z).imag(y)) #else #define __Pyx_SET_CREAL(z,x) __Pyx_CREAL(z) = (x) #define __Pyx_SET_CIMAG(z,y) __Pyx_CIMAG(z) = (y) #endif static CYTHON_INLINE __pyx_t_float_complex __pyx_t_float_complex_from_parts(float, float); #if CYTHON_CCOMPLEX #define __Pyx_c_eqf(a, b) ((a)==(b)) #define __Pyx_c_sumf(a, b) ((a)+(b)) #define __Pyx_c_difff(a, b) ((a)-(b)) #define __Pyx_c_prodf(a, b) ((a)*(b)) #define __Pyx_c_quotf(a, b) ((a)/(b)) #define __Pyx_c_negf(a) (-(a)) #ifdef __cplusplus #define __Pyx_c_is_zerof(z) ((z)==(float)0) #define __Pyx_c_conjf(z) (::std::conj(z)) #if 1 #define __Pyx_c_absf(z) (::std::abs(z)) #define __Pyx_c_powf(a, b) (::std::pow(a, b)) #endif #else #define __Pyx_c_is_zerof(z) ((z)==0) #define __Pyx_c_conjf(z) (conjf(z)) #if 1 #define __Pyx_c_absf(z) (cabsf(z)) #define __Pyx_c_powf(a, b) (cpowf(a, b)) #endif #endif #else static CYTHON_INLINE int __Pyx_c_eqf(__pyx_t_float_complex, __pyx_t_float_complex); static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_sumf(__pyx_t_float_complex, __pyx_t_float_complex); static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_difff(__pyx_t_float_complex, __pyx_t_float_complex); static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_prodf(__pyx_t_float_complex, __pyx_t_float_complex); static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_quotf(__pyx_t_float_complex, __pyx_t_float_complex); static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_negf(__pyx_t_float_complex); static CYTHON_INLINE int __Pyx_c_is_zerof(__pyx_t_float_complex); static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_conjf(__pyx_t_float_complex); #if 1 static CYTHON_INLINE float __Pyx_c_absf(__pyx_t_float_complex); static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_powf(__pyx_t_float_complex, __pyx_t_float_complex); #endif #endif static CYTHON_INLINE __pyx_t_double_complex __pyx_t_double_complex_from_parts(double, double); #if CYTHON_CCOMPLEX #define __Pyx_c_eq(a, b) ((a)==(b)) #define __Pyx_c_sum(a, b) ((a)+(b)) #define __Pyx_c_diff(a, b) ((a)-(b)) #define __Pyx_c_prod(a, b) ((a)*(b)) #define __Pyx_c_quot(a, b) ((a)/(b)) #define __Pyx_c_neg(a) (-(a)) #ifdef __cplusplus #define __Pyx_c_is_zero(z) ((z)==(double)0) #define __Pyx_c_conj(z) (::std::conj(z)) #if 1 #define __Pyx_c_abs(z) (::std::abs(z)) #define __Pyx_c_pow(a, b) (::std::pow(a, b)) #endif #else #define __Pyx_c_is_zero(z) ((z)==0) #define __Pyx_c_conj(z) (conj(z)) #if 1 #define __Pyx_c_abs(z) (cabs(z)) #define __Pyx_c_pow(a, b) (cpow(a, b)) #endif #endif #else static CYTHON_INLINE int __Pyx_c_eq(__pyx_t_double_complex, __pyx_t_double_complex); static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_sum(__pyx_t_double_complex, __pyx_t_double_complex); static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_diff(__pyx_t_double_complex, __pyx_t_double_complex); static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_prod(__pyx_t_double_complex, __pyx_t_double_complex); static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_quot(__pyx_t_double_complex, __pyx_t_double_complex); static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_neg(__pyx_t_double_complex); static CYTHON_INLINE int __Pyx_c_is_zero(__pyx_t_double_complex); static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_conj(__pyx_t_double_complex); #if 1 static CYTHON_INLINE double __Pyx_c_abs(__pyx_t_double_complex); static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_pow(__pyx_t_double_complex, __pyx_t_double_complex); #endif #endif static CYTHON_INLINE unsigned char __Pyx_PyInt_AsUnsignedChar(PyObject *); static CYTHON_INLINE unsigned short __Pyx_PyInt_AsUnsignedShort(PyObject *); static CYTHON_INLINE unsigned int __Pyx_PyInt_AsUnsignedInt(PyObject *); static CYTHON_INLINE char __Pyx_PyInt_AsChar(PyObject *); static CYTHON_INLINE short __Pyx_PyInt_AsShort(PyObject *); static CYTHON_INLINE int __Pyx_PyInt_AsInt(PyObject *); static CYTHON_INLINE signed char __Pyx_PyInt_AsSignedChar(PyObject *); static CYTHON_INLINE signed short __Pyx_PyInt_AsSignedShort(PyObject *); static CYTHON_INLINE signed int __Pyx_PyInt_AsSignedInt(PyObject *); static CYTHON_INLINE int __Pyx_PyInt_AsLongDouble(PyObject *); static CYTHON_INLINE unsigned long __Pyx_PyInt_AsUnsignedLong(PyObject *); static CYTHON_INLINE unsigned PY_LONG_LONG __Pyx_PyInt_AsUnsignedLongLong(PyObject *); static CYTHON_INLINE long __Pyx_PyInt_AsLong(PyObject *); static CYTHON_INLINE PY_LONG_LONG __Pyx_PyInt_AsLongLong(PyObject *); static CYTHON_INLINE signed long __Pyx_PyInt_AsSignedLong(PyObject *); static CYTHON_INLINE signed PY_LONG_LONG __Pyx_PyInt_AsSignedLongLong(PyObject *); static void __Pyx_WriteUnraisable(const char *name, int clineno, int lineno, const char *filename); /*proto*/ static int __Pyx_check_binary_version(void); #if !defined(__Pyx_PyIdentifier_FromString) #if PY_MAJOR_VERSION < 3 #define __Pyx_PyIdentifier_FromString(s) PyString_FromString(s) #else #define __Pyx_PyIdentifier_FromString(s) PyUnicode_FromString(s) #endif #endif static PyObject *__Pyx_ImportModule(const char *name); /*proto*/ static PyTypeObject *__Pyx_ImportType(const char *module_name, const char *class_name, size_t size, int strict); /*proto*/ static void* __Pyx_GetVtable(PyObject *dict); /*proto*/ static int __Pyx_SetVtable(PyObject *dict, void *vtable); /*proto*/ typedef struct { int code_line; PyCodeObject* code_object; } __Pyx_CodeObjectCacheEntry; struct __Pyx_CodeObjectCache { int count; int max_count; __Pyx_CodeObjectCacheEntry* entries; }; static struct __Pyx_CodeObjectCache __pyx_code_cache = {0,0,NULL}; static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line); static PyCodeObject *__pyx_find_code_object(int code_line); static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object); static void __Pyx_AddTraceback(const char *funcname, int c_line, int py_line, const char *filename); /*proto*/ static int __Pyx_InitStrings(__Pyx_StringTabEntry *t); /*proto*/ /* Module declarations from 'cpython.buffer' */ /* Module declarations from 'cpython.ref' */ /* Module declarations from 'libc.stdio' */ /* Module declarations from 'cpython.object' */ /* Module declarations from '__builtin__' */ /* Module declarations from 'cpython.type' */ static PyTypeObject *__pyx_ptype_7cpython_4type_type = 0; /* Module declarations from 'libc.stdlib' */ /* Module declarations from 'numpy' */ /* Module declarations from 'numpy' */ static PyTypeObject *__pyx_ptype_5numpy_dtype = 0; static PyTypeObject *__pyx_ptype_5numpy_flatiter = 0; static PyTypeObject *__pyx_ptype_5numpy_broadcast = 0; static PyTypeObject *__pyx_ptype_5numpy_ndarray = 0; static PyTypeObject *__pyx_ptype_5numpy_ufunc = 0; static CYTHON_INLINE char *__pyx_f_5numpy__util_dtypestring(PyArray_Descr *, char *, char *, int *); /*proto*/ /* Module declarations from 'tables.definitions' */ /* Module declarations from 'tables.hdf5extension' */ static PyTypeObject *__pyx_ptype_6tables_13hdf5extension_Node = 0; static PyTypeObject *__pyx_ptype_6tables_13hdf5extension_Leaf = 0; static PyTypeObject *__pyx_ptype_6tables_13hdf5extension_Array = 0; /* Module declarations from 'tables.lrucacheextension' */ static PyTypeObject *__pyx_ptype_6tables_17lrucacheextension_NodeCache = 0; static PyTypeObject *__pyx_ptype_6tables_17lrucacheextension_BaseCache = 0; static PyTypeObject *__pyx_ptype_6tables_17lrucacheextension_ObjectNode = 0; static PyTypeObject *__pyx_ptype_6tables_17lrucacheextension_ObjectCache = 0; static PyTypeObject *__pyx_ptype_6tables_17lrucacheextension_NumCache = 0; /* Module declarations from 'tables.indexesextension' */ static PyTypeObject *__pyx_ptype_6tables_16indexesextension_Index = 0; static PyTypeObject *__pyx_ptype_6tables_16indexesextension_CacheArray = 0; static PyTypeObject *__pyx_ptype_6tables_16indexesextension_IndexArray = 0; static PyTypeObject *__pyx_ptype_6tables_16indexesextension_LastRowArray = 0; #define __Pyx_MODULE_NAME "tables.indexesextension" int __pyx_module_is_main_tables__indexesextension = 0; /* Implementation of 'tables.indexesextension' */ static PyObject *__pyx_builtin_ValueError; static PyObject *__pyx_builtin_super; static PyObject *__pyx_builtin_range; static PyObject *__pyx_builtin_RuntimeError; static PyObject *__pyx_pf_6tables_16indexesextension_keysort(CYTHON_UNUSED PyObject *__pyx_self, PyArrayObject *__pyx_v_array1, PyArrayObject *__pyx_v_array2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10CacheArray__g_close(struct __pyx_obj_6tables_16indexesextension_CacheArray *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray__read_index_slice(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, hsize_t __pyx_v_irow, hsize_t __pyx_v_start, hsize_t __pyx_v_stop, PyArrayObject *__pyx_v_idx); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_2_init_sorted_slice(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, PyObject *__pyx_v_index); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_4_read_sorted_slice(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, hsize_t __pyx_v_irow, hsize_t __pyx_v_start, hsize_t __pyx_v_stop); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_6_bisect_left(CYTHON_UNUSED struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, PyObject *__pyx_v_a, PyObject *__pyx_v_x, int __pyx_v_hi); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_8_bisect_right(CYTHON_UNUSED struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, PyObject *__pyx_v_a, PyObject *__pyx_v_x, int __pyx_v_hi); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_10_search_bin_na_b(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_12_search_bin_na_ub(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_14_search_bin_na_s(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_16_search_bin_na_us(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_18_search_bin_na_i(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_20_search_bin_na_ui(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_uint32 __pyx_v_item1, npy_uint32 __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_22_search_bin_na_ll(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_int64 __pyx_v_item1, npy_int64 __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_24_search_bin_na_ull(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_uint64 __pyx_v_item1, npy_uint64 __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_26_search_bin_na_e(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_float64 __pyx_v_item1, npy_float64 __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_28_search_bin_na_f(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_float64 __pyx_v_item1, npy_float64 __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_30_search_bin_na_d(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_float64 __pyx_v_item1, npy_float64 __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_32_search_bin_na_g(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_longdouble __pyx_v_item1, npy_longdouble __pyx_v_item2); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_34_g_close(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_12LastRowArray__read_index_slice(struct __pyx_obj_6tables_16indexesextension_LastRowArray *__pyx_v_self, hsize_t __pyx_v_start, hsize_t __pyx_v_stop, PyArrayObject *__pyx_v_idx); /* proto */ static PyObject *__pyx_pf_6tables_16indexesextension_12LastRowArray_2_read_sorted_slice(struct __pyx_obj_6tables_16indexesextension_LastRowArray *__pyx_v_self, struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_sorted, hsize_t __pyx_v_start, hsize_t __pyx_v_stop); /* proto */ static int __pyx_pf_5numpy_7ndarray___getbuffer__(PyArrayObject *__pyx_v_self, Py_buffer *__pyx_v_info, int __pyx_v_flags); /* proto */ static void __pyx_pf_5numpy_7ndarray_2__releasebuffer__(PyArrayObject *__pyx_v_self, Py_buffer *__pyx_v_info); /* proto */ static char __pyx_k_1[] = "This shouldn't happen!"; static char __pyx_k_3[] = "Problems initializing the bounds array data."; static char __pyx_k_5[] = "Problems reading the bounds array data."; static char __pyx_k_7[] = "Problems reading the index indices."; static char __pyx_k_9[] = "non-opt types bounds"; static char __pyx_k_10[] = "Problems reading the array data."; static char __pyx_k_12[] = "Problems reading the index data in Last Row."; static char __pyx_k_14[] = "Problems reading the index data."; static char __pyx_k_16[] = "ndarray is not C contiguous"; static char __pyx_k_18[] = "ndarray is not Fortran contiguous"; static char __pyx_k_20[] = "Non-native byte order not supported"; static char __pyx_k_22[] = "unknown dtype code in numpy.pxd (%d)"; static char __pyx_k_23[] = "Format string allocated too short, see comment in numpy.pxd"; static char __pyx_k_26[] = "Format string allocated too short."; static char __pyx_k_28[] = "cython interface for keeping indexes classes.\n\nClasses (type extensions):\n\n IndexArray\n CacheArray\n LastRowArray\n\nFunctions:\n\nMisc variables:\n\n"; static char __pyx_k_29[] = "tables.exceptions"; static char __pyx_k_30[] = "tables._past"; static char __pyx_k_33[] = "/home/antonio/projects/PyTables/tables/indexesextension.pyx"; static char __pyx_k_34[] = "tables.indexesextension"; static char __pyx_k__B[] = "B"; static char __pyx_k__H[] = "H"; static char __pyx_k__I[] = "I"; static char __pyx_k__L[] = "L"; static char __pyx_k__O[] = "O"; static char __pyx_k__Q[] = "Q"; static char __pyx_k__S[] = "S"; static char __pyx_k__a[] = "a"; static char __pyx_k__b[] = "b"; static char __pyx_k__d[] = "d"; static char __pyx_k__f[] = "f"; static char __pyx_k__g[] = "g"; static char __pyx_k__h[] = "h"; static char __pyx_k__i[] = "i"; static char __pyx_k__l[] = "l"; static char __pyx_k__q[] = "q"; static char __pyx_k__x[] = "x"; static char __pyx_k__Zd[] = "Zd"; static char __pyx_k__Zf[] = "Zf"; static char __pyx_k__Zg[] = "Zg"; static char __pyx_k__hi[] = "hi"; static char __pyx_k__idx[] = "idx"; static char __pyx_k__atom[] = "atom"; static char __pyx_k__bool[] = "bool"; static char __pyx_k__char[] = "char"; static char __pyx_k__int8[] = "int8"; static char __pyx_k__irow[] = "irow"; static char __pyx_k__name[] = "name"; static char __pyx_k__size[] = "size"; static char __pyx_k__stop[] = "stop"; static char __pyx_k__dtype[] = "dtype"; static char __pyx_k__empty[] = "empty"; static char __pyx_k__int16[] = "int16"; static char __pyx_k__int32[] = "int32"; static char __pyx_k__int64[] = "int64"; static char __pyx_k__item1[] = "item1"; static char __pyx_k__item2[] = "item2"; static char __pyx_k__nrows[] = "nrows"; static char __pyx_k__numpy[] = "numpy"; static char __pyx_k__range[] = "range"; static char __pyx_k__shape[] = "shape"; static char __pyx_k__start[] = "start"; static char __pyx_k__super[] = "super"; static char __pyx_k__uint8[] = "uint8"; static char __pyx_k__array1[] = "array1"; static char __pyx_k__array2[] = "array2"; static char __pyx_k__bounds[] = "bounds"; static char __pyx_k__params[] = "params"; static char __pyx_k__ranges[] = "ranges"; static char __pyx_k__sorted[] = "sorted"; static char __pyx_k__starts[] = "starts"; static char __pyx_k__uint16[] = "uint16"; static char __pyx_k__uint32[] = "uint32"; static char __pyx_k__uint64[] = "uint64"; static char __pyx_k___v_file[] = "_v_file"; static char __pyx_k__elsize1[] = "elsize1"; static char __pyx_k__elsize2[] = "elsize2"; static char __pyx_k__float16[] = "float16"; static char __pyx_k__float32[] = "float32"; static char __pyx_k__float64[] = "float64"; static char __pyx_k__float96[] = "float96"; static char __pyx_k__keysort[] = "keysort"; static char __pyx_k__lengths[] = "lengths"; static char __pyx_k__rvcache[] = "rvcache"; static char __pyx_k____main__[] = "__main__"; static char __pyx_k____test__[] = "__test__"; static char __pyx_k___g_close[] = "_g_close"; static char __pyx_k__float128[] = "float128"; static char __pyx_k__itemsize[] = "itemsize"; static char __pyx_k___v_parent[] = "_v_parent"; static char __pyx_k__chunksize[] = "chunksize"; static char __pyx_k__slicesize[] = "slicesize"; static char __pyx_k__ValueError[] = "ValueError"; static char __pyx_k__HDF5ExtError[] = "HDF5ExtError"; static char __pyx_k__RuntimeError[] = "RuntimeError"; static char __pyx_k__previous_api[] = "previous_api"; static char __pyx_k___v_chunkshape[] = "_v_chunkshape"; static char __pyx_k___searchBinNA_b[] = "_searchBinNA_b"; static char __pyx_k___searchBinNA_d[] = "_searchBinNA_d"; static char __pyx_k___searchBinNA_e[] = "_searchBinNA_e"; static char __pyx_k___searchBinNA_f[] = "_searchBinNA_f"; static char __pyx_k___searchBinNA_g[] = "_searchBinNA_g"; static char __pyx_k___searchBinNA_i[] = "_searchBinNA_i"; static char __pyx_k___searchBinNA_s[] = "_searchBinNA_s"; static char __pyx_k__BOUNDS_MAX_SIZE[] = "BOUNDS_MAX_SIZE"; static char __pyx_k__SORTED_MAX_SIZE[] = "SORTED_MAX_SIZE"; static char __pyx_k___readIndexSlice[] = "_readIndexSlice"; static char __pyx_k___searchBinNA_ll[] = "_searchBinNA_ll"; static char __pyx_k___searchBinNA_ub[] = "_searchBinNA_ub"; static char __pyx_k___searchBinNA_ui[] = "_searchBinNA_ui"; static char __pyx_k___searchBinNA_us[] = "_searchBinNA_us"; static char __pyx_k___initSortedSlice[] = "_initSortedSlice"; static char __pyx_k___readSortedSlice[] = "_readSortedSlice"; static char __pyx_k___searchBinNA_ull[] = "_searchBinNA_ull"; static char __pyx_k___search_bin_na_b[] = "_search_bin_na_b"; static char __pyx_k___search_bin_na_d[] = "_search_bin_na_d"; static char __pyx_k___search_bin_na_e[] = "_search_bin_na_e"; static char __pyx_k___search_bin_na_f[] = "_search_bin_na_f"; static char __pyx_k___search_bin_na_g[] = "_search_bin_na_g"; static char __pyx_k___search_bin_na_i[] = "_search_bin_na_i"; static char __pyx_k___search_bin_na_s[] = "_search_bin_na_s"; static char __pyx_k__opt_search_types[] = "opt_search_types"; static char __pyx_k___read_index_slice[] = "_read_index_slice"; static char __pyx_k___search_bin_na_ll[] = "_search_bin_na_ll"; static char __pyx_k___search_bin_na_ub[] = "_search_bin_na_ub"; static char __pyx_k___search_bin_na_ui[] = "_search_bin_na_ui"; static char __pyx_k___search_bin_na_us[] = "_search_bin_na_us"; static char __pyx_k___init_sorted_slice[] = "_init_sorted_slice"; static char __pyx_k___read_sorted_slice[] = "_read_sorted_slice"; static char __pyx_k___search_bin_na_ull[] = "_search_bin_na_ull"; static PyObject *__pyx_kp_s_1; static PyObject *__pyx_kp_s_10; static PyObject *__pyx_kp_s_12; static PyObject *__pyx_kp_s_14; static PyObject *__pyx_kp_u_16; static PyObject *__pyx_kp_u_18; static PyObject *__pyx_kp_u_20; static PyObject *__pyx_kp_u_22; static PyObject *__pyx_kp_u_23; static PyObject *__pyx_kp_u_26; static PyObject *__pyx_n_s_29; static PyObject *__pyx_kp_s_3; static PyObject *__pyx_n_s_30; static PyObject *__pyx_kp_s_33; static PyObject *__pyx_n_s_34; static PyObject *__pyx_kp_s_5; static PyObject *__pyx_kp_s_7; static PyObject *__pyx_kp_s_9; static PyObject *__pyx_n_s__BOUNDS_MAX_SIZE; static PyObject *__pyx_n_s__HDF5ExtError; static PyObject *__pyx_n_s__RuntimeError; static PyObject *__pyx_n_s__S; static PyObject *__pyx_n_s__SORTED_MAX_SIZE; static PyObject *__pyx_n_s__ValueError; static PyObject *__pyx_n_s____main__; static PyObject *__pyx_n_s____test__; static PyObject *__pyx_n_s___g_close; static PyObject *__pyx_n_s___initSortedSlice; static PyObject *__pyx_n_s___init_sorted_slice; static PyObject *__pyx_n_s___readIndexSlice; static PyObject *__pyx_n_s___readSortedSlice; static PyObject *__pyx_n_s___read_index_slice; static PyObject *__pyx_n_s___read_sorted_slice; static PyObject *__pyx_n_s___searchBinNA_b; static PyObject *__pyx_n_s___searchBinNA_d; static PyObject *__pyx_n_s___searchBinNA_e; static PyObject *__pyx_n_s___searchBinNA_f; static PyObject *__pyx_n_s___searchBinNA_g; static PyObject *__pyx_n_s___searchBinNA_i; static PyObject *__pyx_n_s___searchBinNA_ll; static PyObject *__pyx_n_s___searchBinNA_s; static PyObject *__pyx_n_s___searchBinNA_ub; static PyObject *__pyx_n_s___searchBinNA_ui; static PyObject *__pyx_n_s___searchBinNA_ull; static PyObject *__pyx_n_s___searchBinNA_us; static PyObject *__pyx_n_s___search_bin_na_b; static PyObject *__pyx_n_s___search_bin_na_d; static PyObject *__pyx_n_s___search_bin_na_e; static PyObject *__pyx_n_s___search_bin_na_f; static PyObject *__pyx_n_s___search_bin_na_g; static PyObject *__pyx_n_s___search_bin_na_i; static PyObject *__pyx_n_s___search_bin_na_ll; static PyObject *__pyx_n_s___search_bin_na_s; static PyObject *__pyx_n_s___search_bin_na_ub; static PyObject *__pyx_n_s___search_bin_na_ui; static PyObject *__pyx_n_s___search_bin_na_ull; static PyObject *__pyx_n_s___search_bin_na_us; static PyObject *__pyx_n_s___v_chunkshape; static PyObject *__pyx_n_s___v_file; static PyObject *__pyx_n_s___v_parent; static PyObject *__pyx_n_s__a; static PyObject *__pyx_n_s__array1; static PyObject *__pyx_n_s__array2; static PyObject *__pyx_n_s__atom; static PyObject *__pyx_n_s__bool; static PyObject *__pyx_n_s__bounds; static PyObject *__pyx_n_s__char; static PyObject *__pyx_n_s__chunksize; static PyObject *__pyx_n_s__dtype; static PyObject *__pyx_n_s__elsize1; static PyObject *__pyx_n_s__elsize2; static PyObject *__pyx_n_s__empty; static PyObject *__pyx_n_s__float128; static PyObject *__pyx_n_s__float16; static PyObject *__pyx_n_s__float32; static PyObject *__pyx_n_s__float64; static PyObject *__pyx_n_s__float96; static PyObject *__pyx_n_s__hi; static PyObject *__pyx_n_s__idx; static PyObject *__pyx_n_s__int16; static PyObject *__pyx_n_s__int32; static PyObject *__pyx_n_s__int64; static PyObject *__pyx_n_s__int8; static PyObject *__pyx_n_s__irow; static PyObject *__pyx_n_s__item1; static PyObject *__pyx_n_s__item2; static PyObject *__pyx_n_s__itemsize; static PyObject *__pyx_n_s__keysort; static PyObject *__pyx_n_s__lengths; static PyObject *__pyx_n_s__name; static PyObject *__pyx_n_s__nrows; static PyObject *__pyx_n_s__numpy; static PyObject *__pyx_n_s__opt_search_types; static PyObject *__pyx_n_s__params; static PyObject *__pyx_n_s__previous_api; static PyObject *__pyx_n_s__range; static PyObject *__pyx_n_s__ranges; static PyObject *__pyx_n_s__rvcache; static PyObject *__pyx_n_s__shape; static PyObject *__pyx_n_s__size; static PyObject *__pyx_n_s__slicesize; static PyObject *__pyx_n_s__sorted; static PyObject *__pyx_n_s__start; static PyObject *__pyx_n_s__starts; static PyObject *__pyx_n_s__stop; static PyObject *__pyx_n_s__super; static PyObject *__pyx_n_s__uint16; static PyObject *__pyx_n_s__uint32; static PyObject *__pyx_n_s__uint64; static PyObject *__pyx_n_s__uint8; static PyObject *__pyx_n_s__x; static PyObject *__pyx_int_0; static PyObject *__pyx_int_15; static PyObject *__pyx_k_tuple_2; static PyObject *__pyx_k_tuple_4; static PyObject *__pyx_k_tuple_6; static PyObject *__pyx_k_tuple_8; static PyObject *__pyx_k_tuple_11; static PyObject *__pyx_k_tuple_13; static PyObject *__pyx_k_tuple_15; static PyObject *__pyx_k_tuple_17; static PyObject *__pyx_k_tuple_19; static PyObject *__pyx_k_tuple_21; static PyObject *__pyx_k_tuple_24; static PyObject *__pyx_k_tuple_25; static PyObject *__pyx_k_tuple_27; static PyObject *__pyx_k_tuple_31; static PyObject *__pyx_k_codeobj_32; /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_1keysort(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_6tables_16indexesextension_keysort[] = "Sort array1 in-place. array2 is also sorted following the array1 order.\n\n array1 can be of any type, except complex or string. array2 may be made of\n elements on any size.\n\n "; static PyMethodDef __pyx_mdef_6tables_16indexesextension_1keysort = {__Pyx_NAMESTR("keysort"), (PyCFunction)__pyx_pw_6tables_16indexesextension_1keysort, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_6tables_16indexesextension_keysort)}; static PyObject *__pyx_pw_6tables_16indexesextension_1keysort(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyArrayObject *__pyx_v_array1 = 0; PyArrayObject *__pyx_v_array2 = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("keysort (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__array1,&__pyx_n_s__array2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__array1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__array2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("keysort", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "keysort") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_array1 = ((PyArrayObject *)values[0]); __pyx_v_array2 = ((PyArrayObject *)values[1]); } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("keysort", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.keysort", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_array1), __pyx_ptype_5numpy_ndarray, 1, "array1", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_array2), __pyx_ptype_5numpy_ndarray, 1, "array2", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_r = __pyx_pf_6tables_16indexesextension_keysort(__pyx_self, __pyx_v_array1, __pyx_v_array2); goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":129 * * # Sorting functions * def keysort(ndarray array1, ndarray array2): # <<<<<<<<<<<<<< * """Sort array1 in-place. array2 is also sorted following the array1 order. * */ static PyObject *__pyx_pf_6tables_16indexesextension_keysort(CYTHON_UNUSED PyObject *__pyx_self, PyArrayObject *__pyx_v_array1, PyArrayObject *__pyx_v_array2) { npy_intp __pyx_v_size; int __pyx_v_elsize1; int __pyx_v_elsize2; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; npy_intp __pyx_t_2; int __pyx_t_3; PyObject *__pyx_t_4 = NULL; int __pyx_t_5; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("keysort", 0); /* "tables/indexesextension.pyx":140 * cdef int elsize1, elsize2 * * size = array1.size # <<<<<<<<<<<<<< * elsize1 = array1.itemsize * elsize2 = array2.itemsize */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__size); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_PyInt_from_py_Py_intptr_t(__pyx_t_1); if (unlikely((__pyx_t_2 == (npy_intp)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_v_size = __pyx_t_2; /* "tables/indexesextension.pyx":141 * * size = array1.size * elsize1 = array1.itemsize # <<<<<<<<<<<<<< * elsize2 = array2.itemsize * if array1.dtype == "float64": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__itemsize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_3 = __Pyx_PyInt_AsInt(__pyx_t_1); if (unlikely((__pyx_t_3 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_v_elsize1 = __pyx_t_3; /* "tables/indexesextension.pyx":142 * size = array1.size * elsize1 = array1.itemsize * elsize2 = array2.itemsize # <<<<<<<<<<<<<< * if array1.dtype == "float64": * return keysort_f64(array1.data, array2.data, size, elsize2) */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array2), __pyx_n_s__itemsize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 142; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_3 = __Pyx_PyInt_AsInt(__pyx_t_1); if (unlikely((__pyx_t_3 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 142; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_v_elsize2 = __pyx_t_3; /* "tables/indexesextension.pyx":143 * elsize1 = array1.itemsize * elsize2 = array2.itemsize * if array1.dtype == "float64": # <<<<<<<<<<<<<< * return keysort_f64(array1.data, array2.data, size, elsize2) * elif array1.dtype == "float32": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 143; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_RichCompare(__pyx_t_1, ((PyObject *)__pyx_n_s__float64), Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 143; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 143; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":144 * elsize2 = array2.itemsize * if array1.dtype == "float64": * return keysort_f64(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "float32": * return keysort_f32(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyInt_FromLong(keysort_f64(((npy_float64 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 144; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":145 * if array1.dtype == "float64": * return keysort_f64(array1.data, array2.data, size, elsize2) * elif array1.dtype == "float32": # <<<<<<<<<<<<<< * return keysort_f32(array1.data, array2.data, size, elsize2) * # elif array1.dtype == "float16": # raises an error if float16 is not defined */ __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 145; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_1 = PyObject_RichCompare(__pyx_t_4, ((PyObject *)__pyx_n_s__float32), Py_EQ); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 145; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 145; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":146 * return keysort_f64(array1.data, array2.data, size, elsize2) * elif array1.dtype == "float32": * return keysort_f32(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * # elif array1.dtype == "float16": # raises an error if float16 is not defined * elif array1.dtype.name == "float16": */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(keysort_f32(((npy_float32 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 146; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":148 * return keysort_f32(array1.data, array2.data, size, elsize2) * # elif array1.dtype == "float16": # raises an error if float16 is not defined * elif array1.dtype.name == "float16": # <<<<<<<<<<<<<< * return keysort_f16(array1.data, array2.data, size, elsize2) * elif array1.dtype.name == "float96": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 148; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__name); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 148; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_RichCompare(__pyx_t_4, ((PyObject *)__pyx_n_s__float16), Py_EQ); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 148; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 148; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":149 * # elif array1.dtype == "float16": # raises an error if float16 is not defined * elif array1.dtype.name == "float16": * return keysort_f16(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype.name == "float96": * return keysort_f96(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(keysort_f16(((__pyx_t_6tables_16indexesextension_npy_float16 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 149; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":150 * elif array1.dtype.name == "float16": * return keysort_f16(array1.data, array2.data, size, elsize2) * elif array1.dtype.name == "float96": # <<<<<<<<<<<<<< * return keysort_f96(array1.data, array2.data, size, elsize2) * elif array1.dtype.name == "float128": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 150; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__name); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 150; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_RichCompare(__pyx_t_4, ((PyObject *)__pyx_n_s__float96), Py_EQ); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 150; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 150; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":151 * return keysort_f16(array1.data, array2.data, size, elsize2) * elif array1.dtype.name == "float96": * return keysort_f96(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype.name == "float128": * return keysort_f128(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(keysort_f96(((npy_float96 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 151; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":152 * elif array1.dtype.name == "float96": * return keysort_f96(array1.data, array2.data, size, elsize2) * elif array1.dtype.name == "float128": # <<<<<<<<<<<<<< * return keysort_f128(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int64": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__name); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_RichCompare(__pyx_t_4, ((PyObject *)__pyx_n_s__float128), Py_EQ); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 152; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":153 * return keysort_f96(array1.data, array2.data, size, elsize2) * elif array1.dtype.name == "float128": * return keysort_f128(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "int64": * return keysort_i64(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(keysort_f128(((npy_float128 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 153; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":154 * elif array1.dtype.name == "float128": * return keysort_f128(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int64": # <<<<<<<<<<<<<< * return keysort_i64(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint64": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_RichCompare(__pyx_t_1, ((PyObject *)__pyx_n_s__int64), Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 154; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":155 * return keysort_f128(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int64": * return keysort_i64(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "uint64": * return keysort_u64(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyInt_FromLong(keysort_i64(((npy_int64 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 155; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":156 * elif array1.dtype == "int64": * return keysort_i64(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint64": # <<<<<<<<<<<<<< * return keysort_u64(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int32": */ __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 156; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_1 = PyObject_RichCompare(__pyx_t_4, ((PyObject *)__pyx_n_s__uint64), Py_EQ); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 156; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 156; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":157 * return keysort_i64(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint64": * return keysort_u64(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "int32": * return keysort_i32(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(keysort_u64(((npy_uint64 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 157; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":158 * elif array1.dtype == "uint64": * return keysort_u64(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int32": # <<<<<<<<<<<<<< * return keysort_i32(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint32": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 158; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_RichCompare(__pyx_t_1, ((PyObject *)__pyx_n_s__int32), Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 158; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 158; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":159 * return keysort_u64(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int32": * return keysort_i32(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "uint32": * return keysort_u32(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyInt_FromLong(keysort_i32(((npy_int32 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 159; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":160 * elif array1.dtype == "int32": * return keysort_i32(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint32": # <<<<<<<<<<<<<< * return keysort_u32(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int16": */ __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 160; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_1 = PyObject_RichCompare(__pyx_t_4, ((PyObject *)__pyx_n_s__uint32), Py_EQ); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 160; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 160; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":161 * return keysort_i32(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint32": * return keysort_u32(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "int16": * return keysort_i16(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(keysort_u32(((npy_uint32 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 161; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":162 * elif array1.dtype == "uint32": * return keysort_u32(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int16": # <<<<<<<<<<<<<< * return keysort_i16(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint16": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 162; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_RichCompare(__pyx_t_1, ((PyObject *)__pyx_n_s__int16), Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 162; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 162; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":163 * return keysort_u32(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int16": * return keysort_i16(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "uint16": * return keysort_u16(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyInt_FromLong(keysort_i16(((npy_int16 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 163; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":164 * elif array1.dtype == "int16": * return keysort_i16(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint16": # <<<<<<<<<<<<<< * return keysort_u16(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int8": */ __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 164; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_1 = PyObject_RichCompare(__pyx_t_4, ((PyObject *)__pyx_n_s__uint16), Py_EQ); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 164; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 164; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":165 * return keysort_i16(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint16": * return keysort_u16(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "int8": * return keysort_i8(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(keysort_u16(((npy_uint16 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 165; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":166 * elif array1.dtype == "uint16": * return keysort_u16(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int8": # <<<<<<<<<<<<<< * return keysort_i8(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint8": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 166; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_RichCompare(__pyx_t_1, ((PyObject *)__pyx_n_s__int8), Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 166; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 166; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":167 * return keysort_u16(array1.data, array2.data, size, elsize2) * elif array1.dtype == "int8": * return keysort_i8(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "uint8": * return keysort_u8(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyInt_FromLong(keysort_i8(((npy_int8 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 167; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":168 * elif array1.dtype == "int8": * return keysort_i8(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint8": # <<<<<<<<<<<<<< * return keysort_u8(array1.data, array2.data, size, elsize2) * elif array1.dtype == "bool": */ __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 168; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_1 = PyObject_RichCompare(__pyx_t_4, ((PyObject *)__pyx_n_s__uint8), Py_EQ); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 168; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 168; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":169 * return keysort_i8(array1.data, array2.data, size, elsize2) * elif array1.dtype == "uint8": * return keysort_u8(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype == "bool": * return keysort_u8(array1.data, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(keysort_u8(((npy_uint8 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 169; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":170 * elif array1.dtype == "uint8": * return keysort_u8(array1.data, array2.data, size, elsize2) * elif array1.dtype == "bool": # <<<<<<<<<<<<<< * return keysort_u8(array1.data, array2.data, size, elsize2) * elif array1.dtype.char == "S": */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 170; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_RichCompare(__pyx_t_1, ((PyObject *)__pyx_n_s__bool), Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 170; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 170; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":171 * return keysort_u8(array1.data, array2.data, size, elsize2) * elif array1.dtype == "bool": * return keysort_u8(array1.data, array2.data, size, elsize2) # <<<<<<<<<<<<<< * elif array1.dtype.char == "S": * return keysort_S(array1.data, elsize1, array2.data, size, elsize2) */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyInt_FromLong(keysort_u8(((npy_uint8 *)__pyx_v_array1->data), __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 171; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; goto __pyx_L3; } /* "tables/indexesextension.pyx":172 * elif array1.dtype == "bool": * return keysort_u8(array1.data, array2.data, size, elsize2) * elif array1.dtype.char == "S": # <<<<<<<<<<<<<< * return keysort_S(array1.data, elsize1, array2.data, size, elsize2) * # As it turns out, an indirect sort is always faster, and much faster on */ __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_array1), __pyx_n_s__dtype); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_1 = PyObject_GetAttr(__pyx_t_4, __pyx_n_s__char); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_4 = PyObject_RichCompare(__pyx_t_1, ((PyObject *)__pyx_n_s__S), Py_EQ); __Pyx_XGOTREF(__pyx_t_4); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_5 = __Pyx_PyObject_IsTrue(__pyx_t_4); if (unlikely(__pyx_t_5 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 172; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (__pyx_t_5) { /* "tables/indexesextension.pyx":173 * return keysort_u8(array1.data, array2.data, size, elsize2) * elif array1.dtype.char == "S": * return keysort_S(array1.data, elsize1, array2.data, size, elsize2) # <<<<<<<<<<<<<< * # As it turns out, an indirect sort is always faster, and much faster on * # new processors. See */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = PyInt_FromLong(keysort_S(__pyx_v_array1->data, __pyx_v_elsize1, __pyx_v_array2->data, __pyx_v_size, __pyx_v_elsize2)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 173; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; goto __pyx_L3; } /*else*/ { /* "tables/indexesextension.pyx":186 * #return 0 * else: * raise ValueError("This shouldn't happen!") # <<<<<<<<<<<<<< * * */ __pyx_t_4 = PyObject_Call(__pyx_builtin_ValueError, ((PyObject *)__pyx_k_tuple_2), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_L3:; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("tables.indexesextension.keysort", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":201 * cdef hid_t mem_space_id * * cdef initread(self, int nbounds): # <<<<<<<<<<<<<< * # "Actions to accelerate the reads afterwards." * */ static PyObject *__pyx_f_6tables_16indexesextension_10CacheArray_initread(struct __pyx_obj_6tables_16indexesextension_CacheArray *__pyx_v_self, int __pyx_v_nbounds) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("initread", 0); /* "tables/indexesextension.pyx":206 * # Precompute the mem_space_id * if (H5ARRAYOinit_readSlice(self.dataset_id, &self.mem_space_id, * nbounds) < 0): # <<<<<<<<<<<<<< * raise HDF5ExtError("Problems initializing the bounds array data.") * return */ __pyx_t_1 = (H5ARRAYOinit_readSlice(__pyx_v_self->__pyx_base.__pyx_base.dataset_id, (&__pyx_v_self->mem_space_id), __pyx_v_nbounds) < 0); if (__pyx_t_1) { /* "tables/indexesextension.pyx":207 * if (H5ARRAYOinit_readSlice(self.dataset_id, &self.mem_space_id, * nbounds) < 0): * raise HDF5ExtError("Problems initializing the bounds array data.") # <<<<<<<<<<<<<< * return * */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__HDF5ExtError); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 207; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_k_tuple_4), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 207; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; {__pyx_filename = __pyx_f[0]; __pyx_lineno = 207; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L3; } __pyx_L3:; /* "tables/indexesextension.pyx":208 * nbounds) < 0): * raise HDF5ExtError("Problems initializing the bounds array data.") * return # <<<<<<<<<<<<<< * * cdef read_slice(self, hsize_t nrow, hsize_t start, hsize_t stop, void *rbuf): */ __Pyx_XDECREF(__pyx_r); __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("tables.indexesextension.CacheArray.initread", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":210 * return * * cdef read_slice(self, hsize_t nrow, hsize_t start, hsize_t stop, void *rbuf): # <<<<<<<<<<<<<< * # "Read an slice of bounds." * */ static PyObject *__pyx_f_6tables_16indexesextension_10CacheArray_read_slice(struct __pyx_obj_6tables_16indexesextension_CacheArray *__pyx_v_self, hsize_t __pyx_v_nrow, hsize_t __pyx_v_start, hsize_t __pyx_v_stop, void *__pyx_v_rbuf) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("read_slice", 0); /* "tables/indexesextension.pyx":215 * if (H5ARRAYOread_readBoundsSlice( * self.dataset_id, self.mem_space_id, self.type_id, * nrow, start, stop, rbuf) < 0): # <<<<<<<<<<<<<< * raise HDF5ExtError("Problems reading the bounds array data.") * return */ __pyx_t_1 = (H5ARRAYOread_readBoundsSlice(__pyx_v_self->__pyx_base.__pyx_base.dataset_id, __pyx_v_self->mem_space_id, __pyx_v_self->__pyx_base.__pyx_base.type_id, __pyx_v_nrow, __pyx_v_start, __pyx_v_stop, __pyx_v_rbuf) < 0); if (__pyx_t_1) { /* "tables/indexesextension.pyx":216 * self.dataset_id, self.mem_space_id, self.type_id, * nrow, start, stop, rbuf) < 0): * raise HDF5ExtError("Problems reading the bounds array data.") # <<<<<<<<<<<<<< * return * */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__HDF5ExtError); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 216; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_k_tuple_6), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 216; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; {__pyx_filename = __pyx_f[0]; __pyx_lineno = 216; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L3; } __pyx_L3:; /* "tables/indexesextension.pyx":217 * nrow, start, stop, rbuf) < 0): * raise HDF5ExtError("Problems reading the bounds array data.") * return # <<<<<<<<<<<<<< * * def _g_close(self): */ __Pyx_XDECREF(__pyx_r); __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("tables.indexesextension.CacheArray.read_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10CacheArray_1_g_close(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10CacheArray_1_g_close(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_g_close (wrapper)", 0); __pyx_r = __pyx_pf_6tables_16indexesextension_10CacheArray__g_close(((struct __pyx_obj_6tables_16indexesextension_CacheArray *)__pyx_v_self)); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":219 * return * * def _g_close(self): # <<<<<<<<<<<<<< * super(Array, self)._g_close() * # Release specific resources of this class */ static PyObject *__pyx_pf_6tables_16indexesextension_10CacheArray__g_close(struct __pyx_obj_6tables_16indexesextension_CacheArray *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_g_close", 0); /* "tables/indexesextension.pyx":220 * * def _g_close(self): * super(Array, self)._g_close() # <<<<<<<<<<<<<< * # Release specific resources of this class * if self.mem_space_id > 0: */ __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(((PyObject *)((PyObject*)__pyx_ptype_6tables_13hdf5extension_Array))); PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)((PyObject*)__pyx_ptype_6tables_13hdf5extension_Array))); __Pyx_GIVEREF(((PyObject *)((PyObject*)__pyx_ptype_6tables_13hdf5extension_Array))); __Pyx_INCREF(((PyObject *)__pyx_v_self)); PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_v_self)); __Pyx_GIVEREF(((PyObject *)__pyx_v_self)); __pyx_t_2 = PyObject_Call(__pyx_builtin_super, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; __pyx_t_1 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s___g_close); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "tables/indexesextension.pyx":222 * super(Array, self)._g_close() * # Release specific resources of this class * if self.mem_space_id > 0: # <<<<<<<<<<<<<< * H5Sclose(self.mem_space_id) * */ __pyx_t_3 = (__pyx_v_self->mem_space_id > 0); if (__pyx_t_3) { /* "tables/indexesextension.pyx":223 * # Release specific resources of this class * if self.mem_space_id > 0: * H5Sclose(self.mem_space_id) # <<<<<<<<<<<<<< * * */ H5Sclose(__pyx_v_self->mem_space_id); goto __pyx_L3; } __pyx_L3:; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.CacheArray._g_close", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_1_read_index_slice(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_1_read_index_slice(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { hsize_t __pyx_v_irow; hsize_t __pyx_v_start; hsize_t __pyx_v_stop; PyArrayObject *__pyx_v_idx = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_read_index_slice (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__irow,&__pyx_n_s__start,&__pyx_n_s__stop,&__pyx_n_s__idx,0}; PyObject* values[4] = {0,0,0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3); case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__irow)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__start)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_read_index_slice", 1, 4, 4, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 236; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } case 2: if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__stop)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_read_index_slice", 1, 4, 4, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 236; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } case 3: if (likely((values[3] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__idx)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_read_index_slice", 1, 4, 4, 3); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 236; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_read_index_slice") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 236; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 4) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); values[2] = PyTuple_GET_ITEM(__pyx_args, 2); values[3] = PyTuple_GET_ITEM(__pyx_args, 3); } __pyx_v_irow = __Pyx_PyInt_from_py_hsize_t(values[0]); if (unlikely((__pyx_v_irow == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 236; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_start = __Pyx_PyInt_from_py_hsize_t(values[1]); if (unlikely((__pyx_v_start == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 236; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_stop = __Pyx_PyInt_from_py_hsize_t(values[2]); if (unlikely((__pyx_v_stop == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 236; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_idx = ((PyArrayObject *)values[3]); } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_read_index_slice", 1, 4, 4, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 236; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._read_index_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_idx), __pyx_ptype_5numpy_ndarray, 1, "idx", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 237; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray__read_index_slice(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_irow, __pyx_v_start, __pyx_v_stop, __pyx_v_idx); goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":236 * cdef ndarray bufferbc, bufferlb * * def _read_index_slice(self, hsize_t irow, hsize_t start, hsize_t stop, # <<<<<<<<<<<<<< * ndarray idx): * cdef herr_t ret */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray__read_index_slice(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, hsize_t __pyx_v_irow, hsize_t __pyx_v_start, hsize_t __pyx_v_stop, PyArrayObject *__pyx_v_idx) { herr_t __pyx_v_ret; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_read_index_slice", 0); /* "tables/indexesextension.pyx":241 * * # Do the physical read * with nogil: # <<<<<<<<<<<<<< * ret = H5ARRAYOread_readSlice(self.dataset_id, self.type_id, * irow, start, stop, idx.data) */ { #ifdef WITH_THREAD PyThreadState *_save = NULL; #endif Py_UNBLOCK_THREADS /*try:*/ { /* "tables/indexesextension.pyx":243 * with nogil: * ret = H5ARRAYOread_readSlice(self.dataset_id, self.type_id, * irow, start, stop, idx.data) # <<<<<<<<<<<<<< * * if ret < 0: */ __pyx_v_ret = H5ARRAYOread_readSlice(__pyx_v_self->__pyx_base.__pyx_base.dataset_id, __pyx_v_self->__pyx_base.__pyx_base.type_id, __pyx_v_irow, __pyx_v_start, __pyx_v_stop, __pyx_v_idx->data); } /* "tables/indexesextension.pyx":241 * * # Do the physical read * with nogil: # <<<<<<<<<<<<<< * ret = H5ARRAYOread_readSlice(self.dataset_id, self.type_id, * irow, start, stop, idx.data) */ /*finally:*/ { Py_BLOCK_THREADS } } /* "tables/indexesextension.pyx":245 * irow, start, stop, idx.data) * * if ret < 0: # <<<<<<<<<<<<<< * raise HDF5ExtError("Problems reading the index indices.") * */ __pyx_t_1 = (__pyx_v_ret < 0); if (__pyx_t_1) { /* "tables/indexesextension.pyx":246 * * if ret < 0: * raise HDF5ExtError("Problems reading the index indices.") # <<<<<<<<<<<<<< * * _readIndexSlice = previous_api(_read_index_slice) */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__HDF5ExtError); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 246; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_k_tuple_8), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 246; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; {__pyx_filename = __pyx_f[0]; __pyx_lineno = 246; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L6; } __pyx_L6:; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("tables.indexesextension.IndexArray._read_index_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_3_init_sorted_slice(PyObject *__pyx_v_self, PyObject *__pyx_v_index); /*proto*/ static char __pyx_doc_6tables_16indexesextension_10IndexArray_2_init_sorted_slice[] = "Initialize the structures for doing a binary search."; static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_3_init_sorted_slice(PyObject *__pyx_v_self, PyObject *__pyx_v_index) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_init_sorted_slice (wrapper)", 0); __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_2_init_sorted_slice(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), ((PyObject *)__pyx_v_index)); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":250 * _readIndexSlice = previous_api(_read_index_slice) * * def _init_sorted_slice(self, index): # <<<<<<<<<<<<<< * """Initialize the structures for doing a binary search.""" * */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_2_init_sorted_slice(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, PyObject *__pyx_v_index) { int __pyx_v_rank; hsize_t __pyx_v_count[2]; PyArrayObject *__pyx_v_starts = 0; PyArrayObject *__pyx_v_lengths = 0; PyArrayObject *__pyx_v_rvcache = 0; PyObject *__pyx_v_maxslots = 0; PyObject *__pyx_v_rowsize = 0; PyObject *__pyx_v_dtype = NULL; PyObject *__pyx_v_params = NULL; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; PyObject *__pyx_t_4 = NULL; char *__pyx_t_5; hsize_t __pyx_t_6; int __pyx_t_7; PyObject *__pyx_t_8 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_init_sorted_slice", 0); /* "tables/indexesextension.pyx":260 * cdef object maxslots, rowsize * * dtype = self.atom.dtype # <<<<<<<<<<<<<< * # Create the buffer for reading sorted data chunks if not created yet * if self.bufferlb is None: */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__atom); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 260; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__dtype); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 260; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_v_dtype = __pyx_t_2; __pyx_t_2 = 0; /* "tables/indexesextension.pyx":262 * dtype = self.atom.dtype * # Create the buffer for reading sorted data chunks if not created yet * if self.bufferlb is None: # <<<<<<<<<<<<<< * # Internal buffers * self.bufferlb = numpy.empty(dtype=dtype, shape=self.chunksize) */ __pyx_t_3 = (((PyObject *)__pyx_v_self->bufferlb) == Py_None); if (__pyx_t_3) { /* "tables/indexesextension.pyx":264 * if self.bufferlb is None: * # Internal buffers * self.bufferlb = numpy.empty(dtype=dtype, shape=self.chunksize) # <<<<<<<<<<<<<< * # Get the pointers to the different buffer data areas * self.rbuflb = self.bufferlb.data */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__numpy); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 264; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s__empty); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 264; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyDict_New(); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 264; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_2)); if (PyDict_SetItem(__pyx_t_2, ((PyObject *)__pyx_n_s__dtype), __pyx_v_dtype) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 264; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__chunksize); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 264; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); if (PyDict_SetItem(__pyx_t_2, ((PyObject *)__pyx_n_s__shape), __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 264; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_4 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), ((PyObject *)__pyx_t_2)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 264; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; if (!(likely(((__pyx_t_4) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_4, __pyx_ptype_5numpy_ndarray))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 264; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GIVEREF(__pyx_t_4); __Pyx_GOTREF(__pyx_v_self->bufferlb); __Pyx_DECREF(((PyObject *)__pyx_v_self->bufferlb)); __pyx_v_self->bufferlb = ((PyArrayObject *)__pyx_t_4); __pyx_t_4 = 0; /* "tables/indexesextension.pyx":266 * self.bufferlb = numpy.empty(dtype=dtype, shape=self.chunksize) * # Get the pointers to the different buffer data areas * self.rbuflb = self.bufferlb.data # <<<<<<<<<<<<<< * # Init structures for accelerating sorted array reads * rank = 2 */ __pyx_t_5 = __pyx_v_self->bufferlb->data; __pyx_v_self->rbuflb = __pyx_t_5; /* "tables/indexesextension.pyx":268 * self.rbuflb = self.bufferlb.data * # Init structures for accelerating sorted array reads * rank = 2 # <<<<<<<<<<<<<< * count[0] = 1; count[1] = self.chunksize * self.mem_space_id = H5Screate_simple(rank, count, NULL) */ __pyx_v_rank = 2; /* "tables/indexesextension.pyx":269 * # Init structures for accelerating sorted array reads * rank = 2 * count[0] = 1; count[1] = self.chunksize # <<<<<<<<<<<<<< * self.mem_space_id = H5Screate_simple(rank, count, NULL) * # Cache some counters in local extension variables */ (__pyx_v_count[0]) = 1; __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__chunksize); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 269; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_6 = __Pyx_PyInt_from_py_hsize_t(__pyx_t_4); if (unlikely((__pyx_t_6 == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 269; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; (__pyx_v_count[1]) = __pyx_t_6; /* "tables/indexesextension.pyx":270 * rank = 2 * count[0] = 1; count[1] = self.chunksize * self.mem_space_id = H5Screate_simple(rank, count, NULL) # <<<<<<<<<<<<<< * # Cache some counters in local extension variables * self.l_chunksize = self.chunksize */ __pyx_v_self->mem_space_id = H5Screate_simple(__pyx_v_rank, __pyx_v_count, NULL); /* "tables/indexesextension.pyx":272 * self.mem_space_id = H5Screate_simple(rank, count, NULL) * # Cache some counters in local extension variables * self.l_chunksize = self.chunksize # <<<<<<<<<<<<<< * self.l_slicesize = self.slicesize * */ __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__chunksize); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 272; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_7 = __Pyx_PyInt_AsInt(__pyx_t_4); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 272; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_v_self->l_chunksize = __pyx_t_7; /* "tables/indexesextension.pyx":273 * # Cache some counters in local extension variables * self.l_chunksize = self.chunksize * self.l_slicesize = self.slicesize # <<<<<<<<<<<<<< * * # Get the addresses of buffer data */ __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__slicesize); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 273; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_7 = __Pyx_PyInt_AsInt(__pyx_t_4); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 273; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_v_self->l_slicesize = __pyx_t_7; goto __pyx_L3; } __pyx_L3:; /* "tables/indexesextension.pyx":276 * * # Get the addresses of buffer data * starts = index.starts; lengths = index.lengths # <<<<<<<<<<<<<< * self.rbufst = starts.data * self.rbufln = lengths.data */ __pyx_t_4 = PyObject_GetAttr(__pyx_v_index, __pyx_n_s__starts); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 276; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); if (!(likely(((__pyx_t_4) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_4, __pyx_ptype_5numpy_ndarray))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 276; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_starts = ((PyArrayObject *)__pyx_t_4); __pyx_t_4 = 0; __pyx_t_4 = PyObject_GetAttr(__pyx_v_index, __pyx_n_s__lengths); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 276; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); if (!(likely(((__pyx_t_4) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_4, __pyx_ptype_5numpy_ndarray))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 276; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_lengths = ((PyArrayObject *)__pyx_t_4); __pyx_t_4 = 0; /* "tables/indexesextension.pyx":277 * # Get the addresses of buffer data * starts = index.starts; lengths = index.lengths * self.rbufst = starts.data # <<<<<<<<<<<<<< * self.rbufln = lengths.data * # The 1st cache is loaded completely in memory and needs to be reloaded */ __pyx_t_5 = __pyx_v_starts->data; __pyx_v_self->rbufst = __pyx_t_5; /* "tables/indexesextension.pyx":278 * starts = index.starts; lengths = index.lengths * self.rbufst = starts.data * self.rbufln = lengths.data # <<<<<<<<<<<<<< * # The 1st cache is loaded completely in memory and needs to be reloaded * rvcache = index.ranges[:] */ __pyx_t_5 = __pyx_v_lengths->data; __pyx_v_self->rbufln = __pyx_t_5; /* "tables/indexesextension.pyx":280 * self.rbufln = lengths.data * # The 1st cache is loaded completely in memory and needs to be reloaded * rvcache = index.ranges[:] # <<<<<<<<<<<<<< * self.rbufrv = rvcache.data * index.rvcache = rvcache */ __pyx_t_4 = PyObject_GetAttr(__pyx_v_index, __pyx_n_s__ranges); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 280; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_2 = __Pyx_PySequence_GetSlice(__pyx_t_4, 0, PY_SSIZE_T_MAX); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 280; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; if (!(likely(((__pyx_t_2) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_2, __pyx_ptype_5numpy_ndarray))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 280; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_rvcache = ((PyArrayObject *)__pyx_t_2); __pyx_t_2 = 0; /* "tables/indexesextension.pyx":281 * # The 1st cache is loaded completely in memory and needs to be reloaded * rvcache = index.ranges[:] * self.rbufrv = rvcache.data # <<<<<<<<<<<<<< * index.rvcache = rvcache * # Init the bounds array for reading */ __pyx_t_5 = __pyx_v_rvcache->data; __pyx_v_self->rbufrv = __pyx_t_5; /* "tables/indexesextension.pyx":282 * rvcache = index.ranges[:] * self.rbufrv = rvcache.data * index.rvcache = rvcache # <<<<<<<<<<<<<< * # Init the bounds array for reading * self.nbounds = index.bounds.shape[1] */ if (PyObject_SetAttr(__pyx_v_index, __pyx_n_s__rvcache, ((PyObject *)__pyx_v_rvcache)) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 282; __pyx_clineno = __LINE__; goto __pyx_L1_error;} /* "tables/indexesextension.pyx":284 * index.rvcache = rvcache * # Init the bounds array for reading * self.nbounds = index.bounds.shape[1] # <<<<<<<<<<<<<< * self.bounds_ext = index.bounds * self.bounds_ext.initread(self.nbounds) */ __pyx_t_2 = PyObject_GetAttr(__pyx_v_index, __pyx_n_s__bounds); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 284; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s__shape); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 284; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = __Pyx_GetItemInt(__pyx_t_4, 1, sizeof(long), PyInt_FromLong); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 284; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_7 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_7 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 284; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_self->nbounds = __pyx_t_7; /* "tables/indexesextension.pyx":285 * # Init the bounds array for reading * self.nbounds = index.bounds.shape[1] * self.bounds_ext = index.bounds # <<<<<<<<<<<<<< * self.bounds_ext.initread(self.nbounds) * if str(dtype) in self._v_parent.opt_search_types: */ __pyx_t_2 = PyObject_GetAttr(__pyx_v_index, __pyx_n_s__bounds); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 285; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(((PyObject *)((struct __pyx_obj_6tables_16indexesextension_CacheArray *)__pyx_t_2))); __Pyx_GIVEREF(__pyx_t_2); __Pyx_GOTREF(__pyx_v_self->bounds_ext); __Pyx_DECREF(((PyObject *)__pyx_v_self->bounds_ext)); __pyx_v_self->bounds_ext = ((struct __pyx_obj_6tables_16indexesextension_CacheArray *)__pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "tables/indexesextension.pyx":286 * self.nbounds = index.bounds.shape[1] * self.bounds_ext = index.bounds * self.bounds_ext.initread(self.nbounds) # <<<<<<<<<<<<<< * if str(dtype) in self._v_parent.opt_search_types: * # The next caches should be defined only for optimized search types. */ __pyx_t_2 = ((struct __pyx_vtabstruct_6tables_16indexesextension_CacheArray *)__pyx_v_self->bounds_ext->__pyx_base.__pyx_base.__pyx_vtab)->initread(__pyx_v_self->bounds_ext, __pyx_v_self->nbounds); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 286; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "tables/indexesextension.pyx":287 * self.bounds_ext = index.bounds * self.bounds_ext.initread(self.nbounds) * if str(dtype) in self._v_parent.opt_search_types: # <<<<<<<<<<<<<< * # The next caches should be defined only for optimized search types. * # The 2nd level cache will replace the already existing ObjectCache and */ __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 287; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_v_dtype); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_v_dtype); __Pyx_GIVEREF(__pyx_v_dtype); __pyx_t_4 = PyObject_Call(((PyObject *)((PyObject*)(&PyString_Type))), ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 287; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s___v_parent); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 287; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s__opt_search_types); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 287; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_3 = (__Pyx_PySequence_Contains(__pyx_t_4, __pyx_t_1, Py_EQ)); if (unlikely(__pyx_t_3 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 287; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_3) { /* "tables/indexesextension.pyx":292 * # already bound to the boundscache attribute. This way, the cache will * # not be duplicated (I know, this smells badly, but anyway). * params = self._v_file.params # <<<<<<<<<<<<<< * rowsize = (self.bounds_ext._v_chunkshape[1] * dtype.itemsize) * maxslots = params['BOUNDS_MAX_SIZE'] / rowsize */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s___v_file); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 292; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__params); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 292; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_v_params = __pyx_t_4; __pyx_t_4 = 0; /* "tables/indexesextension.pyx":293 * # not be duplicated (I know, this smells badly, but anyway). * params = self._v_file.params * rowsize = (self.bounds_ext._v_chunkshape[1] * dtype.itemsize) # <<<<<<<<<<<<<< * maxslots = params['BOUNDS_MAX_SIZE'] / rowsize * self.boundscache = NumCache( */ __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_self->bounds_ext), __pyx_n_s___v_chunkshape); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 293; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_1 = __Pyx_GetItemInt(__pyx_t_4, 1, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 293; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_4 = PyObject_GetAttr(__pyx_v_dtype, __pyx_n_s__itemsize); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 293; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_2 = PyNumber_Multiply(__pyx_t_1, __pyx_t_4); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 293; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_v_rowsize = __pyx_t_2; __pyx_t_2 = 0; /* "tables/indexesextension.pyx":294 * params = self._v_file.params * rowsize = (self.bounds_ext._v_chunkshape[1] * dtype.itemsize) * maxslots = params['BOUNDS_MAX_SIZE'] / rowsize # <<<<<<<<<<<<<< * self.boundscache = NumCache( * (maxslots, self.nbounds), dtype, 'non-opt types bounds') */ __pyx_t_2 = PyObject_GetItem(__pyx_v_params, ((PyObject *)__pyx_n_s__BOUNDS_MAX_SIZE)); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 294; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = __Pyx_PyNumber_Divide(__pyx_t_2, __pyx_v_rowsize); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 294; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_maxslots = __pyx_t_4; __pyx_t_4 = 0; /* "tables/indexesextension.pyx":296 * maxslots = params['BOUNDS_MAX_SIZE'] / rowsize * self.boundscache = NumCache( * (maxslots, self.nbounds), dtype, 'non-opt types bounds') # <<<<<<<<<<<<<< * self.bufferbc = numpy.empty(dtype=dtype, shape=self.nbounds) * # Get the pointer for the internal buffer for 2nd level cache */ __pyx_t_4 = PyInt_FromLong(__pyx_v_self->nbounds); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 296; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_2 = PyTuple_New(2); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 296; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(__pyx_v_maxslots); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_v_maxslots); __Pyx_GIVEREF(__pyx_v_maxslots); PyTuple_SET_ITEM(__pyx_t_2, 1, __pyx_t_4); __Pyx_GIVEREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 295; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_4, 0, ((PyObject *)__pyx_t_2)); __Pyx_GIVEREF(((PyObject *)__pyx_t_2)); __Pyx_INCREF(__pyx_v_dtype); PyTuple_SET_ITEM(__pyx_t_4, 1, __pyx_v_dtype); __Pyx_GIVEREF(__pyx_v_dtype); __Pyx_INCREF(((PyObject *)__pyx_kp_s_9)); PyTuple_SET_ITEM(__pyx_t_4, 2, ((PyObject *)__pyx_kp_s_9)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_9)); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(((PyObject *)((PyObject*)__pyx_ptype_6tables_17lrucacheextension_NumCache)), ((PyObject *)__pyx_t_4), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 295; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0; __pyx_t_4 = __pyx_t_2; __Pyx_INCREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "tables/indexesextension.pyx":295 * rowsize = (self.bounds_ext._v_chunkshape[1] * dtype.itemsize) * maxslots = params['BOUNDS_MAX_SIZE'] / rowsize * self.boundscache = NumCache( # <<<<<<<<<<<<<< * (maxslots, self.nbounds), dtype, 'non-opt types bounds') * self.bufferbc = numpy.empty(dtype=dtype, shape=self.nbounds) */ __Pyx_GIVEREF(__pyx_t_4); __Pyx_GOTREF(__pyx_v_self->boundscache); __Pyx_DECREF(((PyObject *)__pyx_v_self->boundscache)); __pyx_v_self->boundscache = ((struct __pyx_obj_6tables_17lrucacheextension_NumCache *)__pyx_t_4); __pyx_t_4 = 0; /* "tables/indexesextension.pyx":297 * self.boundscache = NumCache( * (maxslots, self.nbounds), dtype, 'non-opt types bounds') * self.bufferbc = numpy.empty(dtype=dtype, shape=self.nbounds) # <<<<<<<<<<<<<< * # Get the pointer for the internal buffer for 2nd level cache * self.rbufbc = self.bufferbc.data */ __pyx_t_4 = __Pyx_GetName(__pyx_m, __pyx_n_s__numpy); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 297; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_2 = PyObject_GetAttr(__pyx_t_4, __pyx_n_s__empty); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 297; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_4 = PyDict_New(); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 297; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_4)); if (PyDict_SetItem(__pyx_t_4, ((PyObject *)__pyx_n_s__dtype), __pyx_v_dtype) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 297; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_t_1 = PyInt_FromLong(__pyx_v_self->nbounds); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 297; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (PyDict_SetItem(__pyx_t_4, ((PyObject *)__pyx_n_s__shape), __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 297; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_empty_tuple), ((PyObject *)__pyx_t_4)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 297; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0; if (!(likely(((__pyx_t_1) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_1, __pyx_ptype_5numpy_ndarray))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 297; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GIVEREF(__pyx_t_1); __Pyx_GOTREF(__pyx_v_self->bufferbc); __Pyx_DECREF(((PyObject *)__pyx_v_self->bufferbc)); __pyx_v_self->bufferbc = ((PyArrayObject *)__pyx_t_1); __pyx_t_1 = 0; /* "tables/indexesextension.pyx":299 * self.bufferbc = numpy.empty(dtype=dtype, shape=self.nbounds) * # Get the pointer for the internal buffer for 2nd level cache * self.rbufbc = self.bufferbc.data # <<<<<<<<<<<<<< * # Another NumCache for the sorted values * rowsize = (self.chunksize*dtype.itemsize) */ __pyx_t_5 = __pyx_v_self->bufferbc->data; __pyx_v_self->rbufbc = __pyx_t_5; /* "tables/indexesextension.pyx":301 * self.rbufbc = self.bufferbc.data * # Another NumCache for the sorted values * rowsize = (self.chunksize*dtype.itemsize) # <<<<<<<<<<<<<< * maxslots = params['SORTED_MAX_SIZE'] / (self.chunksize*dtype.itemsize) * self.sortedcache = NumCache( */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__chunksize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 301; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_4 = PyObject_GetAttr(__pyx_v_dtype, __pyx_n_s__itemsize); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 301; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_2 = PyNumber_Multiply(__pyx_t_1, __pyx_t_4); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 301; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_v_rowsize); __pyx_v_rowsize = __pyx_t_2; __pyx_t_2 = 0; /* "tables/indexesextension.pyx":302 * # Another NumCache for the sorted values * rowsize = (self.chunksize*dtype.itemsize) * maxslots = params['SORTED_MAX_SIZE'] / (self.chunksize*dtype.itemsize) # <<<<<<<<<<<<<< * self.sortedcache = NumCache( * (maxslots, self.chunksize), dtype, 'sorted') */ __pyx_t_2 = PyObject_GetItem(__pyx_v_params, ((PyObject *)__pyx_n_s__SORTED_MAX_SIZE)); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 302; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_4 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__chunksize); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 302; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_1 = PyObject_GetAttr(__pyx_v_dtype, __pyx_n_s__itemsize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 302; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_8 = PyNumber_Multiply(__pyx_t_4, __pyx_t_1); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 302; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = __Pyx_PyNumber_Divide(__pyx_t_2, __pyx_t_8); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 302; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; __Pyx_DECREF(__pyx_v_maxslots); __pyx_v_maxslots = __pyx_t_1; __pyx_t_1 = 0; /* "tables/indexesextension.pyx":304 * maxslots = params['SORTED_MAX_SIZE'] / (self.chunksize*dtype.itemsize) * self.sortedcache = NumCache( * (maxslots, self.chunksize), dtype, 'sorted') # <<<<<<<<<<<<<< * * */ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__chunksize); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 304; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __Pyx_INCREF(__pyx_v_maxslots); PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_v_maxslots); __Pyx_GIVEREF(__pyx_v_maxslots); PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyTuple_New(3); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 303; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_t_8)); __Pyx_GIVEREF(((PyObject *)__pyx_t_8)); __Pyx_INCREF(__pyx_v_dtype); PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_v_dtype); __Pyx_GIVEREF(__pyx_v_dtype); __Pyx_INCREF(((PyObject *)__pyx_n_s__sorted)); PyTuple_SET_ITEM(__pyx_t_1, 2, ((PyObject *)__pyx_n_s__sorted)); __Pyx_GIVEREF(((PyObject *)__pyx_n_s__sorted)); __pyx_t_8 = 0; __pyx_t_8 = PyObject_Call(((PyObject *)((PyObject*)__pyx_ptype_6tables_17lrucacheextension_NumCache)), ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 303; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; __pyx_t_1 = __pyx_t_8; __Pyx_INCREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; /* "tables/indexesextension.pyx":303 * rowsize = (self.chunksize*dtype.itemsize) * maxslots = params['SORTED_MAX_SIZE'] / (self.chunksize*dtype.itemsize) * self.sortedcache = NumCache( # <<<<<<<<<<<<<< * (maxslots, self.chunksize), dtype, 'sorted') * */ __Pyx_GIVEREF(__pyx_t_1); __Pyx_GOTREF(__pyx_v_self->sortedcache); __Pyx_DECREF(((PyObject *)__pyx_v_self->sortedcache)); __pyx_v_self->sortedcache = ((struct __pyx_obj_6tables_17lrucacheextension_NumCache *)__pyx_t_1); __pyx_t_1 = 0; goto __pyx_L4; } __pyx_L4:; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("tables.indexesextension.IndexArray._init_sorted_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_starts); __Pyx_XDECREF((PyObject *)__pyx_v_lengths); __Pyx_XDECREF((PyObject *)__pyx_v_rvcache); __Pyx_XDECREF(__pyx_v_maxslots); __Pyx_XDECREF(__pyx_v_rowsize); __Pyx_XDECREF(__pyx_v_dtype); __Pyx_XDECREF(__pyx_v_params); __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":309 * _initSortedSlice = previous_api(_init_sorted_slice) * * cdef void *_g_read_sorted_slice(self, hsize_t irow, hsize_t start, # <<<<<<<<<<<<<< * hsize_t stop): * """Read the sorted part of an index.""" */ static void *__pyx_f_6tables_16indexesextension_10IndexArray__g_read_sorted_slice(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, hsize_t __pyx_v_irow, hsize_t __pyx_v_start, hsize_t __pyx_v_stop) { herr_t __pyx_v_ret; void *__pyx_r; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_g_read_sorted_slice", 0); /* "tables/indexesextension.pyx":313 * """Read the sorted part of an index.""" * * with nogil: # <<<<<<<<<<<<<< * ret = H5ARRAYOread_readSortedSlice( * self.dataset_id, self.mem_space_id, self.type_id, */ { #ifdef WITH_THREAD PyThreadState *_save = NULL; #endif Py_UNBLOCK_THREADS /*try:*/ { /* "tables/indexesextension.pyx":316 * ret = H5ARRAYOread_readSortedSlice( * self.dataset_id, self.mem_space_id, self.type_id, * irow, start, stop, self.rbuflb) # <<<<<<<<<<<<<< * * if ret < 0: */ __pyx_v_ret = H5ARRAYOread_readSortedSlice(__pyx_v_self->__pyx_base.__pyx_base.dataset_id, __pyx_v_self->mem_space_id, __pyx_v_self->__pyx_base.__pyx_base.type_id, __pyx_v_irow, __pyx_v_start, __pyx_v_stop, __pyx_v_self->rbuflb); } /* "tables/indexesextension.pyx":313 * """Read the sorted part of an index.""" * * with nogil: # <<<<<<<<<<<<<< * ret = H5ARRAYOread_readSortedSlice( * self.dataset_id, self.mem_space_id, self.type_id, */ /*finally:*/ { Py_BLOCK_THREADS } } /* "tables/indexesextension.pyx":318 * irow, start, stop, self.rbuflb) * * if ret < 0: # <<<<<<<<<<<<<< * raise HDF5ExtError("Problems reading the array data.") * */ __pyx_t_1 = (__pyx_v_ret < 0); if (__pyx_t_1) { /* "tables/indexesextension.pyx":319 * * if ret < 0: * raise HDF5ExtError("Problems reading the array data.") # <<<<<<<<<<<<<< * * return self.rbuflb */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__HDF5ExtError); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 319; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_k_tuple_11), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 319; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; {__pyx_filename = __pyx_f[0]; __pyx_lineno = 319; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L6; } __pyx_L6:; /* "tables/indexesextension.pyx":321 * raise HDF5ExtError("Problems reading the array data.") * * return self.rbuflb # <<<<<<<<<<<<<< * * # can't time machine since this function is cdef'd */ __pyx_r = __pyx_v_self->rbuflb; goto __pyx_L0; __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_WriteUnraisable("tables.indexesextension.IndexArray._g_read_sorted_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_5_read_sorted_slice(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_6tables_16indexesextension_10IndexArray_4_read_sorted_slice[] = "Read the sorted part of an index."; static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_5_read_sorted_slice(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { hsize_t __pyx_v_irow; hsize_t __pyx_v_start; hsize_t __pyx_v_stop; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_read_sorted_slice (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__irow,&__pyx_n_s__start,&__pyx_n_s__stop,0}; PyObject* values[3] = {0,0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__irow)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__start)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_read_sorted_slice", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 327; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } case 2: if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__stop)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_read_sorted_slice", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 327; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_read_sorted_slice") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 327; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 3) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); values[2] = PyTuple_GET_ITEM(__pyx_args, 2); } __pyx_v_irow = __Pyx_PyInt_from_py_hsize_t(values[0]); if (unlikely((__pyx_v_irow == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 327; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_start = __Pyx_PyInt_from_py_hsize_t(values[1]); if (unlikely((__pyx_v_start == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 327; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_stop = __Pyx_PyInt_from_py_hsize_t(values[2]); if (unlikely((__pyx_v_stop == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 327; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_read_sorted_slice", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 327; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._read_sorted_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_4_read_sorted_slice(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_irow, __pyx_v_start, __pyx_v_stop); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":327 * * # This is callable from python * def _read_sorted_slice(self, hsize_t irow, hsize_t start, hsize_t stop): # <<<<<<<<<<<<<< * """Read the sorted part of an index.""" * */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_4_read_sorted_slice(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, hsize_t __pyx_v_irow, hsize_t __pyx_v_start, hsize_t __pyx_v_stop) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_read_sorted_slice", 0); /* "tables/indexesextension.pyx":330 * """Read the sorted part of an index.""" * * self._g_read_sorted_slice(irow, start, stop) # <<<<<<<<<<<<<< * return self.bufferlb * */ ((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->_g_read_sorted_slice(__pyx_v_self, __pyx_v_irow, __pyx_v_start, __pyx_v_stop); /* "tables/indexesextension.pyx":331 * * self._g_read_sorted_slice(irow, start, stop) * return self.bufferlb # <<<<<<<<<<<<<< * * _readSortedSlice = previous_api(_read_sorted_slice) */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(((PyObject *)__pyx_v_self->bufferlb)); __pyx_r = ((PyObject *)__pyx_v_self->bufferlb); goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_7_bisect_left(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_6tables_16indexesextension_10IndexArray_6_bisect_left[] = "Return the index where to insert item x in list a, assuming a is sorted.\n\n The return value i is such that all e in a[:i] have e < x, and all e in\n a[i:] have e >= x. So if x already appears in the list, i points just\n before the leftmost x already there.\n\n "; static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_7_bisect_left(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_a = 0; PyObject *__pyx_v_x = 0; int __pyx_v_hi; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_bisect_left (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__a,&__pyx_n_s__x,&__pyx_n_s__hi,0}; PyObject* values[3] = {0,0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__a)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__x)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_bisect_left", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 339; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } case 2: if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__hi)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_bisect_left", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 339; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_bisect_left") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 339; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 3) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); values[2] = PyTuple_GET_ITEM(__pyx_args, 2); } __pyx_v_a = values[0]; __pyx_v_x = values[1]; __pyx_v_hi = __Pyx_PyInt_AsInt(values[2]); if (unlikely((__pyx_v_hi == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 339; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_bisect_left", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 339; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._bisect_left", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_6_bisect_left(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_a, __pyx_v_x, __pyx_v_hi); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":339 * # because I forsee that this should be a very common case. * # 2004-05-20 * def _bisect_left(self, a, x, int hi): # <<<<<<<<<<<<<< * """Return the index where to insert item x in list a, assuming a is sorted. * */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_6_bisect_left(CYTHON_UNUSED struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, PyObject *__pyx_v_a, PyObject *__pyx_v_x, int __pyx_v_hi) { int __pyx_v_lo; int __pyx_v_mid; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_bisect_left", 0); /* "tables/indexesextension.pyx":350 * cdef int lo, mid * * lo = 0 # <<<<<<<<<<<<<< * if x <= a[0]: return 0 * if a[-1] < x: return hi */ __pyx_v_lo = 0; /* "tables/indexesextension.pyx":351 * * lo = 0 * if x <= a[0]: return 0 # <<<<<<<<<<<<<< * if a[-1] < x: return hi * while lo < hi: */ __pyx_t_1 = __Pyx_GetItemInt(__pyx_v_a, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 351; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_RichCompare(__pyx_v_x, __pyx_t_1, Py_LE); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 351; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_3 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 351; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (__pyx_t_3) { __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_int_0); __pyx_r = __pyx_int_0; goto __pyx_L0; goto __pyx_L3; } __pyx_L3:; /* "tables/indexesextension.pyx":352 * lo = 0 * if x <= a[0]: return 0 * if a[-1] < x: return hi # <<<<<<<<<<<<<< * while lo < hi: * mid = (lo+hi)/2 */ __pyx_t_2 = __Pyx_GetItemInt(__pyx_v_a, -1, sizeof(long), PyInt_FromLong); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 352; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = PyObject_RichCompare(__pyx_t_2, __pyx_v_x, Py_LT); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 352; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_3 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 352; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_3) { __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(__pyx_v_hi); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 352; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L4; } __pyx_L4:; /* "tables/indexesextension.pyx":353 * if x <= a[0]: return 0 * if a[-1] < x: return hi * while lo < hi: # <<<<<<<<<<<<<< * mid = (lo+hi)/2 * if a[mid] < x: lo = mid+1 */ while (1) { __pyx_t_3 = (__pyx_v_lo < __pyx_v_hi); if (!__pyx_t_3) break; /* "tables/indexesextension.pyx":354 * if a[-1] < x: return hi * while lo < hi: * mid = (lo+hi)/2 # <<<<<<<<<<<<<< * if a[mid] < x: lo = mid+1 * else: hi = mid */ __pyx_v_mid = __Pyx_div_long((__pyx_v_lo + __pyx_v_hi), 2); /* "tables/indexesextension.pyx":355 * while lo < hi: * mid = (lo+hi)/2 * if a[mid] < x: lo = mid+1 # <<<<<<<<<<<<<< * else: hi = mid * return lo */ __pyx_t_1 = __Pyx_GetItemInt(__pyx_v_a, __pyx_v_mid, sizeof(int), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 355; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_RichCompare(__pyx_t_1, __pyx_v_x, Py_LT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 355; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_3 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 355; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (__pyx_t_3) { __pyx_v_lo = (__pyx_v_mid + 1); goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":356 * mid = (lo+hi)/2 * if a[mid] < x: lo = mid+1 * else: hi = mid # <<<<<<<<<<<<<< * return lo * */ __pyx_v_hi = __pyx_v_mid; } __pyx_L7:; } /* "tables/indexesextension.pyx":357 * if a[mid] < x: lo = mid+1 * else: hi = mid * return lo # <<<<<<<<<<<<<< * * def _bisect_right(self, a, x, int hi): */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_lo); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 357; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._bisect_left", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_9_bisect_right(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_6tables_16indexesextension_10IndexArray_8_bisect_right[] = "Return the index where to insert item x in list a, assuming a is sorted.\n\n The return value i is such that all e in a[:i] have e <= x, and all e in\n a[i:] have e > x. So if x already appears in the list, i points just\n beyond the rightmost x already there.\n\n "; static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_9_bisect_right(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { PyObject *__pyx_v_a = 0; PyObject *__pyx_v_x = 0; int __pyx_v_hi; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_bisect_right (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__a,&__pyx_n_s__x,&__pyx_n_s__hi,0}; PyObject* values[3] = {0,0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__a)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__x)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_bisect_right", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 359; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } case 2: if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__hi)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_bisect_right", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 359; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_bisect_right") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 359; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 3) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); values[2] = PyTuple_GET_ITEM(__pyx_args, 2); } __pyx_v_a = values[0]; __pyx_v_x = values[1]; __pyx_v_hi = __Pyx_PyInt_AsInt(values[2]); if (unlikely((__pyx_v_hi == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 359; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_bisect_right", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 359; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._bisect_right", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_8_bisect_right(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_a, __pyx_v_x, __pyx_v_hi); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":359 * return lo * * def _bisect_right(self, a, x, int hi): # <<<<<<<<<<<<<< * """Return the index where to insert item x in list a, assuming a is sorted. * */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_8_bisect_right(CYTHON_UNUSED struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, PyObject *__pyx_v_a, PyObject *__pyx_v_x, int __pyx_v_hi) { int __pyx_v_lo; int __pyx_v_mid; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_bisect_right", 0); /* "tables/indexesextension.pyx":370 * cdef int lo, mid * * lo = 0 # <<<<<<<<<<<<<< * if x < a[0]: return 0 * if a[-1] <= x: return hi */ __pyx_v_lo = 0; /* "tables/indexesextension.pyx":371 * * lo = 0 * if x < a[0]: return 0 # <<<<<<<<<<<<<< * if a[-1] <= x: return hi * while lo < hi: */ __pyx_t_1 = __Pyx_GetItemInt(__pyx_v_a, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 371; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_RichCompare(__pyx_v_x, __pyx_t_1, Py_LT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 371; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_3 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 371; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (__pyx_t_3) { __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(__pyx_int_0); __pyx_r = __pyx_int_0; goto __pyx_L0; goto __pyx_L3; } __pyx_L3:; /* "tables/indexesextension.pyx":372 * lo = 0 * if x < a[0]: return 0 * if a[-1] <= x: return hi # <<<<<<<<<<<<<< * while lo < hi: * mid = (lo+hi)/2 */ __pyx_t_2 = __Pyx_GetItemInt(__pyx_v_a, -1, sizeof(long), PyInt_FromLong); if (!__pyx_t_2) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 372; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = PyObject_RichCompare(__pyx_t_2, __pyx_v_x, Py_LE); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 372; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_3 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 372; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; if (__pyx_t_3) { __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyInt_FromLong(__pyx_v_hi); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 372; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; goto __pyx_L4; } __pyx_L4:; /* "tables/indexesextension.pyx":373 * if x < a[0]: return 0 * if a[-1] <= x: return hi * while lo < hi: # <<<<<<<<<<<<<< * mid = (lo+hi)/2 * if x < a[mid]: hi = mid */ while (1) { __pyx_t_3 = (__pyx_v_lo < __pyx_v_hi); if (!__pyx_t_3) break; /* "tables/indexesextension.pyx":374 * if a[-1] <= x: return hi * while lo < hi: * mid = (lo+hi)/2 # <<<<<<<<<<<<<< * if x < a[mid]: hi = mid * else: lo = mid+1 */ __pyx_v_mid = __Pyx_div_long((__pyx_v_lo + __pyx_v_hi), 2); /* "tables/indexesextension.pyx":375 * while lo < hi: * mid = (lo+hi)/2 * if x < a[mid]: hi = mid # <<<<<<<<<<<<<< * else: lo = mid+1 * return lo */ __pyx_t_1 = __Pyx_GetItemInt(__pyx_v_a, __pyx_v_mid, sizeof(int), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 375; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyObject_RichCompare(__pyx_v_x, __pyx_t_1, Py_LT); __Pyx_XGOTREF(__pyx_t_2); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 375; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_3 = __Pyx_PyObject_IsTrue(__pyx_t_2); if (unlikely(__pyx_t_3 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 375; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; if (__pyx_t_3) { __pyx_v_hi = __pyx_v_mid; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":376 * mid = (lo+hi)/2 * if x < a[mid]: hi = mid * else: lo = mid+1 # <<<<<<<<<<<<<< * return lo * */ __pyx_v_lo = (__pyx_v_mid + 1); } __pyx_L7:; } /* "tables/indexesextension.pyx":377 * if x < a[mid]: hi = mid * else: lo = mid+1 * return lo # <<<<<<<<<<<<<< * * cdef void *get_lru_bounds(self, int nrow, int nbounds): */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_lo); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 377; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._bisect_right", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":379 * return lo * * cdef void *get_lru_bounds(self, int nrow, int nbounds): # <<<<<<<<<<<<<< * """Get the bounds from the cache, or read them.""" * */ static void *__pyx_f_6tables_16indexesextension_10IndexArray_get_lru_bounds(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, int __pyx_v_nrow, int __pyx_v_nbounds) { void *__pyx_v_vpointer; long __pyx_v_nslot; void *__pyx_r; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; void *__pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("get_lru_bounds", 0); /* "tables/indexesextension.pyx":385 * cdef long nslot * * nslot = self.boundscache.getslot_(nrow) # <<<<<<<<<<<<<< * if nslot >= 0: * vpointer = self.boundscache.getitem1_(nslot) */ __pyx_v_nslot = ((struct __pyx_vtabstruct_6tables_17lrucacheextension_NumCache *)__pyx_v_self->boundscache->__pyx_base.__pyx_vtab)->getslot_(__pyx_v_self->boundscache, __pyx_v_nrow); /* "tables/indexesextension.pyx":386 * * nslot = self.boundscache.getslot_(nrow) * if nslot >= 0: # <<<<<<<<<<<<<< * vpointer = self.boundscache.getitem1_(nslot) * else: */ __pyx_t_1 = (__pyx_v_nslot >= 0); if (__pyx_t_1) { /* "tables/indexesextension.pyx":387 * nslot = self.boundscache.getslot_(nrow) * if nslot >= 0: * vpointer = self.boundscache.getitem1_(nslot) # <<<<<<<<<<<<<< * else: * # Bounds row is not in cache. Read it and put it in the LRU cache. */ __pyx_v_vpointer = ((struct __pyx_vtabstruct_6tables_17lrucacheextension_NumCache *)__pyx_v_self->boundscache->__pyx_base.__pyx_vtab)->getitem1_(__pyx_v_self->boundscache, __pyx_v_nslot); goto __pyx_L3; } /*else*/ { /* "tables/indexesextension.pyx":390 * else: * # Bounds row is not in cache. Read it and put it in the LRU cache. * self.bounds_ext.read_slice(nrow, 0, nbounds, self.rbufbc) # <<<<<<<<<<<<<< * self.boundscache.setitem_(nrow, self.rbufbc, 0) * vpointer = self.rbufbc */ __pyx_t_2 = ((struct __pyx_vtabstruct_6tables_16indexesextension_CacheArray *)__pyx_v_self->bounds_ext->__pyx_base.__pyx_base.__pyx_vtab)->read_slice(__pyx_v_self->bounds_ext, __pyx_v_nrow, 0, __pyx_v_nbounds, __pyx_v_self->rbufbc); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 390; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "tables/indexesextension.pyx":391 * # Bounds row is not in cache. Read it and put it in the LRU cache. * self.bounds_ext.read_slice(nrow, 0, nbounds, self.rbufbc) * self.boundscache.setitem_(nrow, self.rbufbc, 0) # <<<<<<<<<<<<<< * vpointer = self.rbufbc * return vpointer */ ((struct __pyx_vtabstruct_6tables_17lrucacheextension_NumCache *)__pyx_v_self->boundscache->__pyx_base.__pyx_vtab)->setitem_(__pyx_v_self->boundscache, __pyx_v_nrow, __pyx_v_self->rbufbc, 0); /* "tables/indexesextension.pyx":392 * self.bounds_ext.read_slice(nrow, 0, nbounds, self.rbufbc) * self.boundscache.setitem_(nrow, self.rbufbc, 0) * vpointer = self.rbufbc # <<<<<<<<<<<<<< * return vpointer * */ __pyx_t_3 = __pyx_v_self->rbufbc; __pyx_v_vpointer = __pyx_t_3; } __pyx_L3:; /* "tables/indexesextension.pyx":393 * self.boundscache.setitem_(nrow, self.rbufbc, 0) * vpointer = self.rbufbc * return vpointer # <<<<<<<<<<<<<< * * # can't time machine since get_lru_bounds() function is cdef'd */ __pyx_r = __pyx_v_vpointer; goto __pyx_L0; __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_WriteUnraisable("tables.indexesextension.IndexArray.get_lru_bounds", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":397 * # can't time machine since get_lru_bounds() function is cdef'd * * cdef void *get_lru_sorted(self, int nrow, int ncs, int nchunk, int cs): # <<<<<<<<<<<<<< * """Get the sorted row from the cache or read it.""" * */ static void *__pyx_f_6tables_16indexesextension_10IndexArray_get_lru_sorted(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, int __pyx_v_nrow, int __pyx_v_ncs, int __pyx_v_nchunk, int __pyx_v_cs) { void *__pyx_v_vpointer; npy_int64 __pyx_v_nckey; long __pyx_v_nslot; hsize_t __pyx_v_start; hsize_t __pyx_v_stop; void *__pyx_r; __Pyx_RefNannyDeclarations int __pyx_t_1; __Pyx_RefNannySetupContext("get_lru_sorted", 0); /* "tables/indexesextension.pyx":406 * * # Compute the number of chunk read and use it as the key for the cache. * nckey = nrow*ncs+nchunk # <<<<<<<<<<<<<< * nslot = self.sortedcache.getslot_(nckey) * if nslot >= 0: */ __pyx_v_nckey = ((__pyx_v_nrow * __pyx_v_ncs) + __pyx_v_nchunk); /* "tables/indexesextension.pyx":407 * # Compute the number of chunk read and use it as the key for the cache. * nckey = nrow*ncs+nchunk * nslot = self.sortedcache.getslot_(nckey) # <<<<<<<<<<<<<< * if nslot >= 0: * vpointer = self.sortedcache.getitem1_(nslot) */ __pyx_v_nslot = ((struct __pyx_vtabstruct_6tables_17lrucacheextension_NumCache *)__pyx_v_self->sortedcache->__pyx_base.__pyx_vtab)->getslot_(__pyx_v_self->sortedcache, __pyx_v_nckey); /* "tables/indexesextension.pyx":408 * nckey = nrow*ncs+nchunk * nslot = self.sortedcache.getslot_(nckey) * if nslot >= 0: # <<<<<<<<<<<<<< * vpointer = self.sortedcache.getitem1_(nslot) * else: */ __pyx_t_1 = (__pyx_v_nslot >= 0); if (__pyx_t_1) { /* "tables/indexesextension.pyx":409 * nslot = self.sortedcache.getslot_(nckey) * if nslot >= 0: * vpointer = self.sortedcache.getitem1_(nslot) # <<<<<<<<<<<<<< * else: * # The sorted chunk is not in cache. Read it and put it in the LRU cache. */ __pyx_v_vpointer = ((struct __pyx_vtabstruct_6tables_17lrucacheextension_NumCache *)__pyx_v_self->sortedcache->__pyx_base.__pyx_vtab)->getitem1_(__pyx_v_self->sortedcache, __pyx_v_nslot); goto __pyx_L3; } /*else*/ { /* "tables/indexesextension.pyx":412 * else: * # The sorted chunk is not in cache. Read it and put it in the LRU cache. * start = cs*nchunk; stop = cs*(nchunk+1) # <<<<<<<<<<<<<< * vpointer = self._g_read_sorted_slice(nrow, start, stop) * self.sortedcache.setitem_(nckey, vpointer, 0) */ __pyx_v_start = (__pyx_v_cs * __pyx_v_nchunk); __pyx_v_stop = (__pyx_v_cs * (__pyx_v_nchunk + 1)); /* "tables/indexesextension.pyx":413 * # The sorted chunk is not in cache. Read it and put it in the LRU cache. * start = cs*nchunk; stop = cs*(nchunk+1) * vpointer = self._g_read_sorted_slice(nrow, start, stop) # <<<<<<<<<<<<<< * self.sortedcache.setitem_(nckey, vpointer, 0) * return vpointer */ __pyx_v_vpointer = ((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->_g_read_sorted_slice(__pyx_v_self, __pyx_v_nrow, __pyx_v_start, __pyx_v_stop); /* "tables/indexesextension.pyx":414 * start = cs*nchunk; stop = cs*(nchunk+1) * vpointer = self._g_read_sorted_slice(nrow, start, stop) * self.sortedcache.setitem_(nckey, vpointer, 0) # <<<<<<<<<<<<<< * return vpointer * */ ((struct __pyx_vtabstruct_6tables_17lrucacheextension_NumCache *)__pyx_v_self->sortedcache->__pyx_base.__pyx_vtab)->setitem_(__pyx_v_self->sortedcache, __pyx_v_nckey, __pyx_v_vpointer, 0); } __pyx_L3:; /* "tables/indexesextension.pyx":415 * vpointer = self._g_read_sorted_slice(nrow, start, stop) * self.sortedcache.setitem_(nckey, vpointer, 0) * return vpointer # <<<<<<<<<<<<<< * * # can't time machine since get_lru_sorted() function is cdef'd */ __pyx_r = __pyx_v_vpointer; goto __pyx_L0; __pyx_r = 0; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_11_search_bin_na_b(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_11_search_bin_na_b(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { long __pyx_v_item1; long __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_b (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_b", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 420; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_b") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 420; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __Pyx_PyInt_AsLong(values[0]); if (unlikely((__pyx_v_item1 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 420; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __Pyx_PyInt_AsLong(values[1]); if (unlikely((__pyx_v_item2 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 420; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_b", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 420; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_b", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_10_search_bin_na_b(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":420 * * # Optimized version for int8 * def _search_bin_na_b(self, long item1, long item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_10_search_bin_na_b(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_int8 *__pyx_v_rbufrv; npy_int8 *__pyx_v_rbufbc; npy_int8 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_b", 0); /* "tables/indexesextension.pyx":425 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_int8 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":427 * cdef npy_int8 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 427; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 427; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":428 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 428; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 428; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; /* "tables/indexesextension.pyx":429 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":430 * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_int8 *)__pyx_v_self->rbufrv); __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":431 * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":432 * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":434 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":435 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":437 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_b(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_int8 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":438 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_b(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":439 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_b(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_b(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":441 * nchunk = bisect_left_b(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_b(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_int8 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":442 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_b(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_b(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":444 * start = bisect_left_b(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":446 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":448 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":449 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":450 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":452 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_b(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_int8 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":453 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_b(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_b(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":454 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_b(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":456 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_b(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_int8 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":457 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_b(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_b(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":459 * stop = bisect_right_b(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":461 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":462 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":463 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":464 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_b = previous_api(_search_bin_na_b) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 464; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_b", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_13_search_bin_na_ub(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_13_search_bin_na_ub(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { long __pyx_v_item1; long __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_ub (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_ub", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 469; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_ub") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 469; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __Pyx_PyInt_AsLong(values[0]); if (unlikely((__pyx_v_item1 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 469; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __Pyx_PyInt_AsLong(values[1]); if (unlikely((__pyx_v_item2 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 469; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_ub", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 469; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_ub", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_12_search_bin_na_ub(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":469 * * # Optimized version for uint8 * def _search_bin_na_ub(self, long item1, long item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_12_search_bin_na_ub(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_uint8 *__pyx_v_rbufrv; npy_uint8 *__pyx_v_rbufbc; npy_uint8 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_ub", 0); /* "tables/indexesextension.pyx":474 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_uint8 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":476 * cdef npy_uint8 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 476; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 476; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":477 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 477; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 477; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; /* "tables/indexesextension.pyx":478 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":479 * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_uint8 *)__pyx_v_self->rbufrv); __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":480 * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":481 * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":483 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":484 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":486 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_ub(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_uint8 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":487 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_ub(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":488 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_ub(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_ub(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":490 * nchunk = bisect_left_ub(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_ub(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_uint8 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":491 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_ub(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_ub(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":493 * start = bisect_left_ub(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":495 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":497 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":498 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":499 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":501 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_ub(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_uint8 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":502 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_ub(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_ub(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":503 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_ub(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":505 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_ub(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_uint8 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":506 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_ub(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_ub(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":508 * stop = bisect_right_ub(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":510 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":511 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":512 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":513 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_ub = previous_api(_search_bin_na_ub) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 513; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_ub", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_15_search_bin_na_s(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_15_search_bin_na_s(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { long __pyx_v_item1; long __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_s (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_s", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 518; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_s") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 518; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __Pyx_PyInt_AsLong(values[0]); if (unlikely((__pyx_v_item1 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 518; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __Pyx_PyInt_AsLong(values[1]); if (unlikely((__pyx_v_item2 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 518; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_s", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 518; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_s", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_14_search_bin_na_s(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":518 * * # Optimized version for int16 * def _search_bin_na_s(self, long item1, long item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_14_search_bin_na_s(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_int16 *__pyx_v_rbufrv; npy_int16 *__pyx_v_rbufbc; npy_int16 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_s", 0); /* "tables/indexesextension.pyx":523 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_int16 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":525 * cdef npy_int16 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 525; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 525; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":526 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 526; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 526; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; /* "tables/indexesextension.pyx":527 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":528 * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_int16 *)__pyx_v_self->rbufrv); __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":529 * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":530 * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":532 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":533 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":535 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_s(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_int16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":536 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_s(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":537 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_s(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_s(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":539 * nchunk = bisect_left_s(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_s(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_int16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":540 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_s(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_s(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":542 * start = bisect_left_s(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":544 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":546 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":547 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":548 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":550 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_s(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_int16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":551 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_s(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_s(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":552 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_s(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":554 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_s(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_int16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":555 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_s(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_s(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":557 * stop = bisect_right_s(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":559 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":560 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":561 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":562 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_s = previous_api(_search_bin_na_s) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 562; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_s", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_17_search_bin_na_us(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_17_search_bin_na_us(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { long __pyx_v_item1; long __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_us (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_us", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 567; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_us") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 567; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __Pyx_PyInt_AsLong(values[0]); if (unlikely((__pyx_v_item1 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 567; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __Pyx_PyInt_AsLong(values[1]); if (unlikely((__pyx_v_item2 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 567; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_us", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 567; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_us", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_16_search_bin_na_us(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":567 * * # Optimized version for uint16 * def _search_bin_na_us(self, long item1, long item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_16_search_bin_na_us(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_uint16 *__pyx_v_rbufrv; npy_uint16 *__pyx_v_rbufbc; npy_uint16 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_us", 0); /* "tables/indexesextension.pyx":572 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_uint16 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":574 * cdef npy_uint16 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 574; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 574; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":575 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 575; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 575; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; /* "tables/indexesextension.pyx":576 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":577 * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_uint16 *)__pyx_v_self->rbufrv); __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":578 * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":579 * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":581 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":582 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":584 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_us(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_uint16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":585 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_us(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":586 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_us(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_us(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":588 * nchunk = bisect_left_us(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_us(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_uint16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":589 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_us(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_us(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":591 * start = bisect_left_us(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":593 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":595 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":596 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":597 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":599 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_us(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_uint16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":600 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_us(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_us(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":601 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_us(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":603 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_us(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_uint16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":604 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_us(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_us(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":606 * stop = bisect_right_us(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":608 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":609 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":610 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":611 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_us = previous_api(_search_bin_na_us) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 611; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_us", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_19_search_bin_na_i(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_19_search_bin_na_i(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { long __pyx_v_item1; long __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_i (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_i", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 616; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_i") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 616; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __Pyx_PyInt_AsLong(values[0]); if (unlikely((__pyx_v_item1 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 616; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __Pyx_PyInt_AsLong(values[1]); if (unlikely((__pyx_v_item2 == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 616; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_i", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 616; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_i", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_18_search_bin_na_i(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":616 * * # Optimized version for int32 * def _search_bin_na_i(self, long item1, long item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_18_search_bin_na_i(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, long __pyx_v_item1, long __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_int32 *__pyx_v_rbufrv; npy_int32 *__pyx_v_rbufbc; npy_int32 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_i", 0); /* "tables/indexesextension.pyx":621 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_int32 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":623 * cdef npy_int32 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 623; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 623; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":624 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 624; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 624; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; /* "tables/indexesextension.pyx":625 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":626 * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_int32 *)__pyx_v_self->rbufrv); __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":627 * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":628 * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":630 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":631 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":633 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_i(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_int32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":634 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_i(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":635 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_i(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_i(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":637 * nchunk = bisect_left_i(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_i(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_int32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":638 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_i(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_i(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":640 * start = bisect_left_i(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":642 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":644 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":645 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":646 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":648 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_i(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_int32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":649 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_i(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_i(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":650 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_i(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":652 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_i(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_int32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":653 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_i(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_i(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":655 * stop = bisect_right_i(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":657 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":658 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":659 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":660 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_i = previous_api(_search_bin_na_i) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 660; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_i", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_21_search_bin_na_ui(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_21_search_bin_na_ui(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { npy_uint32 __pyx_v_item1; npy_uint32 __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_ui (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_ui", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 665; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_ui") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 665; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __Pyx_PyInt_from_py_npy_uint32(values[0]); if (unlikely((__pyx_v_item1 == (npy_uint32)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 665; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __Pyx_PyInt_from_py_npy_uint32(values[1]); if (unlikely((__pyx_v_item2 == (npy_uint32)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 665; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_ui", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 665; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_ui", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_20_search_bin_na_ui(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":665 * * # Optimized version for uint32 * def _search_bin_na_ui(self, npy_uint32 item1, npy_uint32 item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_20_search_bin_na_ui(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_uint32 __pyx_v_item1, npy_uint32 __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_uint32 *__pyx_v_rbufrv; npy_uint32 *__pyx_v_rbufbc; npy_uint32 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_ui", 0); /* "tables/indexesextension.pyx":670 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_uint32 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":672 * cdef npy_uint32 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 672; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 672; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":673 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 673; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 673; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; /* "tables/indexesextension.pyx":674 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":675 * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_uint32 *)__pyx_v_self->rbufrv); __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":676 * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":677 * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":679 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":680 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":682 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_ui(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_uint32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":683 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_ui(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":684 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_ui(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_ui(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":686 * nchunk = bisect_left_ui(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_ui(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_uint32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":687 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_ui(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_ui(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":689 * start = bisect_left_ui(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":691 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":693 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":694 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":695 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":697 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_ui(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_uint32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":698 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_ui(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_ui(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":699 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_ui(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":701 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_ui(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_uint32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":702 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_ui(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_ui(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":704 * stop = bisect_right_ui(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":706 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":707 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":708 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":709 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_ui = previous_api(_search_bin_na_ui) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 709; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_ui", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_23_search_bin_na_ll(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_23_search_bin_na_ll(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { npy_int64 __pyx_v_item1; npy_int64 __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_ll (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_ll", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 714; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_ll") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 714; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __Pyx_PyInt_from_py_npy_int64(values[0]); if (unlikely((__pyx_v_item1 == (npy_int64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 714; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __Pyx_PyInt_from_py_npy_int64(values[1]); if (unlikely((__pyx_v_item2 == (npy_int64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 714; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_ll", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 714; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_ll", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_22_search_bin_na_ll(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":714 * * # Optimized version for int64 * def _search_bin_na_ll(self, npy_int64 item1, npy_int64 item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_22_search_bin_na_ll(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_int64 __pyx_v_item1, npy_int64 __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_int64 *__pyx_v_rbufrv; npy_int64 *__pyx_v_rbufbc; npy_int64 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_ll", 0); /* "tables/indexesextension.pyx":719 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_int64 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":721 * cdef npy_int64 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 721; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 721; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":722 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 722; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 722; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; /* "tables/indexesextension.pyx":723 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":724 * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_int64 *)__pyx_v_self->rbufrv); __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":725 * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":726 * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":728 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":729 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":731 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_ll(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_int64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":732 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_ll(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":733 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_ll(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_ll(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":735 * nchunk = bisect_left_ll(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_ll(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_int64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":736 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_ll(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_ll(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":738 * start = bisect_left_ll(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":740 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":742 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":743 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":744 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":746 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_ll(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_int64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":747 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_ll(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_ll(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":748 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_ll(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":750 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_ll(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_int64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":751 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_ll(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_ll(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":753 * stop = bisect_right_ll(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":755 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":756 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":757 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":758 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_ll = previous_api(_search_bin_na_ll) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 758; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_ll", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_25_search_bin_na_ull(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_25_search_bin_na_ull(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { npy_uint64 __pyx_v_item1; npy_uint64 __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_ull (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_ull", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 763; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_ull") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 763; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __Pyx_PyInt_from_py_npy_uint64(values[0]); if (unlikely((__pyx_v_item1 == (npy_uint64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 763; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __Pyx_PyInt_from_py_npy_uint64(values[1]); if (unlikely((__pyx_v_item2 == (npy_uint64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 763; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_ull", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 763; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_ull", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_24_search_bin_na_ull(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":763 * * # Optimized version for uint64 * def _search_bin_na_ull(self, npy_uint64 item1, npy_uint64 item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_24_search_bin_na_ull(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_uint64 __pyx_v_item1, npy_uint64 __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_uint64 *__pyx_v_rbufrv; npy_uint64 *__pyx_v_rbufbc; npy_uint64 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_ull", 0); /* "tables/indexesextension.pyx":768 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_uint64 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":770 * cdef npy_uint64 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 770; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 770; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":771 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 771; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 771; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; /* "tables/indexesextension.pyx":772 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":773 * nbounds = self.nbounds; nrows = self.nrows * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_uint64 *)__pyx_v_self->rbufrv); __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":774 * rbufst = self.rbufst; rbufln = self.rbufln * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":775 * rbufrv = self.rbufrv; tlength = 0 * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":777 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":778 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":780 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_ull(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_uint64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":781 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_ull(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":782 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_ull(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_ull(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":784 * nchunk = bisect_left_ull(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_ull(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_uint64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":785 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_ull(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_ull(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":787 * start = bisect_left_ull(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":789 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":791 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":792 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":793 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":795 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_ull(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_uint64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":796 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_ull(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_ull(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":797 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_ull(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":799 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_ull(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_uint64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":800 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_ull(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_ull(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":802 * stop = bisect_right_ull(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":804 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":805 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":806 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":807 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_ull = previous_api(_search_bin_na_ull) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 807; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_ull", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_27_search_bin_na_e(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_27_search_bin_na_e(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { npy_float64 __pyx_v_item1; npy_float64 __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_e (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_e", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 812; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_e") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 812; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __pyx_PyFloat_AsDouble(values[0]); if (unlikely((__pyx_v_item1 == (npy_float64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 812; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __pyx_PyFloat_AsDouble(values[1]); if (unlikely((__pyx_v_item2 == (npy_float64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 812; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_e", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 812; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_e", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_26_search_bin_na_e(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":812 * * # Optimized version for float16 * def _search_bin_na_e(self, npy_float64 item1, npy_float64 item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nrow2, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_26_search_bin_na_e(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_float64 __pyx_v_item1, npy_float64 __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; __pyx_t_6tables_16indexesextension_npy_float16 *__pyx_v_rbufrv; __pyx_t_6tables_16indexesextension_npy_float16 *__pyx_v_rbufbc; __pyx_t_6tables_16indexesextension_npy_float16 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_e", 0); /* "tables/indexesextension.pyx":817 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_float16 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":819 * cdef npy_float16 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 819; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 819; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":820 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * # Limits not in cache, do a lookup */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 820; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 820; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":821 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * # Limits not in cache, do a lookup * rbufrv = self.rbufrv */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":823 * rbufst = self.rbufst; rbufln = self.rbufln * # Limits not in cache, do a lookup * rbufrv = self.rbufrv # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((__pyx_t_6tables_16indexesextension_npy_float16 *)__pyx_v_self->rbufrv); /* "tables/indexesextension.pyx":824 * # Limits not in cache, do a lookup * rbufrv = self.rbufrv * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":825 * rbufrv = self.rbufrv * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":827 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":828 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":830 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_e(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((__pyx_t_6tables_16indexesextension_npy_float16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":831 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_e(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":832 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_e(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_e(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":834 * nchunk = bisect_left_e(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_e(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((__pyx_t_6tables_16indexesextension_npy_float16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":835 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_e(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_e(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":837 * start = bisect_left_e(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":839 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":841 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":842 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":843 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":845 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_e(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((__pyx_t_6tables_16indexesextension_npy_float16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":846 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_e(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_e(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":847 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_e(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":849 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_e(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((__pyx_t_6tables_16indexesextension_npy_float16 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":850 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_e(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_e(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":852 * stop = bisect_right_e(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":854 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":855 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":856 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":857 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_e = previous_api(_search_bin_na_e) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 857; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_e", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_29_search_bin_na_f(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_29_search_bin_na_f(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { npy_float64 __pyx_v_item1; npy_float64 __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_f (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_f", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 862; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_f") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 862; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __pyx_PyFloat_AsDouble(values[0]); if (unlikely((__pyx_v_item1 == (npy_float64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 862; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __pyx_PyFloat_AsDouble(values[1]); if (unlikely((__pyx_v_item2 == (npy_float64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 862; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_f", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 862; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_f", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_28_search_bin_na_f(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":862 * * # Optimized version for float32 * def _search_bin_na_f(self, npy_float64 item1, npy_float64 item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nrow2, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_28_search_bin_na_f(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_float64 __pyx_v_item1, npy_float64 __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_float32 *__pyx_v_rbufrv; npy_float32 *__pyx_v_rbufbc; npy_float32 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_f", 0); /* "tables/indexesextension.pyx":867 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_float32 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":869 * cdef npy_float32 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 869; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 869; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":870 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * # Limits not in cache, do a lookup */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 870; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 870; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":871 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * # Limits not in cache, do a lookup * rbufrv = self.rbufrv */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":873 * rbufst = self.rbufst; rbufln = self.rbufln * # Limits not in cache, do a lookup * rbufrv = self.rbufrv # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_float32 *)__pyx_v_self->rbufrv); /* "tables/indexesextension.pyx":874 * # Limits not in cache, do a lookup * rbufrv = self.rbufrv * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":875 * rbufrv = self.rbufrv * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":877 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":878 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":880 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_f(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_float32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":881 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_f(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":882 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_f(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_f(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":884 * nchunk = bisect_left_f(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_f(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_float32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":885 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_f(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_f(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":887 * start = bisect_left_f(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":889 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":891 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":892 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":893 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":895 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_f(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_float32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":896 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_f(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_f(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":897 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_f(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":899 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_f(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_float32 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":900 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_f(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_f(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":902 * stop = bisect_right_f(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":904 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":905 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":906 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":907 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_f = previous_api(_search_bin_na_f) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 907; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_f", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_31_search_bin_na_d(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_31_search_bin_na_d(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { npy_float64 __pyx_v_item1; npy_float64 __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_d (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_d", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 912; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_d") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 912; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __pyx_PyFloat_AsDouble(values[0]); if (unlikely((__pyx_v_item1 == (npy_float64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 912; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __pyx_PyFloat_AsDouble(values[1]); if (unlikely((__pyx_v_item2 == (npy_float64)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 912; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_d", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 912; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_d", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_30_search_bin_na_d(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":912 * * # Optimized version for float64 * def _search_bin_na_d(self, npy_float64 item1, npy_float64 item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nrow2, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_30_search_bin_na_d(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_float64 __pyx_v_item1, npy_float64 __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_float64 *__pyx_v_rbufrv; npy_float64 *__pyx_v_rbufbc; npy_float64 *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_d", 0); /* "tables/indexesextension.pyx":917 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_float64 *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":919 * cdef npy_float64 *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 919; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 919; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":920 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * # Limits not in cache, do a lookup */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 920; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 920; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":921 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * # Limits not in cache, do a lookup * rbufrv = self.rbufrv */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":923 * rbufst = self.rbufst; rbufln = self.rbufln * # Limits not in cache, do a lookup * rbufrv = self.rbufrv # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_float64 *)__pyx_v_self->rbufrv); /* "tables/indexesextension.pyx":924 * # Limits not in cache, do a lookup * rbufrv = self.rbufrv * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":925 * rbufrv = self.rbufrv * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":927 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":928 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":930 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_d(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_float64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":931 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_d(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":932 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_d(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_d(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":934 * nchunk = bisect_left_d(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_d(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_float64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":935 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_d(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_d(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":937 * start = bisect_left_d(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":939 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":941 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":942 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":943 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":945 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_d(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_float64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":946 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_d(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_d(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":947 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_d(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":949 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_d(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_float64 *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":950 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_d(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_d(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":952 * stop = bisect_right_d(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":954 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":955 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":956 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":957 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_d = previous_api(_search_bin_na_d) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 957; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_d", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_33_search_bin_na_g(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_33_search_bin_na_g(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { npy_longdouble __pyx_v_item1; npy_longdouble __pyx_v_item2; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_search_bin_na_g (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__item1,&__pyx_n_s__item2,0}; PyObject* values[2] = {0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item1)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__item2)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_search_bin_na_g", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 962; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_search_bin_na_g") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 962; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 2) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); } __pyx_v_item1 = __pyx_PyFloat_AsDouble(values[0]); if (unlikely((__pyx_v_item1 == (npy_longdouble)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 962; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_item2 = __pyx_PyFloat_AsDouble(values[1]); if (unlikely((__pyx_v_item2 == (npy_longdouble)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 962; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_search_bin_na_g", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 962; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_g", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_32_search_bin_na_g(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self), __pyx_v_item1, __pyx_v_item2); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":962 * * # Optimized version for npy_longdouble/float96/float128 * def _search_bin_na_g(self, npy_longdouble item1, npy_longdouble item2): # <<<<<<<<<<<<<< * cdef int cs, ss, ncs, nrow, nrows, nrow2, nbounds, rvrow * cdef int start, stop, tlength, length, bread, nchunk, nchunk2 */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_32_search_bin_na_g(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self, npy_longdouble __pyx_v_item1, npy_longdouble __pyx_v_item2) { int __pyx_v_cs; int __pyx_v_ss; int __pyx_v_ncs; int __pyx_v_nrow; int __pyx_v_nrows; int __pyx_v_nbounds; int __pyx_v_rvrow; int __pyx_v_start; int __pyx_v_stop; int __pyx_v_tlength; int __pyx_v_length; int __pyx_v_bread; int __pyx_v_nchunk; int __pyx_v_nchunk2; int *__pyx_v_rbufst; int *__pyx_v_rbufln; npy_longdouble *__pyx_v_rbufrv; npy_longdouble *__pyx_v_rbufbc; npy_longdouble *__pyx_v_rbuflb; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_search_bin_na_g", 0); /* "tables/indexesextension.pyx":967 * cdef int *rbufst, *rbufln * # Variables with specific type * cdef npy_longdouble *rbufrv, *rbufbc = NULL, *rbuflb = NULL # <<<<<<<<<<<<<< * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs */ __pyx_v_rbufbc = NULL; __pyx_v_rbuflb = NULL; /* "tables/indexesextension.pyx":969 * cdef npy_longdouble *rbufrv, *rbufbc = NULL, *rbuflb = NULL * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs # <<<<<<<<<<<<<< * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 * rbufst = self.rbufst; rbufln = self.rbufln */ __pyx_t_1 = __pyx_v_self->l_chunksize; __pyx_v_cs = __pyx_t_1; __pyx_t_1 = __pyx_v_self->l_slicesize; __pyx_v_ss = __pyx_t_1; if (unlikely(__pyx_v_cs == 0)) { PyErr_Format(PyExc_ZeroDivisionError, "integer division or modulo by zero"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 969; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else if (sizeof(int) == sizeof(long) && unlikely(__pyx_v_cs == -1) && unlikely(UNARY_NEG_WOULD_OVERFLOW(__pyx_v_ss))) { PyErr_Format(PyExc_OverflowError, "value too large to perform division"); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 969; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_v_ncs = __Pyx_div_int(__pyx_v_ss, __pyx_v_cs); /* "tables/indexesextension.pyx":970 * * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 # <<<<<<<<<<<<<< * rbufst = self.rbufst; rbufln = self.rbufln * # Limits not in cache, do a lookup */ __pyx_t_1 = __pyx_v_self->nbounds; __pyx_v_nbounds = __pyx_t_1; __pyx_t_2 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__nrows); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 970; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_1 = __Pyx_PyInt_AsInt(__pyx_t_2); if (unlikely((__pyx_t_1 == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 970; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_v_nrows = __pyx_t_1; __pyx_v_tlength = 0; /* "tables/indexesextension.pyx":971 * cs = self.l_chunksize; ss = self.l_slicesize; ncs = ss / cs * nbounds = self.nbounds; nrows = self.nrows; tlength = 0 * rbufst = self.rbufst; rbufln = self.rbufln # <<<<<<<<<<<<<< * # Limits not in cache, do a lookup * rbufrv = self.rbufrv */ __pyx_v_rbufst = ((int *)__pyx_v_self->rbufst); __pyx_v_rbufln = ((int *)__pyx_v_self->rbufln); /* "tables/indexesextension.pyx":973 * rbufst = self.rbufst; rbufln = self.rbufln * # Limits not in cache, do a lookup * rbufrv = self.rbufrv # <<<<<<<<<<<<<< * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 */ __pyx_v_rbufrv = ((npy_longdouble *)__pyx_v_self->rbufrv); /* "tables/indexesextension.pyx":974 * # Limits not in cache, do a lookup * rbufrv = self.rbufrv * for nrow from 0 <= nrow < nrows: # <<<<<<<<<<<<<< * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row */ __pyx_t_1 = __pyx_v_nrows; for (__pyx_v_nrow = 0; __pyx_v_nrow < __pyx_t_1; __pyx_v_nrow++) { /* "tables/indexesextension.pyx":975 * rbufrv = self.rbufrv * for nrow from 0 <= nrow < nrows: * rvrow = nrow*2; bread = 0; nchunk = -1 # <<<<<<<<<<<<<< * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: */ __pyx_v_rvrow = (__pyx_v_nrow * 2); __pyx_v_bread = 0; __pyx_v_nchunk = -1; /* "tables/indexesextension.pyx":977 * rvrow = nrow*2; bread = 0; nchunk = -1 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item1 > (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":978 * # Look if item1 is in this row * if item1 > rbufrv[rvrow]: * if item1 <= rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (__pyx_v_item1 <= (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":980 * if item1 <= rbufrv[rvrow+1]: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * bread = 1 * nchunk = bisect_left_g(rbufbc, item1, nbounds, 0) */ __pyx_v_rbufbc = ((npy_longdouble *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); /* "tables/indexesextension.pyx":981 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 # <<<<<<<<<<<<<< * nchunk = bisect_left_g(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. */ __pyx_v_bread = 1; /* "tables/indexesextension.pyx":982 * rbufbc = self.get_lru_bounds(nrow, nbounds) * bread = 1 * nchunk = bisect_left_g(rbufbc, item1, nbounds, 0) # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) */ __pyx_v_nchunk = bisect_left_g(__pyx_v_rbufbc, __pyx_v_item1, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":984 * nchunk = bisect_left_g(rbufbc, item1, nbounds, 0) * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) # <<<<<<<<<<<<<< * start = bisect_left_g(rbuflb, item1, cs, 0) + cs*nchunk * else: */ __pyx_v_rbuflb = ((npy_longdouble *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk, __pyx_v_cs)); /* "tables/indexesextension.pyx":985 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk, cs) * start = bisect_left_g(rbuflb, item1, cs, 0) + cs*nchunk # <<<<<<<<<<<<<< * else: * start = ss */ __pyx_v_start = (bisect_left_g(__pyx_v_rbuflb, __pyx_v_item1, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk)); goto __pyx_L6; } /*else*/ { /* "tables/indexesextension.pyx":987 * start = bisect_left_g(rbuflb, item1, cs, 0) + cs*nchunk * else: * start = ss # <<<<<<<<<<<<<< * else: * start = 0 */ __pyx_v_start = __pyx_v_ss; } __pyx_L6:; goto __pyx_L5; } /*else*/ { /* "tables/indexesextension.pyx":989 * start = ss * else: * start = 0 # <<<<<<<<<<<<<< * # Now, for item2 * if item2 >= rbufrv[rvrow]: */ __pyx_v_start = 0; } __pyx_L5:; /* "tables/indexesextension.pyx":991 * start = 0 * # Now, for item2 * if item2 >= rbufrv[rvrow]: # <<<<<<<<<<<<<< * if item2 < rbufrv[rvrow+1]: * if not bread: */ __pyx_t_3 = (__pyx_v_item2 >= (__pyx_v_rbufrv[__pyx_v_rvrow])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":992 * # Now, for item2 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: # <<<<<<<<<<<<<< * if not bread: * # Get the bounds row from the LRU cache or read them. */ __pyx_t_3 = (__pyx_v_item2 < (__pyx_v_rbufrv[(__pyx_v_rvrow + 1)])); if (__pyx_t_3) { /* "tables/indexesextension.pyx":993 * if item2 >= rbufrv[rvrow]: * if item2 < rbufrv[rvrow+1]: * if not bread: # <<<<<<<<<<<<<< * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) */ __pyx_t_3 = (!__pyx_v_bread); if (__pyx_t_3) { /* "tables/indexesextension.pyx":995 * if not bread: * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) # <<<<<<<<<<<<<< * nchunk2 = bisect_right_g(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: */ __pyx_v_rbufbc = ((npy_longdouble *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_bounds(__pyx_v_self, __pyx_v_nrow, __pyx_v_nbounds)); goto __pyx_L9; } __pyx_L9:; /* "tables/indexesextension.pyx":996 * # Get the bounds row from the LRU cache or read them. * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_g(rbufbc, item2, nbounds, 0) # <<<<<<<<<<<<<< * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. */ __pyx_v_nchunk2 = bisect_right_g(__pyx_v_rbufbc, __pyx_v_item2, __pyx_v_nbounds, 0); /* "tables/indexesextension.pyx":997 * rbufbc = self.get_lru_bounds(nrow, nbounds) * nchunk2 = bisect_right_g(rbufbc, item2, nbounds, 0) * if nchunk2 <> nchunk: # <<<<<<<<<<<<<< * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) */ __pyx_t_3 = (__pyx_v_nchunk2 != __pyx_v_nchunk); if (__pyx_t_3) { /* "tables/indexesextension.pyx":999 * if nchunk2 <> nchunk: * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) # <<<<<<<<<<<<<< * stop = bisect_right_g(rbuflb, item2, cs, 0) + cs*nchunk2 * else: */ __pyx_v_rbuflb = ((npy_longdouble *)((struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray *)__pyx_v_self->__pyx_base.__pyx_base.__pyx_vtab)->get_lru_sorted(__pyx_v_self, __pyx_v_nrow, __pyx_v_ncs, __pyx_v_nchunk2, __pyx_v_cs)); goto __pyx_L10; } __pyx_L10:; /* "tables/indexesextension.pyx":1000 * # Get the sorted row from the LRU cache or read it. * rbuflb = self.get_lru_sorted(nrow, ncs, nchunk2, cs) * stop = bisect_right_g(rbuflb, item2, cs, 0) + cs*nchunk2 # <<<<<<<<<<<<<< * else: * stop = ss */ __pyx_v_stop = (bisect_right_g(__pyx_v_rbuflb, __pyx_v_item2, __pyx_v_cs, 0) + (__pyx_v_cs * __pyx_v_nchunk2)); goto __pyx_L8; } /*else*/ { /* "tables/indexesextension.pyx":1002 * stop = bisect_right_g(rbuflb, item2, cs, 0) + cs*nchunk2 * else: * stop = ss # <<<<<<<<<<<<<< * else: * stop = 0 */ __pyx_v_stop = __pyx_v_ss; } __pyx_L8:; goto __pyx_L7; } /*else*/ { /* "tables/indexesextension.pyx":1004 * stop = ss * else: * stop = 0 # <<<<<<<<<<<<<< * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; */ __pyx_v_stop = 0; } __pyx_L7:; /* "tables/indexesextension.pyx":1005 * else: * stop = 0 * length = stop - start; tlength = tlength + length # <<<<<<<<<<<<<< * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength */ __pyx_v_length = (__pyx_v_stop - __pyx_v_start); __pyx_v_tlength = (__pyx_v_tlength + __pyx_v_length); /* "tables/indexesextension.pyx":1006 * stop = 0 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; # <<<<<<<<<<<<<< * return tlength * */ (__pyx_v_rbufst[__pyx_v_nrow]) = __pyx_v_start; (__pyx_v_rbufln[__pyx_v_nrow]) = __pyx_v_length; } /* "tables/indexesextension.pyx":1007 * length = stop - start; tlength = tlength + length * rbufst[nrow] = start; rbufln[nrow] = length; * return tlength # <<<<<<<<<<<<<< * * _searchBinNA_g = previous_api(_search_bin_na_g) */ __Pyx_XDECREF(__pyx_r); __pyx_t_2 = PyInt_FromLong(__pyx_v_tlength); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1007; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_r = __pyx_t_2; __pyx_t_2 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._search_bin_na_g", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_35_g_close(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/ static PyObject *__pyx_pw_6tables_16indexesextension_10IndexArray_35_g_close(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) { PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_g_close (wrapper)", 0); __pyx_r = __pyx_pf_6tables_16indexesextension_10IndexArray_34_g_close(((struct __pyx_obj_6tables_16indexesextension_IndexArray *)__pyx_v_self)); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":1011 * _searchBinNA_g = previous_api(_search_bin_na_g) * * def _g_close(self): # <<<<<<<<<<<<<< * super(Array, self)._g_close() * # Release specific resources of this class */ static PyObject *__pyx_pf_6tables_16indexesextension_10IndexArray_34_g_close(struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_self) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; int __pyx_t_3; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_g_close", 0); /* "tables/indexesextension.pyx":1012 * * def _g_close(self): * super(Array, self)._g_close() # <<<<<<<<<<<<<< * # Release specific resources of this class * if self.mem_space_id > 0: */ __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1012; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(((PyObject *)((PyObject*)__pyx_ptype_6tables_13hdf5extension_Array))); PyTuple_SET_ITEM(__pyx_t_1, 0, ((PyObject *)((PyObject*)__pyx_ptype_6tables_13hdf5extension_Array))); __Pyx_GIVEREF(((PyObject *)((PyObject*)__pyx_ptype_6tables_13hdf5extension_Array))); __Pyx_INCREF(((PyObject *)__pyx_v_self)); PyTuple_SET_ITEM(__pyx_t_1, 1, ((PyObject *)__pyx_v_self)); __Pyx_GIVEREF(((PyObject *)__pyx_v_self)); __pyx_t_2 = PyObject_Call(__pyx_builtin_super, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1012; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; __pyx_t_1 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s___g_close); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1012; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1012; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "tables/indexesextension.pyx":1014 * super(Array, self)._g_close() * # Release specific resources of this class * if self.mem_space_id > 0: # <<<<<<<<<<<<<< * H5Sclose(self.mem_space_id) * */ __pyx_t_3 = (__pyx_v_self->mem_space_id > 0); if (__pyx_t_3) { /* "tables/indexesextension.pyx":1015 * # Release specific resources of this class * if self.mem_space_id > 0: * H5Sclose(self.mem_space_id) # <<<<<<<<<<<<<< * * */ H5Sclose(__pyx_v_self->mem_space_id); goto __pyx_L3; } __pyx_L3:; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_AddTraceback("tables.indexesextension.IndexArray._g_close", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_12LastRowArray_1_read_index_slice(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_6tables_16indexesextension_12LastRowArray__read_index_slice[] = "Read the reverse index part of an LR index."; static PyObject *__pyx_pw_6tables_16indexesextension_12LastRowArray_1_read_index_slice(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { hsize_t __pyx_v_start; hsize_t __pyx_v_stop; PyArrayObject *__pyx_v_idx = 0; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_read_index_slice (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__start,&__pyx_n_s__stop,&__pyx_n_s__idx,0}; PyObject* values[3] = {0,0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__start)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__stop)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_read_index_slice", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1023; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } case 2: if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__idx)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_read_index_slice", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1023; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_read_index_slice") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1023; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 3) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); values[2] = PyTuple_GET_ITEM(__pyx_args, 2); } __pyx_v_start = __Pyx_PyInt_from_py_hsize_t(values[0]); if (unlikely((__pyx_v_start == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1023; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_stop = __Pyx_PyInt_from_py_hsize_t(values[1]); if (unlikely((__pyx_v_stop == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1023; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_idx = ((PyArrayObject *)values[2]); } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_read_index_slice", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1023; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.LastRowArray._read_index_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_idx), __pyx_ptype_5numpy_ndarray, 1, "idx", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1023; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_r = __pyx_pf_6tables_16indexesextension_12LastRowArray__read_index_slice(((struct __pyx_obj_6tables_16indexesextension_LastRowArray *)__pyx_v_self), __pyx_v_start, __pyx_v_stop, __pyx_v_idx); goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":1023 * """ * * def _read_index_slice(self, hsize_t start, hsize_t stop, ndarray idx): # <<<<<<<<<<<<<< * """Read the reverse index part of an LR index.""" * */ static PyObject *__pyx_pf_6tables_16indexesextension_12LastRowArray__read_index_slice(struct __pyx_obj_6tables_16indexesextension_LastRowArray *__pyx_v_self, hsize_t __pyx_v_start, hsize_t __pyx_v_stop, PyArrayObject *__pyx_v_idx) { herr_t __pyx_v_ret; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_read_index_slice", 0); /* "tables/indexesextension.pyx":1026 * """Read the reverse index part of an LR index.""" * * with nogil: # <<<<<<<<<<<<<< * ret = H5ARRAYOreadSliceLR(self.dataset_id, self.type_id, * start, stop, idx.data) */ { #ifdef WITH_THREAD PyThreadState *_save = NULL; #endif Py_UNBLOCK_THREADS /*try:*/ { /* "tables/indexesextension.pyx":1028 * with nogil: * ret = H5ARRAYOreadSliceLR(self.dataset_id, self.type_id, * start, stop, idx.data) # <<<<<<<<<<<<<< * * if ret < 0: */ __pyx_v_ret = H5ARRAYOreadSliceLR(__pyx_v_self->__pyx_base.__pyx_base.dataset_id, __pyx_v_self->__pyx_base.__pyx_base.type_id, __pyx_v_start, __pyx_v_stop, __pyx_v_idx->data); } /* "tables/indexesextension.pyx":1026 * """Read the reverse index part of an LR index.""" * * with nogil: # <<<<<<<<<<<<<< * ret = H5ARRAYOreadSliceLR(self.dataset_id, self.type_id, * start, stop, idx.data) */ /*finally:*/ { Py_BLOCK_THREADS } } /* "tables/indexesextension.pyx":1030 * start, stop, idx.data) * * if ret < 0: # <<<<<<<<<<<<<< * raise HDF5ExtError("Problems reading the index data in Last Row.") * */ __pyx_t_1 = (__pyx_v_ret < 0); if (__pyx_t_1) { /* "tables/indexesextension.pyx":1031 * * if ret < 0: * raise HDF5ExtError("Problems reading the index data in Last Row.") # <<<<<<<<<<<<<< * * _readIndexSlice = previous_api(_read_index_slice) */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__HDF5ExtError); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1031; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_k_tuple_13), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1031; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1031; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L6; } __pyx_L6:; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); __Pyx_AddTraceback("tables.indexesextension.LastRowArray._read_index_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static PyObject *__pyx_pw_6tables_16indexesextension_12LastRowArray_3_read_sorted_slice(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/ static char __pyx_doc_6tables_16indexesextension_12LastRowArray_2_read_sorted_slice[] = "Read the sorted part of an LR index."; static PyObject *__pyx_pw_6tables_16indexesextension_12LastRowArray_3_read_sorted_slice(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) { struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_sorted = 0; hsize_t __pyx_v_start; hsize_t __pyx_v_stop; PyObject *__pyx_r = 0; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("_read_sorted_slice (wrapper)", 0); { static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__sorted,&__pyx_n_s__start,&__pyx_n_s__stop,0}; PyObject* values[3] = {0,0,0}; if (unlikely(__pyx_kwds)) { Py_ssize_t kw_args; const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args); switch (pos_args) { case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2); case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1); case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0); case 0: break; default: goto __pyx_L5_argtuple_error; } kw_args = PyDict_Size(__pyx_kwds); switch (pos_args) { case 0: if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__sorted)) != 0)) kw_args--; else goto __pyx_L5_argtuple_error; case 1: if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__start)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_read_sorted_slice", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1035; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } case 2: if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__stop)) != 0)) kw_args--; else { __Pyx_RaiseArgtupleInvalid("_read_sorted_slice", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1035; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } if (unlikely(kw_args > 0)) { if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_read_sorted_slice") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1035; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } } else if (PyTuple_GET_SIZE(__pyx_args) != 3) { goto __pyx_L5_argtuple_error; } else { values[0] = PyTuple_GET_ITEM(__pyx_args, 0); values[1] = PyTuple_GET_ITEM(__pyx_args, 1); values[2] = PyTuple_GET_ITEM(__pyx_args, 2); } __pyx_v_sorted = ((struct __pyx_obj_6tables_16indexesextension_IndexArray *)values[0]); __pyx_v_start = __Pyx_PyInt_from_py_hsize_t(values[1]); if (unlikely((__pyx_v_start == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1035; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_v_stop = __Pyx_PyInt_from_py_hsize_t(values[2]); if (unlikely((__pyx_v_stop == (hsize_t)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1035; __pyx_clineno = __LINE__; goto __pyx_L3_error;} } goto __pyx_L4_argument_unpacking_done; __pyx_L5_argtuple_error:; __Pyx_RaiseArgtupleInvalid("_read_sorted_slice", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1035; __pyx_clineno = __LINE__; goto __pyx_L3_error;} __pyx_L3_error:; __Pyx_AddTraceback("tables.indexesextension.LastRowArray._read_sorted_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __Pyx_RefNannyFinishContext(); return NULL; __pyx_L4_argument_unpacking_done:; if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_sorted), __pyx_ptype_6tables_16indexesextension_IndexArray, 1, "sorted", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1035; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_r = __pyx_pf_6tables_16indexesextension_12LastRowArray_2_read_sorted_slice(((struct __pyx_obj_6tables_16indexesextension_LastRowArray *)__pyx_v_self), __pyx_v_sorted, __pyx_v_start, __pyx_v_stop); goto __pyx_L0; __pyx_L1_error:; __pyx_r = NULL; __pyx_L0:; __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "tables/indexesextension.pyx":1035 * _readIndexSlice = previous_api(_read_index_slice) * * def _read_sorted_slice(self, IndexArray sorted, hsize_t start, hsize_t stop): # <<<<<<<<<<<<<< * """Read the sorted part of an LR index.""" * */ static PyObject *__pyx_pf_6tables_16indexesextension_12LastRowArray_2_read_sorted_slice(struct __pyx_obj_6tables_16indexesextension_LastRowArray *__pyx_v_self, struct __pyx_obj_6tables_16indexesextension_IndexArray *__pyx_v_sorted, hsize_t __pyx_v_start, hsize_t __pyx_v_stop) { void *__pyx_v_rbuflb; herr_t __pyx_v_ret; PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations void *__pyx_t_1; int __pyx_t_2; PyObject *__pyx_t_3 = NULL; PyObject *__pyx_t_4 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_read_sorted_slice", 0); /* "tables/indexesextension.pyx":1040 * cdef void *rbuflb * * rbuflb = sorted.rbuflb # direct access to rbuflb: very fast. # <<<<<<<<<<<<<< * with nogil: * ret = H5ARRAYOreadSliceLR(self.dataset_id, self.type_id, */ __pyx_t_1 = __pyx_v_sorted->rbuflb; __pyx_v_rbuflb = __pyx_t_1; /* "tables/indexesextension.pyx":1041 * * rbuflb = sorted.rbuflb # direct access to rbuflb: very fast. * with nogil: # <<<<<<<<<<<<<< * ret = H5ARRAYOreadSliceLR(self.dataset_id, self.type_id, * start, stop, rbuflb) */ { #ifdef WITH_THREAD PyThreadState *_save = NULL; #endif Py_UNBLOCK_THREADS /*try:*/ { /* "tables/indexesextension.pyx":1043 * with nogil: * ret = H5ARRAYOreadSliceLR(self.dataset_id, self.type_id, * start, stop, rbuflb) # <<<<<<<<<<<<<< * * if ret < 0: */ __pyx_v_ret = H5ARRAYOreadSliceLR(__pyx_v_self->__pyx_base.__pyx_base.dataset_id, __pyx_v_self->__pyx_base.__pyx_base.type_id, __pyx_v_start, __pyx_v_stop, __pyx_v_rbuflb); } /* "tables/indexesextension.pyx":1041 * * rbuflb = sorted.rbuflb # direct access to rbuflb: very fast. * with nogil: # <<<<<<<<<<<<<< * ret = H5ARRAYOreadSliceLR(self.dataset_id, self.type_id, * start, stop, rbuflb) */ /*finally:*/ { Py_BLOCK_THREADS } } /* "tables/indexesextension.pyx":1045 * start, stop, rbuflb) * * if ret < 0: # <<<<<<<<<<<<<< * raise HDF5ExtError("Problems reading the index data.") * return sorted.bufferlb[:stop-start] */ __pyx_t_2 = (__pyx_v_ret < 0); if (__pyx_t_2) { /* "tables/indexesextension.pyx":1046 * * if ret < 0: * raise HDF5ExtError("Problems reading the index data.") # <<<<<<<<<<<<<< * return sorted.bufferlb[:stop-start] * */ __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__HDF5ExtError); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1046; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_4 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_k_tuple_15), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1046; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1046; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L6; } __pyx_L6:; /* "tables/indexesextension.pyx":1047 * if ret < 0: * raise HDF5ExtError("Problems reading the index data.") * return sorted.bufferlb[:stop-start] # <<<<<<<<<<<<<< * * _readSortedSlice = previous_api(_read_sorted_slice) */ __Pyx_XDECREF(__pyx_r); __pyx_t_4 = __Pyx_PySequence_GetSlice(((PyObject *)__pyx_v_sorted->bufferlb), 0, (__pyx_v_stop - __pyx_v_start)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1047; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_r = __pyx_t_4; __pyx_t_4 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_AddTraceback("tables.indexesextension.LastRowArray._read_sorted_slice", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static CYTHON_UNUSED int __pyx_pw_5numpy_7ndarray_1__getbuffer__(PyObject *__pyx_v_self, Py_buffer *__pyx_v_info, int __pyx_v_flags); /*proto*/ static CYTHON_UNUSED int __pyx_pw_5numpy_7ndarray_1__getbuffer__(PyObject *__pyx_v_self, Py_buffer *__pyx_v_info, int __pyx_v_flags) { int __pyx_r; __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__getbuffer__ (wrapper)", 0); __pyx_r = __pyx_pf_5numpy_7ndarray___getbuffer__(((PyArrayObject *)__pyx_v_self), ((Py_buffer *)__pyx_v_info), ((int)__pyx_v_flags)); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "numpy.pxd":194 * # experimental exception made for __getbuffer__ and __releasebuffer__ * # -- the details of this may change. * def __getbuffer__(ndarray self, Py_buffer* info, int flags): # <<<<<<<<<<<<<< * # This implementation of getbuffer is geared towards Cython * # requirements, and does not yet fullfill the PEP. */ static int __pyx_pf_5numpy_7ndarray___getbuffer__(PyArrayObject *__pyx_v_self, Py_buffer *__pyx_v_info, int __pyx_v_flags) { int __pyx_v_copy_shape; int __pyx_v_i; int __pyx_v_ndim; int __pyx_v_endian_detector; int __pyx_v_little_endian; int __pyx_v_t; char *__pyx_v_f; PyArray_Descr *__pyx_v_descr = 0; int __pyx_v_offset; int __pyx_v_hasfields; int __pyx_r; __Pyx_RefNannyDeclarations int __pyx_t_1; int __pyx_t_2; int __pyx_t_3; PyObject *__pyx_t_4 = NULL; int __pyx_t_5; int __pyx_t_6; int __pyx_t_7; PyObject *__pyx_t_8 = NULL; char *__pyx_t_9; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("__getbuffer__", 0); if (__pyx_v_info != NULL) { __pyx_v_info->obj = Py_None; __Pyx_INCREF(Py_None); __Pyx_GIVEREF(__pyx_v_info->obj); } /* "numpy.pxd":200 * # of flags * * if info == NULL: return # <<<<<<<<<<<<<< * * cdef int copy_shape, i, ndim */ __pyx_t_1 = (__pyx_v_info == NULL); if (__pyx_t_1) { __pyx_r = 0; goto __pyx_L0; goto __pyx_L3; } __pyx_L3:; /* "numpy.pxd":203 * * cdef int copy_shape, i, ndim * cdef int endian_detector = 1 # <<<<<<<<<<<<<< * cdef bint little_endian = ((&endian_detector)[0] != 0) * */ __pyx_v_endian_detector = 1; /* "numpy.pxd":204 * cdef int copy_shape, i, ndim * cdef int endian_detector = 1 * cdef bint little_endian = ((&endian_detector)[0] != 0) # <<<<<<<<<<<<<< * * ndim = PyArray_NDIM(self) */ __pyx_v_little_endian = ((((char *)(&__pyx_v_endian_detector))[0]) != 0); /* "numpy.pxd":206 * cdef bint little_endian = ((&endian_detector)[0] != 0) * * ndim = PyArray_NDIM(self) # <<<<<<<<<<<<<< * * if sizeof(npy_intp) != sizeof(Py_ssize_t): */ __pyx_v_ndim = PyArray_NDIM(__pyx_v_self); /* "numpy.pxd":208 * ndim = PyArray_NDIM(self) * * if sizeof(npy_intp) != sizeof(Py_ssize_t): # <<<<<<<<<<<<<< * copy_shape = 1 * else: */ __pyx_t_1 = ((sizeof(npy_intp)) != (sizeof(Py_ssize_t))); if (__pyx_t_1) { /* "numpy.pxd":209 * * if sizeof(npy_intp) != sizeof(Py_ssize_t): * copy_shape = 1 # <<<<<<<<<<<<<< * else: * copy_shape = 0 */ __pyx_v_copy_shape = 1; goto __pyx_L4; } /*else*/ { /* "numpy.pxd":211 * copy_shape = 1 * else: * copy_shape = 0 # <<<<<<<<<<<<<< * * if ((flags & pybuf.PyBUF_C_CONTIGUOUS == pybuf.PyBUF_C_CONTIGUOUS) */ __pyx_v_copy_shape = 0; } __pyx_L4:; /* "numpy.pxd":213 * copy_shape = 0 * * if ((flags & pybuf.PyBUF_C_CONTIGUOUS == pybuf.PyBUF_C_CONTIGUOUS) # <<<<<<<<<<<<<< * and not PyArray_CHKFLAGS(self, NPY_C_CONTIGUOUS)): * raise ValueError(u"ndarray is not C contiguous") */ __pyx_t_1 = ((__pyx_v_flags & PyBUF_C_CONTIGUOUS) == PyBUF_C_CONTIGUOUS); if (__pyx_t_1) { /* "numpy.pxd":214 * * if ((flags & pybuf.PyBUF_C_CONTIGUOUS == pybuf.PyBUF_C_CONTIGUOUS) * and not PyArray_CHKFLAGS(self, NPY_C_CONTIGUOUS)): # <<<<<<<<<<<<<< * raise ValueError(u"ndarray is not C contiguous") * */ __pyx_t_2 = (!PyArray_CHKFLAGS(__pyx_v_self, NPY_C_CONTIGUOUS)); __pyx_t_3 = __pyx_t_2; } else { __pyx_t_3 = __pyx_t_1; } if (__pyx_t_3) { /* "numpy.pxd":215 * if ((flags & pybuf.PyBUF_C_CONTIGUOUS == pybuf.PyBUF_C_CONTIGUOUS) * and not PyArray_CHKFLAGS(self, NPY_C_CONTIGUOUS)): * raise ValueError(u"ndarray is not C contiguous") # <<<<<<<<<<<<<< * * if ((flags & pybuf.PyBUF_F_CONTIGUOUS == pybuf.PyBUF_F_CONTIGUOUS) */ __pyx_t_4 = PyObject_Call(__pyx_builtin_ValueError, ((PyObject *)__pyx_k_tuple_17), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 215; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; {__pyx_filename = __pyx_f[1]; __pyx_lineno = 215; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L5; } __pyx_L5:; /* "numpy.pxd":217 * raise ValueError(u"ndarray is not C contiguous") * * if ((flags & pybuf.PyBUF_F_CONTIGUOUS == pybuf.PyBUF_F_CONTIGUOUS) # <<<<<<<<<<<<<< * and not PyArray_CHKFLAGS(self, NPY_F_CONTIGUOUS)): * raise ValueError(u"ndarray is not Fortran contiguous") */ __pyx_t_3 = ((__pyx_v_flags & PyBUF_F_CONTIGUOUS) == PyBUF_F_CONTIGUOUS); if (__pyx_t_3) { /* "numpy.pxd":218 * * if ((flags & pybuf.PyBUF_F_CONTIGUOUS == pybuf.PyBUF_F_CONTIGUOUS) * and not PyArray_CHKFLAGS(self, NPY_F_CONTIGUOUS)): # <<<<<<<<<<<<<< * raise ValueError(u"ndarray is not Fortran contiguous") * */ __pyx_t_1 = (!PyArray_CHKFLAGS(__pyx_v_self, NPY_F_CONTIGUOUS)); __pyx_t_2 = __pyx_t_1; } else { __pyx_t_2 = __pyx_t_3; } if (__pyx_t_2) { /* "numpy.pxd":219 * if ((flags & pybuf.PyBUF_F_CONTIGUOUS == pybuf.PyBUF_F_CONTIGUOUS) * and not PyArray_CHKFLAGS(self, NPY_F_CONTIGUOUS)): * raise ValueError(u"ndarray is not Fortran contiguous") # <<<<<<<<<<<<<< * * info.buf = PyArray_DATA(self) */ __pyx_t_4 = PyObject_Call(__pyx_builtin_ValueError, ((PyObject *)__pyx_k_tuple_19), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 219; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; {__pyx_filename = __pyx_f[1]; __pyx_lineno = 219; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L6; } __pyx_L6:; /* "numpy.pxd":221 * raise ValueError(u"ndarray is not Fortran contiguous") * * info.buf = PyArray_DATA(self) # <<<<<<<<<<<<<< * info.ndim = ndim * if copy_shape: */ __pyx_v_info->buf = PyArray_DATA(__pyx_v_self); /* "numpy.pxd":222 * * info.buf = PyArray_DATA(self) * info.ndim = ndim # <<<<<<<<<<<<<< * if copy_shape: * # Allocate new buffer for strides and shape info. */ __pyx_v_info->ndim = __pyx_v_ndim; /* "numpy.pxd":223 * info.buf = PyArray_DATA(self) * info.ndim = ndim * if copy_shape: # <<<<<<<<<<<<<< * # Allocate new buffer for strides and shape info. * # This is allocated as one block, strides first. */ if (__pyx_v_copy_shape) { /* "numpy.pxd":226 * # Allocate new buffer for strides and shape info. * # This is allocated as one block, strides first. * info.strides = stdlib.malloc(sizeof(Py_ssize_t) * ndim * 2) # <<<<<<<<<<<<<< * info.shape = info.strides + ndim * for i in range(ndim): */ __pyx_v_info->strides = ((Py_ssize_t *)malloc((((sizeof(Py_ssize_t)) * ((size_t)__pyx_v_ndim)) * 2))); /* "numpy.pxd":227 * # This is allocated as one block, strides first. * info.strides = stdlib.malloc(sizeof(Py_ssize_t) * ndim * 2) * info.shape = info.strides + ndim # <<<<<<<<<<<<<< * for i in range(ndim): * info.strides[i] = PyArray_STRIDES(self)[i] */ __pyx_v_info->shape = (__pyx_v_info->strides + __pyx_v_ndim); /* "numpy.pxd":228 * info.strides = stdlib.malloc(sizeof(Py_ssize_t) * ndim * 2) * info.shape = info.strides + ndim * for i in range(ndim): # <<<<<<<<<<<<<< * info.strides[i] = PyArray_STRIDES(self)[i] * info.shape[i] = PyArray_DIMS(self)[i] */ __pyx_t_5 = __pyx_v_ndim; for (__pyx_t_6 = 0; __pyx_t_6 < __pyx_t_5; __pyx_t_6+=1) { __pyx_v_i = __pyx_t_6; /* "numpy.pxd":229 * info.shape = info.strides + ndim * for i in range(ndim): * info.strides[i] = PyArray_STRIDES(self)[i] # <<<<<<<<<<<<<< * info.shape[i] = PyArray_DIMS(self)[i] * else: */ (__pyx_v_info->strides[__pyx_v_i]) = (PyArray_STRIDES(__pyx_v_self)[__pyx_v_i]); /* "numpy.pxd":230 * for i in range(ndim): * info.strides[i] = PyArray_STRIDES(self)[i] * info.shape[i] = PyArray_DIMS(self)[i] # <<<<<<<<<<<<<< * else: * info.strides = PyArray_STRIDES(self) */ (__pyx_v_info->shape[__pyx_v_i]) = (PyArray_DIMS(__pyx_v_self)[__pyx_v_i]); } goto __pyx_L7; } /*else*/ { /* "numpy.pxd":232 * info.shape[i] = PyArray_DIMS(self)[i] * else: * info.strides = PyArray_STRIDES(self) # <<<<<<<<<<<<<< * info.shape = PyArray_DIMS(self) * info.suboffsets = NULL */ __pyx_v_info->strides = ((Py_ssize_t *)PyArray_STRIDES(__pyx_v_self)); /* "numpy.pxd":233 * else: * info.strides = PyArray_STRIDES(self) * info.shape = PyArray_DIMS(self) # <<<<<<<<<<<<<< * info.suboffsets = NULL * info.itemsize = PyArray_ITEMSIZE(self) */ __pyx_v_info->shape = ((Py_ssize_t *)PyArray_DIMS(__pyx_v_self)); } __pyx_L7:; /* "numpy.pxd":234 * info.strides = PyArray_STRIDES(self) * info.shape = PyArray_DIMS(self) * info.suboffsets = NULL # <<<<<<<<<<<<<< * info.itemsize = PyArray_ITEMSIZE(self) * info.readonly = not PyArray_ISWRITEABLE(self) */ __pyx_v_info->suboffsets = NULL; /* "numpy.pxd":235 * info.shape = PyArray_DIMS(self) * info.suboffsets = NULL * info.itemsize = PyArray_ITEMSIZE(self) # <<<<<<<<<<<<<< * info.readonly = not PyArray_ISWRITEABLE(self) * */ __pyx_v_info->itemsize = PyArray_ITEMSIZE(__pyx_v_self); /* "numpy.pxd":236 * info.suboffsets = NULL * info.itemsize = PyArray_ITEMSIZE(self) * info.readonly = not PyArray_ISWRITEABLE(self) # <<<<<<<<<<<<<< * * cdef int t */ __pyx_v_info->readonly = (!PyArray_ISWRITEABLE(__pyx_v_self)); /* "numpy.pxd":239 * * cdef int t * cdef char* f = NULL # <<<<<<<<<<<<<< * cdef dtype descr = self.descr * cdef list stack */ __pyx_v_f = NULL; /* "numpy.pxd":240 * cdef int t * cdef char* f = NULL * cdef dtype descr = self.descr # <<<<<<<<<<<<<< * cdef list stack * cdef int offset */ __pyx_t_4 = ((PyObject *)__pyx_v_self->descr); __Pyx_INCREF(__pyx_t_4); __pyx_v_descr = ((PyArray_Descr *)__pyx_t_4); __pyx_t_4 = 0; /* "numpy.pxd":244 * cdef int offset * * cdef bint hasfields = PyDataType_HASFIELDS(descr) # <<<<<<<<<<<<<< * * if not hasfields and not copy_shape: */ __pyx_v_hasfields = PyDataType_HASFIELDS(__pyx_v_descr); /* "numpy.pxd":246 * cdef bint hasfields = PyDataType_HASFIELDS(descr) * * if not hasfields and not copy_shape: # <<<<<<<<<<<<<< * # do not call releasebuffer * info.obj = None */ __pyx_t_2 = (!__pyx_v_hasfields); if (__pyx_t_2) { __pyx_t_3 = (!__pyx_v_copy_shape); __pyx_t_1 = __pyx_t_3; } else { __pyx_t_1 = __pyx_t_2; } if (__pyx_t_1) { /* "numpy.pxd":248 * if not hasfields and not copy_shape: * # do not call releasebuffer * info.obj = None # <<<<<<<<<<<<<< * else: * # need to call releasebuffer */ __Pyx_INCREF(Py_None); __Pyx_GIVEREF(Py_None); __Pyx_GOTREF(__pyx_v_info->obj); __Pyx_DECREF(__pyx_v_info->obj); __pyx_v_info->obj = Py_None; goto __pyx_L10; } /*else*/ { /* "numpy.pxd":251 * else: * # need to call releasebuffer * info.obj = self # <<<<<<<<<<<<<< * * if not hasfields: */ __Pyx_INCREF(((PyObject *)__pyx_v_self)); __Pyx_GIVEREF(((PyObject *)__pyx_v_self)); __Pyx_GOTREF(__pyx_v_info->obj); __Pyx_DECREF(__pyx_v_info->obj); __pyx_v_info->obj = ((PyObject *)__pyx_v_self); } __pyx_L10:; /* "numpy.pxd":253 * info.obj = self * * if not hasfields: # <<<<<<<<<<<<<< * t = descr.type_num * if ((descr.byteorder == c'>' and little_endian) or */ __pyx_t_1 = (!__pyx_v_hasfields); if (__pyx_t_1) { /* "numpy.pxd":254 * * if not hasfields: * t = descr.type_num # <<<<<<<<<<<<<< * if ((descr.byteorder == c'>' and little_endian) or * (descr.byteorder == c'<' and not little_endian)): */ __pyx_t_5 = __pyx_v_descr->type_num; __pyx_v_t = __pyx_t_5; /* "numpy.pxd":255 * if not hasfields: * t = descr.type_num * if ((descr.byteorder == c'>' and little_endian) or # <<<<<<<<<<<<<< * (descr.byteorder == c'<' and not little_endian)): * raise ValueError(u"Non-native byte order not supported") */ __pyx_t_1 = (__pyx_v_descr->byteorder == '>'); if (__pyx_t_1) { __pyx_t_2 = __pyx_v_little_endian; } else { __pyx_t_2 = __pyx_t_1; } if (!__pyx_t_2) { /* "numpy.pxd":256 * t = descr.type_num * if ((descr.byteorder == c'>' and little_endian) or * (descr.byteorder == c'<' and not little_endian)): # <<<<<<<<<<<<<< * raise ValueError(u"Non-native byte order not supported") * if t == NPY_BYTE: f = "b" */ __pyx_t_1 = (__pyx_v_descr->byteorder == '<'); if (__pyx_t_1) { __pyx_t_3 = (!__pyx_v_little_endian); __pyx_t_7 = __pyx_t_3; } else { __pyx_t_7 = __pyx_t_1; } __pyx_t_1 = __pyx_t_7; } else { __pyx_t_1 = __pyx_t_2; } if (__pyx_t_1) { /* "numpy.pxd":257 * if ((descr.byteorder == c'>' and little_endian) or * (descr.byteorder == c'<' and not little_endian)): * raise ValueError(u"Non-native byte order not supported") # <<<<<<<<<<<<<< * if t == NPY_BYTE: f = "b" * elif t == NPY_UBYTE: f = "B" */ __pyx_t_4 = PyObject_Call(__pyx_builtin_ValueError, ((PyObject *)__pyx_k_tuple_21), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 257; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __Pyx_Raise(__pyx_t_4, 0, 0, 0); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; {__pyx_filename = __pyx_f[1]; __pyx_lineno = 257; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L12; } __pyx_L12:; /* "numpy.pxd":258 * (descr.byteorder == c'<' and not little_endian)): * raise ValueError(u"Non-native byte order not supported") * if t == NPY_BYTE: f = "b" # <<<<<<<<<<<<<< * elif t == NPY_UBYTE: f = "B" * elif t == NPY_SHORT: f = "h" */ __pyx_t_1 = (__pyx_v_t == NPY_BYTE); if (__pyx_t_1) { __pyx_v_f = __pyx_k__b; goto __pyx_L13; } /* "numpy.pxd":259 * raise ValueError(u"Non-native byte order not supported") * if t == NPY_BYTE: f = "b" * elif t == NPY_UBYTE: f = "B" # <<<<<<<<<<<<<< * elif t == NPY_SHORT: f = "h" * elif t == NPY_USHORT: f = "H" */ __pyx_t_1 = (__pyx_v_t == NPY_UBYTE); if (__pyx_t_1) { __pyx_v_f = __pyx_k__B; goto __pyx_L13; } /* "numpy.pxd":260 * if t == NPY_BYTE: f = "b" * elif t == NPY_UBYTE: f = "B" * elif t == NPY_SHORT: f = "h" # <<<<<<<<<<<<<< * elif t == NPY_USHORT: f = "H" * elif t == NPY_INT: f = "i" */ __pyx_t_1 = (__pyx_v_t == NPY_SHORT); if (__pyx_t_1) { __pyx_v_f = __pyx_k__h; goto __pyx_L13; } /* "numpy.pxd":261 * elif t == NPY_UBYTE: f = "B" * elif t == NPY_SHORT: f = "h" * elif t == NPY_USHORT: f = "H" # <<<<<<<<<<<<<< * elif t == NPY_INT: f = "i" * elif t == NPY_UINT: f = "I" */ __pyx_t_1 = (__pyx_v_t == NPY_USHORT); if (__pyx_t_1) { __pyx_v_f = __pyx_k__H; goto __pyx_L13; } /* "numpy.pxd":262 * elif t == NPY_SHORT: f = "h" * elif t == NPY_USHORT: f = "H" * elif t == NPY_INT: f = "i" # <<<<<<<<<<<<<< * elif t == NPY_UINT: f = "I" * elif t == NPY_LONG: f = "l" */ __pyx_t_1 = (__pyx_v_t == NPY_INT); if (__pyx_t_1) { __pyx_v_f = __pyx_k__i; goto __pyx_L13; } /* "numpy.pxd":263 * elif t == NPY_USHORT: f = "H" * elif t == NPY_INT: f = "i" * elif t == NPY_UINT: f = "I" # <<<<<<<<<<<<<< * elif t == NPY_LONG: f = "l" * elif t == NPY_ULONG: f = "L" */ __pyx_t_1 = (__pyx_v_t == NPY_UINT); if (__pyx_t_1) { __pyx_v_f = __pyx_k__I; goto __pyx_L13; } /* "numpy.pxd":264 * elif t == NPY_INT: f = "i" * elif t == NPY_UINT: f = "I" * elif t == NPY_LONG: f = "l" # <<<<<<<<<<<<<< * elif t == NPY_ULONG: f = "L" * elif t == NPY_LONGLONG: f = "q" */ __pyx_t_1 = (__pyx_v_t == NPY_LONG); if (__pyx_t_1) { __pyx_v_f = __pyx_k__l; goto __pyx_L13; } /* "numpy.pxd":265 * elif t == NPY_UINT: f = "I" * elif t == NPY_LONG: f = "l" * elif t == NPY_ULONG: f = "L" # <<<<<<<<<<<<<< * elif t == NPY_LONGLONG: f = "q" * elif t == NPY_ULONGLONG: f = "Q" */ __pyx_t_1 = (__pyx_v_t == NPY_ULONG); if (__pyx_t_1) { __pyx_v_f = __pyx_k__L; goto __pyx_L13; } /* "numpy.pxd":266 * elif t == NPY_LONG: f = "l" * elif t == NPY_ULONG: f = "L" * elif t == NPY_LONGLONG: f = "q" # <<<<<<<<<<<<<< * elif t == NPY_ULONGLONG: f = "Q" * elif t == NPY_FLOAT: f = "f" */ __pyx_t_1 = (__pyx_v_t == NPY_LONGLONG); if (__pyx_t_1) { __pyx_v_f = __pyx_k__q; goto __pyx_L13; } /* "numpy.pxd":267 * elif t == NPY_ULONG: f = "L" * elif t == NPY_LONGLONG: f = "q" * elif t == NPY_ULONGLONG: f = "Q" # <<<<<<<<<<<<<< * elif t == NPY_FLOAT: f = "f" * elif t == NPY_DOUBLE: f = "d" */ __pyx_t_1 = (__pyx_v_t == NPY_ULONGLONG); if (__pyx_t_1) { __pyx_v_f = __pyx_k__Q; goto __pyx_L13; } /* "numpy.pxd":268 * elif t == NPY_LONGLONG: f = "q" * elif t == NPY_ULONGLONG: f = "Q" * elif t == NPY_FLOAT: f = "f" # <<<<<<<<<<<<<< * elif t == NPY_DOUBLE: f = "d" * elif t == NPY_LONGDOUBLE: f = "g" */ __pyx_t_1 = (__pyx_v_t == NPY_FLOAT); if (__pyx_t_1) { __pyx_v_f = __pyx_k__f; goto __pyx_L13; } /* "numpy.pxd":269 * elif t == NPY_ULONGLONG: f = "Q" * elif t == NPY_FLOAT: f = "f" * elif t == NPY_DOUBLE: f = "d" # <<<<<<<<<<<<<< * elif t == NPY_LONGDOUBLE: f = "g" * elif t == NPY_CFLOAT: f = "Zf" */ __pyx_t_1 = (__pyx_v_t == NPY_DOUBLE); if (__pyx_t_1) { __pyx_v_f = __pyx_k__d; goto __pyx_L13; } /* "numpy.pxd":270 * elif t == NPY_FLOAT: f = "f" * elif t == NPY_DOUBLE: f = "d" * elif t == NPY_LONGDOUBLE: f = "g" # <<<<<<<<<<<<<< * elif t == NPY_CFLOAT: f = "Zf" * elif t == NPY_CDOUBLE: f = "Zd" */ __pyx_t_1 = (__pyx_v_t == NPY_LONGDOUBLE); if (__pyx_t_1) { __pyx_v_f = __pyx_k__g; goto __pyx_L13; } /* "numpy.pxd":271 * elif t == NPY_DOUBLE: f = "d" * elif t == NPY_LONGDOUBLE: f = "g" * elif t == NPY_CFLOAT: f = "Zf" # <<<<<<<<<<<<<< * elif t == NPY_CDOUBLE: f = "Zd" * elif t == NPY_CLONGDOUBLE: f = "Zg" */ __pyx_t_1 = (__pyx_v_t == NPY_CFLOAT); if (__pyx_t_1) { __pyx_v_f = __pyx_k__Zf; goto __pyx_L13; } /* "numpy.pxd":272 * elif t == NPY_LONGDOUBLE: f = "g" * elif t == NPY_CFLOAT: f = "Zf" * elif t == NPY_CDOUBLE: f = "Zd" # <<<<<<<<<<<<<< * elif t == NPY_CLONGDOUBLE: f = "Zg" * elif t == NPY_OBJECT: f = "O" */ __pyx_t_1 = (__pyx_v_t == NPY_CDOUBLE); if (__pyx_t_1) { __pyx_v_f = __pyx_k__Zd; goto __pyx_L13; } /* "numpy.pxd":273 * elif t == NPY_CFLOAT: f = "Zf" * elif t == NPY_CDOUBLE: f = "Zd" * elif t == NPY_CLONGDOUBLE: f = "Zg" # <<<<<<<<<<<<<< * elif t == NPY_OBJECT: f = "O" * else: */ __pyx_t_1 = (__pyx_v_t == NPY_CLONGDOUBLE); if (__pyx_t_1) { __pyx_v_f = __pyx_k__Zg; goto __pyx_L13; } /* "numpy.pxd":274 * elif t == NPY_CDOUBLE: f = "Zd" * elif t == NPY_CLONGDOUBLE: f = "Zg" * elif t == NPY_OBJECT: f = "O" # <<<<<<<<<<<<<< * else: * raise ValueError(u"unknown dtype code in numpy.pxd (%d)" % t) */ __pyx_t_1 = (__pyx_v_t == NPY_OBJECT); if (__pyx_t_1) { __pyx_v_f = __pyx_k__O; goto __pyx_L13; } /*else*/ { /* "numpy.pxd":276 * elif t == NPY_OBJECT: f = "O" * else: * raise ValueError(u"unknown dtype code in numpy.pxd (%d)" % t) # <<<<<<<<<<<<<< * info.format = f * return */ __pyx_t_4 = PyInt_FromLong(__pyx_v_t); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 276; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_8 = PyNumber_Remainder(((PyObject *)__pyx_kp_u_22), __pyx_t_4); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 276; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_8)); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 276; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); PyTuple_SET_ITEM(__pyx_t_4, 0, ((PyObject *)__pyx_t_8)); __Pyx_GIVEREF(((PyObject *)__pyx_t_8)); __pyx_t_8 = 0; __pyx_t_8 = PyObject_Call(__pyx_builtin_ValueError, ((PyObject *)__pyx_t_4), NULL); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 276; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_8); __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0; __Pyx_Raise(__pyx_t_8, 0, 0, 0); __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0; {__pyx_filename = __pyx_f[1]; __pyx_lineno = 276; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_L13:; /* "numpy.pxd":277 * else: * raise ValueError(u"unknown dtype code in numpy.pxd (%d)" % t) * info.format = f # <<<<<<<<<<<<<< * return * else: */ __pyx_v_info->format = __pyx_v_f; /* "numpy.pxd":278 * raise ValueError(u"unknown dtype code in numpy.pxd (%d)" % t) * info.format = f * return # <<<<<<<<<<<<<< * else: * info.format = stdlib.malloc(_buffer_format_string_len) */ __pyx_r = 0; goto __pyx_L0; goto __pyx_L11; } /*else*/ { /* "numpy.pxd":280 * return * else: * info.format = stdlib.malloc(_buffer_format_string_len) # <<<<<<<<<<<<<< * info.format[0] = c'^' # Native data types, manual alignment * offset = 0 */ __pyx_v_info->format = ((char *)malloc(255)); /* "numpy.pxd":281 * else: * info.format = stdlib.malloc(_buffer_format_string_len) * info.format[0] = c'^' # Native data types, manual alignment # <<<<<<<<<<<<<< * offset = 0 * f = _util_dtypestring(descr, info.format + 1, */ (__pyx_v_info->format[0]) = '^'; /* "numpy.pxd":282 * info.format = stdlib.malloc(_buffer_format_string_len) * info.format[0] = c'^' # Native data types, manual alignment * offset = 0 # <<<<<<<<<<<<<< * f = _util_dtypestring(descr, info.format + 1, * info.format + _buffer_format_string_len, */ __pyx_v_offset = 0; /* "numpy.pxd":285 * f = _util_dtypestring(descr, info.format + 1, * info.format + _buffer_format_string_len, * &offset) # <<<<<<<<<<<<<< * f[0] = c'\0' # Terminate format string * */ __pyx_t_9 = __pyx_f_5numpy__util_dtypestring(__pyx_v_descr, (__pyx_v_info->format + 1), (__pyx_v_info->format + 255), (&__pyx_v_offset)); if (unlikely(__pyx_t_9 == NULL)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 283; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_f = __pyx_t_9; /* "numpy.pxd":286 * info.format + _buffer_format_string_len, * &offset) * f[0] = c'\0' # Terminate format string # <<<<<<<<<<<<<< * * def __releasebuffer__(ndarray self, Py_buffer* info): */ (__pyx_v_f[0]) = '\x00'; } __pyx_L11:; __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_8); __Pyx_AddTraceback("numpy.ndarray.__getbuffer__", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = -1; if (__pyx_v_info != NULL && __pyx_v_info->obj != NULL) { __Pyx_GOTREF(__pyx_v_info->obj); __Pyx_DECREF(__pyx_v_info->obj); __pyx_v_info->obj = NULL; } goto __pyx_L2; __pyx_L0:; if (__pyx_v_info != NULL && __pyx_v_info->obj == Py_None) { __Pyx_GOTREF(Py_None); __Pyx_DECREF(Py_None); __pyx_v_info->obj = NULL; } __pyx_L2:; __Pyx_XDECREF((PyObject *)__pyx_v_descr); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* Python wrapper */ static CYTHON_UNUSED void __pyx_pw_5numpy_7ndarray_3__releasebuffer__(PyObject *__pyx_v_self, Py_buffer *__pyx_v_info); /*proto*/ static CYTHON_UNUSED void __pyx_pw_5numpy_7ndarray_3__releasebuffer__(PyObject *__pyx_v_self, Py_buffer *__pyx_v_info) { __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__releasebuffer__ (wrapper)", 0); __pyx_pf_5numpy_7ndarray_2__releasebuffer__(((PyArrayObject *)__pyx_v_self), ((Py_buffer *)__pyx_v_info)); __Pyx_RefNannyFinishContext(); } /* "numpy.pxd":288 * f[0] = c'\0' # Terminate format string * * def __releasebuffer__(ndarray self, Py_buffer* info): # <<<<<<<<<<<<<< * if PyArray_HASFIELDS(self): * stdlib.free(info.format) */ static void __pyx_pf_5numpy_7ndarray_2__releasebuffer__(PyArrayObject *__pyx_v_self, Py_buffer *__pyx_v_info) { __Pyx_RefNannyDeclarations int __pyx_t_1; __Pyx_RefNannySetupContext("__releasebuffer__", 0); /* "numpy.pxd":289 * * def __releasebuffer__(ndarray self, Py_buffer* info): * if PyArray_HASFIELDS(self): # <<<<<<<<<<<<<< * stdlib.free(info.format) * if sizeof(npy_intp) != sizeof(Py_ssize_t): */ __pyx_t_1 = PyArray_HASFIELDS(__pyx_v_self); if (__pyx_t_1) { /* "numpy.pxd":290 * def __releasebuffer__(ndarray self, Py_buffer* info): * if PyArray_HASFIELDS(self): * stdlib.free(info.format) # <<<<<<<<<<<<<< * if sizeof(npy_intp) != sizeof(Py_ssize_t): * stdlib.free(info.strides) */ free(__pyx_v_info->format); goto __pyx_L3; } __pyx_L3:; /* "numpy.pxd":291 * if PyArray_HASFIELDS(self): * stdlib.free(info.format) * if sizeof(npy_intp) != sizeof(Py_ssize_t): # <<<<<<<<<<<<<< * stdlib.free(info.strides) * # info.shape was stored after info.strides in the same block */ __pyx_t_1 = ((sizeof(npy_intp)) != (sizeof(Py_ssize_t))); if (__pyx_t_1) { /* "numpy.pxd":292 * stdlib.free(info.format) * if sizeof(npy_intp) != sizeof(Py_ssize_t): * stdlib.free(info.strides) # <<<<<<<<<<<<<< * # info.shape was stored after info.strides in the same block * */ free(__pyx_v_info->strides); goto __pyx_L4; } __pyx_L4:; __Pyx_RefNannyFinishContext(); } /* "numpy.pxd":768 * ctypedef npy_cdouble complex_t * * cdef inline object PyArray_MultiIterNew1(a): # <<<<<<<<<<<<<< * return PyArray_MultiIterNew(1, a) * */ static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew1(PyObject *__pyx_v_a) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("PyArray_MultiIterNew1", 0); /* "numpy.pxd":769 * * cdef inline object PyArray_MultiIterNew1(a): * return PyArray_MultiIterNew(1, a) # <<<<<<<<<<<<<< * * cdef inline object PyArray_MultiIterNew2(a, b): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyArray_MultiIterNew(1, ((void *)__pyx_v_a)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 769; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("numpy.PyArray_MultiIterNew1", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "numpy.pxd":771 * return PyArray_MultiIterNew(1, a) * * cdef inline object PyArray_MultiIterNew2(a, b): # <<<<<<<<<<<<<< * return PyArray_MultiIterNew(2, a, b) * */ static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew2(PyObject *__pyx_v_a, PyObject *__pyx_v_b) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("PyArray_MultiIterNew2", 0); /* "numpy.pxd":772 * * cdef inline object PyArray_MultiIterNew2(a, b): * return PyArray_MultiIterNew(2, a, b) # <<<<<<<<<<<<<< * * cdef inline object PyArray_MultiIterNew3(a, b, c): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyArray_MultiIterNew(2, ((void *)__pyx_v_a), ((void *)__pyx_v_b)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 772; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("numpy.PyArray_MultiIterNew2", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "numpy.pxd":774 * return PyArray_MultiIterNew(2, a, b) * * cdef inline object PyArray_MultiIterNew3(a, b, c): # <<<<<<<<<<<<<< * return PyArray_MultiIterNew(3, a, b, c) * */ static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew3(PyObject *__pyx_v_a, PyObject *__pyx_v_b, PyObject *__pyx_v_c) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("PyArray_MultiIterNew3", 0); /* "numpy.pxd":775 * * cdef inline object PyArray_MultiIterNew3(a, b, c): * return PyArray_MultiIterNew(3, a, b, c) # <<<<<<<<<<<<<< * * cdef inline object PyArray_MultiIterNew4(a, b, c, d): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyArray_MultiIterNew(3, ((void *)__pyx_v_a), ((void *)__pyx_v_b), ((void *)__pyx_v_c)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 775; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("numpy.PyArray_MultiIterNew3", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "numpy.pxd":777 * return PyArray_MultiIterNew(3, a, b, c) * * cdef inline object PyArray_MultiIterNew4(a, b, c, d): # <<<<<<<<<<<<<< * return PyArray_MultiIterNew(4, a, b, c, d) * */ static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew4(PyObject *__pyx_v_a, PyObject *__pyx_v_b, PyObject *__pyx_v_c, PyObject *__pyx_v_d) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("PyArray_MultiIterNew4", 0); /* "numpy.pxd":778 * * cdef inline object PyArray_MultiIterNew4(a, b, c, d): * return PyArray_MultiIterNew(4, a, b, c, d) # <<<<<<<<<<<<<< * * cdef inline object PyArray_MultiIterNew5(a, b, c, d, e): */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyArray_MultiIterNew(4, ((void *)__pyx_v_a), ((void *)__pyx_v_b), ((void *)__pyx_v_c), ((void *)__pyx_v_d)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 778; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("numpy.PyArray_MultiIterNew4", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "numpy.pxd":780 * return PyArray_MultiIterNew(4, a, b, c, d) * * cdef inline object PyArray_MultiIterNew5(a, b, c, d, e): # <<<<<<<<<<<<<< * return PyArray_MultiIterNew(5, a, b, c, d, e) * */ static CYTHON_INLINE PyObject *__pyx_f_5numpy_PyArray_MultiIterNew5(PyObject *__pyx_v_a, PyObject *__pyx_v_b, PyObject *__pyx_v_c, PyObject *__pyx_v_d, PyObject *__pyx_v_e) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("PyArray_MultiIterNew5", 0); /* "numpy.pxd":781 * * cdef inline object PyArray_MultiIterNew5(a, b, c, d, e): * return PyArray_MultiIterNew(5, a, b, c, d, e) # <<<<<<<<<<<<<< * * cdef inline char* _util_dtypestring(dtype descr, char* f, char* end, int* offset) except NULL: */ __Pyx_XDECREF(__pyx_r); __pyx_t_1 = PyArray_MultiIterNew(5, ((void *)__pyx_v_a), ((void *)__pyx_v_b), ((void *)__pyx_v_c), ((void *)__pyx_v_d), ((void *)__pyx_v_e)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 781; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_r = __pyx_t_1; __pyx_t_1 = 0; goto __pyx_L0; __pyx_r = Py_None; __Pyx_INCREF(Py_None); goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_AddTraceback("numpy.PyArray_MultiIterNew5", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = 0; __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "numpy.pxd":783 * return PyArray_MultiIterNew(5, a, b, c, d, e) * * cdef inline char* _util_dtypestring(dtype descr, char* f, char* end, int* offset) except NULL: # <<<<<<<<<<<<<< * # Recursive utility function used in __getbuffer__ to get format * # string. The new location in the format string is returned. */ static CYTHON_INLINE char *__pyx_f_5numpy__util_dtypestring(PyArray_Descr *__pyx_v_descr, char *__pyx_v_f, char *__pyx_v_end, int *__pyx_v_offset) { PyArray_Descr *__pyx_v_child = 0; int __pyx_v_endian_detector; int __pyx_v_little_endian; PyObject *__pyx_v_fields = 0; PyObject *__pyx_v_childname = NULL; PyObject *__pyx_v_new_offset = NULL; PyObject *__pyx_v_t = NULL; char *__pyx_r; __Pyx_RefNannyDeclarations PyObject *__pyx_t_1 = NULL; Py_ssize_t __pyx_t_2; PyObject *__pyx_t_3 = NULL; PyObject *__pyx_t_4 = NULL; PyObject *__pyx_t_5 = NULL; PyObject *(*__pyx_t_6)(PyObject *); int __pyx_t_7; int __pyx_t_8; int __pyx_t_9; int __pyx_t_10; long __pyx_t_11; char *__pyx_t_12; int __pyx_lineno = 0; const char *__pyx_filename = NULL; int __pyx_clineno = 0; __Pyx_RefNannySetupContext("_util_dtypestring", 0); /* "numpy.pxd":790 * cdef int delta_offset * cdef tuple i * cdef int endian_detector = 1 # <<<<<<<<<<<<<< * cdef bint little_endian = ((&endian_detector)[0] != 0) * cdef tuple fields */ __pyx_v_endian_detector = 1; /* "numpy.pxd":791 * cdef tuple i * cdef int endian_detector = 1 * cdef bint little_endian = ((&endian_detector)[0] != 0) # <<<<<<<<<<<<<< * cdef tuple fields * */ __pyx_v_little_endian = ((((char *)(&__pyx_v_endian_detector))[0]) != 0); /* "numpy.pxd":794 * cdef tuple fields * * for childname in descr.names: # <<<<<<<<<<<<<< * fields = descr.fields[childname] * child, new_offset = fields */ if (unlikely(((PyObject *)__pyx_v_descr->names) == Py_None)) { PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); {__pyx_filename = __pyx_f[1]; __pyx_lineno = 794; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_t_1 = ((PyObject *)__pyx_v_descr->names); __Pyx_INCREF(__pyx_t_1); __pyx_t_2 = 0; for (;;) { if (__pyx_t_2 >= PyTuple_GET_SIZE(__pyx_t_1)) break; #if CYTHON_COMPILING_IN_CPYTHON __pyx_t_3 = PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_2); __Pyx_INCREF(__pyx_t_3); __pyx_t_2++; if (unlikely(0 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 794; __pyx_clineno = __LINE__; goto __pyx_L1_error;} #else __pyx_t_3 = PySequence_ITEM(__pyx_t_1, __pyx_t_2); __pyx_t_2++; if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 794; __pyx_clineno = __LINE__; goto __pyx_L1_error;} #endif __Pyx_XDECREF(__pyx_v_childname); __pyx_v_childname = __pyx_t_3; __pyx_t_3 = 0; /* "numpy.pxd":795 * * for childname in descr.names: * fields = descr.fields[childname] # <<<<<<<<<<<<<< * child, new_offset = fields * */ __pyx_t_3 = PyObject_GetItem(__pyx_v_descr->fields, __pyx_v_childname); if (!__pyx_t_3) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 795; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); if (!(likely(PyTuple_CheckExact(__pyx_t_3))||((__pyx_t_3) == Py_None)||(PyErr_Format(PyExc_TypeError, "Expected tuple, got %.200s", Py_TYPE(__pyx_t_3)->tp_name), 0))) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 795; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_XDECREF(((PyObject *)__pyx_v_fields)); __pyx_v_fields = ((PyObject*)__pyx_t_3); __pyx_t_3 = 0; /* "numpy.pxd":796 * for childname in descr.names: * fields = descr.fields[childname] * child, new_offset = fields # <<<<<<<<<<<<<< * * if (end - f) - (new_offset - offset[0]) < 15: */ if (likely(PyTuple_CheckExact(((PyObject *)__pyx_v_fields)))) { PyObject* sequence = ((PyObject *)__pyx_v_fields); #if CYTHON_COMPILING_IN_CPYTHON Py_ssize_t size = Py_SIZE(sequence); #else Py_ssize_t size = PySequence_Size(sequence); #endif if (unlikely(size != 2)) { if (size > 2) __Pyx_RaiseTooManyValuesError(2); else if (size >= 0) __Pyx_RaiseNeedMoreValuesError(size); {__pyx_filename = __pyx_f[1]; __pyx_lineno = 796; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } #if CYTHON_COMPILING_IN_CPYTHON __pyx_t_3 = PyTuple_GET_ITEM(sequence, 0); __pyx_t_4 = PyTuple_GET_ITEM(sequence, 1); __Pyx_INCREF(__pyx_t_3); __Pyx_INCREF(__pyx_t_4); #else __pyx_t_3 = PySequence_ITEM(sequence, 0); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 796; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_t_4 = PySequence_ITEM(sequence, 1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 796; __pyx_clineno = __LINE__; goto __pyx_L1_error;} #endif } else if (1) { __Pyx_RaiseNoneNotIterableError(); {__pyx_filename = __pyx_f[1]; __pyx_lineno = 796; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } else { Py_ssize_t index = -1; __pyx_t_5 = PyObject_GetIter(((PyObject *)__pyx_v_fields)); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 796; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_6 = Py_TYPE(__pyx_t_5)->tp_iternext; index = 0; __pyx_t_3 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_3)) goto __pyx_L5_unpacking_failed; __Pyx_GOTREF(__pyx_t_3); index = 1; __pyx_t_4 = __pyx_t_6(__pyx_t_5); if (unlikely(!__pyx_t_4)) goto __pyx_L5_unpacking_failed; __Pyx_GOTREF(__pyx_t_4); if (__Pyx_IternextUnpackEndCheck(__pyx_t_6(__pyx_t_5), 2) < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 796; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_t_6 = NULL; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; goto __pyx_L6_unpacking_done; __pyx_L5_unpacking_failed:; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_6 = NULL; if (__Pyx_IterFinish() == 0) __Pyx_RaiseNeedMoreValuesError(index); {__pyx_filename = __pyx_f[1]; __pyx_lineno = 796; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_L6_unpacking_done:; } if (!(likely(((__pyx_t_3) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_3, __pyx_ptype_5numpy_dtype))))) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 796; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_XDECREF(((PyObject *)__pyx_v_child)); __pyx_v_child = ((PyArray_Descr *)__pyx_t_3); __pyx_t_3 = 0; __Pyx_XDECREF(__pyx_v_new_offset); __pyx_v_new_offset = __pyx_t_4; __pyx_t_4 = 0; /* "numpy.pxd":798 * child, new_offset = fields * * if (end - f) - (new_offset - offset[0]) < 15: # <<<<<<<<<<<<<< * raise RuntimeError(u"Format string allocated too short, see comment in numpy.pxd") * */ __pyx_t_4 = PyInt_FromLong((__pyx_v_end - __pyx_v_f)); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 798; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_4); __pyx_t_3 = PyInt_FromLong((__pyx_v_offset[0])); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 798; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyNumber_Subtract(__pyx_v_new_offset, __pyx_t_3); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 798; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyNumber_Subtract(__pyx_t_4, __pyx_t_5); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 798; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0; __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_5 = PyObject_RichCompare(__pyx_t_3, __pyx_int_15, Py_LT); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 798; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 798; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { /* "numpy.pxd":799 * * if (end - f) - (new_offset - offset[0]) < 15: * raise RuntimeError(u"Format string allocated too short, see comment in numpy.pxd") # <<<<<<<<<<<<<< * * if ((child.byteorder == c'>' and little_endian) or */ __pyx_t_5 = PyObject_Call(__pyx_builtin_RuntimeError, ((PyObject *)__pyx_k_tuple_24), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 799; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __Pyx_Raise(__pyx_t_5, 0, 0, 0); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; {__pyx_filename = __pyx_f[1]; __pyx_lineno = 799; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L7; } __pyx_L7:; /* "numpy.pxd":801 * raise RuntimeError(u"Format string allocated too short, see comment in numpy.pxd") * * if ((child.byteorder == c'>' and little_endian) or # <<<<<<<<<<<<<< * (child.byteorder == c'<' and not little_endian)): * raise ValueError(u"Non-native byte order not supported") */ __pyx_t_7 = (__pyx_v_child->byteorder == '>'); if (__pyx_t_7) { __pyx_t_8 = __pyx_v_little_endian; } else { __pyx_t_8 = __pyx_t_7; } if (!__pyx_t_8) { /* "numpy.pxd":802 * * if ((child.byteorder == c'>' and little_endian) or * (child.byteorder == c'<' and not little_endian)): # <<<<<<<<<<<<<< * raise ValueError(u"Non-native byte order not supported") * # One could encode it in the format string and have Cython */ __pyx_t_7 = (__pyx_v_child->byteorder == '<'); if (__pyx_t_7) { __pyx_t_9 = (!__pyx_v_little_endian); __pyx_t_10 = __pyx_t_9; } else { __pyx_t_10 = __pyx_t_7; } __pyx_t_7 = __pyx_t_10; } else { __pyx_t_7 = __pyx_t_8; } if (__pyx_t_7) { /* "numpy.pxd":803 * if ((child.byteorder == c'>' and little_endian) or * (child.byteorder == c'<' and not little_endian)): * raise ValueError(u"Non-native byte order not supported") # <<<<<<<<<<<<<< * # One could encode it in the format string and have Cython * # complain instead, BUT: < and > in format strings also imply */ __pyx_t_5 = PyObject_Call(__pyx_builtin_ValueError, ((PyObject *)__pyx_k_tuple_25), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 803; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __Pyx_Raise(__pyx_t_5, 0, 0, 0); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; {__pyx_filename = __pyx_f[1]; __pyx_lineno = 803; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L8; } __pyx_L8:; /* "numpy.pxd":813 * * # Output padding bytes * while offset[0] < new_offset: # <<<<<<<<<<<<<< * f[0] = 120 # "x"; pad byte * f += 1 */ while (1) { __pyx_t_5 = PyInt_FromLong((__pyx_v_offset[0])); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 813; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyObject_RichCompare(__pyx_t_5, __pyx_v_new_offset, Py_LT); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 813; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 813; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (!__pyx_t_7) break; /* "numpy.pxd":814 * # Output padding bytes * while offset[0] < new_offset: * f[0] = 120 # "x"; pad byte # <<<<<<<<<<<<<< * f += 1 * offset[0] += 1 */ (__pyx_v_f[0]) = 120; /* "numpy.pxd":815 * while offset[0] < new_offset: * f[0] = 120 # "x"; pad byte * f += 1 # <<<<<<<<<<<<<< * offset[0] += 1 * */ __pyx_v_f = (__pyx_v_f + 1); /* "numpy.pxd":816 * f[0] = 120 # "x"; pad byte * f += 1 * offset[0] += 1 # <<<<<<<<<<<<<< * * offset[0] += child.itemsize */ __pyx_t_11 = 0; (__pyx_v_offset[__pyx_t_11]) = ((__pyx_v_offset[__pyx_t_11]) + 1); } /* "numpy.pxd":818 * offset[0] += 1 * * offset[0] += child.itemsize # <<<<<<<<<<<<<< * * if not PyDataType_HASFIELDS(child): */ __pyx_t_11 = 0; (__pyx_v_offset[__pyx_t_11]) = ((__pyx_v_offset[__pyx_t_11]) + __pyx_v_child->elsize); /* "numpy.pxd":820 * offset[0] += child.itemsize * * if not PyDataType_HASFIELDS(child): # <<<<<<<<<<<<<< * t = child.type_num * if end - f < 5: */ __pyx_t_7 = (!PyDataType_HASFIELDS(__pyx_v_child)); if (__pyx_t_7) { /* "numpy.pxd":821 * * if not PyDataType_HASFIELDS(child): * t = child.type_num # <<<<<<<<<<<<<< * if end - f < 5: * raise RuntimeError(u"Format string allocated too short.") */ __pyx_t_3 = PyInt_FromLong(__pyx_v_child->type_num); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 821; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_XDECREF(__pyx_v_t); __pyx_v_t = __pyx_t_3; __pyx_t_3 = 0; /* "numpy.pxd":822 * if not PyDataType_HASFIELDS(child): * t = child.type_num * if end - f < 5: # <<<<<<<<<<<<<< * raise RuntimeError(u"Format string allocated too short.") * */ __pyx_t_7 = ((__pyx_v_end - __pyx_v_f) < 5); if (__pyx_t_7) { /* "numpy.pxd":823 * t = child.type_num * if end - f < 5: * raise RuntimeError(u"Format string allocated too short.") # <<<<<<<<<<<<<< * * # Until ticket #99 is fixed, use integers to avoid warnings */ __pyx_t_3 = PyObject_Call(__pyx_builtin_RuntimeError, ((PyObject *)__pyx_k_tuple_27), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 823; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_Raise(__pyx_t_3, 0, 0, 0); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; {__pyx_filename = __pyx_f[1]; __pyx_lineno = 823; __pyx_clineno = __LINE__; goto __pyx_L1_error;} goto __pyx_L12; } __pyx_L12:; /* "numpy.pxd":826 * * # Until ticket #99 is fixed, use integers to avoid warnings * if t == NPY_BYTE: f[0] = 98 #"b" # <<<<<<<<<<<<<< * elif t == NPY_UBYTE: f[0] = 66 #"B" * elif t == NPY_SHORT: f[0] = 104 #"h" */ __pyx_t_3 = PyInt_FromLong(NPY_BYTE); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 826; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyObject_RichCompare(__pyx_v_t, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 826; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 826; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 98; goto __pyx_L13; } /* "numpy.pxd":827 * # Until ticket #99 is fixed, use integers to avoid warnings * if t == NPY_BYTE: f[0] = 98 #"b" * elif t == NPY_UBYTE: f[0] = 66 #"B" # <<<<<<<<<<<<<< * elif t == NPY_SHORT: f[0] = 104 #"h" * elif t == NPY_USHORT: f[0] = 72 #"H" */ __pyx_t_5 = PyInt_FromLong(NPY_UBYTE); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 827; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyObject_RichCompare(__pyx_v_t, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 827; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 827; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 66; goto __pyx_L13; } /* "numpy.pxd":828 * if t == NPY_BYTE: f[0] = 98 #"b" * elif t == NPY_UBYTE: f[0] = 66 #"B" * elif t == NPY_SHORT: f[0] = 104 #"h" # <<<<<<<<<<<<<< * elif t == NPY_USHORT: f[0] = 72 #"H" * elif t == NPY_INT: f[0] = 105 #"i" */ __pyx_t_3 = PyInt_FromLong(NPY_SHORT); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 828; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyObject_RichCompare(__pyx_v_t, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 828; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 828; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 104; goto __pyx_L13; } /* "numpy.pxd":829 * elif t == NPY_UBYTE: f[0] = 66 #"B" * elif t == NPY_SHORT: f[0] = 104 #"h" * elif t == NPY_USHORT: f[0] = 72 #"H" # <<<<<<<<<<<<<< * elif t == NPY_INT: f[0] = 105 #"i" * elif t == NPY_UINT: f[0] = 73 #"I" */ __pyx_t_5 = PyInt_FromLong(NPY_USHORT); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 829; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyObject_RichCompare(__pyx_v_t, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 829; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 829; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 72; goto __pyx_L13; } /* "numpy.pxd":830 * elif t == NPY_SHORT: f[0] = 104 #"h" * elif t == NPY_USHORT: f[0] = 72 #"H" * elif t == NPY_INT: f[0] = 105 #"i" # <<<<<<<<<<<<<< * elif t == NPY_UINT: f[0] = 73 #"I" * elif t == NPY_LONG: f[0] = 108 #"l" */ __pyx_t_3 = PyInt_FromLong(NPY_INT); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 830; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyObject_RichCompare(__pyx_v_t, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 830; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 830; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 105; goto __pyx_L13; } /* "numpy.pxd":831 * elif t == NPY_USHORT: f[0] = 72 #"H" * elif t == NPY_INT: f[0] = 105 #"i" * elif t == NPY_UINT: f[0] = 73 #"I" # <<<<<<<<<<<<<< * elif t == NPY_LONG: f[0] = 108 #"l" * elif t == NPY_ULONG: f[0] = 76 #"L" */ __pyx_t_5 = PyInt_FromLong(NPY_UINT); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 831; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyObject_RichCompare(__pyx_v_t, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 831; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 831; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 73; goto __pyx_L13; } /* "numpy.pxd":832 * elif t == NPY_INT: f[0] = 105 #"i" * elif t == NPY_UINT: f[0] = 73 #"I" * elif t == NPY_LONG: f[0] = 108 #"l" # <<<<<<<<<<<<<< * elif t == NPY_ULONG: f[0] = 76 #"L" * elif t == NPY_LONGLONG: f[0] = 113 #"q" */ __pyx_t_3 = PyInt_FromLong(NPY_LONG); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 832; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyObject_RichCompare(__pyx_v_t, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 832; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 832; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 108; goto __pyx_L13; } /* "numpy.pxd":833 * elif t == NPY_UINT: f[0] = 73 #"I" * elif t == NPY_LONG: f[0] = 108 #"l" * elif t == NPY_ULONG: f[0] = 76 #"L" # <<<<<<<<<<<<<< * elif t == NPY_LONGLONG: f[0] = 113 #"q" * elif t == NPY_ULONGLONG: f[0] = 81 #"Q" */ __pyx_t_5 = PyInt_FromLong(NPY_ULONG); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 833; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyObject_RichCompare(__pyx_v_t, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 833; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 833; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 76; goto __pyx_L13; } /* "numpy.pxd":834 * elif t == NPY_LONG: f[0] = 108 #"l" * elif t == NPY_ULONG: f[0] = 76 #"L" * elif t == NPY_LONGLONG: f[0] = 113 #"q" # <<<<<<<<<<<<<< * elif t == NPY_ULONGLONG: f[0] = 81 #"Q" * elif t == NPY_FLOAT: f[0] = 102 #"f" */ __pyx_t_3 = PyInt_FromLong(NPY_LONGLONG); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 834; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyObject_RichCompare(__pyx_v_t, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 834; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 834; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 113; goto __pyx_L13; } /* "numpy.pxd":835 * elif t == NPY_ULONG: f[0] = 76 #"L" * elif t == NPY_LONGLONG: f[0] = 113 #"q" * elif t == NPY_ULONGLONG: f[0] = 81 #"Q" # <<<<<<<<<<<<<< * elif t == NPY_FLOAT: f[0] = 102 #"f" * elif t == NPY_DOUBLE: f[0] = 100 #"d" */ __pyx_t_5 = PyInt_FromLong(NPY_ULONGLONG); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 835; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyObject_RichCompare(__pyx_v_t, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 835; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 835; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 81; goto __pyx_L13; } /* "numpy.pxd":836 * elif t == NPY_LONGLONG: f[0] = 113 #"q" * elif t == NPY_ULONGLONG: f[0] = 81 #"Q" * elif t == NPY_FLOAT: f[0] = 102 #"f" # <<<<<<<<<<<<<< * elif t == NPY_DOUBLE: f[0] = 100 #"d" * elif t == NPY_LONGDOUBLE: f[0] = 103 #"g" */ __pyx_t_3 = PyInt_FromLong(NPY_FLOAT); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 836; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyObject_RichCompare(__pyx_v_t, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 836; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 836; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 102; goto __pyx_L13; } /* "numpy.pxd":837 * elif t == NPY_ULONGLONG: f[0] = 81 #"Q" * elif t == NPY_FLOAT: f[0] = 102 #"f" * elif t == NPY_DOUBLE: f[0] = 100 #"d" # <<<<<<<<<<<<<< * elif t == NPY_LONGDOUBLE: f[0] = 103 #"g" * elif t == NPY_CFLOAT: f[0] = 90; f[1] = 102; f += 1 # Zf */ __pyx_t_5 = PyInt_FromLong(NPY_DOUBLE); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 837; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyObject_RichCompare(__pyx_v_t, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 837; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 837; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 100; goto __pyx_L13; } /* "numpy.pxd":838 * elif t == NPY_FLOAT: f[0] = 102 #"f" * elif t == NPY_DOUBLE: f[0] = 100 #"d" * elif t == NPY_LONGDOUBLE: f[0] = 103 #"g" # <<<<<<<<<<<<<< * elif t == NPY_CFLOAT: f[0] = 90; f[1] = 102; f += 1 # Zf * elif t == NPY_CDOUBLE: f[0] = 90; f[1] = 100; f += 1 # Zd */ __pyx_t_3 = PyInt_FromLong(NPY_LONGDOUBLE); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 838; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyObject_RichCompare(__pyx_v_t, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 838; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 838; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 103; goto __pyx_L13; } /* "numpy.pxd":839 * elif t == NPY_DOUBLE: f[0] = 100 #"d" * elif t == NPY_LONGDOUBLE: f[0] = 103 #"g" * elif t == NPY_CFLOAT: f[0] = 90; f[1] = 102; f += 1 # Zf # <<<<<<<<<<<<<< * elif t == NPY_CDOUBLE: f[0] = 90; f[1] = 100; f += 1 # Zd * elif t == NPY_CLONGDOUBLE: f[0] = 90; f[1] = 103; f += 1 # Zg */ __pyx_t_5 = PyInt_FromLong(NPY_CFLOAT); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 839; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyObject_RichCompare(__pyx_v_t, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 839; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 839; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 90; (__pyx_v_f[1]) = 102; __pyx_v_f = (__pyx_v_f + 1); goto __pyx_L13; } /* "numpy.pxd":840 * elif t == NPY_LONGDOUBLE: f[0] = 103 #"g" * elif t == NPY_CFLOAT: f[0] = 90; f[1] = 102; f += 1 # Zf * elif t == NPY_CDOUBLE: f[0] = 90; f[1] = 100; f += 1 # Zd # <<<<<<<<<<<<<< * elif t == NPY_CLONGDOUBLE: f[0] = 90; f[1] = 103; f += 1 # Zg * elif t == NPY_OBJECT: f[0] = 79 #"O" */ __pyx_t_3 = PyInt_FromLong(NPY_CDOUBLE); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 840; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyObject_RichCompare(__pyx_v_t, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 840; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 840; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 90; (__pyx_v_f[1]) = 100; __pyx_v_f = (__pyx_v_f + 1); goto __pyx_L13; } /* "numpy.pxd":841 * elif t == NPY_CFLOAT: f[0] = 90; f[1] = 102; f += 1 # Zf * elif t == NPY_CDOUBLE: f[0] = 90; f[1] = 100; f += 1 # Zd * elif t == NPY_CLONGDOUBLE: f[0] = 90; f[1] = 103; f += 1 # Zg # <<<<<<<<<<<<<< * elif t == NPY_OBJECT: f[0] = 79 #"O" * else: */ __pyx_t_5 = PyInt_FromLong(NPY_CLONGDOUBLE); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 841; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __pyx_t_3 = PyObject_RichCompare(__pyx_v_t, __pyx_t_5, Py_EQ); __Pyx_XGOTREF(__pyx_t_3); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 841; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_3); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 841; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 90; (__pyx_v_f[1]) = 103; __pyx_v_f = (__pyx_v_f + 1); goto __pyx_L13; } /* "numpy.pxd":842 * elif t == NPY_CDOUBLE: f[0] = 90; f[1] = 100; f += 1 # Zd * elif t == NPY_CLONGDOUBLE: f[0] = 90; f[1] = 103; f += 1 # Zg * elif t == NPY_OBJECT: f[0] = 79 #"O" # <<<<<<<<<<<<<< * else: * raise ValueError(u"unknown dtype code in numpy.pxd (%d)" % t) */ __pyx_t_3 = PyInt_FromLong(NPY_OBJECT); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 842; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_5 = PyObject_RichCompare(__pyx_v_t, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_5); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 842; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_7 = __Pyx_PyObject_IsTrue(__pyx_t_5); if (unlikely(__pyx_t_7 < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 842; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; if (__pyx_t_7) { (__pyx_v_f[0]) = 79; goto __pyx_L13; } /*else*/ { /* "numpy.pxd":844 * elif t == NPY_OBJECT: f[0] = 79 #"O" * else: * raise ValueError(u"unknown dtype code in numpy.pxd (%d)" % t) # <<<<<<<<<<<<<< * f += 1 * else: */ __pyx_t_5 = PyNumber_Remainder(((PyObject *)__pyx_kp_u_22), __pyx_v_t); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 844; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_5)); __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 844; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_3, 0, ((PyObject *)__pyx_t_5)); __Pyx_GIVEREF(((PyObject *)__pyx_t_5)); __pyx_t_5 = 0; __pyx_t_5 = PyObject_Call(__pyx_builtin_ValueError, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 844; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_5); __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; __Pyx_Raise(__pyx_t_5, 0, 0, 0); __Pyx_DECREF(__pyx_t_5); __pyx_t_5 = 0; {__pyx_filename = __pyx_f[1]; __pyx_lineno = 844; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __pyx_L13:; /* "numpy.pxd":845 * else: * raise ValueError(u"unknown dtype code in numpy.pxd (%d)" % t) * f += 1 # <<<<<<<<<<<<<< * else: * # Cython ignores struct boundary information ("T{...}"), */ __pyx_v_f = (__pyx_v_f + 1); goto __pyx_L11; } /*else*/ { /* "numpy.pxd":849 * # Cython ignores struct boundary information ("T{...}"), * # so don't output it * f = _util_dtypestring(child, f, end, offset) # <<<<<<<<<<<<<< * return f * */ __pyx_t_12 = __pyx_f_5numpy__util_dtypestring(__pyx_v_child, __pyx_v_f, __pyx_v_end, __pyx_v_offset); if (unlikely(__pyx_t_12 == NULL)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 849; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_v_f = __pyx_t_12; } __pyx_L11:; } __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "numpy.pxd":850 * # so don't output it * f = _util_dtypestring(child, f, end, offset) * return f # <<<<<<<<<<<<<< * * */ __pyx_r = __pyx_v_f; goto __pyx_L0; __pyx_r = 0; goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_3); __Pyx_XDECREF(__pyx_t_4); __Pyx_XDECREF(__pyx_t_5); __Pyx_AddTraceback("numpy._util_dtypestring", __pyx_clineno, __pyx_lineno, __pyx_filename); __pyx_r = NULL; __pyx_L0:; __Pyx_XDECREF((PyObject *)__pyx_v_child); __Pyx_XDECREF(__pyx_v_fields); __Pyx_XDECREF(__pyx_v_childname); __Pyx_XDECREF(__pyx_v_new_offset); __Pyx_XDECREF(__pyx_v_t); __Pyx_RefNannyFinishContext(); return __pyx_r; } /* "numpy.pxd":965 * * * cdef inline void set_array_base(ndarray arr, object base): # <<<<<<<<<<<<<< * cdef PyObject* baseptr * if base is None: */ static CYTHON_INLINE void __pyx_f_5numpy_set_array_base(PyArrayObject *__pyx_v_arr, PyObject *__pyx_v_base) { PyObject *__pyx_v_baseptr; __Pyx_RefNannyDeclarations int __pyx_t_1; __Pyx_RefNannySetupContext("set_array_base", 0); /* "numpy.pxd":967 * cdef inline void set_array_base(ndarray arr, object base): * cdef PyObject* baseptr * if base is None: # <<<<<<<<<<<<<< * baseptr = NULL * else: */ __pyx_t_1 = (__pyx_v_base == Py_None); if (__pyx_t_1) { /* "numpy.pxd":968 * cdef PyObject* baseptr * if base is None: * baseptr = NULL # <<<<<<<<<<<<<< * else: * Py_INCREF(base) # important to do this before decref below! */ __pyx_v_baseptr = NULL; goto __pyx_L3; } /*else*/ { /* "numpy.pxd":970 * baseptr = NULL * else: * Py_INCREF(base) # important to do this before decref below! # <<<<<<<<<<<<<< * baseptr = base * Py_XDECREF(arr.base) */ Py_INCREF(__pyx_v_base); /* "numpy.pxd":971 * else: * Py_INCREF(base) # important to do this before decref below! * baseptr = base # <<<<<<<<<<<<<< * Py_XDECREF(arr.base) * arr.base = baseptr */ __pyx_v_baseptr = ((PyObject *)__pyx_v_base); } __pyx_L3:; /* "numpy.pxd":972 * Py_INCREF(base) # important to do this before decref below! * baseptr = base * Py_XDECREF(arr.base) # <<<<<<<<<<<<<< * arr.base = baseptr * */ Py_XDECREF(__pyx_v_arr->base); /* "numpy.pxd":973 * baseptr = base * Py_XDECREF(arr.base) * arr.base = baseptr # <<<<<<<<<<<<<< * * cdef inline object get_array_base(ndarray arr): */ __pyx_v_arr->base = __pyx_v_baseptr; __Pyx_RefNannyFinishContext(); } /* "numpy.pxd":975 * arr.base = baseptr * * cdef inline object get_array_base(ndarray arr): # <<<<<<<<<<<<<< * if arr.base is NULL: * return None */ static CYTHON_INLINE PyObject *__pyx_f_5numpy_get_array_base(PyArrayObject *__pyx_v_arr) { PyObject *__pyx_r = NULL; __Pyx_RefNannyDeclarations int __pyx_t_1; __Pyx_RefNannySetupContext("get_array_base", 0); /* "numpy.pxd":976 * * cdef inline object get_array_base(ndarray arr): * if arr.base is NULL: # <<<<<<<<<<<<<< * return None * else: */ __pyx_t_1 = (__pyx_v_arr->base == NULL); if (__pyx_t_1) { /* "numpy.pxd":977 * cdef inline object get_array_base(ndarray arr): * if arr.base is NULL: * return None # <<<<<<<<<<<<<< * else: * return arr.base */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(Py_None); __pyx_r = Py_None; goto __pyx_L0; goto __pyx_L3; } /*else*/ { /* "numpy.pxd":979 * return None * else: * return arr.base # <<<<<<<<<<<<<< */ __Pyx_XDECREF(__pyx_r); __Pyx_INCREF(((PyObject *)__pyx_v_arr->base)); __pyx_r = ((PyObject *)__pyx_v_arr->base); goto __pyx_L0; } __pyx_L3:; __pyx_r = Py_None; __Pyx_INCREF(Py_None); __pyx_L0:; __Pyx_XGIVEREF(__pyx_r); __Pyx_RefNannyFinishContext(); return __pyx_r; } static PyObject *__pyx_tp_new_6tables_16indexesextension_Index(PyTypeObject *t, CYTHON_UNUSED PyObject *a, CYTHON_UNUSED PyObject *k) { PyObject *o = (*t->tp_alloc)(t, 0); if (!o) return 0; return o; } static void __pyx_tp_dealloc_6tables_16indexesextension_Index(PyObject *o) { (*Py_TYPE(o)->tp_free)(o); } static PyMethodDef __pyx_methods_6tables_16indexesextension_Index[] = { {0, 0, 0, 0} }; static PyNumberMethods __pyx_tp_as_number_Index = { 0, /*nb_add*/ 0, /*nb_subtract*/ 0, /*nb_multiply*/ #if PY_MAJOR_VERSION < 3 0, /*nb_divide*/ #endif 0, /*nb_remainder*/ 0, /*nb_divmod*/ 0, /*nb_power*/ 0, /*nb_negative*/ 0, /*nb_positive*/ 0, /*nb_absolute*/ 0, /*nb_nonzero*/ 0, /*nb_invert*/ 0, /*nb_lshift*/ 0, /*nb_rshift*/ 0, /*nb_and*/ 0, /*nb_xor*/ 0, /*nb_or*/ #if PY_MAJOR_VERSION < 3 0, /*nb_coerce*/ #endif 0, /*nb_int*/ #if PY_MAJOR_VERSION < 3 0, /*nb_long*/ #else 0, /*reserved*/ #endif 0, /*nb_float*/ #if PY_MAJOR_VERSION < 3 0, /*nb_oct*/ #endif #if PY_MAJOR_VERSION < 3 0, /*nb_hex*/ #endif 0, /*nb_inplace_add*/ 0, /*nb_inplace_subtract*/ 0, /*nb_inplace_multiply*/ #if PY_MAJOR_VERSION < 3 0, /*nb_inplace_divide*/ #endif 0, /*nb_inplace_remainder*/ 0, /*nb_inplace_power*/ 0, /*nb_inplace_lshift*/ 0, /*nb_inplace_rshift*/ 0, /*nb_inplace_and*/ 0, /*nb_inplace_xor*/ 0, /*nb_inplace_or*/ 0, /*nb_floor_divide*/ 0, /*nb_true_divide*/ 0, /*nb_inplace_floor_divide*/ 0, /*nb_inplace_true_divide*/ #if PY_VERSION_HEX >= 0x02050000 0, /*nb_index*/ #endif }; static PySequenceMethods __pyx_tp_as_sequence_Index = { 0, /*sq_length*/ 0, /*sq_concat*/ 0, /*sq_repeat*/ 0, /*sq_item*/ 0, /*sq_slice*/ 0, /*sq_ass_item*/ 0, /*sq_ass_slice*/ 0, /*sq_contains*/ 0, /*sq_inplace_concat*/ 0, /*sq_inplace_repeat*/ }; static PyMappingMethods __pyx_tp_as_mapping_Index = { 0, /*mp_length*/ 0, /*mp_subscript*/ 0, /*mp_ass_subscript*/ }; static PyBufferProcs __pyx_tp_as_buffer_Index = { #if PY_MAJOR_VERSION < 3 0, /*bf_getreadbuffer*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getwritebuffer*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getsegcount*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getcharbuffer*/ #endif #if PY_VERSION_HEX >= 0x02060000 0, /*bf_getbuffer*/ #endif #if PY_VERSION_HEX >= 0x02060000 0, /*bf_releasebuffer*/ #endif }; static PyTypeObject __pyx_type_6tables_16indexesextension_Index = { PyVarObject_HEAD_INIT(0, 0) __Pyx_NAMESTR("tables.indexesextension.Index"), /*tp_name*/ sizeof(struct __pyx_obj_6tables_16indexesextension_Index), /*tp_basicsize*/ 0, /*tp_itemsize*/ __pyx_tp_dealloc_6tables_16indexesextension_Index, /*tp_dealloc*/ 0, /*tp_print*/ 0, /*tp_getattr*/ 0, /*tp_setattr*/ #if PY_MAJOR_VERSION < 3 0, /*tp_compare*/ #else 0, /*reserved*/ #endif 0, /*tp_repr*/ &__pyx_tp_as_number_Index, /*tp_as_number*/ &__pyx_tp_as_sequence_Index, /*tp_as_sequence*/ &__pyx_tp_as_mapping_Index, /*tp_as_mapping*/ 0, /*tp_hash*/ 0, /*tp_call*/ 0, /*tp_str*/ 0, /*tp_getattro*/ 0, /*tp_setattro*/ &__pyx_tp_as_buffer_Index, /*tp_as_buffer*/ Py_TPFLAGS_DEFAULT|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE, /*tp_flags*/ 0, /*tp_doc*/ 0, /*tp_traverse*/ 0, /*tp_clear*/ 0, /*tp_richcompare*/ 0, /*tp_weaklistoffset*/ 0, /*tp_iter*/ 0, /*tp_iternext*/ __pyx_methods_6tables_16indexesextension_Index, /*tp_methods*/ 0, /*tp_members*/ 0, /*tp_getset*/ 0, /*tp_base*/ 0, /*tp_dict*/ 0, /*tp_descr_get*/ 0, /*tp_descr_set*/ 0, /*tp_dictoffset*/ 0, /*tp_init*/ 0, /*tp_alloc*/ __pyx_tp_new_6tables_16indexesextension_Index, /*tp_new*/ 0, /*tp_free*/ 0, /*tp_is_gc*/ 0, /*tp_bases*/ 0, /*tp_mro*/ 0, /*tp_cache*/ 0, /*tp_subclasses*/ 0, /*tp_weaklist*/ 0, /*tp_del*/ #if PY_VERSION_HEX >= 0x02060000 0, /*tp_version_tag*/ #endif }; static struct __pyx_vtabstruct_6tables_16indexesextension_CacheArray __pyx_vtable_6tables_16indexesextension_CacheArray; static PyObject *__pyx_tp_new_6tables_16indexesextension_CacheArray(PyTypeObject *t, PyObject *a, PyObject *k) { struct __pyx_obj_6tables_16indexesextension_CacheArray *p; PyObject *o = __pyx_ptype_6tables_13hdf5extension_Array->tp_new(t, a, k); if (!o) return 0; p = ((struct __pyx_obj_6tables_16indexesextension_CacheArray *)o); p->__pyx_base.__pyx_base.__pyx_vtab = (struct __pyx_vtabstruct_6tables_13hdf5extension_Leaf*)__pyx_vtabptr_6tables_16indexesextension_CacheArray; return o; } static void __pyx_tp_dealloc_6tables_16indexesextension_CacheArray(PyObject *o) { PyObject_GC_UnTrack(o); PyObject_GC_Track(o); if (likely(__pyx_ptype_6tables_13hdf5extension_Array)) __pyx_ptype_6tables_13hdf5extension_Array->tp_dealloc(o); else __Pyx_call_next_tp_dealloc(o, __pyx_tp_dealloc_6tables_16indexesextension_CacheArray); } static int __pyx_tp_traverse_6tables_16indexesextension_CacheArray(PyObject *o, visitproc v, void *a) { int e; e = ((likely(__pyx_ptype_6tables_13hdf5extension_Array)) ? ((__pyx_ptype_6tables_13hdf5extension_Array->tp_traverse) ? __pyx_ptype_6tables_13hdf5extension_Array->tp_traverse(o, v, a) : 0) : __Pyx_call_next_tp_traverse(o, v, a, __pyx_tp_traverse_6tables_16indexesextension_CacheArray)); if (e) return e; return 0; } static int __pyx_tp_clear_6tables_16indexesextension_CacheArray(PyObject *o) { if (likely(__pyx_ptype_6tables_13hdf5extension_Array)) { if (__pyx_ptype_6tables_13hdf5extension_Array->tp_clear) __pyx_ptype_6tables_13hdf5extension_Array->tp_clear(o); } else __Pyx_call_next_tp_clear(o, __pyx_tp_clear_6tables_16indexesextension_CacheArray); return 0; } static PyMethodDef __pyx_methods_6tables_16indexesextension_CacheArray[] = { {__Pyx_NAMESTR("_g_close"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10CacheArray_1_g_close, METH_NOARGS, __Pyx_DOCSTR(0)}, {0, 0, 0, 0} }; static PyNumberMethods __pyx_tp_as_number_CacheArray = { 0, /*nb_add*/ 0, /*nb_subtract*/ 0, /*nb_multiply*/ #if PY_MAJOR_VERSION < 3 0, /*nb_divide*/ #endif 0, /*nb_remainder*/ 0, /*nb_divmod*/ 0, /*nb_power*/ 0, /*nb_negative*/ 0, /*nb_positive*/ 0, /*nb_absolute*/ 0, /*nb_nonzero*/ 0, /*nb_invert*/ 0, /*nb_lshift*/ 0, /*nb_rshift*/ 0, /*nb_and*/ 0, /*nb_xor*/ 0, /*nb_or*/ #if PY_MAJOR_VERSION < 3 0, /*nb_coerce*/ #endif 0, /*nb_int*/ #if PY_MAJOR_VERSION < 3 0, /*nb_long*/ #else 0, /*reserved*/ #endif 0, /*nb_float*/ #if PY_MAJOR_VERSION < 3 0, /*nb_oct*/ #endif #if PY_MAJOR_VERSION < 3 0, /*nb_hex*/ #endif 0, /*nb_inplace_add*/ 0, /*nb_inplace_subtract*/ 0, /*nb_inplace_multiply*/ #if PY_MAJOR_VERSION < 3 0, /*nb_inplace_divide*/ #endif 0, /*nb_inplace_remainder*/ 0, /*nb_inplace_power*/ 0, /*nb_inplace_lshift*/ 0, /*nb_inplace_rshift*/ 0, /*nb_inplace_and*/ 0, /*nb_inplace_xor*/ 0, /*nb_inplace_or*/ 0, /*nb_floor_divide*/ 0, /*nb_true_divide*/ 0, /*nb_inplace_floor_divide*/ 0, /*nb_inplace_true_divide*/ #if PY_VERSION_HEX >= 0x02050000 0, /*nb_index*/ #endif }; static PySequenceMethods __pyx_tp_as_sequence_CacheArray = { 0, /*sq_length*/ 0, /*sq_concat*/ 0, /*sq_repeat*/ 0, /*sq_item*/ 0, /*sq_slice*/ 0, /*sq_ass_item*/ 0, /*sq_ass_slice*/ 0, /*sq_contains*/ 0, /*sq_inplace_concat*/ 0, /*sq_inplace_repeat*/ }; static PyMappingMethods __pyx_tp_as_mapping_CacheArray = { 0, /*mp_length*/ 0, /*mp_subscript*/ 0, /*mp_ass_subscript*/ }; static PyBufferProcs __pyx_tp_as_buffer_CacheArray = { #if PY_MAJOR_VERSION < 3 0, /*bf_getreadbuffer*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getwritebuffer*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getsegcount*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getcharbuffer*/ #endif #if PY_VERSION_HEX >= 0x02060000 0, /*bf_getbuffer*/ #endif #if PY_VERSION_HEX >= 0x02060000 0, /*bf_releasebuffer*/ #endif }; static PyTypeObject __pyx_type_6tables_16indexesextension_CacheArray = { PyVarObject_HEAD_INIT(0, 0) __Pyx_NAMESTR("tables.indexesextension.CacheArray"), /*tp_name*/ sizeof(struct __pyx_obj_6tables_16indexesextension_CacheArray), /*tp_basicsize*/ 0, /*tp_itemsize*/ __pyx_tp_dealloc_6tables_16indexesextension_CacheArray, /*tp_dealloc*/ 0, /*tp_print*/ 0, /*tp_getattr*/ 0, /*tp_setattr*/ #if PY_MAJOR_VERSION < 3 0, /*tp_compare*/ #else 0, /*reserved*/ #endif 0, /*tp_repr*/ &__pyx_tp_as_number_CacheArray, /*tp_as_number*/ &__pyx_tp_as_sequence_CacheArray, /*tp_as_sequence*/ &__pyx_tp_as_mapping_CacheArray, /*tp_as_mapping*/ 0, /*tp_hash*/ 0, /*tp_call*/ 0, /*tp_str*/ 0, /*tp_getattro*/ 0, /*tp_setattro*/ &__pyx_tp_as_buffer_CacheArray, /*tp_as_buffer*/ Py_TPFLAGS_DEFAULT|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/ __Pyx_DOCSTR("Container for keeping index caches of 1st and 2nd level."), /*tp_doc*/ __pyx_tp_traverse_6tables_16indexesextension_CacheArray, /*tp_traverse*/ __pyx_tp_clear_6tables_16indexesextension_CacheArray, /*tp_clear*/ 0, /*tp_richcompare*/ 0, /*tp_weaklistoffset*/ 0, /*tp_iter*/ 0, /*tp_iternext*/ __pyx_methods_6tables_16indexesextension_CacheArray, /*tp_methods*/ 0, /*tp_members*/ 0, /*tp_getset*/ 0, /*tp_base*/ 0, /*tp_dict*/ 0, /*tp_descr_get*/ 0, /*tp_descr_set*/ 0, /*tp_dictoffset*/ 0, /*tp_init*/ 0, /*tp_alloc*/ __pyx_tp_new_6tables_16indexesextension_CacheArray, /*tp_new*/ 0, /*tp_free*/ 0, /*tp_is_gc*/ 0, /*tp_bases*/ 0, /*tp_mro*/ 0, /*tp_cache*/ 0, /*tp_subclasses*/ 0, /*tp_weaklist*/ 0, /*tp_del*/ #if PY_VERSION_HEX >= 0x02060000 0, /*tp_version_tag*/ #endif }; static struct __pyx_vtabstruct_6tables_16indexesextension_IndexArray __pyx_vtable_6tables_16indexesextension_IndexArray; static PyObject *__pyx_tp_new_6tables_16indexesextension_IndexArray(PyTypeObject *t, PyObject *a, PyObject *k) { struct __pyx_obj_6tables_16indexesextension_IndexArray *p; PyObject *o = __pyx_ptype_6tables_13hdf5extension_Array->tp_new(t, a, k); if (!o) return 0; p = ((struct __pyx_obj_6tables_16indexesextension_IndexArray *)o); p->__pyx_base.__pyx_base.__pyx_vtab = (struct __pyx_vtabstruct_6tables_13hdf5extension_Leaf*)__pyx_vtabptr_6tables_16indexesextension_IndexArray; p->bounds_ext = ((struct __pyx_obj_6tables_16indexesextension_CacheArray *)Py_None); Py_INCREF(Py_None); p->boundscache = ((struct __pyx_obj_6tables_17lrucacheextension_NumCache *)Py_None); Py_INCREF(Py_None); p->sortedcache = ((struct __pyx_obj_6tables_17lrucacheextension_NumCache *)Py_None); Py_INCREF(Py_None); p->bufferbc = ((PyArrayObject *)Py_None); Py_INCREF(Py_None); p->bufferlb = ((PyArrayObject *)Py_None); Py_INCREF(Py_None); return o; } static void __pyx_tp_dealloc_6tables_16indexesextension_IndexArray(PyObject *o) { struct __pyx_obj_6tables_16indexesextension_IndexArray *p = (struct __pyx_obj_6tables_16indexesextension_IndexArray *)o; PyObject_GC_UnTrack(o); Py_CLEAR(p->bounds_ext); Py_CLEAR(p->boundscache); Py_CLEAR(p->sortedcache); Py_CLEAR(p->bufferbc); Py_CLEAR(p->bufferlb); PyObject_GC_Track(o); if (likely(__pyx_ptype_6tables_13hdf5extension_Array)) __pyx_ptype_6tables_13hdf5extension_Array->tp_dealloc(o); else __Pyx_call_next_tp_dealloc(o, __pyx_tp_dealloc_6tables_16indexesextension_IndexArray); } static int __pyx_tp_traverse_6tables_16indexesextension_IndexArray(PyObject *o, visitproc v, void *a) { int e; struct __pyx_obj_6tables_16indexesextension_IndexArray *p = (struct __pyx_obj_6tables_16indexesextension_IndexArray *)o; e = ((likely(__pyx_ptype_6tables_13hdf5extension_Array)) ? ((__pyx_ptype_6tables_13hdf5extension_Array->tp_traverse) ? __pyx_ptype_6tables_13hdf5extension_Array->tp_traverse(o, v, a) : 0) : __Pyx_call_next_tp_traverse(o, v, a, __pyx_tp_traverse_6tables_16indexesextension_IndexArray)); if (e) return e; if (p->bounds_ext) { e = (*v)(((PyObject*)p->bounds_ext), a); if (e) return e; } if (p->boundscache) { e = (*v)(((PyObject*)p->boundscache), a); if (e) return e; } if (p->sortedcache) { e = (*v)(((PyObject*)p->sortedcache), a); if (e) return e; } if (p->bufferbc) { e = (*v)(((PyObject*)p->bufferbc), a); if (e) return e; } if (p->bufferlb) { e = (*v)(((PyObject*)p->bufferlb), a); if (e) return e; } return 0; } static int __pyx_tp_clear_6tables_16indexesextension_IndexArray(PyObject *o) { struct __pyx_obj_6tables_16indexesextension_IndexArray *p = (struct __pyx_obj_6tables_16indexesextension_IndexArray *)o; PyObject* tmp; if (likely(__pyx_ptype_6tables_13hdf5extension_Array)) { if (__pyx_ptype_6tables_13hdf5extension_Array->tp_clear) __pyx_ptype_6tables_13hdf5extension_Array->tp_clear(o); } else __Pyx_call_next_tp_clear(o, __pyx_tp_clear_6tables_16indexesextension_IndexArray); tmp = ((PyObject*)p->bounds_ext); p->bounds_ext = ((struct __pyx_obj_6tables_16indexesextension_CacheArray *)Py_None); Py_INCREF(Py_None); Py_XDECREF(tmp); tmp = ((PyObject*)p->boundscache); p->boundscache = ((struct __pyx_obj_6tables_17lrucacheextension_NumCache *)Py_None); Py_INCREF(Py_None); Py_XDECREF(tmp); tmp = ((PyObject*)p->sortedcache); p->sortedcache = ((struct __pyx_obj_6tables_17lrucacheextension_NumCache *)Py_None); Py_INCREF(Py_None); Py_XDECREF(tmp); tmp = ((PyObject*)p->bufferbc); p->bufferbc = ((PyArrayObject *)Py_None); Py_INCREF(Py_None); Py_XDECREF(tmp); tmp = ((PyObject*)p->bufferlb); p->bufferlb = ((PyArrayObject *)Py_None); Py_INCREF(Py_None); Py_XDECREF(tmp); return 0; } static PyMethodDef __pyx_methods_6tables_16indexesextension_IndexArray[] = { {__Pyx_NAMESTR("_read_index_slice"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_1_read_index_slice, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_init_sorted_slice"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_3_init_sorted_slice, METH_O, __Pyx_DOCSTR(__pyx_doc_6tables_16indexesextension_10IndexArray_2_init_sorted_slice)}, {__Pyx_NAMESTR("_read_sorted_slice"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_5_read_sorted_slice, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_6tables_16indexesextension_10IndexArray_4_read_sorted_slice)}, {__Pyx_NAMESTR("_bisect_left"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_7_bisect_left, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_6tables_16indexesextension_10IndexArray_6_bisect_left)}, {__Pyx_NAMESTR("_bisect_right"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_9_bisect_right, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_6tables_16indexesextension_10IndexArray_8_bisect_right)}, {__Pyx_NAMESTR("_search_bin_na_b"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_11_search_bin_na_b, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_ub"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_13_search_bin_na_ub, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_s"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_15_search_bin_na_s, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_us"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_17_search_bin_na_us, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_i"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_19_search_bin_na_i, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_ui"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_21_search_bin_na_ui, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_ll"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_23_search_bin_na_ll, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_ull"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_25_search_bin_na_ull, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_e"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_27_search_bin_na_e, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_f"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_29_search_bin_na_f, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_d"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_31_search_bin_na_d, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_search_bin_na_g"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_33_search_bin_na_g, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)}, {__Pyx_NAMESTR("_g_close"), (PyCFunction)__pyx_pw_6tables_16indexesextension_10IndexArray_35_g_close, METH_NOARGS, __Pyx_DOCSTR(0)}, {0, 0, 0, 0} }; static PyNumberMethods __pyx_tp_as_number_IndexArray = { 0, /*nb_add*/ 0, /*nb_subtract*/ 0, /*nb_multiply*/ #if PY_MAJOR_VERSION < 3 0, /*nb_divide*/ #endif 0, /*nb_remainder*/ 0, /*nb_divmod*/ 0, /*nb_power*/ 0, /*nb_negative*/ 0, /*nb_positive*/ 0, /*nb_absolute*/ 0, /*nb_nonzero*/ 0, /*nb_invert*/ 0, /*nb_lshift*/ 0, /*nb_rshift*/ 0, /*nb_and*/ 0, /*nb_xor*/ 0, /*nb_or*/ #if PY_MAJOR_VERSION < 3 0, /*nb_coerce*/ #endif 0, /*nb_int*/ #if PY_MAJOR_VERSION < 3 0, /*nb_long*/ #else 0, /*reserved*/ #endif 0, /*nb_float*/ #if PY_MAJOR_VERSION < 3 0, /*nb_oct*/ #endif #if PY_MAJOR_VERSION < 3 0, /*nb_hex*/ #endif 0, /*nb_inplace_add*/ 0, /*nb_inplace_subtract*/ 0, /*nb_inplace_multiply*/ #if PY_MAJOR_VERSION < 3 0, /*nb_inplace_divide*/ #endif 0, /*nb_inplace_remainder*/ 0, /*nb_inplace_power*/ 0, /*nb_inplace_lshift*/ 0, /*nb_inplace_rshift*/ 0, /*nb_inplace_and*/ 0, /*nb_inplace_xor*/ 0, /*nb_inplace_or*/ 0, /*nb_floor_divide*/ 0, /*nb_true_divide*/ 0, /*nb_inplace_floor_divide*/ 0, /*nb_inplace_true_divide*/ #if PY_VERSION_HEX >= 0x02050000 0, /*nb_index*/ #endif }; static PySequenceMethods __pyx_tp_as_sequence_IndexArray = { 0, /*sq_length*/ 0, /*sq_concat*/ 0, /*sq_repeat*/ 0, /*sq_item*/ 0, /*sq_slice*/ 0, /*sq_ass_item*/ 0, /*sq_ass_slice*/ 0, /*sq_contains*/ 0, /*sq_inplace_concat*/ 0, /*sq_inplace_repeat*/ }; static PyMappingMethods __pyx_tp_as_mapping_IndexArray = { 0, /*mp_length*/ 0, /*mp_subscript*/ 0, /*mp_ass_subscript*/ }; static PyBufferProcs __pyx_tp_as_buffer_IndexArray = { #if PY_MAJOR_VERSION < 3 0, /*bf_getreadbuffer*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getwritebuffer*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getsegcount*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getcharbuffer*/ #endif #if PY_VERSION_HEX >= 0x02060000 0, /*bf_getbuffer*/ #endif #if PY_VERSION_HEX >= 0x02060000 0, /*bf_releasebuffer*/ #endif }; static PyTypeObject __pyx_type_6tables_16indexesextension_IndexArray = { PyVarObject_HEAD_INIT(0, 0) __Pyx_NAMESTR("tables.indexesextension.IndexArray"), /*tp_name*/ sizeof(struct __pyx_obj_6tables_16indexesextension_IndexArray), /*tp_basicsize*/ 0, /*tp_itemsize*/ __pyx_tp_dealloc_6tables_16indexesextension_IndexArray, /*tp_dealloc*/ 0, /*tp_print*/ 0, /*tp_getattr*/ 0, /*tp_setattr*/ #if PY_MAJOR_VERSION < 3 0, /*tp_compare*/ #else 0, /*reserved*/ #endif 0, /*tp_repr*/ &__pyx_tp_as_number_IndexArray, /*tp_as_number*/ &__pyx_tp_as_sequence_IndexArray, /*tp_as_sequence*/ &__pyx_tp_as_mapping_IndexArray, /*tp_as_mapping*/ 0, /*tp_hash*/ 0, /*tp_call*/ 0, /*tp_str*/ 0, /*tp_getattro*/ 0, /*tp_setattro*/ &__pyx_tp_as_buffer_IndexArray, /*tp_as_buffer*/ Py_TPFLAGS_DEFAULT|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/ __Pyx_DOCSTR("Container for keeping sorted and indices values."), /*tp_doc*/ __pyx_tp_traverse_6tables_16indexesextension_IndexArray, /*tp_traverse*/ __pyx_tp_clear_6tables_16indexesextension_IndexArray, /*tp_clear*/ 0, /*tp_richcompare*/ 0, /*tp_weaklistoffset*/ 0, /*tp_iter*/ 0, /*tp_iternext*/ __pyx_methods_6tables_16indexesextension_IndexArray, /*tp_methods*/ 0, /*tp_members*/ 0, /*tp_getset*/ 0, /*tp_base*/ 0, /*tp_dict*/ 0, /*tp_descr_get*/ 0, /*tp_descr_set*/ 0, /*tp_dictoffset*/ 0, /*tp_init*/ 0, /*tp_alloc*/ __pyx_tp_new_6tables_16indexesextension_IndexArray, /*tp_new*/ 0, /*tp_free*/ 0, /*tp_is_gc*/ 0, /*tp_bases*/ 0, /*tp_mro*/ 0, /*tp_cache*/ 0, /*tp_subclasses*/ 0, /*tp_weaklist*/ 0, /*tp_del*/ #if PY_VERSION_HEX >= 0x02060000 0, /*tp_version_tag*/ #endif }; static struct __pyx_vtabstruct_6tables_16indexesextension_LastRowArray __pyx_vtable_6tables_16indexesextension_LastRowArray; static PyObject *__pyx_tp_new_6tables_16indexesextension_LastRowArray(PyTypeObject *t, PyObject *a, PyObject *k) { struct __pyx_obj_6tables_16indexesextension_LastRowArray *p; PyObject *o = __pyx_ptype_6tables_13hdf5extension_Array->tp_new(t, a, k); if (!o) return 0; p = ((struct __pyx_obj_6tables_16indexesextension_LastRowArray *)o); p->__pyx_base.__pyx_base.__pyx_vtab = (struct __pyx_vtabstruct_6tables_13hdf5extension_Leaf*)__pyx_vtabptr_6tables_16indexesextension_LastRowArray; return o; } static void __pyx_tp_dealloc_6tables_16indexesextension_LastRowArray(PyObject *o) { PyObject_GC_UnTrack(o); PyObject_GC_Track(o); if (likely(__pyx_ptype_6tables_13hdf5extension_Array)) __pyx_ptype_6tables_13hdf5extension_Array->tp_dealloc(o); else __Pyx_call_next_tp_dealloc(o, __pyx_tp_dealloc_6tables_16indexesextension_LastRowArray); } static int __pyx_tp_traverse_6tables_16indexesextension_LastRowArray(PyObject *o, visitproc v, void *a) { int e; e = ((likely(__pyx_ptype_6tables_13hdf5extension_Array)) ? ((__pyx_ptype_6tables_13hdf5extension_Array->tp_traverse) ? __pyx_ptype_6tables_13hdf5extension_Array->tp_traverse(o, v, a) : 0) : __Pyx_call_next_tp_traverse(o, v, a, __pyx_tp_traverse_6tables_16indexesextension_LastRowArray)); if (e) return e; return 0; } static int __pyx_tp_clear_6tables_16indexesextension_LastRowArray(PyObject *o) { if (likely(__pyx_ptype_6tables_13hdf5extension_Array)) { if (__pyx_ptype_6tables_13hdf5extension_Array->tp_clear) __pyx_ptype_6tables_13hdf5extension_Array->tp_clear(o); } else __Pyx_call_next_tp_clear(o, __pyx_tp_clear_6tables_16indexesextension_LastRowArray); return 0; } static PyMethodDef __pyx_methods_6tables_16indexesextension_LastRowArray[] = { {__Pyx_NAMESTR("_read_index_slice"), (PyCFunction)__pyx_pw_6tables_16indexesextension_12LastRowArray_1_read_index_slice, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_6tables_16indexesextension_12LastRowArray__read_index_slice)}, {__Pyx_NAMESTR("_read_sorted_slice"), (PyCFunction)__pyx_pw_6tables_16indexesextension_12LastRowArray_3_read_sorted_slice, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(__pyx_doc_6tables_16indexesextension_12LastRowArray_2_read_sorted_slice)}, {0, 0, 0, 0} }; static PyNumberMethods __pyx_tp_as_number_LastRowArray = { 0, /*nb_add*/ 0, /*nb_subtract*/ 0, /*nb_multiply*/ #if PY_MAJOR_VERSION < 3 0, /*nb_divide*/ #endif 0, /*nb_remainder*/ 0, /*nb_divmod*/ 0, /*nb_power*/ 0, /*nb_negative*/ 0, /*nb_positive*/ 0, /*nb_absolute*/ 0, /*nb_nonzero*/ 0, /*nb_invert*/ 0, /*nb_lshift*/ 0, /*nb_rshift*/ 0, /*nb_and*/ 0, /*nb_xor*/ 0, /*nb_or*/ #if PY_MAJOR_VERSION < 3 0, /*nb_coerce*/ #endif 0, /*nb_int*/ #if PY_MAJOR_VERSION < 3 0, /*nb_long*/ #else 0, /*reserved*/ #endif 0, /*nb_float*/ #if PY_MAJOR_VERSION < 3 0, /*nb_oct*/ #endif #if PY_MAJOR_VERSION < 3 0, /*nb_hex*/ #endif 0, /*nb_inplace_add*/ 0, /*nb_inplace_subtract*/ 0, /*nb_inplace_multiply*/ #if PY_MAJOR_VERSION < 3 0, /*nb_inplace_divide*/ #endif 0, /*nb_inplace_remainder*/ 0, /*nb_inplace_power*/ 0, /*nb_inplace_lshift*/ 0, /*nb_inplace_rshift*/ 0, /*nb_inplace_and*/ 0, /*nb_inplace_xor*/ 0, /*nb_inplace_or*/ 0, /*nb_floor_divide*/ 0, /*nb_true_divide*/ 0, /*nb_inplace_floor_divide*/ 0, /*nb_inplace_true_divide*/ #if PY_VERSION_HEX >= 0x02050000 0, /*nb_index*/ #endif }; static PySequenceMethods __pyx_tp_as_sequence_LastRowArray = { 0, /*sq_length*/ 0, /*sq_concat*/ 0, /*sq_repeat*/ 0, /*sq_item*/ 0, /*sq_slice*/ 0, /*sq_ass_item*/ 0, /*sq_ass_slice*/ 0, /*sq_contains*/ 0, /*sq_inplace_concat*/ 0, /*sq_inplace_repeat*/ }; static PyMappingMethods __pyx_tp_as_mapping_LastRowArray = { 0, /*mp_length*/ 0, /*mp_subscript*/ 0, /*mp_ass_subscript*/ }; static PyBufferProcs __pyx_tp_as_buffer_LastRowArray = { #if PY_MAJOR_VERSION < 3 0, /*bf_getreadbuffer*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getwritebuffer*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getsegcount*/ #endif #if PY_MAJOR_VERSION < 3 0, /*bf_getcharbuffer*/ #endif #if PY_VERSION_HEX >= 0x02060000 0, /*bf_getbuffer*/ #endif #if PY_VERSION_HEX >= 0x02060000 0, /*bf_releasebuffer*/ #endif }; static PyTypeObject __pyx_type_6tables_16indexesextension_LastRowArray = { PyVarObject_HEAD_INIT(0, 0) __Pyx_NAMESTR("tables.indexesextension.LastRowArray"), /*tp_name*/ sizeof(struct __pyx_obj_6tables_16indexesextension_LastRowArray), /*tp_basicsize*/ 0, /*tp_itemsize*/ __pyx_tp_dealloc_6tables_16indexesextension_LastRowArray, /*tp_dealloc*/ 0, /*tp_print*/ 0, /*tp_getattr*/ 0, /*tp_setattr*/ #if PY_MAJOR_VERSION < 3 0, /*tp_compare*/ #else 0, /*reserved*/ #endif 0, /*tp_repr*/ &__pyx_tp_as_number_LastRowArray, /*tp_as_number*/ &__pyx_tp_as_sequence_LastRowArray, /*tp_as_sequence*/ &__pyx_tp_as_mapping_LastRowArray, /*tp_as_mapping*/ 0, /*tp_hash*/ 0, /*tp_call*/ 0, /*tp_str*/ 0, /*tp_getattro*/ 0, /*tp_setattro*/ &__pyx_tp_as_buffer_LastRowArray, /*tp_as_buffer*/ Py_TPFLAGS_DEFAULT|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/ __Pyx_DOCSTR("\n Container for keeping sorted and indices values of last rows of an index.\n "), /*tp_doc*/ __pyx_tp_traverse_6tables_16indexesextension_LastRowArray, /*tp_traverse*/ __pyx_tp_clear_6tables_16indexesextension_LastRowArray, /*tp_clear*/ 0, /*tp_richcompare*/ 0, /*tp_weaklistoffset*/ 0, /*tp_iter*/ 0, /*tp_iternext*/ __pyx_methods_6tables_16indexesextension_LastRowArray, /*tp_methods*/ 0, /*tp_members*/ 0, /*tp_getset*/ 0, /*tp_base*/ 0, /*tp_dict*/ 0, /*tp_descr_get*/ 0, /*tp_descr_set*/ 0, /*tp_dictoffset*/ 0, /*tp_init*/ 0, /*tp_alloc*/ __pyx_tp_new_6tables_16indexesextension_LastRowArray, /*tp_new*/ 0, /*tp_free*/ 0, /*tp_is_gc*/ 0, /*tp_bases*/ 0, /*tp_mro*/ 0, /*tp_cache*/ 0, /*tp_subclasses*/ 0, /*tp_weaklist*/ 0, /*tp_del*/ #if PY_VERSION_HEX >= 0x02060000 0, /*tp_version_tag*/ #endif }; static PyMethodDef __pyx_methods[] = { {0, 0, 0, 0} }; #if PY_MAJOR_VERSION >= 3 static struct PyModuleDef __pyx_moduledef = { PyModuleDef_HEAD_INIT, __Pyx_NAMESTR("indexesextension"), __Pyx_DOCSTR(__pyx_k_28), /* m_doc */ -1, /* m_size */ __pyx_methods /* m_methods */, NULL, /* m_reload */ NULL, /* m_traverse */ NULL, /* m_clear */ NULL /* m_free */ }; #endif static __Pyx_StringTabEntry __pyx_string_tab[] = { {&__pyx_kp_s_1, __pyx_k_1, sizeof(__pyx_k_1), 0, 0, 1, 0}, {&__pyx_kp_s_10, __pyx_k_10, sizeof(__pyx_k_10), 0, 0, 1, 0}, {&__pyx_kp_s_12, __pyx_k_12, sizeof(__pyx_k_12), 0, 0, 1, 0}, {&__pyx_kp_s_14, __pyx_k_14, sizeof(__pyx_k_14), 0, 0, 1, 0}, {&__pyx_kp_u_16, __pyx_k_16, sizeof(__pyx_k_16), 0, 1, 0, 0}, {&__pyx_kp_u_18, __pyx_k_18, sizeof(__pyx_k_18), 0, 1, 0, 0}, {&__pyx_kp_u_20, __pyx_k_20, sizeof(__pyx_k_20), 0, 1, 0, 0}, {&__pyx_kp_u_22, __pyx_k_22, sizeof(__pyx_k_22), 0, 1, 0, 0}, {&__pyx_kp_u_23, __pyx_k_23, sizeof(__pyx_k_23), 0, 1, 0, 0}, {&__pyx_kp_u_26, __pyx_k_26, sizeof(__pyx_k_26), 0, 1, 0, 0}, {&__pyx_n_s_29, __pyx_k_29, sizeof(__pyx_k_29), 0, 0, 1, 1}, {&__pyx_kp_s_3, __pyx_k_3, sizeof(__pyx_k_3), 0, 0, 1, 0}, {&__pyx_n_s_30, __pyx_k_30, sizeof(__pyx_k_30), 0, 0, 1, 1}, {&__pyx_kp_s_33, __pyx_k_33, sizeof(__pyx_k_33), 0, 0, 1, 0}, {&__pyx_n_s_34, __pyx_k_34, sizeof(__pyx_k_34), 0, 0, 1, 1}, {&__pyx_kp_s_5, __pyx_k_5, sizeof(__pyx_k_5), 0, 0, 1, 0}, {&__pyx_kp_s_7, __pyx_k_7, sizeof(__pyx_k_7), 0, 0, 1, 0}, {&__pyx_kp_s_9, __pyx_k_9, sizeof(__pyx_k_9), 0, 0, 1, 0}, {&__pyx_n_s__BOUNDS_MAX_SIZE, __pyx_k__BOUNDS_MAX_SIZE, sizeof(__pyx_k__BOUNDS_MAX_SIZE), 0, 0, 1, 1}, {&__pyx_n_s__HDF5ExtError, __pyx_k__HDF5ExtError, sizeof(__pyx_k__HDF5ExtError), 0, 0, 1, 1}, {&__pyx_n_s__RuntimeError, __pyx_k__RuntimeError, sizeof(__pyx_k__RuntimeError), 0, 0, 1, 1}, {&__pyx_n_s__S, __pyx_k__S, sizeof(__pyx_k__S), 0, 0, 1, 1}, {&__pyx_n_s__SORTED_MAX_SIZE, __pyx_k__SORTED_MAX_SIZE, sizeof(__pyx_k__SORTED_MAX_SIZE), 0, 0, 1, 1}, {&__pyx_n_s__ValueError, __pyx_k__ValueError, sizeof(__pyx_k__ValueError), 0, 0, 1, 1}, {&__pyx_n_s____main__, __pyx_k____main__, sizeof(__pyx_k____main__), 0, 0, 1, 1}, {&__pyx_n_s____test__, __pyx_k____test__, sizeof(__pyx_k____test__), 0, 0, 1, 1}, {&__pyx_n_s___g_close, __pyx_k___g_close, sizeof(__pyx_k___g_close), 0, 0, 1, 1}, {&__pyx_n_s___initSortedSlice, __pyx_k___initSortedSlice, sizeof(__pyx_k___initSortedSlice), 0, 0, 1, 1}, {&__pyx_n_s___init_sorted_slice, __pyx_k___init_sorted_slice, sizeof(__pyx_k___init_sorted_slice), 0, 0, 1, 1}, {&__pyx_n_s___readIndexSlice, __pyx_k___readIndexSlice, sizeof(__pyx_k___readIndexSlice), 0, 0, 1, 1}, {&__pyx_n_s___readSortedSlice, __pyx_k___readSortedSlice, sizeof(__pyx_k___readSortedSlice), 0, 0, 1, 1}, {&__pyx_n_s___read_index_slice, __pyx_k___read_index_slice, sizeof(__pyx_k___read_index_slice), 0, 0, 1, 1}, {&__pyx_n_s___read_sorted_slice, __pyx_k___read_sorted_slice, sizeof(__pyx_k___read_sorted_slice), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_b, __pyx_k___searchBinNA_b, sizeof(__pyx_k___searchBinNA_b), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_d, __pyx_k___searchBinNA_d, sizeof(__pyx_k___searchBinNA_d), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_e, __pyx_k___searchBinNA_e, sizeof(__pyx_k___searchBinNA_e), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_f, __pyx_k___searchBinNA_f, sizeof(__pyx_k___searchBinNA_f), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_g, __pyx_k___searchBinNA_g, sizeof(__pyx_k___searchBinNA_g), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_i, __pyx_k___searchBinNA_i, sizeof(__pyx_k___searchBinNA_i), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_ll, __pyx_k___searchBinNA_ll, sizeof(__pyx_k___searchBinNA_ll), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_s, __pyx_k___searchBinNA_s, sizeof(__pyx_k___searchBinNA_s), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_ub, __pyx_k___searchBinNA_ub, sizeof(__pyx_k___searchBinNA_ub), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_ui, __pyx_k___searchBinNA_ui, sizeof(__pyx_k___searchBinNA_ui), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_ull, __pyx_k___searchBinNA_ull, sizeof(__pyx_k___searchBinNA_ull), 0, 0, 1, 1}, {&__pyx_n_s___searchBinNA_us, __pyx_k___searchBinNA_us, sizeof(__pyx_k___searchBinNA_us), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_b, __pyx_k___search_bin_na_b, sizeof(__pyx_k___search_bin_na_b), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_d, __pyx_k___search_bin_na_d, sizeof(__pyx_k___search_bin_na_d), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_e, __pyx_k___search_bin_na_e, sizeof(__pyx_k___search_bin_na_e), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_f, __pyx_k___search_bin_na_f, sizeof(__pyx_k___search_bin_na_f), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_g, __pyx_k___search_bin_na_g, sizeof(__pyx_k___search_bin_na_g), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_i, __pyx_k___search_bin_na_i, sizeof(__pyx_k___search_bin_na_i), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_ll, __pyx_k___search_bin_na_ll, sizeof(__pyx_k___search_bin_na_ll), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_s, __pyx_k___search_bin_na_s, sizeof(__pyx_k___search_bin_na_s), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_ub, __pyx_k___search_bin_na_ub, sizeof(__pyx_k___search_bin_na_ub), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_ui, __pyx_k___search_bin_na_ui, sizeof(__pyx_k___search_bin_na_ui), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_ull, __pyx_k___search_bin_na_ull, sizeof(__pyx_k___search_bin_na_ull), 0, 0, 1, 1}, {&__pyx_n_s___search_bin_na_us, __pyx_k___search_bin_na_us, sizeof(__pyx_k___search_bin_na_us), 0, 0, 1, 1}, {&__pyx_n_s___v_chunkshape, __pyx_k___v_chunkshape, sizeof(__pyx_k___v_chunkshape), 0, 0, 1, 1}, {&__pyx_n_s___v_file, __pyx_k___v_file, sizeof(__pyx_k___v_file), 0, 0, 1, 1}, {&__pyx_n_s___v_parent, __pyx_k___v_parent, sizeof(__pyx_k___v_parent), 0, 0, 1, 1}, {&__pyx_n_s__a, __pyx_k__a, sizeof(__pyx_k__a), 0, 0, 1, 1}, {&__pyx_n_s__array1, __pyx_k__array1, sizeof(__pyx_k__array1), 0, 0, 1, 1}, {&__pyx_n_s__array2, __pyx_k__array2, sizeof(__pyx_k__array2), 0, 0, 1, 1}, {&__pyx_n_s__atom, __pyx_k__atom, sizeof(__pyx_k__atom), 0, 0, 1, 1}, {&__pyx_n_s__bool, __pyx_k__bool, sizeof(__pyx_k__bool), 0, 0, 1, 1}, {&__pyx_n_s__bounds, __pyx_k__bounds, sizeof(__pyx_k__bounds), 0, 0, 1, 1}, {&__pyx_n_s__char, __pyx_k__char, sizeof(__pyx_k__char), 0, 0, 1, 1}, {&__pyx_n_s__chunksize, __pyx_k__chunksize, sizeof(__pyx_k__chunksize), 0, 0, 1, 1}, {&__pyx_n_s__dtype, __pyx_k__dtype, sizeof(__pyx_k__dtype), 0, 0, 1, 1}, {&__pyx_n_s__elsize1, __pyx_k__elsize1, sizeof(__pyx_k__elsize1), 0, 0, 1, 1}, {&__pyx_n_s__elsize2, __pyx_k__elsize2, sizeof(__pyx_k__elsize2), 0, 0, 1, 1}, {&__pyx_n_s__empty, __pyx_k__empty, sizeof(__pyx_k__empty), 0, 0, 1, 1}, {&__pyx_n_s__float128, __pyx_k__float128, sizeof(__pyx_k__float128), 0, 0, 1, 1}, {&__pyx_n_s__float16, __pyx_k__float16, sizeof(__pyx_k__float16), 0, 0, 1, 1}, {&__pyx_n_s__float32, __pyx_k__float32, sizeof(__pyx_k__float32), 0, 0, 1, 1}, {&__pyx_n_s__float64, __pyx_k__float64, sizeof(__pyx_k__float64), 0, 0, 1, 1}, {&__pyx_n_s__float96, __pyx_k__float96, sizeof(__pyx_k__float96), 0, 0, 1, 1}, {&__pyx_n_s__hi, __pyx_k__hi, sizeof(__pyx_k__hi), 0, 0, 1, 1}, {&__pyx_n_s__idx, __pyx_k__idx, sizeof(__pyx_k__idx), 0, 0, 1, 1}, {&__pyx_n_s__int16, __pyx_k__int16, sizeof(__pyx_k__int16), 0, 0, 1, 1}, {&__pyx_n_s__int32, __pyx_k__int32, sizeof(__pyx_k__int32), 0, 0, 1, 1}, {&__pyx_n_s__int64, __pyx_k__int64, sizeof(__pyx_k__int64), 0, 0, 1, 1}, {&__pyx_n_s__int8, __pyx_k__int8, sizeof(__pyx_k__int8), 0, 0, 1, 1}, {&__pyx_n_s__irow, __pyx_k__irow, sizeof(__pyx_k__irow), 0, 0, 1, 1}, {&__pyx_n_s__item1, __pyx_k__item1, sizeof(__pyx_k__item1), 0, 0, 1, 1}, {&__pyx_n_s__item2, __pyx_k__item2, sizeof(__pyx_k__item2), 0, 0, 1, 1}, {&__pyx_n_s__itemsize, __pyx_k__itemsize, sizeof(__pyx_k__itemsize), 0, 0, 1, 1}, {&__pyx_n_s__keysort, __pyx_k__keysort, sizeof(__pyx_k__keysort), 0, 0, 1, 1}, {&__pyx_n_s__lengths, __pyx_k__lengths, sizeof(__pyx_k__lengths), 0, 0, 1, 1}, {&__pyx_n_s__name, __pyx_k__name, sizeof(__pyx_k__name), 0, 0, 1, 1}, {&__pyx_n_s__nrows, __pyx_k__nrows, sizeof(__pyx_k__nrows), 0, 0, 1, 1}, {&__pyx_n_s__numpy, __pyx_k__numpy, sizeof(__pyx_k__numpy), 0, 0, 1, 1}, {&__pyx_n_s__opt_search_types, __pyx_k__opt_search_types, sizeof(__pyx_k__opt_search_types), 0, 0, 1, 1}, {&__pyx_n_s__params, __pyx_k__params, sizeof(__pyx_k__params), 0, 0, 1, 1}, {&__pyx_n_s__previous_api, __pyx_k__previous_api, sizeof(__pyx_k__previous_api), 0, 0, 1, 1}, {&__pyx_n_s__range, __pyx_k__range, sizeof(__pyx_k__range), 0, 0, 1, 1}, {&__pyx_n_s__ranges, __pyx_k__ranges, sizeof(__pyx_k__ranges), 0, 0, 1, 1}, {&__pyx_n_s__rvcache, __pyx_k__rvcache, sizeof(__pyx_k__rvcache), 0, 0, 1, 1}, {&__pyx_n_s__shape, __pyx_k__shape, sizeof(__pyx_k__shape), 0, 0, 1, 1}, {&__pyx_n_s__size, __pyx_k__size, sizeof(__pyx_k__size), 0, 0, 1, 1}, {&__pyx_n_s__slicesize, __pyx_k__slicesize, sizeof(__pyx_k__slicesize), 0, 0, 1, 1}, {&__pyx_n_s__sorted, __pyx_k__sorted, sizeof(__pyx_k__sorted), 0, 0, 1, 1}, {&__pyx_n_s__start, __pyx_k__start, sizeof(__pyx_k__start), 0, 0, 1, 1}, {&__pyx_n_s__starts, __pyx_k__starts, sizeof(__pyx_k__starts), 0, 0, 1, 1}, {&__pyx_n_s__stop, __pyx_k__stop, sizeof(__pyx_k__stop), 0, 0, 1, 1}, {&__pyx_n_s__super, __pyx_k__super, sizeof(__pyx_k__super), 0, 0, 1, 1}, {&__pyx_n_s__uint16, __pyx_k__uint16, sizeof(__pyx_k__uint16), 0, 0, 1, 1}, {&__pyx_n_s__uint32, __pyx_k__uint32, sizeof(__pyx_k__uint32), 0, 0, 1, 1}, {&__pyx_n_s__uint64, __pyx_k__uint64, sizeof(__pyx_k__uint64), 0, 0, 1, 1}, {&__pyx_n_s__uint8, __pyx_k__uint8, sizeof(__pyx_k__uint8), 0, 0, 1, 1}, {&__pyx_n_s__x, __pyx_k__x, sizeof(__pyx_k__x), 0, 0, 1, 1}, {0, 0, 0, 0, 0, 0, 0} }; static int __Pyx_InitCachedBuiltins(void) { __pyx_builtin_ValueError = __Pyx_GetName(__pyx_b, __pyx_n_s__ValueError); if (!__pyx_builtin_ValueError) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_builtin_super = __Pyx_GetName(__pyx_b, __pyx_n_s__super); if (!__pyx_builtin_super) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 220; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_builtin_range = __Pyx_GetName(__pyx_b, __pyx_n_s__range); if (!__pyx_builtin_range) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 228; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_builtin_RuntimeError = __Pyx_GetName(__pyx_b, __pyx_n_s__RuntimeError); if (!__pyx_builtin_RuntimeError) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 799; __pyx_clineno = __LINE__; goto __pyx_L1_error;} return 0; __pyx_L1_error:; return -1; } static int __Pyx_InitCachedConstants(void) { __Pyx_RefNannyDeclarations __Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0); /* "tables/indexesextension.pyx":186 * #return 0 * else: * raise ValueError("This shouldn't happen!") # <<<<<<<<<<<<<< * * */ __pyx_k_tuple_2 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 186; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_2); __Pyx_INCREF(((PyObject *)__pyx_kp_s_1)); PyTuple_SET_ITEM(__pyx_k_tuple_2, 0, ((PyObject *)__pyx_kp_s_1)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_1)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_2)); /* "tables/indexesextension.pyx":207 * if (H5ARRAYOinit_readSlice(self.dataset_id, &self.mem_space_id, * nbounds) < 0): * raise HDF5ExtError("Problems initializing the bounds array data.") # <<<<<<<<<<<<<< * return * */ __pyx_k_tuple_4 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 207; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_4); __Pyx_INCREF(((PyObject *)__pyx_kp_s_3)); PyTuple_SET_ITEM(__pyx_k_tuple_4, 0, ((PyObject *)__pyx_kp_s_3)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_3)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_4)); /* "tables/indexesextension.pyx":216 * self.dataset_id, self.mem_space_id, self.type_id, * nrow, start, stop, rbuf) < 0): * raise HDF5ExtError("Problems reading the bounds array data.") # <<<<<<<<<<<<<< * return * */ __pyx_k_tuple_6 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 216; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_6); __Pyx_INCREF(((PyObject *)__pyx_kp_s_5)); PyTuple_SET_ITEM(__pyx_k_tuple_6, 0, ((PyObject *)__pyx_kp_s_5)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_5)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_6)); /* "tables/indexesextension.pyx":246 * * if ret < 0: * raise HDF5ExtError("Problems reading the index indices.") # <<<<<<<<<<<<<< * * _readIndexSlice = previous_api(_read_index_slice) */ __pyx_k_tuple_8 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 246; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_8); __Pyx_INCREF(((PyObject *)__pyx_kp_s_7)); PyTuple_SET_ITEM(__pyx_k_tuple_8, 0, ((PyObject *)__pyx_kp_s_7)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_7)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_8)); /* "tables/indexesextension.pyx":319 * * if ret < 0: * raise HDF5ExtError("Problems reading the array data.") # <<<<<<<<<<<<<< * * return self.rbuflb */ __pyx_k_tuple_11 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_11)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 319; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_11); __Pyx_INCREF(((PyObject *)__pyx_kp_s_10)); PyTuple_SET_ITEM(__pyx_k_tuple_11, 0, ((PyObject *)__pyx_kp_s_10)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_10)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_11)); /* "tables/indexesextension.pyx":1031 * * if ret < 0: * raise HDF5ExtError("Problems reading the index data in Last Row.") # <<<<<<<<<<<<<< * * _readIndexSlice = previous_api(_read_index_slice) */ __pyx_k_tuple_13 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_13)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1031; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_13); __Pyx_INCREF(((PyObject *)__pyx_kp_s_12)); PyTuple_SET_ITEM(__pyx_k_tuple_13, 0, ((PyObject *)__pyx_kp_s_12)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_12)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_13)); /* "tables/indexesextension.pyx":1046 * * if ret < 0: * raise HDF5ExtError("Problems reading the index data.") # <<<<<<<<<<<<<< * return sorted.bufferlb[:stop-start] * */ __pyx_k_tuple_15 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_15)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1046; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_15); __Pyx_INCREF(((PyObject *)__pyx_kp_s_14)); PyTuple_SET_ITEM(__pyx_k_tuple_15, 0, ((PyObject *)__pyx_kp_s_14)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_14)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_15)); /* "numpy.pxd":215 * if ((flags & pybuf.PyBUF_C_CONTIGUOUS == pybuf.PyBUF_C_CONTIGUOUS) * and not PyArray_CHKFLAGS(self, NPY_C_CONTIGUOUS)): * raise ValueError(u"ndarray is not C contiguous") # <<<<<<<<<<<<<< * * if ((flags & pybuf.PyBUF_F_CONTIGUOUS == pybuf.PyBUF_F_CONTIGUOUS) */ __pyx_k_tuple_17 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_17)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 215; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_17); __Pyx_INCREF(((PyObject *)__pyx_kp_u_16)); PyTuple_SET_ITEM(__pyx_k_tuple_17, 0, ((PyObject *)__pyx_kp_u_16)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_u_16)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_17)); /* "numpy.pxd":219 * if ((flags & pybuf.PyBUF_F_CONTIGUOUS == pybuf.PyBUF_F_CONTIGUOUS) * and not PyArray_CHKFLAGS(self, NPY_F_CONTIGUOUS)): * raise ValueError(u"ndarray is not Fortran contiguous") # <<<<<<<<<<<<<< * * info.buf = PyArray_DATA(self) */ __pyx_k_tuple_19 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_19)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 219; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_19); __Pyx_INCREF(((PyObject *)__pyx_kp_u_18)); PyTuple_SET_ITEM(__pyx_k_tuple_19, 0, ((PyObject *)__pyx_kp_u_18)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_u_18)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_19)); /* "numpy.pxd":257 * if ((descr.byteorder == c'>' and little_endian) or * (descr.byteorder == c'<' and not little_endian)): * raise ValueError(u"Non-native byte order not supported") # <<<<<<<<<<<<<< * if t == NPY_BYTE: f = "b" * elif t == NPY_UBYTE: f = "B" */ __pyx_k_tuple_21 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_21)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 257; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_21); __Pyx_INCREF(((PyObject *)__pyx_kp_u_20)); PyTuple_SET_ITEM(__pyx_k_tuple_21, 0, ((PyObject *)__pyx_kp_u_20)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_u_20)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_21)); /* "numpy.pxd":799 * * if (end - f) - (new_offset - offset[0]) < 15: * raise RuntimeError(u"Format string allocated too short, see comment in numpy.pxd") # <<<<<<<<<<<<<< * * if ((child.byteorder == c'>' and little_endian) or */ __pyx_k_tuple_24 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_24)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 799; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_24); __Pyx_INCREF(((PyObject *)__pyx_kp_u_23)); PyTuple_SET_ITEM(__pyx_k_tuple_24, 0, ((PyObject *)__pyx_kp_u_23)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_u_23)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_24)); /* "numpy.pxd":803 * if ((child.byteorder == c'>' and little_endian) or * (child.byteorder == c'<' and not little_endian)): * raise ValueError(u"Non-native byte order not supported") # <<<<<<<<<<<<<< * # One could encode it in the format string and have Cython * # complain instead, BUT: < and > in format strings also imply */ __pyx_k_tuple_25 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_25)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 803; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_25); __Pyx_INCREF(((PyObject *)__pyx_kp_u_20)); PyTuple_SET_ITEM(__pyx_k_tuple_25, 0, ((PyObject *)__pyx_kp_u_20)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_u_20)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_25)); /* "numpy.pxd":823 * t = child.type_num * if end - f < 5: * raise RuntimeError(u"Format string allocated too short.") # <<<<<<<<<<<<<< * * # Until ticket #99 is fixed, use integers to avoid warnings */ __pyx_k_tuple_27 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_27)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 823; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_27); __Pyx_INCREF(((PyObject *)__pyx_kp_u_26)); PyTuple_SET_ITEM(__pyx_k_tuple_27, 0, ((PyObject *)__pyx_kp_u_26)); __Pyx_GIVEREF(((PyObject *)__pyx_kp_u_26)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_27)); /* "tables/indexesextension.pyx":129 * * # Sorting functions * def keysort(ndarray array1, ndarray array2): # <<<<<<<<<<<<<< * """Sort array1 in-place. array2 is also sorted following the array1 order. * */ __pyx_k_tuple_31 = PyTuple_New(5); if (unlikely(!__pyx_k_tuple_31)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_k_tuple_31); __Pyx_INCREF(((PyObject *)__pyx_n_s__array1)); PyTuple_SET_ITEM(__pyx_k_tuple_31, 0, ((PyObject *)__pyx_n_s__array1)); __Pyx_GIVEREF(((PyObject *)__pyx_n_s__array1)); __Pyx_INCREF(((PyObject *)__pyx_n_s__array2)); PyTuple_SET_ITEM(__pyx_k_tuple_31, 1, ((PyObject *)__pyx_n_s__array2)); __Pyx_GIVEREF(((PyObject *)__pyx_n_s__array2)); __Pyx_INCREF(((PyObject *)__pyx_n_s__size)); PyTuple_SET_ITEM(__pyx_k_tuple_31, 2, ((PyObject *)__pyx_n_s__size)); __Pyx_GIVEREF(((PyObject *)__pyx_n_s__size)); __Pyx_INCREF(((PyObject *)__pyx_n_s__elsize1)); PyTuple_SET_ITEM(__pyx_k_tuple_31, 3, ((PyObject *)__pyx_n_s__elsize1)); __Pyx_GIVEREF(((PyObject *)__pyx_n_s__elsize1)); __Pyx_INCREF(((PyObject *)__pyx_n_s__elsize2)); PyTuple_SET_ITEM(__pyx_k_tuple_31, 4, ((PyObject *)__pyx_n_s__elsize2)); __Pyx_GIVEREF(((PyObject *)__pyx_n_s__elsize2)); __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_31)); __pyx_k_codeobj_32 = (PyObject*)__Pyx_PyCode_New(2, 0, 5, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_31, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_33, __pyx_n_s__keysort, 129, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_32)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_RefNannyFinishContext(); return 0; __pyx_L1_error:; __Pyx_RefNannyFinishContext(); return -1; } static int __Pyx_InitGlobals(void) { if (__Pyx_InitStrings(__pyx_string_tab) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}; __pyx_int_0 = PyInt_FromLong(0); if (unlikely(!__pyx_int_0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}; __pyx_int_15 = PyInt_FromLong(15); if (unlikely(!__pyx_int_15)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}; return 0; __pyx_L1_error:; return -1; } #if PY_MAJOR_VERSION < 3 PyMODINIT_FUNC initindexesextension(void); /*proto*/ PyMODINIT_FUNC initindexesextension(void) #else PyMODINIT_FUNC PyInit_indexesextension(void); /*proto*/ PyMODINIT_FUNC PyInit_indexesextension(void) #endif { PyObject *__pyx_t_1 = NULL; PyObject *__pyx_t_2 = NULL; PyObject *__pyx_t_3 = NULL; __Pyx_RefNannyDeclarations #if CYTHON_REFNANNY __Pyx_RefNanny = __Pyx_RefNannyImportAPI("refnanny"); if (!__Pyx_RefNanny) { PyErr_Clear(); __Pyx_RefNanny = __Pyx_RefNannyImportAPI("Cython.Runtime.refnanny"); if (!__Pyx_RefNanny) Py_FatalError("failed to import 'refnanny' module"); } #endif __Pyx_RefNannySetupContext("PyMODINIT_FUNC PyInit_indexesextension(void)", 0); if ( __Pyx_check_binary_version() < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_empty_tuple)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_empty_bytes)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} #ifdef __Pyx_CyFunction_USED if (__Pyx_CyFunction_init() < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} #endif #ifdef __Pyx_FusedFunction_USED if (__pyx_FusedFunction_init() < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} #endif #ifdef __Pyx_Generator_USED if (__pyx_Generator_init() < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} #endif /*--- Library function declarations ---*/ /*--- Threads initialization code ---*/ #if defined(__PYX_FORCE_INIT_THREADS) && __PYX_FORCE_INIT_THREADS #ifdef WITH_THREAD /* Python build with threading support? */ PyEval_InitThreads(); #endif #endif /*--- Module creation code ---*/ #if PY_MAJOR_VERSION < 3 __pyx_m = Py_InitModule4(__Pyx_NAMESTR("indexesextension"), __pyx_methods, __Pyx_DOCSTR(__pyx_k_28), 0, PYTHON_API_VERSION); Py_XINCREF(__pyx_m); #else __pyx_m = PyModule_Create(&__pyx_moduledef); #endif if (unlikely(!__pyx_m)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} #if PY_MAJOR_VERSION >= 3 { PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (!PyDict_GetItemString(modules, "tables.indexesextension")) { if (unlikely(PyDict_SetItemString(modules, "tables.indexesextension", __pyx_m) < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } } #endif __pyx_b = PyImport_AddModule(__Pyx_NAMESTR(__Pyx_BUILTIN_MODULE_NAME)); if (unlikely(!__pyx_b)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} #if CYTHON_COMPILING_IN_PYPY Py_INCREF(__pyx_b); #endif if (__Pyx_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}; /*--- Initialize various global constants etc. ---*/ if (unlikely(__Pyx_InitGlobals() < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__pyx_module_is_main_tables__indexesextension) { if (__Pyx_SetAttrString(__pyx_m, "__name__", __pyx_n_s____main__) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}; } /*--- Builtin init code ---*/ if (unlikely(__Pyx_InitCachedBuiltins() < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} /*--- Constants init code ---*/ if (unlikely(__Pyx_InitCachedConstants() < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} /*--- Global init code ---*/ /*--- Variable export code ---*/ /*--- Function export code ---*/ /*--- Type init code ---*/ if (PyType_Ready(&__pyx_type_6tables_16indexesextension_Index) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 192; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__Pyx_SetAttrString(__pyx_m, "Index", (PyObject *)&__pyx_type_6tables_16indexesextension_Index) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 192; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_16indexesextension_Index = &__pyx_type_6tables_16indexesextension_Index; __pyx_ptype_6tables_13hdf5extension_Array = __Pyx_ImportType("tables.hdf5extension", "Array", sizeof(struct __pyx_obj_6tables_13hdf5extension_Array), 1); if (unlikely(!__pyx_ptype_6tables_13hdf5extension_Array)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_vtabptr_6tables_13hdf5extension_Array = (struct __pyx_vtabstruct_6tables_13hdf5extension_Array*)__Pyx_GetVtable(__pyx_ptype_6tables_13hdf5extension_Array->tp_dict); if (unlikely(!__pyx_vtabptr_6tables_13hdf5extension_Array)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_vtabptr_6tables_16indexesextension_CacheArray = &__pyx_vtable_6tables_16indexesextension_CacheArray; __pyx_vtable_6tables_16indexesextension_CacheArray.__pyx_base = *__pyx_vtabptr_6tables_13hdf5extension_Array; __pyx_vtable_6tables_16indexesextension_CacheArray.initread = (PyObject *(*)(struct __pyx_obj_6tables_16indexesextension_CacheArray *, int))__pyx_f_6tables_16indexesextension_10CacheArray_initread; __pyx_vtable_6tables_16indexesextension_CacheArray.read_slice = (PyObject *(*)(struct __pyx_obj_6tables_16indexesextension_CacheArray *, hsize_t, hsize_t, hsize_t, void *))__pyx_f_6tables_16indexesextension_10CacheArray_read_slice; __pyx_type_6tables_16indexesextension_CacheArray.tp_base = __pyx_ptype_6tables_13hdf5extension_Array; if (PyType_Ready(&__pyx_type_6tables_16indexesextension_CacheArray) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 196; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__Pyx_SetVtable(__pyx_type_6tables_16indexesextension_CacheArray.tp_dict, __pyx_vtabptr_6tables_16indexesextension_CacheArray) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 196; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__Pyx_SetAttrString(__pyx_m, "CacheArray", (PyObject *)&__pyx_type_6tables_16indexesextension_CacheArray) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 196; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_16indexesextension_CacheArray = &__pyx_type_6tables_16indexesextension_CacheArray; __pyx_vtabptr_6tables_16indexesextension_IndexArray = &__pyx_vtable_6tables_16indexesextension_IndexArray; __pyx_vtable_6tables_16indexesextension_IndexArray.__pyx_base = *__pyx_vtabptr_6tables_13hdf5extension_Array; __pyx_vtable_6tables_16indexesextension_IndexArray._g_read_sorted_slice = (void *(*)(struct __pyx_obj_6tables_16indexesextension_IndexArray *, hsize_t, hsize_t, hsize_t))__pyx_f_6tables_16indexesextension_10IndexArray__g_read_sorted_slice; __pyx_vtable_6tables_16indexesextension_IndexArray.get_lru_bounds = (void *(*)(struct __pyx_obj_6tables_16indexesextension_IndexArray *, int, int))__pyx_f_6tables_16indexesextension_10IndexArray_get_lru_bounds; __pyx_vtable_6tables_16indexesextension_IndexArray.get_lru_sorted = (void *(*)(struct __pyx_obj_6tables_16indexesextension_IndexArray *, int, int, int, int))__pyx_f_6tables_16indexesextension_10IndexArray_get_lru_sorted; __pyx_type_6tables_16indexesextension_IndexArray.tp_base = __pyx_ptype_6tables_13hdf5extension_Array; if (PyType_Ready(&__pyx_type_6tables_16indexesextension_IndexArray) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 226; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__Pyx_SetVtable(__pyx_type_6tables_16indexesextension_IndexArray.tp_dict, __pyx_vtabptr_6tables_16indexesextension_IndexArray) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 226; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__Pyx_SetAttrString(__pyx_m, "IndexArray", (PyObject *)&__pyx_type_6tables_16indexesextension_IndexArray) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 226; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_16indexesextension_IndexArray = &__pyx_type_6tables_16indexesextension_IndexArray; __pyx_vtabptr_6tables_16indexesextension_LastRowArray = &__pyx_vtable_6tables_16indexesextension_LastRowArray; __pyx_vtable_6tables_16indexesextension_LastRowArray.__pyx_base = *__pyx_vtabptr_6tables_13hdf5extension_Array; __pyx_type_6tables_16indexesextension_LastRowArray.tp_base = __pyx_ptype_6tables_13hdf5extension_Array; if (PyType_Ready(&__pyx_type_6tables_16indexesextension_LastRowArray) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1018; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__Pyx_SetVtable(__pyx_type_6tables_16indexesextension_LastRowArray.tp_dict, __pyx_vtabptr_6tables_16indexesextension_LastRowArray) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1018; __pyx_clineno = __LINE__; goto __pyx_L1_error;} if (__Pyx_SetAttrString(__pyx_m, "LastRowArray", (PyObject *)&__pyx_type_6tables_16indexesextension_LastRowArray) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1018; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_16indexesextension_LastRowArray = &__pyx_type_6tables_16indexesextension_LastRowArray; /*--- Type import code ---*/ __pyx_ptype_7cpython_4type_type = __Pyx_ImportType(__Pyx_BUILTIN_MODULE_NAME, "type", #if CYTHON_COMPILING_IN_PYPY sizeof(PyTypeObject), #else sizeof(PyHeapTypeObject), #endif 0); if (unlikely(!__pyx_ptype_7cpython_4type_type)) {__pyx_filename = __pyx_f[2]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_5numpy_dtype = __Pyx_ImportType("numpy", "dtype", sizeof(PyArray_Descr), 0); if (unlikely(!__pyx_ptype_5numpy_dtype)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 155; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_5numpy_flatiter = __Pyx_ImportType("numpy", "flatiter", sizeof(PyArrayIterObject), 0); if (unlikely(!__pyx_ptype_5numpy_flatiter)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 165; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_5numpy_broadcast = __Pyx_ImportType("numpy", "broadcast", sizeof(PyArrayMultiIterObject), 0); if (unlikely(!__pyx_ptype_5numpy_broadcast)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 169; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_5numpy_ndarray = __Pyx_ImportType("numpy", "ndarray", sizeof(PyArrayObject), 0); if (unlikely(!__pyx_ptype_5numpy_ndarray)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 178; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_5numpy_ufunc = __Pyx_ImportType("numpy", "ufunc", sizeof(PyUFuncObject), 0); if (unlikely(!__pyx_ptype_5numpy_ufunc)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 861; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_13hdf5extension_Node = __Pyx_ImportType("tables.hdf5extension", "Node", sizeof(struct __pyx_obj_6tables_13hdf5extension_Node), 1); if (unlikely(!__pyx_ptype_6tables_13hdf5extension_Node)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_13hdf5extension_Leaf = __Pyx_ImportType("tables.hdf5extension", "Leaf", sizeof(struct __pyx_obj_6tables_13hdf5extension_Leaf), 1); if (unlikely(!__pyx_ptype_6tables_13hdf5extension_Leaf)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 22; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_vtabptr_6tables_13hdf5extension_Leaf = (struct __pyx_vtabstruct_6tables_13hdf5extension_Leaf*)__Pyx_GetVtable(__pyx_ptype_6tables_13hdf5extension_Leaf->tp_dict); if (unlikely(!__pyx_vtabptr_6tables_13hdf5extension_Leaf)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 22; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_17lrucacheextension_NodeCache = __Pyx_ImportType("tables.lrucacheextension", "NodeCache", sizeof(struct __pyx_obj_6tables_17lrucacheextension_NodeCache), 1); if (unlikely(!__pyx_ptype_6tables_17lrucacheextension_NodeCache)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_vtabptr_6tables_17lrucacheextension_NodeCache = (struct __pyx_vtabstruct_6tables_17lrucacheextension_NodeCache*)__Pyx_GetVtable(__pyx_ptype_6tables_17lrucacheextension_NodeCache->tp_dict); if (unlikely(!__pyx_vtabptr_6tables_17lrucacheextension_NodeCache)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_17lrucacheextension_BaseCache = __Pyx_ImportType("tables.lrucacheextension", "BaseCache", sizeof(struct __pyx_obj_6tables_17lrucacheextension_BaseCache), 1); if (unlikely(!__pyx_ptype_6tables_17lrucacheextension_BaseCache)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_vtabptr_6tables_17lrucacheextension_BaseCache = (struct __pyx_vtabstruct_6tables_17lrucacheextension_BaseCache*)__Pyx_GetVtable(__pyx_ptype_6tables_17lrucacheextension_BaseCache->tp_dict); if (unlikely(!__pyx_vtabptr_6tables_17lrucacheextension_BaseCache)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_17lrucacheextension_ObjectNode = __Pyx_ImportType("tables.lrucacheextension", "ObjectNode", sizeof(struct __pyx_obj_6tables_17lrucacheextension_ObjectNode), 1); if (unlikely(!__pyx_ptype_6tables_17lrucacheextension_ObjectNode)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 43; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_17lrucacheextension_ObjectCache = __Pyx_ImportType("tables.lrucacheextension", "ObjectCache", sizeof(struct __pyx_obj_6tables_17lrucacheextension_ObjectCache), 1); if (unlikely(!__pyx_ptype_6tables_17lrucacheextension_ObjectCache)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_vtabptr_6tables_17lrucacheextension_ObjectCache = (struct __pyx_vtabstruct_6tables_17lrucacheextension_ObjectCache*)__Pyx_GetVtable(__pyx_ptype_6tables_17lrucacheextension_ObjectCache->tp_dict); if (unlikely(!__pyx_vtabptr_6tables_17lrucacheextension_ObjectCache)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_ptype_6tables_17lrucacheextension_NumCache = __Pyx_ImportType("tables.lrucacheextension", "NumCache", sizeof(struct __pyx_obj_6tables_17lrucacheextension_NumCache), 1); if (unlikely(!__pyx_ptype_6tables_17lrucacheextension_NumCache)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 64; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __pyx_vtabptr_6tables_17lrucacheextension_NumCache = (struct __pyx_vtabstruct_6tables_17lrucacheextension_NumCache*)__Pyx_GetVtable(__pyx_ptype_6tables_17lrucacheextension_NumCache->tp_dict); if (unlikely(!__pyx_vtabptr_6tables_17lrucacheextension_NumCache)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 64; __pyx_clineno = __LINE__; goto __pyx_L1_error;} /*--- Variable import code ---*/ /*--- Function import code ---*/ /*--- Execution code ---*/ /* "tables/indexesextension.pyx":27 * """ * * import numpy # <<<<<<<<<<<<<< * * from tables.exceptions import HDF5ExtError */ __pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__numpy), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 27; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (PyObject_SetAttr(__pyx_m, __pyx_n_s__numpy, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 27; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "tables/indexesextension.pyx":29 * import numpy * * from tables.exceptions import HDF5ExtError # <<<<<<<<<<<<<< * from hdf5extension cimport Array * */ __pyx_t_1 = PyList_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_INCREF(((PyObject *)__pyx_n_s__HDF5ExtError)); PyList_SET_ITEM(__pyx_t_1, 0, ((PyObject *)__pyx_n_s__HDF5ExtError)); __Pyx_GIVEREF(((PyObject *)__pyx_n_s__HDF5ExtError)); __pyx_t_2 = __Pyx_Import(((PyObject *)__pyx_n_s_29), ((PyObject *)__pyx_t_1), -1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; __pyx_t_1 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s__HDF5ExtError); if (__pyx_t_1 == NULL) { if (PyErr_ExceptionMatches(PyExc_AttributeError)) __Pyx_RaiseImportError(__pyx_n_s__HDF5ExtError); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __Pyx_GOTREF(__pyx_t_1); if (PyObject_SetAttr(__pyx_m, __pyx_n_s__HDF5ExtError, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; /* "tables/indexesextension.pyx":49 * from lrucacheextension cimport NumCache * * from tables._past import previous_api # <<<<<<<<<<<<<< * * */ __pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_INCREF(((PyObject *)__pyx_n_s__previous_api)); PyList_SET_ITEM(__pyx_t_2, 0, ((PyObject *)__pyx_n_s__previous_api)); __Pyx_GIVEREF(((PyObject *)__pyx_n_s__previous_api)); __pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s_30), ((PyObject *)__pyx_t_2), -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; __pyx_t_2 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s__previous_api); if (__pyx_t_2 == NULL) { if (PyErr_ExceptionMatches(PyExc_AttributeError)) __Pyx_RaiseImportError(__pyx_n_s__previous_api); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;} } __Pyx_GOTREF(__pyx_t_2); if (PyObject_SetAttr(__pyx_m, __pyx_n_s__previous_api, __pyx_t_2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "tables/indexesextension.pyx":122 * # The numpy API requires this function to be called before * # using any numpy facilities in an extension module. * import_array() # <<<<<<<<<<<<<< * * #--------------------------------------------------------------------------- */ import_array(); /* "tables/indexesextension.pyx":129 * * # Sorting functions * def keysort(ndarray array1, ndarray array2): # <<<<<<<<<<<<<< * """Sort array1 in-place. array2 is also sorted following the array1 order. * */ __pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_6tables_16indexesextension_1keysort, NULL, __pyx_n_s_34); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); if (PyObject_SetAttr(__pyx_m, __pyx_n_s__keysort, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 129; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; /* "tables/indexesextension.pyx":248 * raise HDF5ExtError("Problems reading the index indices.") * * _readIndexSlice = previous_api(_read_index_slice) # <<<<<<<<<<<<<< * * def _init_sorted_slice(self, index): */ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 248; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___read_index_slice); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 248; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 248; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 248; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___readIndexSlice, __pyx_t_2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 248; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":307 * * * _initSortedSlice = previous_api(_init_sorted_slice) # <<<<<<<<<<<<<< * * cdef void *_g_read_sorted_slice(self, hsize_t irow, hsize_t start, */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 307; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___init_sorted_slice); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 307; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 307; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 307; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___initSortedSlice, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 307; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":333 * return self.bufferlb * * _readSortedSlice = previous_api(_read_sorted_slice) # <<<<<<<<<<<<<< * * # This has been copied from the standard module bisect. */ __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 333; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___read_sorted_slice); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 333; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 333; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 333; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___readSortedSlice, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 333; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":466 * return tlength * * _searchBinNA_b = previous_api(_search_bin_na_b) # <<<<<<<<<<<<<< * * # Optimized version for uint8 */ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 466; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_b); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 466; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 466; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 466; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_b, __pyx_t_2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 466; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":515 * return tlength * * _searchBinNA_ub = previous_api(_search_bin_na_ub) # <<<<<<<<<<<<<< * * # Optimized version for int16 */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 515; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_ub); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 515; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 515; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 515; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_ub, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 515; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":564 * return tlength * * _searchBinNA_s = previous_api(_search_bin_na_s) # <<<<<<<<<<<<<< * * # Optimized version for uint16 */ __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 564; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_s); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 564; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 564; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 564; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_s, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 564; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":613 * return tlength * * _searchBinNA_us = previous_api(_search_bin_na_us) # <<<<<<<<<<<<<< * * # Optimized version for int32 */ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 613; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_us); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 613; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 613; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 613; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_us, __pyx_t_2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 613; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":662 * return tlength * * _searchBinNA_i = previous_api(_search_bin_na_i) # <<<<<<<<<<<<<< * * # Optimized version for uint32 */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 662; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_i); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 662; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 662; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 662; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_i, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 662; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":711 * return tlength * * _searchBinNA_ui = previous_api(_search_bin_na_ui) # <<<<<<<<<<<<<< * * # Optimized version for int64 */ __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 711; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_ui); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 711; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 711; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 711; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_ui, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 711; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":760 * return tlength * * _searchBinNA_ll = previous_api(_search_bin_na_ll) # <<<<<<<<<<<<<< * * # Optimized version for uint64 */ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 760; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_ll); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 760; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 760; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 760; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_ll, __pyx_t_2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 760; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":809 * return tlength * * _searchBinNA_ull = previous_api(_search_bin_na_ull) # <<<<<<<<<<<<<< * * # Optimized version for float16 */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 809; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_ull); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 809; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 809; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 809; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_ull, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 809; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":859 * return tlength * * _searchBinNA_e = previous_api(_search_bin_na_e) # <<<<<<<<<<<<<< * * # Optimized version for float32 */ __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 859; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_e); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 859; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 859; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 859; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_e, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 859; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":909 * return tlength * * _searchBinNA_f = previous_api(_search_bin_na_f) # <<<<<<<<<<<<<< * * # Optimized version for float64 */ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 909; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_f); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 909; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 909; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 909; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_f, __pyx_t_2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 909; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":959 * return tlength * * _searchBinNA_d = previous_api(_search_bin_na_d) # <<<<<<<<<<<<<< * * # Optimized version for npy_longdouble/float96/float128 */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 959; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_d); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 959; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 959; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 959; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_d, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 959; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":1009 * return tlength * * _searchBinNA_g = previous_api(_search_bin_na_g) # <<<<<<<<<<<<<< * * def _g_close(self): */ __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1009; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray, __pyx_n_s___search_bin_na_g); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1009; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1009; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1); __Pyx_GIVEREF(__pyx_t_1); __pyx_t_1 = 0; __pyx_t_1 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1009; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_IndexArray->tp_dict, __pyx_n_s___searchBinNA_g, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1009; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_IndexArray); /* "tables/indexesextension.pyx":1033 * raise HDF5ExtError("Problems reading the index data in Last Row.") * * _readIndexSlice = previous_api(_read_index_slice) # <<<<<<<<<<<<<< * * def _read_sorted_slice(self, IndexArray sorted, hsize_t start, hsize_t stop): */ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1033; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); __pyx_t_2 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_LastRowArray, __pyx_n_s___read_index_slice); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1033; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1033; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2); __Pyx_GIVEREF(__pyx_t_2); __pyx_t_2 = 0; __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1033; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_LastRowArray->tp_dict, __pyx_n_s___readIndexSlice, __pyx_t_2) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1033; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_LastRowArray); /* "tables/indexesextension.pyx":1049 * return sorted.bufferlb[:stop-start] * * _readSortedSlice = previous_api(_read_sorted_slice) # <<<<<<<<<<<<<< * * */ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__previous_api); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1049; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_2); __pyx_t_3 = __Pyx_GetName((PyObject *)__pyx_ptype_6tables_16indexesextension_LastRowArray, __pyx_n_s___read_sorted_slice); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1049; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __pyx_t_1 = PyTuple_New(1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1049; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_1); PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_t_3); __Pyx_GIVEREF(__pyx_t_3); __pyx_t_3 = 0; __pyx_t_3 = PyObject_Call(__pyx_t_2, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1049; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(__pyx_t_3); __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0; __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0; if (PyDict_SetItem((PyObject *)__pyx_ptype_6tables_16indexesextension_LastRowArray->tp_dict, __pyx_n_s___readSortedSlice, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1049; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0; PyType_Modified(__pyx_ptype_6tables_16indexesextension_LastRowArray); /* "tables/indexesextension.pyx":1 * # -*- coding: utf-8 -*- # <<<<<<<<<<<<<< * * ######################################################################## */ __pyx_t_3 = PyDict_New(); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_GOTREF(((PyObject *)__pyx_t_3)); if (PyObject_SetAttr(__pyx_m, __pyx_n_s____test__, ((PyObject *)__pyx_t_3)) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;} __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0; /* "numpy.pxd":975 * arr.base = baseptr * * cdef inline object get_array_base(ndarray arr): # <<<<<<<<<<<<<< * if arr.base is NULL: * return None */ goto __pyx_L0; __pyx_L1_error:; __Pyx_XDECREF(__pyx_t_1); __Pyx_XDECREF(__pyx_t_2); __Pyx_XDECREF(__pyx_t_3); if (__pyx_m) { __Pyx_AddTraceback("init tables.indexesextension", __pyx_clineno, __pyx_lineno, __pyx_filename); Py_DECREF(__pyx_m); __pyx_m = 0; } else if (!PyErr_Occurred()) { PyErr_SetString(PyExc_ImportError, "init tables.indexesextension"); } __pyx_L0:; __Pyx_RefNannyFinishContext(); #if PY_MAJOR_VERSION < 3 return; #else return __pyx_m; #endif } /* Runtime support code */ #if CYTHON_REFNANNY static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname) { PyObject *m = NULL, *p = NULL; void *r = NULL; m = PyImport_ImportModule((char *)modname); if (!m) goto end; p = PyObject_GetAttrString(m, (char *)"RefNannyAPI"); if (!p) goto end; r = PyLong_AsVoidPtr(p); end: Py_XDECREF(p); Py_XDECREF(m); return (__Pyx_RefNannyAPIStruct *)r; } #endif /* CYTHON_REFNANNY */ static PyObject *__Pyx_GetName(PyObject *dict, PyObject *name) { PyObject *result; result = PyObject_GetAttr(dict, name); if (!result) { if (dict != __pyx_b) { PyErr_Clear(); result = PyObject_GetAttr(__pyx_b, name); } if (!result) { PyErr_SetObject(PyExc_NameError, name); } } return result; } static void __Pyx_RaiseArgtupleInvalid( const char* func_name, int exact, Py_ssize_t num_min, Py_ssize_t num_max, Py_ssize_t num_found) { Py_ssize_t num_expected; const char *more_or_less; if (num_found < num_min) { num_expected = num_min; more_or_less = "at least"; } else { num_expected = num_max; more_or_less = "at most"; } if (exact) { more_or_less = "exactly"; } PyErr_Format(PyExc_TypeError, "%s() takes %s %" CYTHON_FORMAT_SSIZE_T "d positional argument%s (%" CYTHON_FORMAT_SSIZE_T "d given)", func_name, more_or_less, num_expected, (num_expected == 1) ? "" : "s", num_found); } static void __Pyx_RaiseDoubleKeywordsError( const char* func_name, PyObject* kw_name) { PyErr_Format(PyExc_TypeError, #if PY_MAJOR_VERSION >= 3 "%s() got multiple values for keyword argument '%U'", func_name, kw_name); #else "%s() got multiple values for keyword argument '%s'", func_name, PyString_AsString(kw_name)); #endif } static int __Pyx_ParseOptionalKeywords( PyObject *kwds, PyObject **argnames[], PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args, const char* function_name) { PyObject *key = 0, *value = 0; Py_ssize_t pos = 0; PyObject*** name; PyObject*** first_kw_arg = argnames + num_pos_args; while (PyDict_Next(kwds, &pos, &key, &value)) { name = first_kw_arg; while (*name && (**name != key)) name++; if (*name) { values[name-argnames] = value; continue; } name = first_kw_arg; #if PY_MAJOR_VERSION < 3 if (likely(PyString_CheckExact(key)) || likely(PyString_Check(key))) { while (*name) { if ((CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**name) == PyString_GET_SIZE(key)) && _PyString_Eq(**name, key)) { values[name-argnames] = value; break; } name++; } if (*name) continue; else { PyObject*** argname = argnames; while (argname != first_kw_arg) { if ((**argname == key) || ( (CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**argname) == PyString_GET_SIZE(key)) && _PyString_Eq(**argname, key))) { goto arg_passed_twice; } argname++; } } } else #endif if (likely(PyUnicode_Check(key))) { while (*name) { int cmp = (**name == key) ? 0 : #if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3 (PyUnicode_GET_SIZE(**name) != PyUnicode_GET_SIZE(key)) ? 1 : #endif PyUnicode_Compare(**name, key); if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad; if (cmp == 0) { values[name-argnames] = value; break; } name++; } if (*name) continue; else { PyObject*** argname = argnames; while (argname != first_kw_arg) { int cmp = (**argname == key) ? 0 : #if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3 (PyUnicode_GET_SIZE(**argname) != PyUnicode_GET_SIZE(key)) ? 1 : #endif PyUnicode_Compare(**argname, key); if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad; if (cmp == 0) goto arg_passed_twice; argname++; } } } else goto invalid_keyword_type; if (kwds2) { if (unlikely(PyDict_SetItem(kwds2, key, value))) goto bad; } else { goto invalid_keyword; } } return 0; arg_passed_twice: __Pyx_RaiseDoubleKeywordsError(function_name, key); goto bad; invalid_keyword_type: PyErr_Format(PyExc_TypeError, "%s() keywords must be strings", function_name); goto bad; invalid_keyword: PyErr_Format(PyExc_TypeError, #if PY_MAJOR_VERSION < 3 "%s() got an unexpected keyword argument '%s'", function_name, PyString_AsString(key)); #else "%s() got an unexpected keyword argument '%U'", function_name, key); #endif bad: return -1; } static int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed, const char *name, int exact) { if (!type) { PyErr_Format(PyExc_SystemError, "Missing type object"); return 0; } if (none_allowed && obj == Py_None) return 1; else if (exact) { if (Py_TYPE(obj) == type) return 1; } else { if (PyObject_TypeCheck(obj, type)) return 1; } PyErr_Format(PyExc_TypeError, "Argument '%s' has incorrect type (expected %s, got %s)", name, type->tp_name, Py_TYPE(obj)->tp_name); return 0; } static CYTHON_INLINE void __Pyx_ErrRestore(PyObject *type, PyObject *value, PyObject *tb) { #if CYTHON_COMPILING_IN_CPYTHON PyObject *tmp_type, *tmp_value, *tmp_tb; PyThreadState *tstate = PyThreadState_GET(); tmp_type = tstate->curexc_type; tmp_value = tstate->curexc_value; tmp_tb = tstate->curexc_traceback; tstate->curexc_type = type; tstate->curexc_value = value; tstate->curexc_traceback = tb; Py_XDECREF(tmp_type); Py_XDECREF(tmp_value); Py_XDECREF(tmp_tb); #else PyErr_Restore(type, value, tb); #endif } static CYTHON_INLINE void __Pyx_ErrFetch(PyObject **type, PyObject **value, PyObject **tb) { #if CYTHON_COMPILING_IN_CPYTHON PyThreadState *tstate = PyThreadState_GET(); *type = tstate->curexc_type; *value = tstate->curexc_value; *tb = tstate->curexc_traceback; tstate->curexc_type = 0; tstate->curexc_value = 0; tstate->curexc_traceback = 0; #else PyErr_Fetch(type, value, tb); #endif } #if PY_MAJOR_VERSION < 3 static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, CYTHON_UNUSED PyObject *cause) { Py_XINCREF(type); if (!value || value == Py_None) value = NULL; else Py_INCREF(value); if (!tb || tb == Py_None) tb = NULL; else { Py_INCREF(tb); if (!PyTraceBack_Check(tb)) { PyErr_SetString(PyExc_TypeError, "raise: arg 3 must be a traceback or None"); goto raise_error; } } #if PY_VERSION_HEX < 0x02050000 if (PyClass_Check(type)) { #else if (PyType_Check(type)) { #endif #if CYTHON_COMPILING_IN_PYPY if (!value) { Py_INCREF(Py_None); value = Py_None; } #endif PyErr_NormalizeException(&type, &value, &tb); } else { if (value) { PyErr_SetString(PyExc_TypeError, "instance exception may not have a separate value"); goto raise_error; } value = type; #if PY_VERSION_HEX < 0x02050000 if (PyInstance_Check(type)) { type = (PyObject*) ((PyInstanceObject*)type)->in_class; Py_INCREF(type); } else { type = 0; PyErr_SetString(PyExc_TypeError, "raise: exception must be an old-style class or instance"); goto raise_error; } #else type = (PyObject*) Py_TYPE(type); Py_INCREF(type); if (!PyType_IsSubtype((PyTypeObject *)type, (PyTypeObject *)PyExc_BaseException)) { PyErr_SetString(PyExc_TypeError, "raise: exception class must be a subclass of BaseException"); goto raise_error; } #endif } __Pyx_ErrRestore(type, value, tb); return; raise_error: Py_XDECREF(value); Py_XDECREF(type); Py_XDECREF(tb); return; } #else /* Python 3+ */ static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause) { PyObject* owned_instance = NULL; if (tb == Py_None) { tb = 0; } else if (tb && !PyTraceBack_Check(tb)) { PyErr_SetString(PyExc_TypeError, "raise: arg 3 must be a traceback or None"); goto bad; } if (value == Py_None) value = 0; if (PyExceptionInstance_Check(type)) { if (value) { PyErr_SetString(PyExc_TypeError, "instance exception may not have a separate value"); goto bad; } value = type; type = (PyObject*) Py_TYPE(value); } else if (PyExceptionClass_Check(type)) { PyObject *args; if (!value) args = PyTuple_New(0); else if (PyTuple_Check(value)) { Py_INCREF(value); args = value; } else args = PyTuple_Pack(1, value); if (!args) goto bad; owned_instance = PyEval_CallObject(type, args); Py_DECREF(args); if (!owned_instance) goto bad; value = owned_instance; if (!PyExceptionInstance_Check(value)) { PyErr_Format(PyExc_TypeError, "calling %R should have returned an instance of " "BaseException, not %R", type, Py_TYPE(value)); goto bad; } } else { PyErr_SetString(PyExc_TypeError, "raise: exception class must be a subclass of BaseException"); goto bad; } if (cause && cause != Py_None) { PyObject *fixed_cause; if (PyExceptionClass_Check(cause)) { fixed_cause = PyObject_CallObject(cause, NULL); if (fixed_cause == NULL) goto bad; } else if (PyExceptionInstance_Check(cause)) { fixed_cause = cause; Py_INCREF(fixed_cause); } else { PyErr_SetString(PyExc_TypeError, "exception causes must derive from " "BaseException"); goto bad; } PyException_SetCause(value, fixed_cause); } PyErr_SetObject(type, value); if (tb) { PyThreadState *tstate = PyThreadState_GET(); PyObject* tmp_tb = tstate->curexc_traceback; if (tb != tmp_tb) { Py_INCREF(tb); tstate->curexc_traceback = tb; Py_XDECREF(tmp_tb); } } bad: Py_XDECREF(owned_instance); return; } #endif static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type) { if (unlikely(!type)) { PyErr_Format(PyExc_SystemError, "Missing type object"); return 0; } if (likely(PyObject_TypeCheck(obj, type))) return 1; PyErr_Format(PyExc_TypeError, "Cannot convert %.200s to %.200s", Py_TYPE(obj)->tp_name, type->tp_name); return 0; } static CYTHON_INLINE long __Pyx_div_long(long a, long b) { long q = a / b; long r = a - q*b; q -= ((r != 0) & ((r ^ b) < 0)); return q; } static CYTHON_INLINE int __Pyx_div_int(int a, int b) { int q = a / b; int r = a - q*b; q -= ((r != 0) & ((r ^ b) < 0)); return q; } static CYTHON_INLINE void __Pyx_RaiseTooManyValuesError(Py_ssize_t expected) { PyErr_Format(PyExc_ValueError, "too many values to unpack (expected %" CYTHON_FORMAT_SSIZE_T "d)", expected); } static CYTHON_INLINE void __Pyx_RaiseNeedMoreValuesError(Py_ssize_t index) { PyErr_Format(PyExc_ValueError, "need more than %" CYTHON_FORMAT_SSIZE_T "d value%s to unpack", index, (index == 1) ? "" : "s"); } static CYTHON_INLINE void __Pyx_RaiseNoneNotIterableError(void) { PyErr_SetString(PyExc_TypeError, "'NoneType' object is not iterable"); } static CYTHON_INLINE int __Pyx_IterFinish(void) { #if CYTHON_COMPILING_IN_CPYTHON PyThreadState *tstate = PyThreadState_GET(); PyObject* exc_type = tstate->curexc_type; if (unlikely(exc_type)) { if (likely(exc_type == PyExc_StopIteration) || PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration)) { PyObject *exc_value, *exc_tb; exc_value = tstate->curexc_value; exc_tb = tstate->curexc_traceback; tstate->curexc_type = 0; tstate->curexc_value = 0; tstate->curexc_traceback = 0; Py_DECREF(exc_type); Py_XDECREF(exc_value); Py_XDECREF(exc_tb); return 0; } else { return -1; } } return 0; #else if (unlikely(PyErr_Occurred())) { if (likely(PyErr_ExceptionMatches(PyExc_StopIteration))) { PyErr_Clear(); return 0; } else { return -1; } } return 0; #endif } static int __Pyx_IternextUnpackEndCheck(PyObject *retval, Py_ssize_t expected) { if (unlikely(retval)) { Py_DECREF(retval); __Pyx_RaiseTooManyValuesError(expected); return -1; } else { return __Pyx_IterFinish(); } return 0; } static void __Pyx_call_next_tp_dealloc(PyObject* obj, destructor current_tp_dealloc) { PyTypeObject* type = Py_TYPE(obj); while (type && type->tp_dealloc != current_tp_dealloc) type = type->tp_base; while (type && type->tp_dealloc == current_tp_dealloc) type = type->tp_base; if (type) type->tp_dealloc(obj); } static int __Pyx_call_next_tp_traverse(PyObject* obj, visitproc v, void *a, traverseproc current_tp_traverse) { PyTypeObject* type = Py_TYPE(obj); while (type && type->tp_traverse != current_tp_traverse) type = type->tp_base; while (type && type->tp_traverse == current_tp_traverse) type = type->tp_base; if (type && type->tp_traverse) return type->tp_traverse(obj, v, a); return 0; } static void __Pyx_call_next_tp_clear(PyObject* obj, inquiry current_tp_clear) { PyTypeObject* type = Py_TYPE(obj); while (type && type->tp_clear != current_tp_clear) type = type->tp_base; while (type && type->tp_clear == current_tp_clear) type = type->tp_base; if (type && type->tp_clear) type->tp_clear(obj); } static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, long level) { PyObject *py_import = 0; PyObject *empty_list = 0; PyObject *module = 0; PyObject *global_dict = 0; PyObject *empty_dict = 0; PyObject *list; py_import = __Pyx_GetAttrString(__pyx_b, "__import__"); if (!py_import) goto bad; if (from_list) list = from_list; else { empty_list = PyList_New(0); if (!empty_list) goto bad; list = empty_list; } global_dict = PyModule_GetDict(__pyx_m); if (!global_dict) goto bad; empty_dict = PyDict_New(); if (!empty_dict) goto bad; #if PY_VERSION_HEX >= 0x02050000 { #if PY_MAJOR_VERSION >= 3 if (level == -1) { if (strchr(__Pyx_MODULE_NAME, '.')) { /* try package relative import first */ PyObject *py_level = PyInt_FromLong(1); if (!py_level) goto bad; module = PyObject_CallFunctionObjArgs(py_import, name, global_dict, empty_dict, list, py_level, NULL); Py_DECREF(py_level); if (!module) { if (!PyErr_ExceptionMatches(PyExc_ImportError)) goto bad; PyErr_Clear(); } } level = 0; /* try absolute import on failure */ } #endif if (!module) { PyObject *py_level = PyInt_FromLong(level); if (!py_level) goto bad; module = PyObject_CallFunctionObjArgs(py_import, name, global_dict, empty_dict, list, py_level, NULL); Py_DECREF(py_level); } } #else if (level>0) { PyErr_SetString(PyExc_RuntimeError, "Relative import is not supported for Python <=2.4."); goto bad; } module = PyObject_CallFunctionObjArgs(py_import, name, global_dict, empty_dict, list, NULL); #endif bad: Py_XDECREF(empty_list); Py_XDECREF(py_import); Py_XDECREF(empty_dict); return module; } static CYTHON_INLINE void __Pyx_RaiseImportError(PyObject *name) { #if PY_MAJOR_VERSION < 3 PyErr_Format(PyExc_ImportError, "cannot import name %.230s", PyString_AsString(name)); #else PyErr_Format(PyExc_ImportError, "cannot import name %S", name); #endif } static CYTHON_INLINE hsize_t __Pyx_PyInt_from_py_hsize_t(PyObject* x) { const hsize_t neg_one = (hsize_t)-1, const_zero = (hsize_t)0; const int is_unsigned = const_zero < neg_one; if (sizeof(hsize_t) == sizeof(char)) { if (is_unsigned) return (hsize_t)__Pyx_PyInt_AsUnsignedChar(x); else return (hsize_t)__Pyx_PyInt_AsSignedChar(x); } else if (sizeof(hsize_t) == sizeof(short)) { if (is_unsigned) return (hsize_t)__Pyx_PyInt_AsUnsignedShort(x); else return (hsize_t)__Pyx_PyInt_AsSignedShort(x); } else if (sizeof(hsize_t) == sizeof(int)) { if (is_unsigned) return (hsize_t)__Pyx_PyInt_AsUnsignedInt(x); else return (hsize_t)__Pyx_PyInt_AsSignedInt(x); } else if (sizeof(hsize_t) == sizeof(long)) { if (is_unsigned) return (hsize_t)__Pyx_PyInt_AsUnsignedLong(x); else return (hsize_t)__Pyx_PyInt_AsSignedLong(x); } else if (sizeof(hsize_t) == sizeof(PY_LONG_LONG)) { if (is_unsigned) return (hsize_t)__Pyx_PyInt_AsUnsignedLongLong(x); else return (hsize_t)__Pyx_PyInt_AsSignedLongLong(x); } else { #if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray) PyErr_SetString(PyExc_RuntimeError, "_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers"); #else hsize_t val; PyObject *v = __Pyx_PyNumber_Int(x); #if PY_VERSION_HEX < 0x03000000 if (likely(v) && !PyLong_Check(v)) { PyObject *tmp = v; v = PyNumber_Long(tmp); Py_DECREF(tmp); } #endif if (likely(v)) { int one = 1; int is_little = (int)*(unsigned char *)&one; unsigned char *bytes = (unsigned char *)&val; int ret = _PyLong_AsByteArray((PyLongObject *)v, bytes, sizeof(val), is_little, !is_unsigned); Py_DECREF(v); if (likely(!ret)) return val; } #endif return (hsize_t)-1; } } static CYTHON_INLINE npy_uint32 __Pyx_PyInt_from_py_npy_uint32(PyObject* x) { const npy_uint32 neg_one = (npy_uint32)-1, const_zero = (npy_uint32)0; const int is_unsigned = const_zero < neg_one; if (sizeof(npy_uint32) == sizeof(char)) { if (is_unsigned) return (npy_uint32)__Pyx_PyInt_AsUnsignedChar(x); else return (npy_uint32)__Pyx_PyInt_AsSignedChar(x); } else if (sizeof(npy_uint32) == sizeof(short)) { if (is_unsigned) return (npy_uint32)__Pyx_PyInt_AsUnsignedShort(x); else return (npy_uint32)__Pyx_PyInt_AsSignedShort(x); } else if (sizeof(npy_uint32) == sizeof(int)) { if (is_unsigned) return (npy_uint32)__Pyx_PyInt_AsUnsignedInt(x); else return (npy_uint32)__Pyx_PyInt_AsSignedInt(x); } else if (sizeof(npy_uint32) == sizeof(long)) { if (is_unsigned) return (npy_uint32)__Pyx_PyInt_AsUnsignedLong(x); else return (npy_uint32)__Pyx_PyInt_AsSignedLong(x); } else if (sizeof(npy_uint32) == sizeof(PY_LONG_LONG)) { if (is_unsigned) return (npy_uint32)__Pyx_PyInt_AsUnsignedLongLong(x); else return (npy_uint32)__Pyx_PyInt_AsSignedLongLong(x); } else { #if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray) PyErr_SetString(PyExc_RuntimeError, "_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers"); #else npy_uint32 val; PyObject *v = __Pyx_PyNumber_Int(x); #if PY_VERSION_HEX < 0x03000000 if (likely(v) && !PyLong_Check(v)) { PyObject *tmp = v; v = PyNumber_Long(tmp); Py_DECREF(tmp); } #endif if (likely(v)) { int one = 1; int is_little = (int)*(unsigned char *)&one; unsigned char *bytes = (unsigned char *)&val; int ret = _PyLong_AsByteArray((PyLongObject *)v, bytes, sizeof(val), is_little, !is_unsigned); Py_DECREF(v); if (likely(!ret)) return val; } #endif return (npy_uint32)-1; } } static CYTHON_INLINE npy_int64 __Pyx_PyInt_from_py_npy_int64(PyObject* x) { const npy_int64 neg_one = (npy_int64)-1, const_zero = (npy_int64)0; const int is_unsigned = const_zero < neg_one; if (sizeof(npy_int64) == sizeof(char)) { if (is_unsigned) return (npy_int64)__Pyx_PyInt_AsUnsignedChar(x); else return (npy_int64)__Pyx_PyInt_AsSignedChar(x); } else if (sizeof(npy_int64) == sizeof(short)) { if (is_unsigned) return (npy_int64)__Pyx_PyInt_AsUnsignedShort(x); else return (npy_int64)__Pyx_PyInt_AsSignedShort(x); } else if (sizeof(npy_int64) == sizeof(int)) { if (is_unsigned) return (npy_int64)__Pyx_PyInt_AsUnsignedInt(x); else return (npy_int64)__Pyx_PyInt_AsSignedInt(x); } else if (sizeof(npy_int64) == sizeof(long)) { if (is_unsigned) return (npy_int64)__Pyx_PyInt_AsUnsignedLong(x); else return (npy_int64)__Pyx_PyInt_AsSignedLong(x); } else if (sizeof(npy_int64) == sizeof(PY_LONG_LONG)) { if (is_unsigned) return (npy_int64)__Pyx_PyInt_AsUnsignedLongLong(x); else return (npy_int64)__Pyx_PyInt_AsSignedLongLong(x); } else { #if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray) PyErr_SetString(PyExc_RuntimeError, "_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers"); #else npy_int64 val; PyObject *v = __Pyx_PyNumber_Int(x); #if PY_VERSION_HEX < 0x03000000 if (likely(v) && !PyLong_Check(v)) { PyObject *tmp = v; v = PyNumber_Long(tmp); Py_DECREF(tmp); } #endif if (likely(v)) { int one = 1; int is_little = (int)*(unsigned char *)&one; unsigned char *bytes = (unsigned char *)&val; int ret = _PyLong_AsByteArray((PyLongObject *)v, bytes, sizeof(val), is_little, !is_unsigned); Py_DECREF(v); if (likely(!ret)) return val; } #endif return (npy_int64)-1; } } static CYTHON_INLINE npy_uint64 __Pyx_PyInt_from_py_npy_uint64(PyObject* x) { const npy_uint64 neg_one = (npy_uint64)-1, const_zero = (npy_uint64)0; const int is_unsigned = const_zero < neg_one; if (sizeof(npy_uint64) == sizeof(char)) { if (is_unsigned) return (npy_uint64)__Pyx_PyInt_AsUnsignedChar(x); else return (npy_uint64)__Pyx_PyInt_AsSignedChar(x); } else if (sizeof(npy_uint64) == sizeof(short)) { if (is_unsigned) return (npy_uint64)__Pyx_PyInt_AsUnsignedShort(x); else return (npy_uint64)__Pyx_PyInt_AsSignedShort(x); } else if (sizeof(npy_uint64) == sizeof(int)) { if (is_unsigned) return (npy_uint64)__Pyx_PyInt_AsUnsignedInt(x); else return (npy_uint64)__Pyx_PyInt_AsSignedInt(x); } else if (sizeof(npy_uint64) == sizeof(long)) { if (is_unsigned) return (npy_uint64)__Pyx_PyInt_AsUnsignedLong(x); else return (npy_uint64)__Pyx_PyInt_AsSignedLong(x); } else if (sizeof(npy_uint64) == sizeof(PY_LONG_LONG)) { if (is_unsigned) return (npy_uint64)__Pyx_PyInt_AsUnsignedLongLong(x); else return (npy_uint64)__Pyx_PyInt_AsSignedLongLong(x); } else { #if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray) PyErr_SetString(PyExc_RuntimeError, "_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers"); #else npy_uint64 val; PyObject *v = __Pyx_PyNumber_Int(x); #if PY_VERSION_HEX < 0x03000000 if (likely(v) && !PyLong_Check(v)) { PyObject *tmp = v; v = PyNumber_Long(tmp); Py_DECREF(tmp); } #endif if (likely(v)) { int one = 1; int is_little = (int)*(unsigned char *)&one; unsigned char *bytes = (unsigned char *)&val; int ret = _PyLong_AsByteArray((PyLongObject *)v, bytes, sizeof(val), is_little, !is_unsigned); Py_DECREF(v); if (likely(!ret)) return val; } #endif return (npy_uint64)-1; } } static CYTHON_INLINE Py_intptr_t __Pyx_PyInt_from_py_Py_intptr_t(PyObject* x) { const Py_intptr_t neg_one = (Py_intptr_t)-1, const_zero = (Py_intptr_t)0; const int is_unsigned = const_zero < neg_one; if (sizeof(Py_intptr_t) == sizeof(char)) { if (is_unsigned) return (Py_intptr_t)__Pyx_PyInt_AsUnsignedChar(x); else return (Py_intptr_t)__Pyx_PyInt_AsSignedChar(x); } else if (sizeof(Py_intptr_t) == sizeof(short)) { if (is_unsigned) return (Py_intptr_t)__Pyx_PyInt_AsUnsignedShort(x); else return (Py_intptr_t)__Pyx_PyInt_AsSignedShort(x); } else if (sizeof(Py_intptr_t) == sizeof(int)) { if (is_unsigned) return (Py_intptr_t)__Pyx_PyInt_AsUnsignedInt(x); else return (Py_intptr_t)__Pyx_PyInt_AsSignedInt(x); } else if (sizeof(Py_intptr_t) == sizeof(long)) { if (is_unsigned) return (Py_intptr_t)__Pyx_PyInt_AsUnsignedLong(x); else return (Py_intptr_t)__Pyx_PyInt_AsSignedLong(x); } else if (sizeof(Py_intptr_t) == sizeof(PY_LONG_LONG)) { if (is_unsigned) return (Py_intptr_t)__Pyx_PyInt_AsUnsignedLongLong(x); else return (Py_intptr_t)__Pyx_PyInt_AsSignedLongLong(x); } else { #if CYTHON_COMPILING_IN_PYPY && !defined(_PyLong_AsByteArray) PyErr_SetString(PyExc_RuntimeError, "_PyLong_AsByteArray() not available in PyPy, cannot convert large numbers"); #else Py_intptr_t val; PyObject *v = __Pyx_PyNumber_Int(x); #if PY_VERSION_HEX < 0x03000000 if (likely(v) && !PyLong_Check(v)) { PyObject *tmp = v; v = PyNumber_Long(tmp); Py_DECREF(tmp); } #endif if (likely(v)) { int one = 1; int is_little = (int)*(unsigned char *)&one; unsigned char *bytes = (unsigned char *)&val; int ret = _PyLong_AsByteArray((PyLongObject *)v, bytes, sizeof(val), is_little, !is_unsigned); Py_DECREF(v); if (likely(!ret)) return val; } #endif return (Py_intptr_t)-1; } } #if CYTHON_CCOMPLEX #ifdef __cplusplus static CYTHON_INLINE __pyx_t_float_complex __pyx_t_float_complex_from_parts(float x, float y) { return ::std::complex< float >(x, y); } #else static CYTHON_INLINE __pyx_t_float_complex __pyx_t_float_complex_from_parts(float x, float y) { return x + y*(__pyx_t_float_complex)_Complex_I; } #endif #else static CYTHON_INLINE __pyx_t_float_complex __pyx_t_float_complex_from_parts(float x, float y) { __pyx_t_float_complex z; z.real = x; z.imag = y; return z; } #endif #if CYTHON_CCOMPLEX #else static CYTHON_INLINE int __Pyx_c_eqf(__pyx_t_float_complex a, __pyx_t_float_complex b) { return (a.real == b.real) && (a.imag == b.imag); } static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_sumf(__pyx_t_float_complex a, __pyx_t_float_complex b) { __pyx_t_float_complex z; z.real = a.real + b.real; z.imag = a.imag + b.imag; return z; } static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_difff(__pyx_t_float_complex a, __pyx_t_float_complex b) { __pyx_t_float_complex z; z.real = a.real - b.real; z.imag = a.imag - b.imag; return z; } static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_prodf(__pyx_t_float_complex a, __pyx_t_float_complex b) { __pyx_t_float_complex z; z.real = a.real * b.real - a.imag * b.imag; z.imag = a.real * b.imag + a.imag * b.real; return z; } static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_quotf(__pyx_t_float_complex a, __pyx_t_float_complex b) { __pyx_t_float_complex z; float denom = b.real * b.real + b.imag * b.imag; z.real = (a.real * b.real + a.imag * b.imag) / denom; z.imag = (a.imag * b.real - a.real * b.imag) / denom; return z; } static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_negf(__pyx_t_float_complex a) { __pyx_t_float_complex z; z.real = -a.real; z.imag = -a.imag; return z; } static CYTHON_INLINE int __Pyx_c_is_zerof(__pyx_t_float_complex a) { return (a.real == 0) && (a.imag == 0); } static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_conjf(__pyx_t_float_complex a) { __pyx_t_float_complex z; z.real = a.real; z.imag = -a.imag; return z; } #if 1 static CYTHON_INLINE float __Pyx_c_absf(__pyx_t_float_complex z) { #if !defined(HAVE_HYPOT) || defined(_MSC_VER) return sqrtf(z.real*z.real + z.imag*z.imag); #else return hypotf(z.real, z.imag); #endif } static CYTHON_INLINE __pyx_t_float_complex __Pyx_c_powf(__pyx_t_float_complex a, __pyx_t_float_complex b) { __pyx_t_float_complex z; float r, lnr, theta, z_r, z_theta; if (b.imag == 0 && b.real == (int)b.real) { if (b.real < 0) { float denom = a.real * a.real + a.imag * a.imag; a.real = a.real / denom; a.imag = -a.imag / denom; b.real = -b.real; } switch ((int)b.real) { case 0: z.real = 1; z.imag = 0; return z; case 1: return a; case 2: z = __Pyx_c_prodf(a, a); return __Pyx_c_prodf(a, a); case 3: z = __Pyx_c_prodf(a, a); return __Pyx_c_prodf(z, a); case 4: z = __Pyx_c_prodf(a, a); return __Pyx_c_prodf(z, z); } } if (a.imag == 0) { if (a.real == 0) { return a; } r = a.real; theta = 0; } else { r = __Pyx_c_absf(a); theta = atan2f(a.imag, a.real); } lnr = logf(r); z_r = expf(lnr * b.real - theta * b.imag); z_theta = theta * b.real + lnr * b.imag; z.real = z_r * cosf(z_theta); z.imag = z_r * sinf(z_theta); return z; } #endif #endif #if CYTHON_CCOMPLEX #ifdef __cplusplus static CYTHON_INLINE __pyx_t_double_complex __pyx_t_double_complex_from_parts(double x, double y) { return ::std::complex< double >(x, y); } #else static CYTHON_INLINE __pyx_t_double_complex __pyx_t_double_complex_from_parts(double x, double y) { return x + y*(__pyx_t_double_complex)_Complex_I; } #endif #else static CYTHON_INLINE __pyx_t_double_complex __pyx_t_double_complex_from_parts(double x, double y) { __pyx_t_double_complex z; z.real = x; z.imag = y; return z; } #endif #if CYTHON_CCOMPLEX #else static CYTHON_INLINE int __Pyx_c_eq(__pyx_t_double_complex a, __pyx_t_double_complex b) { return (a.real == b.real) && (a.imag == b.imag); } static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_sum(__pyx_t_double_complex a, __pyx_t_double_complex b) { __pyx_t_double_complex z; z.real = a.real + b.real; z.imag = a.imag + b.imag; return z; } static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_diff(__pyx_t_double_complex a, __pyx_t_double_complex b) { __pyx_t_double_complex z; z.real = a.real - b.real; z.imag = a.imag - b.imag; return z; } static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_prod(__pyx_t_double_complex a, __pyx_t_double_complex b) { __pyx_t_double_complex z; z.real = a.real * b.real - a.imag * b.imag; z.imag = a.real * b.imag + a.imag * b.real; return z; } static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_quot(__pyx_t_double_complex a, __pyx_t_double_complex b) { __pyx_t_double_complex z; double denom = b.real * b.real + b.imag * b.imag; z.real = (a.real * b.real + a.imag * b.imag) / denom; z.imag = (a.imag * b.real - a.real * b.imag) / denom; return z; } static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_neg(__pyx_t_double_complex a) { __pyx_t_double_complex z; z.real = -a.real; z.imag = -a.imag; return z; } static CYTHON_INLINE int __Pyx_c_is_zero(__pyx_t_double_complex a) { return (a.real == 0) && (a.imag == 0); } static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_conj(__pyx_t_double_complex a) { __pyx_t_double_complex z; z.real = a.real; z.imag = -a.imag; return z; } #if 1 static CYTHON_INLINE double __Pyx_c_abs(__pyx_t_double_complex z) { #if !defined(HAVE_HYPOT) || defined(_MSC_VER) return sqrt(z.real*z.real + z.imag*z.imag); #else return hypot(z.real, z.imag); #endif } static CYTHON_INLINE __pyx_t_double_complex __Pyx_c_pow(__pyx_t_double_complex a, __pyx_t_double_complex b) { __pyx_t_double_complex z; double r, lnr, theta, z_r, z_theta; if (b.imag == 0 && b.real == (int)b.real) { if (b.real < 0) { double denom = a.real * a.real + a.imag * a.imag; a.real = a.real / denom; a.imag = -a.imag / denom; b.real = -b.real; } switch ((int)b.real) { case 0: z.real = 1; z.imag = 0; return z; case 1: return a; case 2: z = __Pyx_c_prod(a, a); return __Pyx_c_prod(a, a); case 3: z = __Pyx_c_prod(a, a); return __Pyx_c_prod(z, a); case 4: z = __Pyx_c_prod(a, a); return __Pyx_c_prod(z, z); } } if (a.imag == 0) { if (a.real == 0) { return a; } r = a.real; theta = 0; } else { r = __Pyx_c_abs(a); theta = atan2(a.imag, a.real); } lnr = log(r); z_r = exp(lnr * b.real - theta * b.imag); z_theta = theta * b.real + lnr * b.imag; z.real = z_r * cos(z_theta); z.imag = z_r * sin(z_theta); return z; } #endif #endif static CYTHON_INLINE unsigned char __Pyx_PyInt_AsUnsignedChar(PyObject* x) { const unsigned char neg_one = (unsigned char)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(unsigned char) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(unsigned char)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to unsigned char" : "value too large to convert to unsigned char"); } return (unsigned char)-1; } return (unsigned char)val; } return (unsigned char)__Pyx_PyInt_AsUnsignedLong(x); } static CYTHON_INLINE unsigned short __Pyx_PyInt_AsUnsignedShort(PyObject* x) { const unsigned short neg_one = (unsigned short)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(unsigned short) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(unsigned short)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to unsigned short" : "value too large to convert to unsigned short"); } return (unsigned short)-1; } return (unsigned short)val; } return (unsigned short)__Pyx_PyInt_AsUnsignedLong(x); } static CYTHON_INLINE unsigned int __Pyx_PyInt_AsUnsignedInt(PyObject* x) { const unsigned int neg_one = (unsigned int)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(unsigned int) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(unsigned int)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to unsigned int" : "value too large to convert to unsigned int"); } return (unsigned int)-1; } return (unsigned int)val; } return (unsigned int)__Pyx_PyInt_AsUnsignedLong(x); } static CYTHON_INLINE char __Pyx_PyInt_AsChar(PyObject* x) { const char neg_one = (char)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(char) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(char)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to char" : "value too large to convert to char"); } return (char)-1; } return (char)val; } return (char)__Pyx_PyInt_AsLong(x); } static CYTHON_INLINE short __Pyx_PyInt_AsShort(PyObject* x) { const short neg_one = (short)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(short) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(short)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to short" : "value too large to convert to short"); } return (short)-1; } return (short)val; } return (short)__Pyx_PyInt_AsLong(x); } static CYTHON_INLINE int __Pyx_PyInt_AsInt(PyObject* x) { const int neg_one = (int)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(int) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(int)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to int" : "value too large to convert to int"); } return (int)-1; } return (int)val; } return (int)__Pyx_PyInt_AsLong(x); } static CYTHON_INLINE signed char __Pyx_PyInt_AsSignedChar(PyObject* x) { const signed char neg_one = (signed char)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(signed char) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(signed char)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to signed char" : "value too large to convert to signed char"); } return (signed char)-1; } return (signed char)val; } return (signed char)__Pyx_PyInt_AsSignedLong(x); } static CYTHON_INLINE signed short __Pyx_PyInt_AsSignedShort(PyObject* x) { const signed short neg_one = (signed short)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(signed short) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(signed short)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to signed short" : "value too large to convert to signed short"); } return (signed short)-1; } return (signed short)val; } return (signed short)__Pyx_PyInt_AsSignedLong(x); } static CYTHON_INLINE signed int __Pyx_PyInt_AsSignedInt(PyObject* x) { const signed int neg_one = (signed int)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(signed int) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(signed int)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to signed int" : "value too large to convert to signed int"); } return (signed int)-1; } return (signed int)val; } return (signed int)__Pyx_PyInt_AsSignedLong(x); } static CYTHON_INLINE int __Pyx_PyInt_AsLongDouble(PyObject* x) { const int neg_one = (int)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; if (sizeof(int) < sizeof(long)) { long val = __Pyx_PyInt_AsLong(x); if (unlikely(val != (long)(int)val)) { if (!unlikely(val == -1 && PyErr_Occurred())) { PyErr_SetString(PyExc_OverflowError, (is_unsigned && unlikely(val < 0)) ? "can't convert negative value to int" : "value too large to convert to int"); } return (int)-1; } return (int)val; } return (int)__Pyx_PyInt_AsLong(x); } static CYTHON_INLINE unsigned long __Pyx_PyInt_AsUnsignedLong(PyObject* x) { const unsigned long neg_one = (unsigned long)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; #if PY_VERSION_HEX < 0x03000000 if (likely(PyInt_Check(x))) { long val = PyInt_AS_LONG(x); if (is_unsigned && unlikely(val < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to unsigned long"); return (unsigned long)-1; } return (unsigned long)val; } else #endif if (likely(PyLong_Check(x))) { if (is_unsigned) { if (unlikely(Py_SIZE(x) < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to unsigned long"); return (unsigned long)-1; } return (unsigned long)PyLong_AsUnsignedLong(x); } else { return (unsigned long)PyLong_AsLong(x); } } else { unsigned long val; PyObject *tmp = __Pyx_PyNumber_Int(x); if (!tmp) return (unsigned long)-1; val = __Pyx_PyInt_AsUnsignedLong(tmp); Py_DECREF(tmp); return val; } } static CYTHON_INLINE unsigned PY_LONG_LONG __Pyx_PyInt_AsUnsignedLongLong(PyObject* x) { const unsigned PY_LONG_LONG neg_one = (unsigned PY_LONG_LONG)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; #if PY_VERSION_HEX < 0x03000000 if (likely(PyInt_Check(x))) { long val = PyInt_AS_LONG(x); if (is_unsigned && unlikely(val < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to unsigned PY_LONG_LONG"); return (unsigned PY_LONG_LONG)-1; } return (unsigned PY_LONG_LONG)val; } else #endif if (likely(PyLong_Check(x))) { if (is_unsigned) { if (unlikely(Py_SIZE(x) < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to unsigned PY_LONG_LONG"); return (unsigned PY_LONG_LONG)-1; } return (unsigned PY_LONG_LONG)PyLong_AsUnsignedLongLong(x); } else { return (unsigned PY_LONG_LONG)PyLong_AsLongLong(x); } } else { unsigned PY_LONG_LONG val; PyObject *tmp = __Pyx_PyNumber_Int(x); if (!tmp) return (unsigned PY_LONG_LONG)-1; val = __Pyx_PyInt_AsUnsignedLongLong(tmp); Py_DECREF(tmp); return val; } } static CYTHON_INLINE long __Pyx_PyInt_AsLong(PyObject* x) { const long neg_one = (long)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; #if PY_VERSION_HEX < 0x03000000 if (likely(PyInt_Check(x))) { long val = PyInt_AS_LONG(x); if (is_unsigned && unlikely(val < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to long"); return (long)-1; } return (long)val; } else #endif if (likely(PyLong_Check(x))) { if (is_unsigned) { if (unlikely(Py_SIZE(x) < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to long"); return (long)-1; } return (long)PyLong_AsUnsignedLong(x); } else { return (long)PyLong_AsLong(x); } } else { long val; PyObject *tmp = __Pyx_PyNumber_Int(x); if (!tmp) return (long)-1; val = __Pyx_PyInt_AsLong(tmp); Py_DECREF(tmp); return val; } } static CYTHON_INLINE PY_LONG_LONG __Pyx_PyInt_AsLongLong(PyObject* x) { const PY_LONG_LONG neg_one = (PY_LONG_LONG)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; #if PY_VERSION_HEX < 0x03000000 if (likely(PyInt_Check(x))) { long val = PyInt_AS_LONG(x); if (is_unsigned && unlikely(val < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to PY_LONG_LONG"); return (PY_LONG_LONG)-1; } return (PY_LONG_LONG)val; } else #endif if (likely(PyLong_Check(x))) { if (is_unsigned) { if (unlikely(Py_SIZE(x) < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to PY_LONG_LONG"); return (PY_LONG_LONG)-1; } return (PY_LONG_LONG)PyLong_AsUnsignedLongLong(x); } else { return (PY_LONG_LONG)PyLong_AsLongLong(x); } } else { PY_LONG_LONG val; PyObject *tmp = __Pyx_PyNumber_Int(x); if (!tmp) return (PY_LONG_LONG)-1; val = __Pyx_PyInt_AsLongLong(tmp); Py_DECREF(tmp); return val; } } static CYTHON_INLINE signed long __Pyx_PyInt_AsSignedLong(PyObject* x) { const signed long neg_one = (signed long)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; #if PY_VERSION_HEX < 0x03000000 if (likely(PyInt_Check(x))) { long val = PyInt_AS_LONG(x); if (is_unsigned && unlikely(val < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to signed long"); return (signed long)-1; } return (signed long)val; } else #endif if (likely(PyLong_Check(x))) { if (is_unsigned) { if (unlikely(Py_SIZE(x) < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to signed long"); return (signed long)-1; } return (signed long)PyLong_AsUnsignedLong(x); } else { return (signed long)PyLong_AsLong(x); } } else { signed long val; PyObject *tmp = __Pyx_PyNumber_Int(x); if (!tmp) return (signed long)-1; val = __Pyx_PyInt_AsSignedLong(tmp); Py_DECREF(tmp); return val; } } static CYTHON_INLINE signed PY_LONG_LONG __Pyx_PyInt_AsSignedLongLong(PyObject* x) { const signed PY_LONG_LONG neg_one = (signed PY_LONG_LONG)-1, const_zero = 0; const int is_unsigned = neg_one > const_zero; #if PY_VERSION_HEX < 0x03000000 if (likely(PyInt_Check(x))) { long val = PyInt_AS_LONG(x); if (is_unsigned && unlikely(val < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to signed PY_LONG_LONG"); return (signed PY_LONG_LONG)-1; } return (signed PY_LONG_LONG)val; } else #endif if (likely(PyLong_Check(x))) { if (is_unsigned) { if (unlikely(Py_SIZE(x) < 0)) { PyErr_SetString(PyExc_OverflowError, "can't convert negative value to signed PY_LONG_LONG"); return (signed PY_LONG_LONG)-1; } return (signed PY_LONG_LONG)PyLong_AsUnsignedLongLong(x); } else { return (signed PY_LONG_LONG)PyLong_AsLongLong(x); } } else { signed PY_LONG_LONG val; PyObject *tmp = __Pyx_PyNumber_Int(x); if (!tmp) return (signed PY_LONG_LONG)-1; val = __Pyx_PyInt_AsSignedLongLong(tmp); Py_DECREF(tmp); return val; } } static void __Pyx_WriteUnraisable(const char *name, CYTHON_UNUSED int clineno, CYTHON_UNUSED int lineno, CYTHON_UNUSED const char *filename) { PyObject *old_exc, *old_val, *old_tb; PyObject *ctx; __Pyx_ErrFetch(&old_exc, &old_val, &old_tb); #if PY_MAJOR_VERSION < 3 ctx = PyString_FromString(name); #else ctx = PyUnicode_FromString(name); #endif __Pyx_ErrRestore(old_exc, old_val, old_tb); if (!ctx) { PyErr_WriteUnraisable(Py_None); } else { PyErr_WriteUnraisable(ctx); Py_DECREF(ctx); } } static int __Pyx_check_binary_version(void) { char ctversion[4], rtversion[4]; PyOS_snprintf(ctversion, 4, "%d.%d", PY_MAJOR_VERSION, PY_MINOR_VERSION); PyOS_snprintf(rtversion, 4, "%s", Py_GetVersion()); if (ctversion[0] != rtversion[0] || ctversion[2] != rtversion[2]) { char message[200]; PyOS_snprintf(message, sizeof(message), "compiletime version %s of module '%.100s' " "does not match runtime version %s", ctversion, __Pyx_MODULE_NAME, rtversion); #if PY_VERSION_HEX < 0x02050000 return PyErr_Warn(NULL, message); #else return PyErr_WarnEx(NULL, message, 1); #endif } return 0; } #ifndef __PYX_HAVE_RT_ImportModule #define __PYX_HAVE_RT_ImportModule static PyObject *__Pyx_ImportModule(const char *name) { PyObject *py_name = 0; PyObject *py_module = 0; py_name = __Pyx_PyIdentifier_FromString(name); if (!py_name) goto bad; py_module = PyImport_Import(py_name); Py_DECREF(py_name); return py_module; bad: Py_XDECREF(py_name); return 0; } #endif #ifndef __PYX_HAVE_RT_ImportType #define __PYX_HAVE_RT_ImportType static PyTypeObject *__Pyx_ImportType(const char *module_name, const char *class_name, size_t size, int strict) { PyObject *py_module = 0; PyObject *result = 0; PyObject *py_name = 0; char warning[200]; py_module = __Pyx_ImportModule(module_name); if (!py_module) goto bad; py_name = __Pyx_PyIdentifier_FromString(class_name); if (!py_name) goto bad; result = PyObject_GetAttr(py_module, py_name); Py_DECREF(py_name); py_name = 0; Py_DECREF(py_module); py_module = 0; if (!result) goto bad; if (!PyType_Check(result)) { PyErr_Format(PyExc_TypeError, "%s.%s is not a type object", module_name, class_name); goto bad; } if (!strict && (size_t)((PyTypeObject *)result)->tp_basicsize > size) { PyOS_snprintf(warning, sizeof(warning), "%s.%s size changed, may indicate binary incompatibility", module_name, class_name); #if PY_VERSION_HEX < 0x02050000 if (PyErr_Warn(NULL, warning) < 0) goto bad; #else if (PyErr_WarnEx(NULL, warning, 0) < 0) goto bad; #endif } else if ((size_t)((PyTypeObject *)result)->tp_basicsize != size) { PyErr_Format(PyExc_ValueError, "%s.%s has the wrong size, try recompiling", module_name, class_name); goto bad; } return (PyTypeObject *)result; bad: Py_XDECREF(py_module); Py_XDECREF(result); return NULL; } #endif static void* __Pyx_GetVtable(PyObject *dict) { void* ptr; PyObject *ob = PyMapping_GetItemString(dict, (char *)"__pyx_vtable__"); if (!ob) goto bad; #if PY_VERSION_HEX >= 0x02070000 && !(PY_MAJOR_VERSION==3&&PY_MINOR_VERSION==0) ptr = PyCapsule_GetPointer(ob, 0); #else ptr = PyCObject_AsVoidPtr(ob); #endif if (!ptr && !PyErr_Occurred()) PyErr_SetString(PyExc_RuntimeError, "invalid vtable found for imported type"); Py_DECREF(ob); return ptr; bad: Py_XDECREF(ob); return NULL; } static int __Pyx_SetVtable(PyObject *dict, void *vtable) { #if PY_VERSION_HEX >= 0x02070000 && !(PY_MAJOR_VERSION==3&&PY_MINOR_VERSION==0) PyObject *ob = PyCapsule_New(vtable, 0, 0); #else PyObject *ob = PyCObject_FromVoidPtr(vtable, 0); #endif if (!ob) goto bad; if (PyDict_SetItemString(dict, "__pyx_vtable__", ob) < 0) goto bad; Py_DECREF(ob); return 0; bad: Py_XDECREF(ob); return -1; } static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line) { int start = 0, mid = 0, end = count - 1; if (end >= 0 && code_line > entries[end].code_line) { return count; } while (start < end) { mid = (start + end) / 2; if (code_line < entries[mid].code_line) { end = mid; } else if (code_line > entries[mid].code_line) { start = mid + 1; } else { return mid; } } if (code_line <= entries[mid].code_line) { return mid; } else { return mid + 1; } } static PyCodeObject *__pyx_find_code_object(int code_line) { PyCodeObject* code_object; int pos; if (unlikely(!code_line) || unlikely(!__pyx_code_cache.entries)) { return NULL; } pos = __pyx_bisect_code_objects(__pyx_code_cache.entries, __pyx_code_cache.count, code_line); if (unlikely(pos >= __pyx_code_cache.count) || unlikely(__pyx_code_cache.entries[pos].code_line != code_line)) { return NULL; } code_object = __pyx_code_cache.entries[pos].code_object; Py_INCREF(code_object); return code_object; } static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object) { int pos, i; __Pyx_CodeObjectCacheEntry* entries = __pyx_code_cache.entries; if (unlikely(!code_line)) { return; } if (unlikely(!entries)) { entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry)); if (likely(entries)) { __pyx_code_cache.entries = entries; __pyx_code_cache.max_count = 64; __pyx_code_cache.count = 1; entries[0].code_line = code_line; entries[0].code_object = code_object; Py_INCREF(code_object); } return; } pos = __pyx_bisect_code_objects(__pyx_code_cache.entries, __pyx_code_cache.count, code_line); if ((pos < __pyx_code_cache.count) && unlikely(__pyx_code_cache.entries[pos].code_line == code_line)) { PyCodeObject* tmp = entries[pos].code_object; entries[pos].code_object = code_object; Py_DECREF(tmp); return; } if (__pyx_code_cache.count == __pyx_code_cache.max_count) { int new_max = __pyx_code_cache.max_count + 64; entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc( __pyx_code_cache.entries, new_max*sizeof(__Pyx_CodeObjectCacheEntry)); if (unlikely(!entries)) { return; } __pyx_code_cache.entries = entries; __pyx_code_cache.max_count = new_max; } for (i=__pyx_code_cache.count; i>pos; i--) { entries[i] = entries[i-1]; } entries[pos].code_line = code_line; entries[pos].code_object = code_object; __pyx_code_cache.count++; Py_INCREF(code_object); } #include "compile.h" #include "frameobject.h" #include "traceback.h" static PyCodeObject* __Pyx_CreateCodeObjectForTraceback( const char *funcname, int c_line, int py_line, const char *filename) { PyCodeObject *py_code = 0; PyObject *py_srcfile = 0; PyObject *py_funcname = 0; #if PY_MAJOR_VERSION < 3 py_srcfile = PyString_FromString(filename); #else py_srcfile = PyUnicode_FromString(filename); #endif if (!py_srcfile) goto bad; if (c_line) { #if PY_MAJOR_VERSION < 3 py_funcname = PyString_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line); #else py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line); #endif } else { #if PY_MAJOR_VERSION < 3 py_funcname = PyString_FromString(funcname); #else py_funcname = PyUnicode_FromString(funcname); #endif } if (!py_funcname) goto bad; py_code = __Pyx_PyCode_New( 0, /*int argcount,*/ 0, /*int kwonlyargcount,*/ 0, /*int nlocals,*/ 0, /*int stacksize,*/ 0, /*int flags,*/ __pyx_empty_bytes, /*PyObject *code,*/ __pyx_empty_tuple, /*PyObject *consts,*/ __pyx_empty_tuple, /*PyObject *names,*/ __pyx_empty_tuple, /*PyObject *varnames,*/ __pyx_empty_tuple, /*PyObject *freevars,*/ __pyx_empty_tuple, /*PyObject *cellvars,*/ py_srcfile, /*PyObject *filename,*/ py_funcname, /*PyObject *name,*/ py_line, /*int firstlineno,*/ __pyx_empty_bytes /*PyObject *lnotab*/ ); Py_DECREF(py_srcfile); Py_DECREF(py_funcname); return py_code; bad: Py_XDECREF(py_srcfile); Py_XDECREF(py_funcname); return NULL; } static void __Pyx_AddTraceback(const char *funcname, int c_line, int py_line, const char *filename) { PyCodeObject *py_code = 0; PyObject *py_globals = 0; PyFrameObject *py_frame = 0; py_code = __pyx_find_code_object(c_line ? c_line : py_line); if (!py_code) { py_code = __Pyx_CreateCodeObjectForTraceback( funcname, c_line, py_line, filename); if (!py_code) goto bad; __pyx_insert_code_object(c_line ? c_line : py_line, py_code); } py_globals = PyModule_GetDict(__pyx_m); if (!py_globals) goto bad; py_frame = PyFrame_New( PyThreadState_GET(), /*PyThreadState *tstate,*/ py_code, /*PyCodeObject *code,*/ py_globals, /*PyObject *globals,*/ 0 /*PyObject *locals*/ ); if (!py_frame) goto bad; py_frame->f_lineno = py_line; PyTraceBack_Here(py_frame); bad: Py_XDECREF(py_code); Py_XDECREF(py_frame); } static int __Pyx_InitStrings(__Pyx_StringTabEntry *t) { while (t->p) { #if PY_MAJOR_VERSION < 3 if (t->is_unicode) { *t->p = PyUnicode_DecodeUTF8(t->s, t->n - 1, NULL); } else if (t->intern) { *t->p = PyString_InternFromString(t->s); } else { *t->p = PyString_FromStringAndSize(t->s, t->n - 1); } #else /* Python 3+ has unicode identifiers */ if (t->is_unicode | t->is_str) { if (t->intern) { *t->p = PyUnicode_InternFromString(t->s); } else if (t->encoding) { *t->p = PyUnicode_Decode(t->s, t->n - 1, t->encoding, NULL); } else { *t->p = PyUnicode_FromStringAndSize(t->s, t->n - 1); } } else { *t->p = PyBytes_FromStringAndSize(t->s, t->n - 1); } #endif if (!*t->p) return -1; ++t; } return 0; } /* Type Conversion Functions */ static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject* x) { int is_true = x == Py_True; if (is_true | (x == Py_False) | (x == Py_None)) return is_true; else return PyObject_IsTrue(x); } static CYTHON_INLINE PyObject* __Pyx_PyNumber_Int(PyObject* x) { PyNumberMethods *m; const char *name = NULL; PyObject *res = NULL; #if PY_VERSION_HEX < 0x03000000 if (PyInt_Check(x) || PyLong_Check(x)) #else if (PyLong_Check(x)) #endif return Py_INCREF(x), x; m = Py_TYPE(x)->tp_as_number; #if PY_VERSION_HEX < 0x03000000 if (m && m->nb_int) { name = "int"; res = PyNumber_Int(x); } else if (m && m->nb_long) { name = "long"; res = PyNumber_Long(x); } #else if (m && m->nb_int) { name = "int"; res = PyNumber_Long(x); } #endif if (res) { #if PY_VERSION_HEX < 0x03000000 if (!PyInt_Check(res) && !PyLong_Check(res)) { #else if (!PyLong_Check(res)) { #endif PyErr_Format(PyExc_TypeError, "__%s__ returned non-%s (type %.200s)", name, name, Py_TYPE(res)->tp_name); Py_DECREF(res); return NULL; } } else if (!PyErr_Occurred()) { PyErr_SetString(PyExc_TypeError, "an integer is required"); } return res; } static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject* b) { Py_ssize_t ival; PyObject* x = PyNumber_Index(b); if (!x) return -1; ival = PyInt_AsSsize_t(x); Py_DECREF(x); return ival; } static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t ival) { #if PY_VERSION_HEX < 0x02050000 if (ival <= LONG_MAX) return PyInt_FromLong((long)ival); else { unsigned char *bytes = (unsigned char *) &ival; int one = 1; int little = (int)*(unsigned char*)&one; return _PyLong_FromByteArray(bytes, sizeof(size_t), little, 0); } #else return PyInt_FromSize_t(ival); #endif } static CYTHON_INLINE size_t __Pyx_PyInt_AsSize_t(PyObject* x) { unsigned PY_LONG_LONG val = __Pyx_PyInt_AsUnsignedLongLong(x); if (unlikely(val == (unsigned PY_LONG_LONG)-1 && PyErr_Occurred())) { return (size_t)-1; } else if (unlikely(val != (unsigned PY_LONG_LONG)(size_t)val)) { PyErr_SetString(PyExc_OverflowError, "value too large to convert to size_t"); return (size_t)-1; } return (size_t)val; } #endif /* Py_PYTHON_H */