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.101.tar.gz (40.5 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.101-py3-none-any.whl (24.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: hwcomponents-1.0.101.tar.gz
  • Upload date:
  • Size: 40.5 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.101.tar.gz
Algorithm Hash digest
SHA256 0ffa501ea523a5f658537a1b0d27a10d88b56b32db1dfff7c9d694a2c99a4f12
MD5 8636a8904f8400609f7dd9fe2433c32f
BLAKE2b-256 960eee34d455d58ddf54297da349b106806d561be93187339943f8d57df0054f

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: hwcomponents-1.0.101-py3-none-any.whl
  • Upload date:
  • Size: 24.9 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.101-py3-none-any.whl
Algorithm Hash digest
SHA256 f623cb9efc1b29c727baa8ac81ef53f04d71c9f033509c6a08621c4590a137bb
MD5 ca242f4bdce5ba9239ca2f56c18a5972
BLAKE2b-256 38b6aafed95f2118452343a8f80d19cfcab8b8742071c7d61c64f0cf15a09384

See more details on using hashes here.

Provenance

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