Python-geheugengebruik van numpy-arrays

| | | |

Ik gebruik python om een aantal grote bestanden te analyseren en ik loop tegen geheugenproblemen aan, dus ik heb sys.getsizeof() gebruikt om het gebruik bij te houden, maar het gedrag met numpy arrays is bizar. Hier is een voorbeeld van een kaart met albedo's die ik moet openen:

>>> importeer numpy als np >>> import struct >>> van sys import getsizeof >>> f = open("Albedo_map.assoc", "rb") >>> getsizeof(f) 144 >>> albedo = struct.unpack("%df" % (7200*3600), f.read(7200*3600*4)) >>> getsizeof(albedo) 207360056 >>> albedo = np.array(albedo).reshape(3600.7200) >>> getsizeof(albedo) 80 

Nou, de gegevens zijn er nog, maar de grootte van het object, een kaart van 3600x7200 pixels, is van ~200 Mb naar 80 bytes gegaan. om te hopen dat mijn geheugenproblemen voorbij zijn en alles gewoon in numpy arrays om te zetten, maar ik heb het gevoel dat dit gedrag, als het waar is, op de een of andere manier in strijd zou zijn met een of andere wet van informatietheorie of thermodynamica, of zoiets, dus ik ben geneigd te geloven dat getsizeof() werkt niet met numpy arrays. Enig idee?

Shop

Learn programming in R: courses

$

Best Python online courses for 2022

$

Best laptop for Fortnite

$

Best laptop for Excel

$

Best laptop for Solidworks

$

Best laptop for Roblox

$

Best computer for crypto mining

$

Best laptop for Sims 4

$

Latest questions

NUMPYNUMPY

psycopg2: insert multiple rows with one query

12 answers

NUMPYNUMPY

How to convert Nonetype to int or string?

12 answers

NUMPYNUMPY

How to specify multiple return types using type-hints

12 answers

NUMPYNUMPY

Javascript Error: IPython is not defined in JupyterLab

12 answers

News


Wiki

Python OpenCV | cv2.putText () method

numpy.arctan2 () in Python

Python | os.path.realpath () method

Python OpenCV | cv2.circle () method

Python OpenCV cv2.cvtColor () method

Python - Move item to the end of the list

time.perf_counter () function in Python

Check if one list is a subset of another in Python

Python os.path.join () method