В cdef, где я выделяю массив numpy для своих результатов, я получаю следующую ошибку:
---> 56 cdef np.ndarray[DTYPE_t, ndim=2] alignpmf = np.zeros([bin_len, out_len*bin_len],dtype=float)
MemoryError:
Соответствующий код:
from __future__ import division
import numpy as np
cimport numpy as np
cimport cython
DTYPE = np.int
DTYPE_f = np.float
ctypedef np.float_t DTYPE_t
ctypedef np.int_t DTYPE_i
...
@cython.boundscheck(False)
@cython.wraparound(False)
def full_pmfs(np.ndarray[DTYPE_i, ndim=2] align, np.ndarray[DTYPE_i, ndim=1] bins):
assert align.dtype == DTYPE
assert bins.dtype == DTYPE
cdef int loop_ind_i, loop_ind_j, inner_count, inner_count_start, inner_count_stop
cdef int bin_len = bins.shape[0]
cdef int i_start_ind, i_stop_ind
cdef int seqs = align.shape[0]
cdef int residues = align.shape[1]
cdef int size = residues * bin_len
cdef int out_len = residues**2 - residues // 2)
cdef np.ndarray[DTYPE_t, ndim=2] alignpmf = np.zeros([bin_len,
out_len*bin_len],dtype=float)
...
Любые подсказки о причинахОшибка?Если я пишу тот же код на Python, я не получаю ошибку памяти.Когда я запускаю чистый код или код Cython, он почти не потребляет мой оперативный памяти (12 ГБ на этом поле).Для справки: bin_len может составлять около 20, а out_len - 80 000.
Pyx скомпилирован с помощью python setup.py build_ext --inplace:
from distutils.core import setup
from distutils.extension import Extension
from Cython.Distutils import build_ext
import numpy
ext_modules = [Extension("mi", ["mi.pyx"])]
setup(
name = 'MI calcs',
cmdclass = {'build_ext': build_ext},
ext_modules = ext_modules,
include_dirs = [numpy.get_include(),],
)