Skip to main content

SciPy-based photonics mode solver with a small Python API.

Project description

micromode

An electromagnetic mode solver using the FDFD method on a rectilinear Yee-grid.

pip install micromode

License Tests Coverage PyPI Status

Why Use It?

  • Grid-first API: pass already-rasterized material tensors and grid edges directly, with no required CAD or geometry model.
  • Readable SciPy implementation: sparse operators are assembled in Python and solved with SciPy/ARPACK, so the numerical path can be inspected by users who do not want to trust a custom native solver.
  • Small integration surface: MicroMode is the solver piece you embed after geometry has already been rasterized by an FDTD, FEM, or custom photonics pipeline.
  • Tensor-aware: supports scalar, diagonal anisotropic, and full tensor material grids, plus transformed angle and bend solves.
  • Practical outputs: coordinate-aware fields, n_eff, k_eff, mode area, polarization fractions, Lorentz overlaps, plotting, dataframe export, and HDF5 save/load.
  • Works for both 2D cross sections and 1D slices.

MicroMode is intentionally not a full simulation platform or geometry package. That is the point: you give it a mode-plane material grid, and it returns guided modes with the diagnostics and result helpers needed by downstream simulation workflows.

Micromode is the default mode solver in the BEAMZ FDTD engine.

Quick Start

import micromode as mm

wavelength_um = 1.55
freq = mm.C_0 / wavelength_um

# Arrays from your own rasterizer.
eps_xx, x_edges, y_edges = mode_plane_arrays(...)

materials = mm.Materials.from_diagonal(
    eps_xx=eps_xx,
    x_edges=x_edges,
    y_edges=y_edges,
)

data = mm.solve_modes(
    material_grid=materials,
    freqs=[freq],
    num_modes=2,
    target_neff=2.5,
)

print(data.n_eff.values)
data.plot_field("Ex", mode_index=0)
data.to_hdf5("modes.h5")

Examples

Tidy3D Waveguide

Tidy3D modal monitor example

The Tidy3D modal monitor example recreates the strip-waveguide setup from Flexcompute's modal sources and monitors notebook. It solves the first three x-propagating modes of a silicon waveguide on a silica substrate and plots |Ey| and |Ez| on the same y-z mode plane. (See Tidy3D, "Defining Mode Sources and Monitors".)

uv run --extra dev python examples/tidy3d_modal_sources_monitors.py

Hybridization Sweep

Hybridization sweep example

The SOI hybridization example sweeps the width of a 220 nm silicon ridge and solves several modes at each step. It shows how nearby modes exchange character as the geometry changes by plotting effective index and TE fraction across the sweep in separate figures, then rendering representative field profiles.

uv run --extra dev python examples/soi_hybridization_sweep.py

Physics

MicroMode solves the source-free frequency-domain Maxwell equations on a rasterized Yee mode plane, $\nabla\times\mathbf{E}=-i\omega\mu\mathbf{H}, ; \nabla\times\mathbf{H}=i\omega\epsilon\mathbf{E},$ with modal fields $\mathbf{E},\mathbf{H}\propto e^{i k_0 n_\mathrm{eff} z}.$

On diagonal material grids this becomes a transverse eigenproblem, while full tensor or transformed grids use a first-order tensorial form. The detailed derivation is in docs/physics-model.md, and the public solver controls are summarized in docs/mode-solver-methods.md.

Solver

MicroMode assembles the finite-difference sparse operators in Python and solves the shift-invert eigenproblems with SciPy/ARPACK. That makes the numerical method easier for academic users to inspect and debug, while still using a trusted sparse eigensolver stack.

This means MicroMode is differentiated by workflow and inspectability rather than by a custom solver engine: it is built for users who already have permittivity on a Yee grid and want a focused, auditable mode-solver component that fits cleanly into a larger photonics pipeline.

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

micromode-0.1.0a5.tar.gz (52.1 kB view details)

Uploaded Source

Built Distribution

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

micromode-0.1.0a5-py3-none-any.whl (45.6 kB view details)

Uploaded Python 3

File details

Details for the file micromode-0.1.0a5.tar.gz.

File metadata

  • Download URL: micromode-0.1.0a5.tar.gz
  • Upload date:
  • Size: 52.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for micromode-0.1.0a5.tar.gz
Algorithm Hash digest
SHA256 8c9829f0a5aec329eaf04d649524b46600bdda4e211769f2234280f8fa58fb10
MD5 dae63d05a15478d3724998083c8253ef
BLAKE2b-256 d31b074dce3c2c9e4b1b1a4dc66352604f7b74cdfa1a61f9038f7fc9cf19ca5d

See more details on using hashes here.

Provenance

The following attestation bundles were made for micromode-0.1.0a5.tar.gz:

Publisher: publish.yml on beamzorg/micromode

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file micromode-0.1.0a5-py3-none-any.whl.

File metadata

  • Download URL: micromode-0.1.0a5-py3-none-any.whl
  • Upload date:
  • Size: 45.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for micromode-0.1.0a5-py3-none-any.whl
Algorithm Hash digest
SHA256 c500bc02867638bf629699aa1493ac6a56f0bf69a5a76c32fb7fad549866719d
MD5 9e764d9a1a5d7ae77ed746c9388e12e1
BLAKE2b-256 4c8cc22de728132e52df05c87c1471cc0114db1366674efd26fb432579fc8592

See more details on using hashes here.

Provenance

The following attestation bundles were made for micromode-0.1.0a5-py3-none-any.whl:

Publisher: publish.yml on beamzorg/micromode

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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