{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "We want to group by multi-valued columns. For example, take this dataset:" ] }, { "cell_type": "code", "execution_count": 1, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/html": [ "
\n", " | left | \n", "right | \n", "value | \n", "
---|---|---|---|
0 | \n", "[a, b] | \n", "[x, y] | \n", "3 | \n", "
1 | \n", "[a, c] | \n", "[x, z] | \n", "2 | \n", "
Generated by Cython 0.23.4
\n", "\n",
" Yellow lines hint at Python interaction.
\n",
" Click on a line that starts with a \"+
\" to see the C code that Cython generated for it.\n",
"
01:
\n",
"+02: cimport numpy as np\n", "
__Pyx_TraceLine(2,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = PyDict_New(); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_1);\n", " if (PyDict_SetItem(__pyx_d, __pyx_n_s_test, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;\n", "
03:
\n",
"+04: def cython_kpartite(np.ndarray npdata):\n", "
/* Python wrapper */\n", "static PyObject *__pyx_pw_46_cython_magic_61780ddc8d4e3e1667c3753a9a52fcd2_1cython_kpartite(PyObject *__pyx_self, PyObject *__pyx_v_npdata); /*proto*/\n", "static PyMethodDef __pyx_mdef_46_cython_magic_61780ddc8d4e3e1667c3753a9a52fcd2_1cython_kpartite = {\"cython_kpartite\", (PyCFunction)__pyx_pw_46_cython_magic_61780ddc8d4e3e1667c3753a9a52fcd2_1cython_kpartite, METH_O, 0};\n", "static PyObject *__pyx_pw_46_cython_magic_61780ddc8d4e3e1667c3753a9a52fcd2_1cython_kpartite(PyObject *__pyx_self, PyObject *__pyx_v_npdata) {\n", " PyObject *__pyx_r = 0;\n", " __Pyx_RefNannyDeclarations\n", " __Pyx_RefNannySetupContext(\"cython_kpartite (wrapper)\", 0);\n", " if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_npdata), __pyx_ptype_5numpy_ndarray, 1, \"npdata\", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __pyx_r = __pyx_pf_46_cython_magic_61780ddc8d4e3e1667c3753a9a52fcd2_cython_kpartite(__pyx_self, ((PyArrayObject *)__pyx_v_npdata));\n", " CYTHON_UNUSED int __pyx_lineno = 0;\n", " CYTHON_UNUSED const char *__pyx_filename = NULL;\n", " CYTHON_UNUSED int __pyx_clineno = 0;\n", "\n", " /* function exit code */\n", " goto __pyx_L0;\n", " __pyx_L1_error:;\n", " __pyx_r = NULL;\n", " __pyx_L0:;\n", " __Pyx_RefNannyFinishContext();\n", " return __pyx_r;\n", "}\n", "\n", "static PyObject *__pyx_pf_46_cython_magic_61780ddc8d4e3e1667c3753a9a52fcd2_cython_kpartite(CYTHON_UNUSED PyObject *__pyx_self, PyArrayObject *__pyx_v_npdata) {\n", " int __pyx_v_index;\n", " PyArrayObject *__pyx_v_row = 0;\n", " PyObject *__pyx_v_left = 0;\n", " PyObject *__pyx_v_right = 0;\n", " double __pyx_v_value;\n", " PyObject *__pyx_v_a = 0;\n", " PyObject *__pyx_v_b = 0;\n", " PyObject *__pyx_v_key = 0;\n", " PyObject *__pyx_v_result = 0;\n", " PyObject *__pyx_r = NULL;\n", " __Pyx_TraceDeclarations\n", " __Pyx_TraceFrameInit(__pyx_codeobj_)\n", " __Pyx_RefNannyDeclarations\n", " __Pyx_RefNannySetupContext(\"cython_kpartite\", 0);\n", " __Pyx_TraceCall(\"cython_kpartite\", __pyx_f[0], 4, 0, {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; __pyx_clineno = __LINE__; goto __pyx_L1_error;});\n", "/* … */\n", " /* function exit code */\n", " __pyx_L1_error:;\n", " __Pyx_XDECREF(__pyx_t_1);\n", " __Pyx_XDECREF(__pyx_t_6);\n", " __Pyx_XDECREF(__pyx_t_8);\n", " __Pyx_XDECREF(__pyx_t_9);\n", " __Pyx_XDECREF(__pyx_t_10);\n", " __Pyx_AddTraceback(\"_cython_magic_61780ddc8d4e3e1667c3753a9a52fcd2.cython_kpartite\", __pyx_clineno, __pyx_lineno, __pyx_filename);\n", " __pyx_r = NULL;\n", " __pyx_L0:;\n", " __Pyx_XDECREF((PyObject *)__pyx_v_row);\n", " __Pyx_XDECREF(__pyx_v_left);\n", " __Pyx_XDECREF(__pyx_v_right);\n", " __Pyx_XDECREF(__pyx_v_a);\n", " __Pyx_XDECREF(__pyx_v_b);\n", " __Pyx_XDECREF(__pyx_v_key);\n", " __Pyx_XDECREF(__pyx_v_result);\n", " __Pyx_XGIVEREF(__pyx_r);\n", " __Pyx_TraceReturn(__pyx_r, 0);\n", " __Pyx_RefNannyFinishContext();\n", " return __pyx_r;\n", "}\n", "/* … */\n", " __pyx_tuple__8 = PyTuple_Pack(10, __pyx_n_s_npdata, __pyx_n_s_index, __pyx_n_s_row, __pyx_n_s_left, __pyx_n_s_right, __pyx_n_s_value, __pyx_n_s_a, __pyx_n_s_b, __pyx_n_s_key, __pyx_n_s_result); if (unlikely(!__pyx_tuple__8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_tuple__8);\n", " __Pyx_GIVEREF(__pyx_tuple__8);\n", "/* … */\n", " __Pyx_TraceLine(4,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = __Pyx_CyFunction_NewEx(&__pyx_mdef_46_cython_magic_61780ddc8d4e3e1667c3753a9a52fcd2_1cython_kpartite, 0, __pyx_n_s_cython_kpartite, NULL, __pyx_n_s_cython_magic_61780ddc8d4e3e1667, __pyx_d, ((PyObject *)__pyx_codeobj_)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_1);\n", " if (PyDict_SetItem(__pyx_d, __pyx_n_s_cython_kpartite, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 4; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;\n", "
05: cdef int index\n", "
06: cdef np.ndarray row\n", "
07: cdef list left, right\n", "
08: cdef double value\n", "
09: cdef str a, b\n", "
10: cdef tuple key\n", "
+11: cdef dict result = {}\n", "
__Pyx_TraceLine(11,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 11; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = PyDict_New(); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 11; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_1);\n", " __pyx_v_result = ((PyObject*)__pyx_t_1);\n", " __pyx_t_1 = 0;\n", "
+12: for index in range(npdata.shape[0]):\n", "
__Pyx_TraceLine(12,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 12; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_2 = (__pyx_v_npdata->dimensions[0]);\n", " for (__pyx_t_3 = 0; __pyx_t_3 < __pyx_t_2; __pyx_t_3+=1) {\n", " __pyx_v_index = __pyx_t_3;\n", "
+13: row = npdata[index]\n", "
__Pyx_TraceLine(13,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 13; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = __Pyx_GetItemInt(((PyObject *)__pyx_v_npdata), __pyx_v_index, int, 1, __Pyx_PyInt_From_int, 0, 1, 1); if (unlikely(__pyx_t_1 == NULL)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 13; __pyx_clineno = __LINE__; goto __pyx_L1_error;};\n", " __Pyx_GOTREF(__pyx_t_1);\n", " if (!(likely(((__pyx_t_1) == Py_None) || likely(__Pyx_TypeTest(__pyx_t_1, __pyx_ptype_5numpy_ndarray))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 13; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_XDECREF_SET(__pyx_v_row, ((PyArrayObject *)__pyx_t_1));\n", " __pyx_t_1 = 0;\n", "
+14: left = row[0]\n", "
__Pyx_TraceLine(14,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 14; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = __Pyx_GetItemInt(((PyObject *)__pyx_v_row), 0, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(__pyx_t_1 == NULL)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 14; __pyx_clineno = __LINE__; goto __pyx_L1_error;};\n", " __Pyx_GOTREF(__pyx_t_1);\n", " if (!(likely(PyList_CheckExact(__pyx_t_1))||((__pyx_t_1) == Py_None)||(PyErr_Format(PyExc_TypeError, \"Expected %.16s, got %.200s\", \"list\", Py_TYPE(__pyx_t_1)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 14; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_XDECREF_SET(__pyx_v_left, ((PyObject*)__pyx_t_1));\n", " __pyx_t_1 = 0;\n", "
+15: right = row[1]\n", "
__Pyx_TraceLine(15,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 15; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = __Pyx_GetItemInt(((PyObject *)__pyx_v_row), 1, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(__pyx_t_1 == NULL)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 15; __pyx_clineno = __LINE__; goto __pyx_L1_error;};\n", " __Pyx_GOTREF(__pyx_t_1);\n", " if (!(likely(PyList_CheckExact(__pyx_t_1))||((__pyx_t_1) == Py_None)||(PyErr_Format(PyExc_TypeError, \"Expected %.16s, got %.200s\", \"list\", Py_TYPE(__pyx_t_1)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 15; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_XDECREF_SET(__pyx_v_right, ((PyObject*)__pyx_t_1));\n", " __pyx_t_1 = 0;\n", "
+16: value = row[2]\n", "
__Pyx_TraceLine(16,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 16; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = __Pyx_GetItemInt(((PyObject *)__pyx_v_row), 2, long, 1, __Pyx_PyInt_From_long, 0, 0, 1); if (unlikely(__pyx_t_1 == NULL)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 16; __pyx_clineno = __LINE__; goto __pyx_L1_error;};\n", " __Pyx_GOTREF(__pyx_t_1);\n", " __pyx_t_4 = __pyx_PyFloat_AsDouble(__pyx_t_1); if (unlikely((__pyx_t_4 == (double)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 16; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;\n", " __pyx_v_value = __pyx_t_4;\n", "
+17: for a in left:\n", "
__Pyx_TraceLine(17,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " if (unlikely(__pyx_v_left == Py_None)) {\n", " PyErr_SetString(PyExc_TypeError, \"'NoneType' object is not iterable\");\n", " {__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " __pyx_t_1 = __pyx_v_left; __Pyx_INCREF(__pyx_t_1); __pyx_t_5 = 0;\n", " for (;;) {\n", " if (__pyx_t_5 >= PyList_GET_SIZE(__pyx_t_1)) break;\n", " #if CYTHON_COMPILING_IN_CPYTHON\n", " __pyx_t_6 = PyList_GET_ITEM(__pyx_t_1, __pyx_t_5); __Pyx_INCREF(__pyx_t_6); __pyx_t_5++; if (unlikely(0 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " #else\n", " __pyx_t_6 = PySequence_ITEM(__pyx_t_1, __pyx_t_5); __pyx_t_5++; if (unlikely(!__pyx_t_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_6);\n", " #endif\n", " if (!(likely(PyString_CheckExact(__pyx_t_6))||((__pyx_t_6) == Py_None)||(PyErr_Format(PyExc_TypeError, \"Expected %.16s, got %.200s\", \"str\", Py_TYPE(__pyx_t_6)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_XDECREF_SET(__pyx_v_a, ((PyObject*)__pyx_t_6));\n", " __pyx_t_6 = 0;\n", "/* … */\n", " __Pyx_TraceLine(17,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " }\n", " __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;\n", " }\n", "
+18: for b in right:\n", "
__Pyx_TraceLine(18,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " if (unlikely(__pyx_v_right == Py_None)) {\n", " PyErr_SetString(PyExc_TypeError, \"'NoneType' object is not iterable\");\n", " {__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " __pyx_t_6 = __pyx_v_right; __Pyx_INCREF(__pyx_t_6); __pyx_t_7 = 0;\n", " for (;;) {\n", " if (__pyx_t_7 >= PyList_GET_SIZE(__pyx_t_6)) break;\n", " #if CYTHON_COMPILING_IN_CPYTHON\n", " __pyx_t_8 = PyList_GET_ITEM(__pyx_t_6, __pyx_t_7); __Pyx_INCREF(__pyx_t_8); __pyx_t_7++; if (unlikely(0 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " #else\n", " __pyx_t_8 = PySequence_ITEM(__pyx_t_6, __pyx_t_7); __pyx_t_7++; if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_8);\n", " #endif\n", " if (!(likely(PyString_CheckExact(__pyx_t_8))||((__pyx_t_8) == Py_None)||(PyErr_Format(PyExc_TypeError, \"Expected %.16s, got %.200s\", \"str\", Py_TYPE(__pyx_t_8)->tp_name), 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_XDECREF_SET(__pyx_v_b, ((PyObject*)__pyx_t_8));\n", " __pyx_t_8 = 0;\n", "/* … */\n", " __Pyx_TraceLine(18,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " }\n", " __Pyx_DECREF(__pyx_t_6); __pyx_t_6 = 0;\n", "
+19: key = a, b\n", "
__Pyx_TraceLine(19,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_8 = PyTuple_New(2); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_8);\n", " __Pyx_INCREF(__pyx_v_a);\n", " __Pyx_GIVEREF(__pyx_v_a);\n", " PyTuple_SET_ITEM(__pyx_t_8, 0, __pyx_v_a);\n", " __Pyx_INCREF(__pyx_v_b);\n", " __Pyx_GIVEREF(__pyx_v_b);\n", " PyTuple_SET_ITEM(__pyx_t_8, 1, __pyx_v_b);\n", " __Pyx_XDECREF_SET(__pyx_v_key, ((PyObject*)__pyx_t_8));\n", " __pyx_t_8 = 0;\n", "
+20: result[key] = result.get(key, 0) + value\n", "
__Pyx_TraceLine(20,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_8 = __Pyx_PyDict_GetItemDefault(__pyx_v_result, __pyx_v_key, __pyx_int_0); if (unlikely(!__pyx_t_8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_8);\n", " __pyx_t_9 = PyFloat_FromDouble(__pyx_v_value); if (unlikely(!__pyx_t_9)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_9);\n", " __pyx_t_10 = PyNumber_Add(__pyx_t_8, __pyx_t_9); if (unlikely(!__pyx_t_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_10);\n", " __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;\n", " __Pyx_DECREF(__pyx_t_9); __pyx_t_9 = 0;\n", " if (unlikely(PyDict_SetItem(__pyx_v_result, __pyx_v_key, __pyx_t_10) < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_DECREF(__pyx_t_10); __pyx_t_10 = 0;\n", "
+21: return result\n", "
__Pyx_TraceLine(21,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __Pyx_XDECREF(__pyx_r);\n", " __Pyx_INCREF(__pyx_v_result);\n", " __pyx_r = __pyx_v_result;\n", " goto __pyx_L0;\n", "
Generated by Cython 0.23.4
\n", "\n",
" Yellow lines hint at Python interaction.
\n",
" Click on a line that starts with a \"+
\" to see the C code that Cython generated for it.\n",
"
01:
\n",
"+02: cimport numpy as np\n", "
__Pyx_TraceLine(2,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = PyDict_New(); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_1);\n", " if (PyDict_SetItem(__pyx_d, __pyx_n_s_test, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;\n", "
03:
\n",
"04: # cimport cython\n", "
05: # @cython.boundscheck(False)\n", "
06: # @cython.wraparound(False)\n", "
07: # @cython.overflowcheck(False)\n", "
08: # @cython.nonecheck(False)\n", "
+09: def cython_kpartite2( # Split parameters on input (-80ms)\n", "
/* Python wrapper */\n", "static PyObject *__pyx_pw_46_cython_magic_16adb21d1da83629b403b2790d247d8a_1cython_kpartite2(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/\n", "static PyMethodDef __pyx_mdef_46_cython_magic_16adb21d1da83629b403b2790d247d8a_1cython_kpartite2 = {\"cython_kpartite2\", (PyCFunction)__pyx_pw_46_cython_magic_16adb21d1da83629b403b2790d247d8a_1cython_kpartite2, METH_VARARGS|METH_KEYWORDS, 0};\n", "static PyObject *__pyx_pw_46_cython_magic_16adb21d1da83629b403b2790d247d8a_1cython_kpartite2(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {\n", " PyArrayObject *__pyx_v_leftarray = 0;\n", " PyArrayObject *__pyx_v_rightarray = 0;\n", " PyArrayObject *__pyx_v_valuearray = 0;\n", " PyObject *__pyx_r = 0;\n", " __Pyx_RefNannyDeclarations\n", " __Pyx_RefNannySetupContext(\"cython_kpartite2 (wrapper)\", 0);\n", " {\n", " static PyObject **__pyx_pyargnames[] = {&__pyx_n_s_leftarray,&__pyx_n_s_rightarray,&__pyx_n_s_valuearray,0};\n", " PyObject* values[3] = {0,0,0};\n", " if (unlikely(__pyx_kwds)) {\n", " Py_ssize_t kw_args;\n", " const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);\n", " switch (pos_args) {\n", " case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);\n", " case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);\n", " case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);\n", " case 0: break;\n", " default: goto __pyx_L5_argtuple_error;\n", " }\n", " kw_args = PyDict_Size(__pyx_kwds);\n", " switch (pos_args) {\n", " case 0:\n", " if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_leftarray)) != 0)) kw_args--;\n", " else goto __pyx_L5_argtuple_error;\n", " case 1:\n", " if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_rightarray)) != 0)) kw_args--;\n", " else {\n", " __Pyx_RaiseArgtupleInvalid(\"cython_kpartite2\", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L3_error;}\n", " }\n", " case 2:\n", " if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s_valuearray)) != 0)) kw_args--;\n", " else {\n", " __Pyx_RaiseArgtupleInvalid(\"cython_kpartite2\", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L3_error;}\n", " }\n", " }\n", " if (unlikely(kw_args > 0)) {\n", " if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, \"cython_kpartite2\") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L3_error;}\n", " }\n", " } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {\n", " goto __pyx_L5_argtuple_error;\n", " } else {\n", " values[0] = PyTuple_GET_ITEM(__pyx_args, 0);\n", " values[1] = PyTuple_GET_ITEM(__pyx_args, 1);\n", " values[2] = PyTuple_GET_ITEM(__pyx_args, 2);\n", " }\n", " __pyx_v_leftarray = ((PyArrayObject *)values[0]);\n", " __pyx_v_rightarray = ((PyArrayObject *)values[1]);\n", " __pyx_v_valuearray = ((PyArrayObject *)values[2]);\n", " }\n", " goto __pyx_L4_argument_unpacking_done;\n", " __pyx_L5_argtuple_error:;\n", " __Pyx_RaiseArgtupleInvalid(\"cython_kpartite2\", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L3_error;}\n", " __pyx_L3_error:;\n", " __Pyx_AddTraceback(\"_cython_magic_16adb21d1da83629b403b2790d247d8a.cython_kpartite2\", __pyx_clineno, __pyx_lineno, __pyx_filename);\n", " __Pyx_RefNannyFinishContext();\n", " return NULL;\n", " __pyx_L4_argument_unpacking_done:;\n", " if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_leftarray), __pyx_ptype_5numpy_ndarray, 1, \"leftarray\", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 10; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_rightarray), __pyx_ptype_5numpy_ndarray, 1, \"rightarray\", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 11; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_valuearray), __pyx_ptype_5numpy_ndarray, 1, \"valuearray\", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 12; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __pyx_r = __pyx_pf_46_cython_magic_16adb21d1da83629b403b2790d247d8a_cython_kpartite2(__pyx_self, __pyx_v_leftarray, __pyx_v_rightarray, __pyx_v_valuearray);\n", " int __pyx_lineno = 0;\n", " const char *__pyx_filename = NULL;\n", " int __pyx_clineno = 0;\n", "\n", " /* function exit code */\n", " goto __pyx_L0;\n", " __pyx_L1_error:;\n", " __pyx_r = NULL;\n", " __pyx_L0:;\n", " __Pyx_RefNannyFinishContext();\n", " return __pyx_r;\n", "}\n", "\n", "static PyObject *__pyx_pf_46_cython_magic_16adb21d1da83629b403b2790d247d8a_cython_kpartite2(CYTHON_UNUSED PyObject *__pyx_self, PyArrayObject *__pyx_v_leftarray, PyArrayObject *__pyx_v_rightarray, PyArrayObject *__pyx_v_valuearray) {\n", " int __pyx_v_index;\n", " int __pyx_v_n;\n", " PyObject *__pyx_v_result = NULL;\n", " PyObject *__pyx_v_right = NULL;\n", " PyObject *__pyx_v_value = NULL;\n", " PyObject *__pyx_v_a = NULL;\n", " PyObject *__pyx_v_b = NULL;\n", " PyObject *__pyx_v_key = NULL;\n", " __Pyx_LocalBuf_ND __pyx_pybuffernd_leftarray;\n", " __Pyx_Buffer __pyx_pybuffer_leftarray;\n", " __Pyx_LocalBuf_ND __pyx_pybuffernd_rightarray;\n", " __Pyx_Buffer __pyx_pybuffer_rightarray;\n", " __Pyx_LocalBuf_ND __pyx_pybuffernd_valuearray;\n", " __Pyx_Buffer __pyx_pybuffer_valuearray;\n", " PyObject *__pyx_r = NULL;\n", " __Pyx_TraceDeclarations\n", " __Pyx_TraceFrameInit(__pyx_codeobj_)\n", " __Pyx_RefNannyDeclarations\n", " __Pyx_RefNannySetupContext(\"cython_kpartite2\", 0);\n", " __Pyx_TraceCall(\"cython_kpartite2\", __pyx_f[0], 9, 0, {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;});\n", " __pyx_pybuffer_leftarray.pybuffer.buf = NULL;\n", " __pyx_pybuffer_leftarray.refcount = 0;\n", " __pyx_pybuffernd_leftarray.data = NULL;\n", " __pyx_pybuffernd_leftarray.rcbuffer = &__pyx_pybuffer_leftarray;\n", " __pyx_pybuffer_rightarray.pybuffer.buf = NULL;\n", " __pyx_pybuffer_rightarray.refcount = 0;\n", " __pyx_pybuffernd_rightarray.data = NULL;\n", " __pyx_pybuffernd_rightarray.rcbuffer = &__pyx_pybuffer_rightarray;\n", " __pyx_pybuffer_valuearray.pybuffer.buf = NULL;\n", " __pyx_pybuffer_valuearray.refcount = 0;\n", " __pyx_pybuffernd_valuearray.data = NULL;\n", " __pyx_pybuffernd_valuearray.rcbuffer = &__pyx_pybuffer_valuearray;\n", " {\n", " __Pyx_BufFmt_StackElem __pyx_stack[1];\n", " if (unlikely(__Pyx_GetBufferAndValidate(&__pyx_pybuffernd_leftarray.rcbuffer->pybuffer, (PyObject*)__pyx_v_leftarray, &__Pyx_TypeInfo_object, PyBUF_FORMAT| PyBUF_STRIDES, 1, 0, __pyx_stack) == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " __pyx_pybuffernd_leftarray.diminfo[0].strides = __pyx_pybuffernd_leftarray.rcbuffer->pybuffer.strides[0]; __pyx_pybuffernd_leftarray.diminfo[0].shape = __pyx_pybuffernd_leftarray.rcbuffer->pybuffer.shape[0];\n", " {\n", " __Pyx_BufFmt_StackElem __pyx_stack[1];\n", " if (unlikely(__Pyx_GetBufferAndValidate(&__pyx_pybuffernd_rightarray.rcbuffer->pybuffer, (PyObject*)__pyx_v_rightarray, &__Pyx_TypeInfo_object, PyBUF_FORMAT| PyBUF_STRIDES, 1, 0, __pyx_stack) == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " __pyx_pybuffernd_rightarray.diminfo[0].strides = __pyx_pybuffernd_rightarray.rcbuffer->pybuffer.strides[0]; __pyx_pybuffernd_rightarray.diminfo[0].shape = __pyx_pybuffernd_rightarray.rcbuffer->pybuffer.shape[0];\n", " {\n", " __Pyx_BufFmt_StackElem __pyx_stack[1];\n", " if (unlikely(__Pyx_GetBufferAndValidate(&__pyx_pybuffernd_valuearray.rcbuffer->pybuffer, (PyObject*)__pyx_v_valuearray, &__Pyx_TypeInfo_double, PyBUF_FORMAT| PyBUF_STRIDES, 1, 0, __pyx_stack) == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " __pyx_pybuffernd_valuearray.diminfo[0].strides = __pyx_pybuffernd_valuearray.rcbuffer->pybuffer.strides[0]; __pyx_pybuffernd_valuearray.diminfo[0].shape = __pyx_pybuffernd_valuearray.rcbuffer->pybuffer.shape[0];\n", "/* … */\n", " /* function exit code */\n", " __pyx_L1_error:;\n", " __Pyx_XDECREF(__pyx_t_1);\n", " __Pyx_XDECREF(__pyx_t_8);\n", " __Pyx_XDECREF(__pyx_t_12);\n", " __Pyx_XDECREF(__pyx_t_13);\n", " { PyObject *__pyx_type, *__pyx_value, *__pyx_tb;\n", " __Pyx_ErrFetch(&__pyx_type, &__pyx_value, &__pyx_tb);\n", " __Pyx_SafeReleaseBuffer(&__pyx_pybuffernd_leftarray.rcbuffer->pybuffer);\n", " __Pyx_SafeReleaseBuffer(&__pyx_pybuffernd_rightarray.rcbuffer->pybuffer);\n", " __Pyx_SafeReleaseBuffer(&__pyx_pybuffernd_valuearray.rcbuffer->pybuffer);\n", " __Pyx_ErrRestore(__pyx_type, __pyx_value, __pyx_tb);}\n", " __Pyx_AddTraceback(\"_cython_magic_16adb21d1da83629b403b2790d247d8a.cython_kpartite2\", __pyx_clineno, __pyx_lineno, __pyx_filename);\n", " __pyx_r = NULL;\n", " goto __pyx_L2;\n", " __pyx_L0:;\n", " __Pyx_SafeReleaseBuffer(&__pyx_pybuffernd_leftarray.rcbuffer->pybuffer);\n", " __Pyx_SafeReleaseBuffer(&__pyx_pybuffernd_rightarray.rcbuffer->pybuffer);\n", " __Pyx_SafeReleaseBuffer(&__pyx_pybuffernd_valuearray.rcbuffer->pybuffer);\n", " __pyx_L2:;\n", " __Pyx_XDECREF(__pyx_v_result);\n", " __Pyx_XDECREF(__pyx_v_right);\n", " __Pyx_XDECREF(__pyx_v_value);\n", " __Pyx_XDECREF(__pyx_v_a);\n", " __Pyx_XDECREF(__pyx_v_b);\n", " __Pyx_XDECREF(__pyx_v_key);\n", " __Pyx_XGIVEREF(__pyx_r);\n", " __Pyx_TraceReturn(__pyx_r, 0);\n", " __Pyx_RefNannyFinishContext();\n", " return __pyx_r;\n", "}\n", "/* … */\n", " __pyx_tuple__8 = PyTuple_Pack(11, __pyx_n_s_leftarray, __pyx_n_s_rightarray, __pyx_n_s_valuearray, __pyx_n_s_index, __pyx_n_s_n, __pyx_n_s_result, __pyx_n_s_right, __pyx_n_s_value, __pyx_n_s_a, __pyx_n_s_b, __pyx_n_s_key); if (unlikely(!__pyx_tuple__8)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_tuple__8);\n", " __Pyx_GIVEREF(__pyx_tuple__8);\n", "/* … */\n", " __Pyx_TraceLine(9,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = __Pyx_CyFunction_NewEx(&__pyx_mdef_46_cython_magic_16adb21d1da83629b403b2790d247d8a_1cython_kpartite2, 0, __pyx_n_s_cython_kpartite2, NULL, __pyx_n_s_cython_magic_16adb21d1da83629b4, __pyx_d, ((PyObject *)__pyx_codeobj_)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_1);\n", " if (PyDict_SetItem(__pyx_d, __pyx_n_s_cython_kpartite2, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;\n", "
10: np.ndarray[list] leftarray,\n", "
11: np.ndarray[list] rightarray,\n", "
12: np.ndarray[double] valuearray):\n", "
+13: cdef int index, n = leftarray.shape[0]\n", "
__Pyx_TraceLine(13,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 13; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_v_n = (__pyx_v_leftarray->dimensions[0]);\n", "
14: # cdef list left, right\n", "
15: # cdef double value\n", "
+16: result = {}\n", "
__Pyx_TraceLine(16,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 16; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_1 = PyDict_New(); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 16; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_1);\n", " __pyx_v_result = ((PyObject*)__pyx_t_1);\n", " __pyx_t_1 = 0;\n", "
+17: for index in range(n):\n", "
__Pyx_TraceLine(17,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_2 = __pyx_v_n;\n", " for (__pyx_t_3 = 0; __pyx_t_3 < __pyx_t_2; __pyx_t_3+=1) {\n", " __pyx_v_index = __pyx_t_3;\n", "
+18: right = rightarray[index]\n", "
__Pyx_TraceLine(18,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_4 = __pyx_v_index;\n", " __pyx_t_5 = -1;\n", " if (__pyx_t_4 < 0) {\n", " __pyx_t_4 += __pyx_pybuffernd_rightarray.diminfo[0].shape;\n", " if (unlikely(__pyx_t_4 < 0)) __pyx_t_5 = 0;\n", " } else if (unlikely(__pyx_t_4 >= __pyx_pybuffernd_rightarray.diminfo[0].shape)) __pyx_t_5 = 0;\n", " if (unlikely(__pyx_t_5 != -1)) {\n", " __Pyx_RaiseBufferIndexError(__pyx_t_5);\n", " {__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " __pyx_t_1 = (PyObject *) *__Pyx_BufPtrStrided1d(PyObject **, __pyx_pybuffernd_rightarray.rcbuffer->pybuffer.buf, __pyx_t_4, __pyx_pybuffernd_rightarray.diminfo[0].strides);\n", " __Pyx_INCREF((PyObject*)__pyx_t_1);\n", " __Pyx_XDECREF_SET(__pyx_v_right, __pyx_t_1);\n", " __pyx_t_1 = 0;\n", "
+19: value = valuearray[index]\n", "
__Pyx_TraceLine(19,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_6 = __pyx_v_index;\n", " __pyx_t_5 = -1;\n", " if (__pyx_t_6 < 0) {\n", " __pyx_t_6 += __pyx_pybuffernd_valuearray.diminfo[0].shape;\n", " if (unlikely(__pyx_t_6 < 0)) __pyx_t_5 = 0;\n", " } else if (unlikely(__pyx_t_6 >= __pyx_pybuffernd_valuearray.diminfo[0].shape)) __pyx_t_5 = 0;\n", " if (unlikely(__pyx_t_5 != -1)) {\n", " __Pyx_RaiseBufferIndexError(__pyx_t_5);\n", " {__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " __pyx_t_1 = PyFloat_FromDouble((*__Pyx_BufPtrStrided1d(double *, __pyx_pybuffernd_valuearray.rcbuffer->pybuffer.buf, __pyx_t_6, __pyx_pybuffernd_valuearray.diminfo[0].strides))); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_1);\n", " __Pyx_XDECREF_SET(__pyx_v_value, __pyx_t_1);\n", " __pyx_t_1 = 0;\n", "
+20: for a in leftarray[index]:\n", "
__Pyx_TraceLine(20,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_7 = __pyx_v_index;\n", " __pyx_t_5 = -1;\n", " if (__pyx_t_7 < 0) {\n", " __pyx_t_7 += __pyx_pybuffernd_leftarray.diminfo[0].shape;\n", " if (unlikely(__pyx_t_7 < 0)) __pyx_t_5 = 0;\n", " } else if (unlikely(__pyx_t_7 >= __pyx_pybuffernd_leftarray.diminfo[0].shape)) __pyx_t_5 = 0;\n", " if (unlikely(__pyx_t_5 != -1)) {\n", " __Pyx_RaiseBufferIndexError(__pyx_t_5);\n", " {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " __pyx_t_1 = (PyObject *) *__Pyx_BufPtrStrided1d(PyObject **, __pyx_pybuffernd_leftarray.rcbuffer->pybuffer.buf, __pyx_t_7, __pyx_pybuffernd_leftarray.diminfo[0].strides);\n", " __Pyx_INCREF((PyObject*)__pyx_t_1);\n", " if (unlikely(__pyx_t_1 == Py_None)) {\n", " PyErr_SetString(PyExc_TypeError, \"'NoneType' object is not iterable\");\n", " {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " __pyx_t_8 = __pyx_t_1; __Pyx_INCREF(__pyx_t_8); __pyx_t_9 = 0;\n", " __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;\n", " for (;;) {\n", " if (__pyx_t_9 >= PyList_GET_SIZE(__pyx_t_8)) break;\n", " #if CYTHON_COMPILING_IN_CPYTHON\n", " __pyx_t_1 = PyList_GET_ITEM(__pyx_t_8, __pyx_t_9); __Pyx_INCREF(__pyx_t_1); __pyx_t_9++; if (unlikely(0 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " #else\n", " __pyx_t_1 = PySequence_ITEM(__pyx_t_8, __pyx_t_9); __pyx_t_9++; if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_1);\n", " #endif\n", " __Pyx_XDECREF_SET(__pyx_v_a, __pyx_t_1);\n", " __pyx_t_1 = 0;\n", "/* … */\n", " __Pyx_TraceLine(20,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " }\n", " __Pyx_DECREF(__pyx_t_8); __pyx_t_8 = 0;\n", " }\n", "
+21: for b in right:\n", "
__Pyx_TraceLine(21,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " if (likely(PyList_CheckExact(__pyx_v_right)) || PyTuple_CheckExact(__pyx_v_right)) {\n", " __pyx_t_1 = __pyx_v_right; __Pyx_INCREF(__pyx_t_1); __pyx_t_10 = 0;\n", " __pyx_t_11 = NULL;\n", " } else {\n", " __pyx_t_10 = -1; __pyx_t_1 = PyObject_GetIter(__pyx_v_right); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_1);\n", " __pyx_t_11 = Py_TYPE(__pyx_t_1)->tp_iternext; if (unlikely(!__pyx_t_11)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " for (;;) {\n", " if (likely(!__pyx_t_11)) {\n", " if (likely(PyList_CheckExact(__pyx_t_1))) {\n", " if (__pyx_t_10 >= PyList_GET_SIZE(__pyx_t_1)) break;\n", " #if CYTHON_COMPILING_IN_CPYTHON\n", " __pyx_t_12 = PyList_GET_ITEM(__pyx_t_1, __pyx_t_10); __Pyx_INCREF(__pyx_t_12); __pyx_t_10++; if (unlikely(0 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " #else\n", " __pyx_t_12 = PySequence_ITEM(__pyx_t_1, __pyx_t_10); __pyx_t_10++; if (unlikely(!__pyx_t_12)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_12);\n", " #endif\n", " } else {\n", " if (__pyx_t_10 >= PyTuple_GET_SIZE(__pyx_t_1)) break;\n", " #if CYTHON_COMPILING_IN_CPYTHON\n", " __pyx_t_12 = PyTuple_GET_ITEM(__pyx_t_1, __pyx_t_10); __Pyx_INCREF(__pyx_t_12); __pyx_t_10++; if (unlikely(0 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " #else\n", " __pyx_t_12 = PySequence_ITEM(__pyx_t_1, __pyx_t_10); __pyx_t_10++; if (unlikely(!__pyx_t_12)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_12);\n", " #endif\n", " }\n", " } else {\n", " __pyx_t_12 = __pyx_t_11(__pyx_t_1);\n", " if (unlikely(!__pyx_t_12)) {\n", " PyObject* exc_type = PyErr_Occurred();\n", " if (exc_type) {\n", " if (likely(exc_type == PyExc_StopIteration || PyErr_GivenExceptionMatches(exc_type, PyExc_StopIteration))) PyErr_Clear();\n", " else {__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " }\n", " break;\n", " }\n", " __Pyx_GOTREF(__pyx_t_12);\n", " }\n", " __Pyx_XDECREF_SET(__pyx_v_b, __pyx_t_12);\n", " __pyx_t_12 = 0;\n", "/* … */\n", " __Pyx_TraceLine(21,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " }\n", " __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;\n", "
+22: key = a, b # TODO: Use a string instead of a tuple (saves -80ms)\n", "
__Pyx_TraceLine(22,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 22; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_12 = PyTuple_New(2); if (unlikely(!__pyx_t_12)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 22; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_12);\n", " __Pyx_INCREF(__pyx_v_a);\n", " __Pyx_GIVEREF(__pyx_v_a);\n", " PyTuple_SET_ITEM(__pyx_t_12, 0, __pyx_v_a);\n", " __Pyx_INCREF(__pyx_v_b);\n", " __Pyx_GIVEREF(__pyx_v_b);\n", " PyTuple_SET_ITEM(__pyx_t_12, 1, __pyx_v_b);\n", " __Pyx_XDECREF_SET(__pyx_v_key, ((PyObject*)__pyx_t_12));\n", " __pyx_t_12 = 0;\n", "
+23: result[key] = result.get(key, 0.0) + value\n", "
__Pyx_TraceLine(23,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 23; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __pyx_t_12 = __Pyx_PyDict_GetItemDefault(__pyx_v_result, __pyx_v_key, __pyx_float_0_0); if (unlikely(!__pyx_t_12)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 23; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_12);\n", " __pyx_t_13 = PyNumber_Add(__pyx_t_12, __pyx_v_value); if (unlikely(!__pyx_t_13)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 23; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_GOTREF(__pyx_t_13);\n", " __Pyx_DECREF(__pyx_t_12); __pyx_t_12 = 0;\n", " if (unlikely(PyDict_SetItem(__pyx_v_result, __pyx_v_key, __pyx_t_13) < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 23; __pyx_clineno = __LINE__; goto __pyx_L1_error;}\n", " __Pyx_DECREF(__pyx_t_13); __pyx_t_13 = 0;\n", "
+24: return result\n", "
__Pyx_TraceLine(24,0,{__pyx_filename = __pyx_f[0]; __pyx_lineno = 24; __pyx_clineno = __LINE__; goto __pyx_L1_error;})\n", " __Pyx_XDECREF(__pyx_r);\n", " __Pyx_INCREF(__pyx_v_result);\n", " __pyx_r = __pyx_v_result;\n", " goto __pyx_L0;\n", "
\n", " | PA | \n", "IPC | \n", "INV | \n", "keywords | \n", "
---|---|---|---|---|
0 | \n", "[MESSERSCHMITT BOELKOW BLOHM] | \n", "[G10K, B64C, F04D] | \n", "[BSCHORR OSKAR] | \n", "[angular range, control system, fuselage skin,... | \n", "
1 | \n", "[MESSERSCHMITT BOELKOW BLOHM] | \n", "[F02C, B64D] | \n", "[JUNGCLAUS GUENTHER, KROHN ERNST OTTO] | \n", "[air outlet port, air passage, missile body, a... | \n", "
2 | \n", "[CRESSWELL ARNOLD W, VOSS WALDEMAR E, ERNSTING... | \n", "[A62B, B64D] | \n", "[CRESSWELL ARNOLD W, VOSS WALDEMAR E, ERNSTING... | \n", "[air supply duct, sectional area, non-return v... | \n", "
3 | \n", "[Unassigned] | \n", "[C08L] | \n", "[CHEN JOHN Y] | \n", "[gelatinous compositions, soft gelatinous elas... | \n", "
4 | \n", "[Unassigned] | \n", "[B01D, C10G] | \n", "[CHEN JOHN Y] | \n", "[gel rigidity region, metal foil, synthetic re... | \n", "