Metadata-Version: 2.1
Name: inkslab
Version: 0.1.0
Summary: 3D efficient solver for multi-stacked in-plane periodic structures using rcwa.
Home-page: https://github.com/alexysong/inkslab
Author: Alex Y. Song
Author-email: song.alexy@gmail.com
License: UNKNOWN
Description: InkSlab
        ====
        
        **InkSlab** simulates the electromagnetic properties of 3D and 2D multi-layered structures with in-plane periodicicy, such as gratings, photonic-crystal slabs, metasurfaces, vertical-cavity or photonic-crystal surface emitting lasers (VCSEL, PCSEL), (patterned) solar cells, nano-antennas, and more.
        
        <!-- InkSlab allows efficient and flexible parameter-sweeping by storing the unmodified parts of the structure and recalculating only the modified parts. -->
        
        Internally, InkSlab implements rigurous couled-wave analysis (RCWA), a. k. a. Fourier Modal Method (FMM). 
        
        ### InkSlab can calculate: 
        * the reflection, transmission, and the absorption of the structure
        * the total and by-order power fluxes of the propagating and the evanescent waves in each layer
        * electric and magnetic field amplitudes at any locations in the structure,
        * band-structures based on the determinant of the scattering matrix of the structure.
        
        ### Features of InkSlab:
        * It supports efficient and flexible parameter-scanning. You can change part of your sturcture such as the shapes and sizes of some patterns, or some material parameters. InkSlab only recalculates the modified parts and produces the final results efficiently.
        * It allows both tensorial permittivities and tensorial permeabilities, such as in anisotropic, magneto-optical, or gyromagnetic materials. 
        * It can calculate the determinant of the scattering matrix on the complex frequency plane. 
        * Pre-defined shapes of patterns can be used, including rectangular, parallelogram, disk, ellipse, 1D, and polygons. Closed-form Fourier transforms and corrections for Gibbs phenomena are implemented. 
        * It is fully 3D.
        * It is written in pure python, with heavy-lifting done in numpy and scipy.
        
        
        ## Quick Start
        ### Installation:
        
            $ pip install InkSlab
        Or,
        
            $ git clone git://github.com/alexsong/InkSlab
            $ pip install .
        
        ### Usage
        
        The [examples](examples/) folder contains various self-explaining examples to get you started.
        
        ## Dependencies
        
        *   python 3.6+
        *   numpy
        *   scipy
        
        ## Units, conventions, and definitions
        
        ### Unit system
        We adopt a natural unit system, where vacuum permittivity, permeability, and light speed are $\varepsilon_0=\mu_0=c_0=1$.
        
        ### Sign convention
        Sign conventions in electromagnetic waves:
        $$e^{i(kx-\omega t)}$$
        where $k$ is the wavevector, $x$ is spatial location, $\omega$ is frequency, $t$ is time.
        
        By this convention, a permittivity of $\varepsilon_r + i\varepsilon_i$ with $\varepsilon_i>0$ means material loss, and $\varepsilon_i<0$ means material gain.
        
        ### Coordinates and incident angles
        
        <img src="figs/PhC_slab_vector_incident.svg" alt="drawing" width="300"/>
        
        (InkSlab, **In**cident $\bm{k}$ on **slab**s.)
        
        ## Citing
        If you find InkSlab useful for your research, we would apprecite you citing our [paper](https://doi.org/10.1103/PhysRevLett.120.193903). For your convenience, you can use the following BibTex entry:
        
            @article{song2018broadband,
              title={Broadband Control of Topological Nodes in Electromagnetic Fields},
              author={Song, Alex Y and Catrysse, Peter B and Fan, Shanhui},
              journal={Physical review letters},
              volume={120},
              number={19},
              pages={193903},
              year={2018},
              publisher={American Physical Society}
            }
        
           
        
Keywords: rcwa
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 3
Classifier: Topic :: Scientific/Engineering
Classifier: License :: OSI Approved :: GNU Affero General Public License v3 or later (AGPLv3+)
Description-Content-Type: text/markdown
