Reference for ultralytics/utils/logger.py
Note
This file is available at https://github.com/ultralytics/ultralytics/blob/main/ultralytics/utils/logger.py. If you spot a problem please help fix it by contributing a Pull Request 🛠️. Thank you 🙏!
ConsoleLogger(destination)
Console output capture with API/file streaming and deduplication.
Captures stdout/stderr output and streams it to either an API endpoint or local file, with intelligent deduplication to reduce noise from repetitive console output.
Attributes:
| Name | Type | Description | 
|---|---|---|
| destination | str | Path | Target destination for streaming (URL or Path object). | 
| is_api | bool | Whether destination is an API endpoint (True) or local file (False). | 
| original_stdout | Reference to original sys.stdout for restoration. | |
| original_stderr | Reference to original sys.stderr for restoration. | |
| log_queue | Queue | Thread-safe queue for buffering log messages. | 
| active | bool | Whether console capture is currently active. | 
| worker_thread | Thread | Background thread for processing log queue. | 
| last_line | str | Last processed line for deduplication. | 
| last_time | float | Timestamp of last processed line. | 
| last_progress_line | str | Last progress bar line for progress deduplication. | 
| last_was_progress | bool | Whether the last line was a progress bar. | 
Examples:
Basic file logging:
>>> logger = ConsoleLogger("training.log")
>>> logger.start_capture()
>>> print("This will be logged")
>>> logger.stop_capture()
API streaming:
>>> logger = ConsoleLogger("https://api.example.com/logs")
>>> logger.start_capture()
>>> # All output streams to API
>>> logger.stop_capture()
Parameters:
| Name | Type | Description | Default | 
|---|---|---|---|
| destination | str | Path | API endpoint URL (http/https) or local file path for streaming output. | required | 
Source code in ultralytics/utils/logger.py
| 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 |  | 
start_capture()
Start capturing console output and redirect stdout/stderr to custom capture objects.
Source code in ultralytics/utils/logger.py
| 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 |  | 
stop_capture()
Stop capturing console output and restore original stdout/stderr.
Source code in ultralytics/utils/logger.py
| 99 100 101 102 103 104 105 106 107 |  | 
SystemLogger()
Log dynamic system metrics for training monitoring.
Captures real-time system metrics including CPU, RAM, disk I/O, network I/O, and NVIDIA GPU statistics for training performance monitoring and analysis.
Attributes:
| Name | Type | Description | 
|---|---|---|
| pynvml | NVIDIA pynvml module instance if successfully imported, None otherwise. | |
| nvidia_initialized | bool | Whether NVIDIA GPU monitoring is available and initialized. | 
| net_start | Initial network I/O counters for calculating cumulative usage. | |
| disk_start | Initial disk I/O counters for calculating cumulative usage. | 
Examples:
Basic usage:
>>> logger = SystemLogger()
>>> metrics = logger.get_metrics()
>>> print(f"CPU: {metrics['cpu']}%, RAM: {metrics['ram']}%")
>>> if metrics["gpus"]:
...     gpu0 = metrics["gpus"]["0"]
...     print(f"GPU0: {gpu0['usage']}% usage, {gpu0['temp']}°C")
Training loop integration:
>>> system_logger = SystemLogger()
>>> for epoch in range(epochs):
...     # Training code here
...     metrics = system_logger.get_metrics()
...     # Log to database/file
Source code in ultralytics/utils/logger.py
| 259 260 261 262 263 264 265 266 |  | 
get_metrics()
Get current system metrics.
Collects comprehensive system metrics including CPU usage, RAM usage, disk I/O statistics, network I/O statistics, and GPU metrics (if available). Example output:
metrics = {
    "cpu": 45.2,
    "ram": 78.9,
    "disk": {"read_mb": 156.7, "write_mb": 89.3, "used_gb": 256.8},
    "network": {"recv_mb": 157.2, "sent_mb": 89.1},
    "gpus": {
        0: {"usage": 95.6, "memory": 85.4, "temp": 72, "power": 285},
        1: {"usage": 94.1, "memory": 82.7, "temp": 70, "power": 278},
    },
}
- cpu (float): CPU usage percentage (0-100%)
- ram (float): RAM usage percentage (0-100%)
- disk (dict):- read_mb (float): Cumulative disk read in MB since initialization
- write_mb (float): Cumulative disk write in MB since initialization
- used_gb (float): Total disk space used in GB
 
- network (dict):- recv_mb (float): Cumulative network received in MB since initialization
- sent_mb (float): Cumulative network sent in MB since initialization
 
- gpus (dict): GPU metrics by device index (e.g., 0, 1) containing:- usage (int): GPU utilization percentage (0-100%)
- memory (float): CUDA memory usage percentage (0-100%)
- temp (int): GPU temperature in degrees Celsius
- power (int): GPU power consumption in watts
 
Returns:
| Name | Type | Description | 
|---|---|---|
| metrics | dict | System metrics containing 'cpu', 'ram', 'disk', 'network', 'gpus' with respective usage data. | 
Source code in ultralytics/utils/logger.py
| 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 |  |