tmm-fast


Nametmm-fast JSON
Version 0.2.1 PyPI version JSON
download
home_page
Summarytmm_fast is a lightweight package to speed up optical planar multilayer thin-film device computation.
upload_time2023-08-29 08:56:16
maintainer
docs_urlNone
authorHeribert Wankerl
requires_python>=3.7
licenseMIT
keywords one two
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # tmm_fast

tmm_fast or transfer-matrix-method_fast is a lightweight package to speed up optical planar multilayer thin-film device computation. 
Typically, one is interested in computing the Reflection and/or Transmission of light through a multilayer thin-film depending on the 
wavelength and angle of incidence of the incoming light. The package is build on the [original tmm package](https://github.com/sbyrnes321/tmm) from sjbyrnes but quite a lot faster. Depending on the number of layers, wavelength range and angular range speed-ups of ~100x are possible. The physics behind the transfer matrix method can be studied in any textbook on optical devices or in [Multilayer optical calculations](https://arxiv.org/abs/1603.02720)
from Steven J. Byrnes.
More detailed information about the package and its applications can be found in [TMM-Fast: A Transfer Matrix Computation Package for Multilayer Thin-Film Optimization](https://arxiv.org/abs/2111.13667).

![overview](https://user-images.githubusercontent.com/83709614/169793015-0e8b214d-b6f2-4da2-9030-fd8a1ed5ef71.svg)<br/>
Figure 1: Overview about what you can do with this package.

<!-- GETTING STARTED -->
## Getting Started

To get a local copy up and running follow these steps:

### Installation

`tmm-fast` package requires `pytorch`, therefore it is better to install it first following [official instructions](https://pytorch.org/get-started/locally/).

Stable version from [pipy.org](https://pypi.org/project/tmm-fast/):

```sh
pip install tmm-fast
```

Latest version from [github.com](https://github.com/MLResearchAtOSRAM/tmm_fast):

```sh
pip install git+https://github.com/MLResearchAtOSRAM/tmm_fast
```

## Unified functionality of tmm_fast: Sponge PyTorch functionality for free
Parallelized computation of reflection and transmission for coherent light spectra that traverse
a bunch of multilayer thin-films with dispersive materials.
This package is essentially build on Pytorch and its related functionalities such as GPU accelerations and Autograd.
It naturally allows for:
 - GPU accelerated computations
 - To compute gradients regarding the multilayer thin-film (i.e. N, T) thanks to Pytorch Autograd
 - Vectorized computations, i.e. using Einstein summation convention

In general, tmm_fast is a lightweight package to speed up the computations of reflection and transmission of optical planar multilayer thin-films by vectorization regarding
- a set of multilayer thin-films consisting of various layers of particular material and thickness,
- a set of wavelengths, and
- a set of incident angles.
 
### For old guards: Numpy is fully supported
All of the inputs can also be a numpy array format instead of torch tensors.
However, all internal computations are processed via PyTorch and thus the output data is converted back to numpy arrays again.
Hence, the use of numpy input may increase computation time due to data type conversions.

### Benefits and conducted sanity checks, backgrounds
Depending on the number of thin films an their number of layers as well as the considered wavelengths that irradiate the thin film under particular angles of incident, the computation time can be decreased by 2-3 orders of magnitude.
This claim is supported by several cross-checks (https://arxiv.org/abs/2111.13667), conducted with the code provided by Steven J. Byrnes (https://arxiv.org/abs/1603.02720). Of course, the checks covered both, computational time and physical outputs.

The physics behind the transfer matrix method can be studied in any textbook on optical devices or related papers, e.g.
- Chapter on thin films in Microphotonics (http://www.photonics.intec.ugent.be/download/ocs129.pdf) by Dries Van Thourhout, Roel Baets (UGent) and Heidi Ottevaere (VUB)
- Multilayer optical computations (https://arxiv.org/abs/1603.02720) by Steven J. Byrnes
- The Fresnel Coefficient of Thin Film Multilayer Using Transfer Matrix Method (https://iopscience.iop.org/article/10.1088/1757-899X/518/3/032026) by Zahraa Hummam Mohammed

# gym-multilayerthinfilm

The proposed OpenAI/Farama-Foundation gymnasium environment utilizes the parallelized transfer-matrix method (TMM-Fast) to implement the optimization of multi-layer thin films as parameterized Markov decision processes. A very intuitive example is provided in example.py.
Whereas the contained physical methods are well-studied and known since decades, the contribution of this code lies the transfer to an OpenAI/Farama-Foundation gymnasium environment. The intention is to enable AI researchers without optical expertise to solve the corresponding parameterized Markov decision processes. Due to their structure, the solution of such problems is still an active field of research in the AI community.<br/>
The publication [Parameterized Reinforcement learning for Optical System Optimization](https://iopscience.iop.org/article/10.1088/1361-6463/abfddb) used a related environment.

## Getting started
To get started you can do the example py-files for tmm (example_tmm.py) or the gymnasium environment (example_gym.py)!

## Multi-layer thin films meet parameterized reinforcement learning
Reinforcement learning is an area of machine learning concerned with how intelligent agents ought to take actions in an environment in order to maximize the notion of reward. The code to be published implements such an environment for the optimization of multi-layer thin films.
In principle, the proposed code allows to execute actions taken by an agent. These actions determine which material and with which thickness to stack next, thereby consecutively forming a multi-layer thin film as illustrated in Figure 1. Such a multilayer thin-film exhibits optical characteristics. By comparison between the actual and user-defined desired characteristics, a notion of numeric reward is computed based on which the agent learns to distinguish between good and bad design choices. Due to its physical and mathematical structure, the optimization of multi-layer thin film remains a challenging and thus still active field of research in the scientific community. As such it gained recent attention in many publications. Therefore, naturally the need for a standardized environment arises to make the corresponding research more trustful, comparable and consistent.

![image](https://user-images.githubusercontent.com/83709614/127179171-bc7e8fe5-bd83-4125-a84f-12a9e16c3150.png)<br/> 
Figure 2: Principal idea of an OpenAI/Farama-Foundation gymnasium environment. The agent takes an action that specifies the material and thickness of the layer to stack next. The environment implements the multi-layer thin film generation as consecutive conduction of actions and assigns a reward to a proposed multi-layer thin film based on how close the actual (solid orange line) fulfils a desired (dashed orange line) characteristic. The made experience is used to adapt the taken actions made in order to increase the reward and thus generate more and more sophisticated multi-layer thin films.

### Description of key features
The environment can include<br/> 
•	cladding of the multi-layer thin film (e.g. substrate and ambient materials),<br/>
•	dispersive and dissipative materials,<br/>
•	spectral and angular optical behavior of multi-layer thin films (See figure 3),<br/>
•	… and many more.<br/>

The environment class allows to <br/>
•	conduct so-called parameterized actions (See publication) that define a multi-layer thin film,<br/>
•	evaluate the generated thin film given a desired optical response, and<br/>
•	render the results (See figure 3). <br/>

In general, the comprehensive optimization of multi-layer thin films in regards of optical response encompasses <br/>
•	the number of layers (integer),<br/>
•	the thickness of each layer (float),<br/>
•	the material of each layer (categorical, integer).<br/>

![image](https://user-images.githubusercontent.com/83709614/127179200-16aaf611-ad17-4082-a47f-d933ba7cbc83.png)<br/> 
Figure 3: Rendered output of the environment. Reflectivity (left) over angle of incidence and spectrum of a multi-layer thin film (right). Here, the stack features four layers and each layer’s material was chosen from a set of eight alternatives. The reward is computed based on a desired reflectivity, which is one for each angle and wavelength, but not displayed in this figure.


# Citing
If you use the code from this repository for your projects, please cite <br/>
[TMM-Fast: A Transfer Matrix Computation Package for Multilayer Thin-Film Optimization](https://doi.org/10.1364/JOSAA.450928) or/and<br/>
[Parameterized reinforcement learning for optical system optimization](https://iopscience.iop.org/article/10.1088/1361-6463/abfddb) in your publications.

            

Raw data

            {
    "_id": null,
    "home_page": "",
    "name": "tmm-fast",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.7",
    "maintainer_email": "",
    "keywords": "one,two",
    "author": "Heribert Wankerl",
    "author_email": "Alexander Luce <alexander.luce@ams-osram.com>",
    "download_url": "https://files.pythonhosted.org/packages/d7/44/1dff2409321a406d47334597e935819aa78a11830db4486ced856a61d849/tmm_fast-0.2.1.tar.gz",
    "platform": null,
    "description": "# tmm_fast\n\ntmm_fast or transfer-matrix-method_fast is a lightweight package to speed up optical planar multilayer thin-film device computation. \nTypically, one is interested in computing the Reflection and/or Transmission of light through a multilayer thin-film depending on the \nwavelength and angle of incidence of the incoming light. The package is build on the [original tmm package](https://github.com/sbyrnes321/tmm) from sjbyrnes but quite a lot faster. Depending on the number of layers, wavelength range and angular range speed-ups of ~100x are possible. The physics behind the transfer matrix method can be studied in any textbook on optical devices or in [Multilayer optical calculations](https://arxiv.org/abs/1603.02720)\nfrom Steven J. Byrnes.\nMore detailed information about the package and its applications can be found in [TMM-Fast: A Transfer Matrix Computation Package for Multilayer Thin-Film Optimization](https://arxiv.org/abs/2111.13667).\n\n![overview](https://user-images.githubusercontent.com/83709614/169793015-0e8b214d-b6f2-4da2-9030-fd8a1ed5ef71.svg)<br/>\nFigure 1: Overview about what you can do with this package.\n\n<!-- GETTING STARTED -->\n## Getting Started\n\nTo get a local copy up and running follow these steps:\n\n### Installation\n\n`tmm-fast` package requires `pytorch`, therefore it is better to install it first following [official instructions](https://pytorch.org/get-started/locally/).\n\nStable version from [pipy.org](https://pypi.org/project/tmm-fast/):\n\n```sh\npip install tmm-fast\n```\n\nLatest version from [github.com](https://github.com/MLResearchAtOSRAM/tmm_fast):\n\n```sh\npip install git+https://github.com/MLResearchAtOSRAM/tmm_fast\n```\n\n## Unified functionality of tmm_fast: Sponge PyTorch functionality for free\nParallelized computation of reflection and transmission for coherent light spectra that traverse\na bunch of multilayer thin-films with dispersive materials.\nThis package is essentially build on Pytorch and its related functionalities such as GPU accelerations and Autograd.\nIt naturally allows for:\n - GPU accelerated computations\n - To compute gradients regarding the multilayer thin-film (i.e. N, T) thanks to Pytorch Autograd\n - Vectorized computations, i.e. using Einstein summation convention\n\nIn general, tmm_fast is a lightweight package to speed up the computations of reflection and transmission of optical planar multilayer thin-films by vectorization regarding\n- a set of multilayer thin-films consisting of various layers of particular material and thickness,\n- a set of wavelengths, and\n- a set of incident angles.\n \n### For old guards: Numpy is fully supported\nAll of the inputs can also be a numpy array format instead of torch tensors.\nHowever, all internal computations are processed via PyTorch and thus the output data is converted back to numpy arrays again.\nHence, the use of numpy input may increase computation time due to data type conversions.\n\n### Benefits and conducted sanity checks, backgrounds\nDepending on the number of thin films an their number of layers as well as the considered wavelengths that irradiate the thin film under particular angles of incident, the computation time can be decreased by 2-3 orders of magnitude.\nThis claim is supported by several cross-checks (https://arxiv.org/abs/2111.13667), conducted with the code provided by Steven J. Byrnes (https://arxiv.org/abs/1603.02720). Of course, the checks covered both, computational time and physical outputs.\n\nThe physics behind the transfer matrix method can be studied in any textbook on optical devices or related papers, e.g.\n- Chapter on thin films in Microphotonics (http://www.photonics.intec.ugent.be/download/ocs129.pdf) by Dries Van Thourhout, Roel Baets (UGent) and Heidi Ottevaere (VUB)\n- Multilayer optical computations (https://arxiv.org/abs/1603.02720) by Steven J. Byrnes\n- The Fresnel Coefficient of Thin Film Multilayer Using Transfer Matrix Method (https://iopscience.iop.org/article/10.1088/1757-899X/518/3/032026) by Zahraa Hummam Mohammed\n\n# gym-multilayerthinfilm\n\nThe proposed OpenAI/Farama-Foundation gymnasium environment utilizes the parallelized transfer-matrix method (TMM-Fast) to implement the optimization of multi-layer thin films as parameterized Markov decision processes. A very intuitive example is provided in example.py.\nWhereas the contained physical methods are well-studied and known since decades, the contribution of this code lies the transfer to an OpenAI/Farama-Foundation gymnasium environment. The intention is to enable AI researchers without optical expertise to solve the corresponding parameterized Markov decision processes. Due to their structure, the solution of such problems is still an active field of research in the AI community.<br/>\nThe publication [Parameterized Reinforcement learning for Optical System Optimization](https://iopscience.iop.org/article/10.1088/1361-6463/abfddb) used a related environment.\n\n## Getting started\nTo get started you can do the example py-files for tmm (example_tmm.py) or the gymnasium environment (example_gym.py)!\n\n## Multi-layer thin films meet parameterized reinforcement learning\nReinforcement learning is an area of machine learning concerned with how intelligent agents ought to take actions in an environment in order to maximize the notion of reward. The code to be published implements such an environment for the optimization of multi-layer thin films.\nIn principle, the proposed code allows to execute actions taken by an agent. These actions determine which material and with which thickness to stack next, thereby consecutively forming a multi-layer thin film as illustrated in Figure 1. Such a multilayer thin-film exhibits optical characteristics. By comparison between the actual and user-defined desired characteristics, a notion of numeric reward is computed based on which the agent learns to distinguish between good and bad design choices. Due to its physical and mathematical structure, the optimization of multi-layer thin film remains a challenging and thus still active field of research in the scientific community. As such it gained recent attention in many publications. Therefore, naturally the need for a standardized environment arises to make the corresponding research more trustful, comparable and consistent.\n\n![image](https://user-images.githubusercontent.com/83709614/127179171-bc7e8fe5-bd83-4125-a84f-12a9e16c3150.png)<br/> \nFigure 2: Principal idea of an OpenAI/Farama-Foundation gymnasium environment. The agent takes an action that specifies the material and thickness of the layer to stack next. The environment implements the multi-layer thin film generation as consecutive conduction of actions and assigns a reward to a proposed multi-layer thin film based on how close the actual (solid orange line) fulfils a desired (dashed orange line) characteristic. The made experience is used to adapt the taken actions made in order to increase the reward and thus generate more and more sophisticated multi-layer thin films.\n\n### Description of key features\nThe environment can include<br/> \n\u2022\tcladding of the multi-layer thin film (e.g. substrate and ambient materials),<br/>\n\u2022\tdispersive and dissipative materials,<br/>\n\u2022\tspectral and angular optical behavior of multi-layer thin films (See figure 3),<br/>\n\u2022\t\u2026 and many more.<br/>\n\nThe environment class allows to <br/>\n\u2022\tconduct so-called parameterized actions (See publication) that define a multi-layer thin film,<br/>\n\u2022\tevaluate the generated thin film given a desired optical response, and<br/>\n\u2022\trender the results (See figure 3). <br/>\n\nIn general, the comprehensive optimization of multi-layer thin films in regards of optical response encompasses <br/>\n\u2022\tthe number of layers (integer),<br/>\n\u2022\tthe thickness of each layer (float),<br/>\n\u2022\tthe material of each layer (categorical, integer).<br/>\n\n![image](https://user-images.githubusercontent.com/83709614/127179200-16aaf611-ad17-4082-a47f-d933ba7cbc83.png)<br/> \nFigure 3: Rendered output of the environment. Reflectivity (left) over angle of incidence and spectrum of a multi-layer thin film (right). Here, the stack features four layers and each layer\u2019s material was chosen from a set of eight alternatives. The reward is computed based on a desired reflectivity, which is one for each angle and wavelength, but not displayed in this figure.\n\n\n# Citing\nIf you use the code from this repository for your projects, please cite <br/>\n[TMM-Fast: A Transfer Matrix Computation Package for Multilayer Thin-Film Optimization](https://doi.org/10.1364/JOSAA.450928) or/and<br/>\n[Parameterized reinforcement learning for optical system optimization](https://iopscience.iop.org/article/10.1088/1361-6463/abfddb) in your publications.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "tmm_fast is a lightweight package to speed up optical planar multilayer thin-film device computation.",
    "version": "0.2.1",
    "project_urls": null,
    "split_keywords": [
        "one",
        "two"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "09fde71153410607f5555d1c42395659f2d90d2c176af1b7b1413baebbd5f3e3",
                "md5": "ca51a347a336490b3626cd03b1e07936",
                "sha256": "d18177c07d57927378ccaf5f137ff214a1b0519625c85139dc469c700ecf6e3e"
            },
            "downloads": -1,
            "filename": "tmm_fast-0.2.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "ca51a347a336490b3626cd03b1e07936",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.7",
            "size": 162860,
            "upload_time": "2023-08-29T08:56:14",
            "upload_time_iso_8601": "2023-08-29T08:56:14.973741Z",
            "url": "https://files.pythonhosted.org/packages/09/fd/e71153410607f5555d1c42395659f2d90d2c176af1b7b1413baebbd5f3e3/tmm_fast-0.2.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "d7441dff2409321a406d47334597e935819aa78a11830db4486ced856a61d849",
                "md5": "58cc291fb5b850cf1674acabbc2a9831",
                "sha256": "de9a4521d8bd2cbc37026d25ecb084fa9855236013e4faea28ee8be9c39ef650"
            },
            "downloads": -1,
            "filename": "tmm_fast-0.2.1.tar.gz",
            "has_sig": false,
            "md5_digest": "58cc291fb5b850cf1674acabbc2a9831",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7",
            "size": 160140,
            "upload_time": "2023-08-29T08:56:16",
            "upload_time_iso_8601": "2023-08-29T08:56:16.690774Z",
            "url": "https://files.pythonhosted.org/packages/d7/44/1dff2409321a406d47334597e935819aa78a11830db4486ced856a61d849/tmm_fast-0.2.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-08-29 08:56:16",
    "github": false,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "lcname": "tmm-fast"
}
        
Elapsed time: 0.14279s