You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
masque/masque
jan dc4f24a028 delete FlatBuilder (Builder subsumes it) 1 year ago
..
builder delete FlatBuilder (Builder subsumes it) 1 year ago
file cleanup 1 year ago
shapes comment updates 1 year ago
traits cleanup 1 year ago
utils redo library class naming 1 year ago
LICENSE.md Move from setuputils and setup.py to hatch and pyproject.toml 1 year ago
README.md Move from setuputils and setup.py to hatch and pyproject.toml 1 year ago
__init__.py delete FlatBuilder (Builder subsumes it) 1 year ago
abstract.py redo library class naming 1 year ago
error.py add @oneshot decorator 1 year ago
label.py use Self type 1 year ago
library.py comment 1 year ago
pattern.py shorten labels 1 year ago
ports.py split out find_ptransform (static version, only need ports) 1 year ago
py.typed add py.typed to enable type checking for downstream 4 years ago
ref.py cleanup 1 year ago
repetition.py modernize type annotations 1 year ago

README.md

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 (optional, used for gdsii i/o)
  • 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
  • Deal with shape repetitions for dxf, svg
  • Maybe lib.create(bname) -> (name, pat)
  • Schematic:
    • Simple cell:
      • Assumes no internal hierarchy, or only other simple hierarchy
      • Return pattern, refer to it by a well-known name
    • Parametrized cell:
      • Take in lib
      • lib.create(), and return a string
      • Can have pcell hierarchy inside