Update 202505: I've "deployed" a Gradio based GUI on Hugging Face, future development will likely continue there:
BPM is a Python library for simulating beam propagation in integrated photonics using the Beam Propagation Method (BPM). The package provides functions to generate refractive index distributions for various structures (e.g., lenses, waveguides, and MMI splitters), a mode solver for slab waveguides, and BPM propagation routines with support for Perfectly Matched Layers (PML) for absorbing boundary conditions.
Currently it is 2D only, and use analytic solutions to launch slab modes. Propagation direction is upward and is called z. Transverse direction is x.
- Generate refractive index distributions:
- Spherical lens
- S-bend waveguide
- MMI-based splitter
- Solve for guided slab waveguide modes (even/odd modes)
- BPM propagation using a Runge-Kutta integrator
- PML boundary absorption
- [] Import from GDSII
Clone the repository and install using pip:
git clone https://github.com/jwt625/bpm.git
cd bpm
pip install -e .
Slab mode solver and launcher:
Refractive index distribution of an MMI:
Simulated example MMI:
Simulated example S bend. The waveguide is multimode:
Optical tomographic reconstruction based on multi-slice wave propagation method
Light propagation through microlenses: a new simulation method
Light propagation in graded-index optical fibers
- https://doi.org/10.1364/AO.17.003990
- this one is a classic
Numerical Simulation of Optical Wave Propagation with Examples in MATLAB
Photonic Devices for Telecommunications
- Chung1990: An assessment of finite difference beam propagation method
- Vassallo1992: Improvement of finite difference methods for step-index optical waveguides