Skip to content

Multi-source electromagnetic simulations in frequency domain, implementing the augmented partial factorization (APF) and other methods.

License

Notifications You must be signed in to change notification settings

ZevenGo/MESTI.m

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MESTI

MESTI (Maxwell's Equations Solver with Thousands of Inputs) is an open-source software for full-wave electromagnetic simulations in frequency domain using finite-difference discretization on the Yee lattice.

MESTI implements the augmented partial factorization (APF) method described in this paper. While conventional methods solve Maxwell's equations on every element of the discretization basis set (which contains much more information than is typically needed), APF bypasses such intermediate solution step and directly computes the information of interest: a generalized scattering matrix given any list of input source profiles and any list of output projection profiles. It can jointly handle thousands of inputs without a loop over them, using fewer computing resources than what a conventional direct method uses to handle a single input. It is exact with no approximation beyond discretization.

MESTI.m here uses MATLAB with double-precision arithmetic and considers 2D systems either in transverse-magnetic (TM) polarization (Hx,Hy,Ez) with

$$ \left[ -\frac{\partial^2}{\partial x^2} -\frac{\partial^2}{\partial y^2} - \frac{\omega^2}{c^2}\varepsilon(x,y) \right] E_z(x,y)= b(x,y), $$

or in transverse-electric (TE) polarization (Ex,Ey,Hz) with

$$\begin{align*} &\left[ -\frac{\partial}{\partial x}\left(\varepsilon^{-1}\right)_{yy}(x,y) \frac{\partial}{\partial x} -\frac{\partial}{\partial y}\left(\varepsilon^{-1}\right)_{xx}(x,y) \frac{\partial}{\partial y} \right. \\\ &\,\,\,\left. +\frac{\partial}{\partial y}\left(\varepsilon^{-1}\right)_{xy}(x,y) \frac{\partial}{\partial x} +\frac{\partial}{\partial x}\left(\varepsilon^{-1}\right)_{yx}(x,y) \frac{\partial}{\partial y} - \frac{\omega^2}{c^2} \right] H_z(x,y) = b(x,y), \end{align*}$$

where b(x,y) is the source profile.

We also have a Julia version, MESTI.jl, that supports everything in MESTI.m here plus 3D vectorial capability with anisotropic ε, MPI parallelization, subpixel smoothing for common geometries, and single-precision arithmetic.

MESTI.m is a general-purpose solver with its interface written to provide maximal flexibility. It supports

  • TM or TE polarization.
  • Any relative permittivity profile ε(x,y), real-valued or complex-valued. The imaginary part of ε(x,y) describes absorption and linear gain. Users can optionally average the interface pixels for subpixel smoothing (which produces an anisotropic ε in TE polarization) before calling MESTI.
  • Infinite open spaces can be described with a perfectly matched layer (PML) placed on any side(s), which also allows for infinite substrates, waveguides, photonic crystals, etc. The PML implemented in MESTI includes both imaginary-coordinate and real-coordinate stretching, so it can accelerate the attenuation of evanescent waves in addition to attenuating the propagating waves.
  • Any material dispersion ε(ω) can be used since this is in frequency domain.
  • Any list of input source profiles (user-specified or automatically built).
  • Any list of output projection profiles (or no projection, in which case the complete field profiles are returned).
  • Periodic, Bloch periodic, perfect electrical conductor (PEC), and/or perfect magnetic conductor (PMC) boundary conditions.
  • Exact outgoing boundaries in two-sided or one-sided geometries.
  • Real-valued or complex-valued frequency ω.
  • Automatic or manual choice between APF, conventional direct solver (e.g., to compute the full field profile), and the recursive Green's function method as the solution method.
  • Linear solver using MUMPS (requires installation) or the built-in routines in MATLAB (which uses UMFPACK).
  • Shared memory parallelism (with multithreaded BLAS and with OpenMP in MUMPS).

When to use MESTI?

MESTI can perform most linear-response computations in 2D and 1D for arbitrary structures, such as

Since MESTI can use the APF method to handle a large number of input states simultaneously, the computational advantage of MESTI is the most pronounced in multi-input systems.

There are use cases that MESTI can handle but is not necessarily the most efficient, such as

  • Broadband response problems involving many frequencies but only a few input states. Time-domain methods like FDTD may be preferred as they can compute a broadband response without looping over frequencies.
  • Problems like plasmonics that require more than an order of magnitude difference in the discretization grid size at different regions of the structure. Finite-element methods may be preferred as they can handle varying spatial resolutions. (Finite-element methods can also adopt APF, but MESTI uses finite difference with a fixed grid size.)
  • Homogeneous structures with a small surface-to-volume ratio. Boundary element methods may be preferred as they only discretize the surface.

Problems that MESTI currently does not handle:

  • Nonlinear systems (e.g., χ(2), χ(3), gain media).
  • Magnetic systems (e.g., spatially varying permeability μ)

For eigenmode computation, such as waveguide mode solver and photonic band structure computation, one can use mesti_build_fdfd_matrix.m to build the matrix and then compute its eigenmodes. However, we don't currently provide a dedicated function to do so.

Installation

No installation is required for MESTI.m itself. To use, simply download it and add the MESTI.m/src folder to the MATLAB search path using the addpath command. The MATLAB version should be R2019b or later. (Using an earlier version is possible but requires minor edits.)

However, to use the APF method, the user needs to install the serial version of MUMPS and its MATLAB interface (note: the serial version of MUMPS already supports multithreading). Without MUMPS, MESTI will still run but will only use other methods, which generally take longer and use more memory. So, MUMPS installation is strongly recommended for large-scale multi-input simulations or whenever efficiency is important. See this MUMPS installation page for steps to install MUMPS.

Usage Summary

The function mesti(syst, B, C, D) provides the most flexibility. Structure syst specifies the polarization to use, permittivity profile, boundary conditions in x and y, which side(s) to put PML with what parameters, the wavelength, and the discretization grid size. Any list of input source profiles can be specified with matrix B, each column of which specifies one source profile b(x,y). Any list of output projection profiles can be specified with matrix C. Matrix D is optional (treated as zero when not specified) and subtracts the baseline contribution; see this paper for details.

The function mesti2s(syst, in, out) deals specifically with scattering problems in two-sided or one-sided geometries where ε(x,y) consists of an inhomogeneous scattering region with homogeneous spaces on the left (-x) and right (+x), light is incident from the left and/or right, the boundary condition in x is outgoing, and the boundary condition in y is closed (e.g., periodic or PEC). The user only needs to specify the input and output sides or channel indices or wavefronts through in and out. The function mesti2s() automatically builds the source matrix B, projection matrix C, baseline matrix D, and calls mesti() for the computation. Flux normalization in x is applied automatically and exactly, so the full scattering matrix is always unitary when ε(x,y) is real-valued. mesti2s() also offers the additional features of (1) exact outgoing boundaries in x based on the Green's function in free space, and (2) the recursive Green's function method when TM polarization is used; they are efficient for 1D systems and for 2D systems where the width in y is not large.

To compute the complete field profiles, simply omit the argument C or out, or set it to [].

The solution method, the linear solver to use, and other options can be specified with a structure opts as an optional input argument to mesti() or mesti2s(); see documentation for details. They are chosen automatically when not explicitly specified.

The function mesti_build_channels() can be used to build the input and/or output matrices when using mesti(), or to determine which channels are of interest when using mesti2s().

Additional functions that build the input/output matrices for different applications and the anisotropic ε(x,y) from subpixel smoothing will be added in the future.

Documentation

Detailed documentation is given in comments at the beginning of the function files:

For example, typing help mesti in MATLAB brings up the documentation for mesti().

Multithreading

If MUMPS is installed, MESTI can leverage the multithreading feature during computation. Note that multithreading is applied specifically to the factorization and solving stages in MUMPS, which are the most computationally demanding (Nature Computational Science 2, 815–822 (2022)).

To control the number of threads used in MUMPS, we can assign a value to opts.nthreads_OMP and include opts as an input argument in the script. This allows us to determine the desired number of threads for MUMPS to utilize. Notice that we should not set opts.nthreads_OMP larger than the number of threads available on the machine. By default (i.e. without setting opts.nthreads_OMP), MUMPS uses the maximum number of threads available on the machine.

To check the actual number of threads, #OMP, used by MUMPS, set opts.verbal_solver to true and include opts as an input argument in the script. MUMPS prints detailed information to the standard output, allowing you to see the #OMP in the output. For example, MUMPS prints

      executing #MPI =      1 and #OMP =      4

and it shows that the number of threads in this computation is 4. Note that in the serial version of MUMPS, #MPI is always 1.

Examples

Examples in the examples folder illustrate the usage and the main functionalities of MESTI. Each example has its own folder, with its .m script, auxiliary files specific to that example, and a README.md page that shows the example script with its outputs:

Also see the following repositories:

Gallery

Here are some animations from the examples above:

  1. Propagation through a Fabry–Pérot etalon

  1. Open channel propagating through disorder

  1. Reflection matrix of a scatterer in Gaussian-beam basis:

  1. Angle dependence of a mm-wide hyperbolic metalens

  1. Inverse design of a wide-angle metasurface beamsplitter

  1. Numerical experiments of tomographic imaging inside scattering media

Reference & Credit

For more information on the theory, capability, and benchmarks (e.g., scaling of computing time, memory usage, and accuracy), please see:

@article{2022_Lin_NCS,
  title = {Fast multi-source nanophotonic simulations using augmented partial factorization},
  author = {Lin, Ho-Chun and Wang, Zeyu and Hsu, Chia Wei},
  journal = {Nat. Comput. Sci.},
  volume = {2},
  issue = {12},
  pages = {815--822},
  year = {2022},
  month = {Dec},
  doi = {10.1038/s43588-022-00370-6}
}

Please cite this paper when you use MESTI.

About

Multi-source electromagnetic simulations in frequency domain, implementing the augmented partial factorization (APF) and other methods.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • MATLAB 82.9%
  • C 8.0%
  • Makefile 6.3%
  • NASL 2.8%