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)