Python package for lithography mask design.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Jan Petykiewicz f2c58c290f add .oas.gz to .gitignore 2 years ago
examples small example updates 2 years ago
masque Add basic support for OASIS and update setup/docs for OASIS and DXF support 2 years ago
.gitignore add .oas.gz to .gitignore 2 years ago
LICENSE.md Add license 6 years ago
MANIFEST.in Use separate VERSION file 3 years ago
README.md Add basic support for OASIS and update setup/docs for OASIS and DXF support 2 years ago
setup.py Add basic support for OASIS and update setup/docs for OASIS and DXF support 2 years 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), better support for E-beam doses, and the ability to output to multiple formats.

Installation

Requirements:

  • python >= 3.7 (written and tested with 3.8)
  • numpy
  • matplotlib (optional, used for visualization functions and text)
  • python-gdsii (optional, used for gdsii i/o)
  • 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,gdsii,oasis,dxf,svg,text]'

Alternatively, install from git

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

TODO

  • Polygon de-embedding
  • Construct from bitmap
  • Boolean operations on polygons (using pyclipper)
  • Implement shape/cell properties
  • Implement OASIS-style repetitions for shapes