Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Why can't objgraph capture the growth of np.array()?

See the code:

import objgraph
import numpy as np
objgraph.show_growth()
j = 20
y = []
for i in range(5):
    for l in range(j):
        y.append(np.array([np.random.randint(500),np.random.randint(500)]))
    print 'i:',i
    objgraph.show_growth()
    print '___'
    #objgraph.show_most_common_types(limit=100)
    j += 1

the result is:

i: 1
wrapper_descriptor 1596 +3
weakref 625 +1
dict 870 +1
method_descriptor 824 +1
i: 2
i: 3
i: 4

For the 2,3 and 4 epoch, it shows nothing growing. But it should show that the number of numpy.array grows

like image 462
Jason Avatar asked Oct 29 '25 13:10

Jason


1 Answers

I'm not that familiar with objgraph specifically, but I think the same issue applies to other Python heap analysis tools such as heapy.

Numpy arrays are implemented in C, and do their own reference counting by internally calling Py_INCREF and Py_DECREF. As such, they are not tracked by the Python garbage collector. Tools like heapy and (presumably) objgraph use the Python garbage collector to track references to objects, so as a result numpy arrays are invisible to them.

like image 165
ali_m Avatar answered Oct 31 '25 02:10

ali_m



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!