Skip to main content

Hardware Component Area, Energy, Latency, and Leak Power Models

Project description

HWComponents

Area, energy, latency, and leak power models for hardware components.


PyPI Python License Docs

CI Code style: black PRs Welcome


HWComponents provides area, energy, latency, and leak power estimates for hardware components in hardware architectures. It is part of the CiMLoop project and serves as the estimation backend for AccelForge.

Learn more at the website or on GitHub.

⚡ Features

  • Simple Python API for writing area, energy, latency, and leak power models. New models can be written in minutes.
  • Automatic parameter scaling across configurations, including scaling to different technology nodes.
  • Plugin ecosystem that automatically gathers components from installed Python packages.
  • Included model packages for multiple projects, plus a general-purpose component library.

📦 Install

# Core package
pip install hwcomponents

# Model packages
pip install hwcomponents-cacti
pip install hwcomponents-neurosim
pip install hwcomponents-adc
pip install hwcomponents-library

# List available models
hwc --list

🧪 Examples

See the notebooks/ directory for tutorials, and the docs for the full API.

📚 Cite

If you use HWComponents in your work, please cite this repository and the CiMLoop project:

@software{hwcomponents,
  author={Andrulis, Tanner},
  title={HWComponents},
  url={https://github.com/Accelergy-Project/hwcomponents},
  license={MIT},
}

@INPROCEEDINGS{cimloop,
  author={Andrulis, Tanner and Emer, Joel S. and Sze, Vivienne},
  booktitle={2024 IEEE International Symposium on Performance Analysis of Systems and Software (ISPASS)},
  title={CiMLoop: A Flexible, Accurate, and Fast Compute-In-Memory Modeling Tool},
  year={2024},
  pages={10-23},
  doi={10.1109/ISPASS61541.2024.00012}
}

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

hwcomponents-1.0.104.tar.gz (40.7 kB view details)

Uploaded Source

Built Distribution

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

hwcomponents-1.0.104-py3-none-any.whl (25.2 kB view details)

Uploaded Python 3

File details

Details for the file hwcomponents-1.0.104.tar.gz.

File metadata

  • Download URL: hwcomponents-1.0.104.tar.gz
  • Upload date:
  • Size: 40.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hwcomponents-1.0.104.tar.gz
Algorithm Hash digest
SHA256 b77766885902172a2909e043f99dfc136ab5e232ff02a56da7deda94d6a3e0e5
MD5 1e1e6adf47d59e69637f98b1ce69bb70
BLAKE2b-256 248f7ae102249b9bf78f153bb4c6a571affd3c3af7f355dfa1b23b984021d98c

See more details on using hashes here.

Provenance

The following attestation bundles were made for hwcomponents-1.0.104.tar.gz:

Publisher: publish.yaml on Accelergy-Project/hwcomponents

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file hwcomponents-1.0.104-py3-none-any.whl.

File metadata

  • Download URL: hwcomponents-1.0.104-py3-none-any.whl
  • Upload date:
  • Size: 25.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hwcomponents-1.0.104-py3-none-any.whl
Algorithm Hash digest
SHA256 9e9c03157e1e25f5afbdb0dfff22bcc2efc63655114e966233bb93b7da49b11e
MD5 399dc31e7c1a05fdf7dc60cbf2a32a69
BLAKE2b-256 489a2f67a771b5a626a69a4180789037d3c476a34299bdcb8a24ba93e1ec660e

See more details on using hashes here.

Provenance

The following attestation bundles were made for hwcomponents-1.0.104-py3-none-any.whl:

Publisher: publish.yaml on Accelergy-Project/hwcomponents

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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