arrayfire-python icon indicating copy to clipboard operation
arrayfire-python copied to clipboard

af.features.Features crashes when its __del__ method is called

Open dan-nf opened this issue 1 year ago • 1 comments

When using a Features() object, arrayfire crashes silently when calling the object's __del__() method if the object's get_xpos() method has already been deleted (or has fallen out of scope).

Potentially due to a similar root case as mentioned in #169 (or due to the changes made as a result of this in commit a9031fb5e0db371bc88c958f0b8d43efd7fe8f45)

Running on Windows; using arrayfire 3.8.0.

Minimum working example:

import arrayfire as af

def get_feature_locations(features):
    # Get x and y positions of features
    x_pos = features.get_xpos()
    y_pos = features.get_ypos()
    
    # If this is uncommented, the code works as intended
    # return x_pos, y_pos

img = af.randn(d0=500, d1=500)
features, descriptors = af.orb(img, threshold=1, max_features=10, num_levels=1)
feature_locations = get_feature_locations(features)

print("Before delete")
del features
print("After delete")

Which outputs:

Before delete

Uncommenting line 10 (return x_pos, y_pos) outputs:

Before delete
After delete

Thanks!

dan-nf avatar Sep 20 '24 07:09 dan-nf

Current workaround is explicitly setting .feat attribute to None and deleting the features object before it falls out of scope; e.g.:

features.feat = None
del features

dan-nf avatar Dec 06 '24 06:12 dan-nf