Skip to main content

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 Logo

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


PyPI - Version Python 3.9+ License: MIT Downloads VS Code Extension


[!TIP] VS Code Extension: Monitor application carbon footprint in real-time during development. Download here.


EcoTrace Demo

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_limit and get real-time alerts at 80% and 100% thresholds, with optional callback hooks.
  • CI/CD Carbon Gateecotrace gate --budget 10.0 returns 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


Contributing

We welcome contributions! Please see our CONTRIBUTING.MD for guidelines on reporting bugs, suggesting features, or contributing hardware data.


Community

Join Discord

CHANGELOG.md · SECURITY.MD


Author and License

Emre OzkalGitHub · ecotraceteam@gmail.com

MIT License — Use it however you like.

Developed for sustainable software development practices.

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

ecotrace-1.0.1.tar.gz (416.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ecotrace-1.0.1-py3-none-any.whl (434.5 kB view details)

Uploaded Python 3

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

Hashes for ecotrace-1.0.1.tar.gz
Algorithm Hash digest
SHA256 863285cb52ca50ba36a553ba46952d0c9c2caa46aac5f7833f4b860d86972ff4
MD5 14f7125f207430afaf319c3b124f5e54
BLAKE2b-256 2fa33a4b7b8c1ae6ed821dae40e959fa6f3891b2c21c00d51518c90e56aab49b

See more details on using hashes here.

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

Hashes for ecotrace-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 fbb87bbb228f4ae8e871eac318c0e8d6522e07b13224ebd1cddfde7fa14ecf8e
MD5 f4aa9df0fa6d17fa1da4ca015e60214b
BLAKE2b-256 81c499ce02eda9918ccf7c1b07f19eeb06c997f084407197635b371fb97c44bb

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page