Skip to content Skip to sidebar Skip to footer

Cython Interfaced With C++: Segmentation Fault For Large Arrays

I am transferring my code from Python/C interfaced using ctypes to Python/C++ interfaced using Cython. The new interface will give me an easier to maintain code, because I can expl

Solution 1:

The memory is being managed by your numpy arrays. As soon as they go out of scope (most likely at the end of the PySparse constructor) the arrays cease to exist, and all your pointers are invalid. This applies to both large and small arrays, but presumably you just get lucky with small arrays.

You need to hold a reference to all the numpy arrays you use for the lifetime of your PySparse object:

cdefclass PySparse:

  # ----------------------------------------------------------------------------

  cdefSparse *ptr
  cdefobject _held_reference # added# ----------------------------------------------------------------------------def__cinit__(self,**kwargs):
      # ....# your constructor code code goes here, unchanged...# ....

      self._held_reference = [data] # add any other numpy arrays you use to this list

As a rule you need to be thinking quite hard about who owns what whenever you're dealing with C/C++ pointers, which is a big change from the normal Python approach. Getting a pointer from a numpy array does not copy the data and it does not give numpy any indication that you're still using the data.


Edit note: In my original version I tried to use locals() as a quick way of gathering a collection of all the arrays I wanted to keep. Unfortunately, that doesn't seem to include to cdefed arrays so it didn't manage to keep the ones you were actually using (note here that astype() makes a copy unless you tell it otherwise, so you need to hold the reference to the copy, rather than the original passed in as an argument).

Post a Comment for "Cython Interfaced With C++: Segmentation Fault For Large Arrays"