Source code for capytaine.tools.memory_monitor
import logging
import time
from threading import Thread
from capytaine.tools.optional_imports import silently_import_optional_dependency
LOG = logging.getLogger(__name__)
[docs]
class MemoryMonitor(Thread):
"""Monitor the memory usage in a separate thread.
from : https://joblib.readthedocs.io/en/stable/auto_examples/parallel_generator.html#sphx-glr-auto-examples-parallel-generator-py
"""
def __init__(self):
super().__init__()
self.stop = False
self.memory_buffer = [0]
self.psutil = silently_import_optional_dependency("psutil")
self.start()
[docs]
def get_memory(self):
"Get memory of a process and its children."
p = self.psutil.Process()
memory = p.memory_info().rss
for c in p.children():
memory += c.memory_info().rss
return memory
[docs]
def run(self):
if self.psutil is not None:
memory_start = self.get_memory()
while not self.stop:
self.memory_buffer.append(self.get_memory() - memory_start)
time.sleep(0.2)
[docs]
def get_memory_peak(self):
self.stop = True
super().join()
if self.psutil is None:
return None
else:
return round(max(self.memory_buffer) / 1e9, 2)