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.103.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.103-py3-none-any.whl (25.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: hwcomponents-1.0.103.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.103.tar.gz
Algorithm Hash digest
SHA256 e92eb0ac7c93e74d7cbe270948041f499888286fc20c97fadee1737a9f017154
MD5 8ab184ab6b11b03c6fecc67b3a15bdca
BLAKE2b-256 e525177d9fd30c99210b52d06dfbe1c50be15713a96c870efd323cb0a7de2ddc

See more details on using hashes here.

Provenance

The following attestation bundles were made for hwcomponents-1.0.103.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.103-py3-none-any.whl.

File metadata

  • Download URL: hwcomponents-1.0.103-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.103-py3-none-any.whl
Algorithm Hash digest
SHA256 5b82a6a951273fc29661ac665b0dd5983899d10b911a09541fe4c8423ee97ec5
MD5 1ad7d1d8253fca1fd3472842034efa8c
BLAKE2b-256 d874e8e3407a61335c492f215e679a18737bbe09c5714732a48ca17a530e8865

See more details on using hashes here.

Provenance

The following attestation bundles were made for hwcomponents-1.0.103-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