EcoTrace: High-precision carbon tracking engine for production Python. Function-level CPU/GPU emission measurement with 50ms continuous sampling, Boavizta TDP database, and audit-ready PDF reporting.
Project description
EcoTrace
High-Precision Energy and Emissions Instrumentation
v1.0.1 — Production/Stable Release. Features carbon budget enforcement, CI/CD gate, differential tracking, and session summaries.
EcoTrace is a lightweight library for granular carbon footprint measurement of Python applications. No configuration files, no background services—just real-time hardware-level transparency.
Real-time monitoring | 50+ Global Zones | AI-powered insights | Zero-configuration
[!TIP] VS Code Extension: Monitor application carbon footprint in real-time during development. Download here.
Function-level carbon measurement with real-time monitoring
What's New in v1.0.1
EcoTrace is heading towards Production/Stable. The upcoming v1.0.1 release introduces active carbon budget enforcement — shifting from just measuring to active enforcement.
- Carbon Budget Enforcement — Set
carbon_limitand get real-time alerts at 80% and 100% thresholds, with optional callback hooks. - CI/CD Carbon Gate —
ecotrace gate --budget 10.0returns exit code 1 if budget exceeded. No competitor has this. - Differential Tracking — OS idle noise is now subtracted from measurements. You see only YOUR code's carbon cost.
- Session Summary — Automatic summary table at process exit: duration, functions tracked, total carbon, budget status.
- Carbon Equivalences — Abstract gCO2 values converted to relatable comparisons (Google searches, LED bulb time, car km).
- Critical Bug Fixes — Exception handling, GPU crash fixes, and packaging corrections. See CHANGELOG.md.
Quick Install
pip install ecotrace
Optional extras:
pip install ecotrace[gpu] # NVIDIA GPU support
pip install ecotrace[ai] # Gemini AI insights
pip install ecotrace[all] # Everything
Quick Start
Option 1: Zero-Code Profiling (CLI)
Measure any script without changing a single line of code:
ecotrace run my_script.py
Option 2: Programmatic Tracking (Library)
Decorate functions for granular instrumentation:
from ecotrace import EcoTrace
eco = EcoTrace(region_code="US")
@eco.track
def my_function():
# Your heavy processing here
pass
my_function()
# Export audit-ready reports or check cumulative totals
eco.generate_pdf_report("carbon_audit.pdf")
print(f"Total Carbon Emitted: {eco.total_carbon} gCO2")
Option 3: Carbon Budget Mode
Set a limit and let EcoTrace enforce it:
eco = EcoTrace(
region_code="TR",
carbon_limit=5.0, # 5 gCO2 budget
on_budget_exceeded=lambda t, l: print(f"Budget exceeded: {t:.4f}/{l:.4f} gCO2")
)
@eco.track
def training_pipeline():
...
training_pipeline()
print(f"Remaining budget: {eco.remaining_budget} gCO2")
Expected Output
When initialized, EcoTrace performs automated hardware detection:
[EcoTrace] INFO: [INFO] EcoTrace instrumentation session initialized (STATIC).
[EcoTrace] INFO: -----------------------------------------------------
[EcoTrace] INFO: Region : TR (475 gCO2/kWh)
[EcoTrace] INFO: Hardware Logic: 13th Gen Intel Core i7-13700H
[EcoTrace] INFO: Specifications: 20 Cores | 45.0W TDP
[EcoTrace] INFO: Energy Sensor : Boavizta Advanced Estimation
[EcoTrace] INFO: Memory Config : 15.6 GB DDR4
[EcoTrace] INFO: GPU Accelerator: Intel Iris Xe Graphics (15.0W TDP)
[EcoTrace] INFO: -----------------------------------------------------
At process exit, a session summary is printed automatically:
=======================================================
EcoTrace — Session Summary
=======================================================
Duration : 12.34s
Functions : 5 tracked
Total Carbon : 0.00312000 gCO2
Region : TR (475 gCO2/kWh)
Budget : 0.003120 / 5.000000 gCO2 (0.1%) [OK]
Equivalent : 0.4 min of LED bulb (10W)
=======================================================
CI/CD Integration
Enforce carbon budgets in your pipeline with a single command:
# .github/workflows/ci.yml
- name: Run tests
run: python -m pytest tests/
- name: Carbon Gate
run: ecotrace gate --budget 10.0
If total emissions exceed the budget, the gate fails with exit code 1 — preventing carbon-heavy code from being merged.
Why EcoTrace?
| Feature | EcoTrace v1.0 | CodeCarbon | CarbonTracker |
|---|---|---|---|
| Sampling Interval | 50ms | 15s | Per Epoch |
| Isolation | Process-scoped | System-wide | System-wide |
| Budget Enforcement | Built-in | No | No |
| CI/CD Gate | Built-in | No | No |
| Idle Noise Subtraction | Automatic | No | No |
| Async Support | Native | Limited | No |
- Deep Transparency: Derived from verified manufacturer TDP specifications rather than category averages.
- Fail-Safe Architecture: Guaranteed application continuity even if hardware drivers or API keys are missing.
- Actionable AI: Integrates with Google Gemini to provide specific code optimization advice (optional).
Documentation
- Architecture and Science — How the energy model and process isolation work.
- Advanced Usage — GPU tracking, AI insights, benchmarks, and comparison tables.
- Support and Reference — Troubleshooting, region codes, and hardware compatibility.
Contributing
We welcome contributions! Please see our CONTRIBUTING.MD for guidelines on reporting bugs, suggesting features, or contributing hardware data.
Community
Author and License
Emre Ozkal — GitHub · ecotraceteam@gmail.com
MIT License — Use it however you like.
Developed for sustainable software development practices.
Project details
Release history Release notifications | RSS feed
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 ecotrace-1.0.1.tar.gz.
File metadata
- Download URL: ecotrace-1.0.1.tar.gz
- Upload date:
- Size: 416.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
863285cb52ca50ba36a553ba46952d0c9c2caa46aac5f7833f4b860d86972ff4
|
|
| MD5 |
14f7125f207430afaf319c3b124f5e54
|
|
| BLAKE2b-256 |
2fa33a4b7b8c1ae6ed821dae40e959fa6f3891b2c21c00d51518c90e56aab49b
|
File details
Details for the file ecotrace-1.0.1-py3-none-any.whl.
File metadata
- Download URL: ecotrace-1.0.1-py3-none-any.whl
- Upload date:
- Size: 434.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fbb87bbb228f4ae8e871eac318c0e8d6522e07b13224ebd1cddfde7fa14ecf8e
|
|
| MD5 |
f4aa9df0fa6d17fa1da4ca015e60214b
|
|
| BLAKE2b-256 |
81c499ce02eda9918ccf7c1b07f19eeb06c997f084407197635b371fb97c44bb
|