Skip to main content

Python interface for the Coloquinte VLSI placer

Project description

Build Codacy Badge GitHub PyPI

Coloquinte Place&Route

Coloquinte is a Place&Route tool for electronic circuits. Its goal is to provide a single package of well-tested and well-tuned Place&Route algorithms, to be used in open source electronic design toolchains.

This replaces and extends the placement library used in the Coriolis toolchain.

Using Coloquinte

ISPD placement and routing benchmarks are available directly in this repository using Git LFS. Placement benchmarks can be run with the Python package:

coloquinte ISPD06/adaptec1

For other applications, you can use Coloquinte as a C++ library or a Python package: see src/coloquinte.hpp or help(coloquinte.Circuit).

Installing Coloquinte

Python package

On Linux, you may install Coloquinte from pip:

pip install coloquinte

For the latest version or for other OSes, install the dependencies and build the module. For example:

sudo apt-get install g++ cmake libboost-all-dev libeigen3-dev liblemon-dev
cd pycoloquinte
python setup.py install

C++ library

Install dependencies and build Coloquinte using CMake:

sudo apt-get install g++ cmake libboost-all-dev libeigen3-dev liblemon-dev
cmake -B build; cmake --build build; ctest --test-dir build

Or using Meson:

meson setup build; meson compile -C build; meson test -C build

Benchmarks

Coloquinte is tested on the ISPD06 benchmark suite. Below is the reported half-perimeter wirelength on these benchmarks (x107) for various effort parameters. Higher effort = higher quality but higher runtime.

Benchmark Effort 1 WL Effort 3 WL Effort 6 WL
adaptec1 8,04 7,62 7,55
adaptec2 8,83 8,48 8,38
adaptec3 21,07 20,31 19,95
adaptec4 18,84 17,97 17,77
adaptec5 32,65 31,18 30,89
bigblue1 10,01 9,36 9,20
bigblue2 14,79 14,25 14,17
bigblue3 35,23 32,67 31,98
bigblue4 83,15 79,16 77,66
newblue1 60,68 18,75 34,54
newblue2 19,38 18,31 17,97
newblue3 33,70 26,06 25,84
newblue4 24,32 23,35 23,33
newblue5 42,29 39,39 39,02
newblue6 48,43 45,80 45,39
newblue7 102,11 97,81 96,47

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

coloquinte-0.4.1-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (427.5 kB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ x86-64

coloquinte-0.4.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (428.7 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64

coloquinte-0.4.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (428.8 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

coloquinte-0.4.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (428.9 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

coloquinte-0.4.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (428.6 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

coloquinte-0.4.1-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (433.2 kB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.17+ x86-64

coloquinte-0.4.1-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (433.2 kB view hashes)

Uploaded CPython 3.6m manylinux: glibc 2.17+ x86-64

Supported by

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