masque/masque
2023-10-15 16:18:32 -07:00
..
builder more wip -- most central stuff is first pass done 2023-10-15 16:18:32 -07:00
file more wip -- most central stuff is first pass done 2023-10-15 16:18:32 -07:00
shapes wip 2023-10-15 16:18:32 -07:00
traits wip 2023-10-15 16:18:32 -07:00
utils wip 2023-10-15 16:18:32 -07:00
__init__.py more wip -- most central stuff is first pass done 2023-10-15 16:18:32 -07:00
error.py more wip -- most central stuff is first pass done 2023-10-15 16:18:32 -07:00
label.py get rid of "identifier" 2023-10-15 16:18:32 -07:00
library.py more wip -- most central stuff is first pass done 2023-10-15 16:18:32 -07:00
LICENSE.md Move from setuputils and setup.py to hatch and pyproject.toml 2023-01-11 17:37:36 -08:00
pattern.py more wip -- most central stuff is first pass done 2023-10-15 16:18:32 -07:00
ports.py more wip -- most central stuff is first pass done 2023-10-15 16:18:32 -07:00
py.typed add py.typed to enable type checking for downstream 2020-05-19 00:15:51 -07:00
README.md Move from setuputils and setup.py to hatch and pyproject.toml 2023-01-11 17:37:36 -08:00
ref.py wip -- more fixes 2023-10-15 16:18:32 -07:00
repetition.py wip 2023-10-15 16:18:32 -07:00

Masque README

Masque is a Python module for designing lithography masks.

The general idea is to implement something resembling the GDSII file-format, but with some vectorized element types (eg. circles, not just polygons) and the ability to output to multiple formats.

Installation

Requirements:

  • python >= 3.8
  • numpy
  • klamath (used for gdsii i/o and library management)
  • matplotlib (optional, used for visualization functions and text)
  • ezdxf (optional, used for dxf i/o)
  • fatamorgana (optional, used for oasis i/o)
  • svgwrite (optional, used for svg output)
  • freetype (optional, used for text)

Install with pip:

pip3 install 'masque[visualization,oasis,dxf,svg,text]'

Alternatively, install from git

pip3 install git+https://mpxd.net/code/jan/masque.git@release

Translation

  • Pattern: OASIS or GDS "Cell", DXF "Block"
  • Ref: GDS "AREF/SREF", OASIS "Placement"
  • Shape: OASIS or GDS "Geometry element", DXF "LWPolyline" or "Polyline"
  • repetition: OASIS "repetition". GDS "AREF" is a Ref combined with a Grid repetition.
  • Label: OASIS, GDS, DXF "Text".
  • annotation: OASIS or GDS "property"

TODO

  • Better interface for polygon operations (e.g. with pyclipper)

    • de-embedding
    • boolean ops
  • Construct polygons from bitmap using skimage.find_contours

  • Deal with shape repetitions for dxf, svg

  • this approach has an issue: how add devices together?

    • need to add the other device by name
    • need to know the other device's ports
    • also: device doesn't know its own name, can't wrap itself into a ref