A carbon tracking library for Python applications
Project description
Carbon Tracker
Name
Carbon (CO2) / Power usage tracker
Description
This repository provides a comprehensive solution for tracking the environmental impact of machine learning (ML) applications. Designed to offer insights into the power usage and carbon dioxide emissions associated with training and inference processes, it encompasses a Client, a Server, a connected Database, and a dashboard for visualizing the results.
Architecture
-
Client: The Client component serves as the interface through which users interact with the Carbon Tracker system. Users can submit their ML code for analysis, specifying parameters such as the training dataset, inference workload, and hardware configuration.
-
Server: The Server component acts as the central processing unit of the Carbon Tracker system. Upon receiving input from the Client, it orchestrates the execution of ML tasks, monitors resource consumption, and calculates associated carbon emissions. The Server is responsible for managing the interaction between various system modules and ensuring smooth operation.
-
Database: The connected Database serves as the repository for storing relevant data generated during the tracking process. This includes information such as power usage metrics, carbon emissions estimates, hardware specifications, and execution times. The Database facilitates data retrieval for subsequent analysis and visualization.
-
Dashboard: The resulting dashboard provides users with a graphical representation of the environmental impact of their ML applications. Through intuitive visualizations, users can gain insights into the energy consumption, CO2 emissions, and runtime performance of their algorithms. The dashboard enables users to make informed decisions regarding optimization strategies and resource allocation.s
Functionality
-
Tracking ML Workloads: The Carbon Tracker system tracks both the training and inference phases of ML applications. It captures resource utilization metrics such as CPU/GPU usage for a varying number of computing units.
-
Carbon Emission Estimation: By correlating resource usage data with corresponding carbon emission factors, the system calculates the environmental impact of ML tasks. This includes estimating the amount of CO2 emissions generated during the execution of algorithms, as well as comparing the execution times.
-
Customization and Scalability: The Carbon Tracker repository offers flexibility for customization according to user requirements and supports scalability to accommodate varying workload sizes and hardware configurations.
Installation
Installing using pip: pip install carbontracking
Cloning using git clone
Usage
CURRENTLY ONLY UNDER PYTHON==3.10
Usage is displayed in following colab notebook: https://colab.research.google.com/drive/1AsMpi_7Tdr8Rmd2oFDK5qvPyLJl5XH6W?usp=sharing
Support
Tell people where they can go to for help. It can be any combination of an issue tracker, a chat room, an email address, etc.
Roadmap
If you have ideas for releases in the future, it is a good idea to list them in the README.
Authors and acknowledgment
Show your appreciation to those who have contributed to the project.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file carbontracking-0.0.50.tar.gz.
File metadata
- Download URL: carbontracking-0.0.50.tar.gz
- Upload date:
- Size: 1.5 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0db81b571e8999f18155ea212ba87c69274bc22e577cfacd92e6eab81cd4a320
|
|
| MD5 |
063a2be39747706d0e6abd0692ba718b
|
|
| BLAKE2b-256 |
3e68d5742cd18feb4b314ed057d99818e1c8e4c19c15c9d5c011e7a175d5aa71
|
File details
Details for the file carbontracking-0.0.50-py3-none-any.whl.
File metadata
- Download URL: carbontracking-0.0.50-py3-none-any.whl
- Upload date:
- Size: 1.5 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7d829ad43c39d552eb0c494591ceec48e834096589656fc7697fbc7c614d9a98
|
|
| MD5 |
538657210596ad5fed70cd83aff07cf7
|
|
| BLAKE2b-256 |
8aa242b0f8bba9488e600943623a13c676adc020bee942a19d0deaf3c29d5a18
|