Skip to main content

A library for netlist modification and analysis

Project description

Netlist Carpentry

Netlist Carpentry is a Python library that allows you to access and modify a digital circuit in an accessible way. It covers the following use cases:

  • Navigate through your circuit and introduce custom checks
  • Implement new algorithms that do optimizations or modifications with your circuit
  • ...

It uses Yosys to get the circuit from a behavioral code and converts it into a pythonic structure along with a networkx graph. This allows for using standard graph algorithms on the circuit as well as pretty-printing facilities.

Once in Python, the structure can be examined and modified. Netlist carpentry internally tracks all the changes and lets you write out your modified circuit to Verilog. Back in verilog, the most simulation or synthesis tools can be used.

A simple example:

import netlist_carpentry

# Load your Circuit
circuit = netlist_carpentry.read("simpleAdder.v")
# Define your top module
circuit.set_top('simpleAdder')

print(f"The top module '{top_module.name}' has the following items:")
for instance_name, instance_object in top_module.instances.items():
    print(f"\tInstance '{instance_name}'.")

for port_name, port_object in top_module.ports.items():
    print(f"\tPort '{port_name}', which is an {port_object.direction} port and {port_object.width} bit wide!")

for wire_name, wire_object in top_module.wires.items():
    print(f"\tWire '{wire_name}', which is {wire_object.width} bit wide!")

Netlist Carpentry is designed for making the access to the circuit as easy as possible. The runtime-performance was not always in focus -- so don't expect it to work as fast as a custom-knitted C++ software. If you want to propose changes, please submit an issue or even a pull request.

Installation

Install the package via...

pip install netlist-carpentry

... and have fun!

The package requires at least Python 3.9 (recommended is 3.12).

Alternatively, you can clone this repository and install the package in editable mode.

Examples

Examples on how to use Netlist Carpentry (and how it can be integrated into design workflows) can be found in docs/src/user_guide along with the documentation. Most of them are Jupyter Notebooks, meaning they can be executed and modified to experiment with Netlist Carpentry. They can also be viewed in the online documentation.

Development Guide

A guide on how to expand or modify the tool is also given. Visit docs/src/dev_guide or the online development guide for more information.

Citation

If you use Netlist Carpentry in your research, please consider citing it:

DOI

Citations of individual versions are also possible using the version-specific DOIs on the Zenodo-Site. Please use the link of the DOI-badge for more information.

Acknowledgement

The DI-Meta-X project where this software has been developed is funded by the German Federal Ministry of Research, Technology and Space under the reference 16ME0976. Responsibility for the content of this publication lies with the author.

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

netlist_carpentry-0.3.2.tar.gz (2.6 MB view details)

Uploaded Source

Built Distribution

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

netlist_carpentry-0.3.2-py3-none-any.whl (194.3 kB view details)

Uploaded Python 3

File details

Details for the file netlist_carpentry-0.3.2.tar.gz.

File metadata

  • Download URL: netlist_carpentry-0.3.2.tar.gz
  • Upload date:
  • Size: 2.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for netlist_carpentry-0.3.2.tar.gz
Algorithm Hash digest
SHA256 ba26dd1133fc6be365f5eff7806d57b889021a1624a51b4cbf57cd27592fc6f5
MD5 d16072a88fb066642ff1ef15f840fa52
BLAKE2b-256 1d9c476c0df299d1d0d1a817ac6c4f59947e3beba3f9767e549caa313e9b74ae

See more details on using hashes here.

File details

Details for the file netlist_carpentry-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: netlist_carpentry-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 194.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for netlist_carpentry-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 01ee42c8ab7699b2e40a7ec6daff2fdf04dd3604332e7cb206b7d734f20706e1
MD5 3ab24d04f1723eea8657505ff44bd2fa
BLAKE2b-256 6e186f8259eaac28cd49ae240d33492879645757b4f4e19d820ebfa0b8da727d

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