Skip to content

A numerical swiss army knife for computing the optical response of a multilayered structure.

License

Notifications You must be signed in to change notification settings

AnMoreau/PyMoosh

Repository files navigation

PyMoosh

A Python-based Multilayer Optics Optimization and Simulation Hub !

A versatile tool for teaching and research in optics

PyMoosh is a versatile numerical tool written in Python that simulates light interaction with multilayered structures.

Much like a Swiss Army knife, PyMoosh offers a comprehensive set of functionalities while its code remains easy to understand and modify. Its user-friendly design makes it accessible to first-year students who can quickly compute basic properties like reflection coefficients, while advanced users (researchers) benefit from sophisticated features including complex material models and optimization tools.

PyMoosh is particularly valuable for research in fields such as plasmonics, photovoltaics, and ellipsometry. The library comes with extensive Jupyter Notebooks that demonstrate all its capabilities and facilitate learning.

We are continuously developing PyMoosh, adding new features while prioritizing backward compatibility. Our team provides support and welcomes suggestions for improvement from the user community.

Installation and Setup

Requirements

  • Python 3.10 or higher is required for RefractiveIndex library integration
  • If Python 3.10+ is problematic, contact us for a version without RefractiveIndex

Basic Installation

For Python 3.10:

pip install pymoosh

For Python 3.11+:

Python 3.11+ requires using virtual environments:

# Create and activate a virtual environment
python -m venv pymoosh-env
# On Linux/macOS:
source pymoosh-env/bin/activate
# On Windows:
pymoosh-env\Scripts\activate

# Install PyMoosh
pip install pymoosh

Conda Installation (Windows)

# Create and activate environment
conda create -n pymoosh python=3.10
conda activate pymoosh

# Install dependencies first, then PyMoosh
conda install -c conda-forge numpy scipy matplotlib jupyter
pip install pymoosh

Remember to activate your environment each time you use PyMoosh.

Quick Start Example

PyMoosh is designed to be simple and intuitive. Here's a minimal working example to get you started:

from PyMoosh import *
import matplotlib.pyplot as plt
# Define a simple interface (air/glass)
wl = 600  # wavelength in nm
interface = Structure([1., 2.25], [0, 1], [20*wl, 20*wl])
# Compute and represent its reflection coefficient
incidence, r, t, R, T = angular(interface, wl, 0, 0., 80., 400)
plt.plot(incidence, R)
plt.savefig('fresnel.png')
# Define the window and the incident beam of light
# Arguments : width, relative position of the beam, resolution in x and y
domain = Window(100*wl, 0.2, 10., 10.)
# Define the incident Beam
# Wavelength, incidence angle, polarization,
beam = Beam(wl, 56.3/180*np.pi, 0, 10*wl)
# Compute the field
E_field = field(interface, beam, domain)
# Visualize the result
plt.figure()
plt.imshow(np.abs(E_field), cmap='jet', extent=[0, domain.width, 0, sum(interface.thickness)])
plt.axis('off')
plt.savefig('refraction.png')
plt.show()

The code above produces these results:

Reflection coefficient vs. incidence angle:

Fresnel reflection coefficient

Light refraction at an air/glass interface:

Refraction field visualization

With just these few lines, you can calculate and visualize electromagnetic fields and reflection coefficients for multilayered structures. The examples above demonstrate a simple air/glass interface, but PyMoosh can handle complex stacks with many materials and layers.

References and Scientific Publications

Technical Documentation

For a detailed and regularly updated technical description of PyMoosh, see our arXiv paper.

Tutorial Papers

PyMoosh has been released with a trilogy of tutorial papers, that are open access:

  1. Official PyMoosh Presentation Paper
    Journal of the Optical Society of America B, 41(2), A67-A78 (2024)

    If you use PyMoosh in your research, please cite:

    @article{langevin2024pymoosh,
      title={PyMoosh: a comprehensive numerical toolkit for computing the optical properties of multilayered structures},
      author={Langevin, Denis and Bennet, Pauline and Khaireh-Walieh, Abdourahman and Wiecha, Peter and Teytaud, Olivier and Moreau, Antoine},
      journal={Journal of the Optical Society of America B},
      volume={41},
      number={2},
      pages={A67--A78},
      year={2024},
      publisher={Optica Publishing Group}
    }
  2. Global Optimization in Nanophotonics Tutorial
    Journal of the Optical Society of America B, 41(2), A126 (2024)
    And a bunch of informative Jupyter notebooks can be found in this repository

  3. Challenges of Deep Learning for Inverse Design
    Nanophotonics (2023)

Research Applications

PyMoosh is a research-grade program. PyMoosh and its predecessor Moosh have been used in various research projects:

Illustrations

A punctual source inside a dielectric layer :

A punctual source inside a dielectric layer

Excitation of a surface plasmon

Excitation of a surface plasmon using a prism coupler in the Kretschman Raether configuration.

Contributors

Here is a list of contributors to PyMoosh (one way or another) so far:

  • Pauline Bennet (@Ellawin)
  • Tristan Berthelot (@Tilmedor)
  • Anorld Capo-Chichi
  • Pierre Chevalier
  • Aidan Costard (@Dratsa)
  • Denis Langevin (@Milloupe)
  • Demetrio Macias
  • Téo Mottin (@HawhawPdB)
  • Amine Sakkali
  • Olivier Teytaud (@teytaud)
  • Antoine Vezon
  • Peter R. Wiecha

and the contributors to the original Moosh program should not be forgotten : Josselin Defrance, Rémi Pollès, Fabien Krayzel, Paul-Henri Tichit, Jessica Benedicto mainly, but David R. Smith and Cristian Ciraci too ! Special thanks to Gérard Granet and Jean-Pierre Plumey.

About

A numerical swiss army knife for computing the optical response of a multilayered structure.

Resources

License

Stars

Watchers

Forks

Packages

No packages published