Skip to main content

An all-in-one photonic electro-optic modulator design tool with complete modularity providing consistent optical mode solving, charge transport simulations, RF mode solving and transmission line analysis for arbitrary materials and cross sections.

Project description

Welcome to the Imodulator's repository

Imodulator is an all-in-one tool for the simulation of electro-optic phase modulators.
Simply define your geometry and materials, and then send the information to the various solvers available — including optical mode solver, RF mode solver with small-signal analysis, charge transport simulations, and electro-optic interaction simulations.

Check out the docs to see how to install and use this package.


Current Limitations

For the moment, the full functionality of the Imodulator package is limited to InGaAsP alloys lattice-matched to InP. However, when we consider the different parts of the simulator, we have various limitations that may or may not be relevant.

  • OpticalSimulatorFEMWELL:
    There is virtually no limitation here. As long as you provide a refractive index for each polygon, you're good to go.

  • OpticalSimulatorMODE:
    There is virtually no limitation here. As long as you provide a refractive index for each polygon, you're good to go.

  • RFSimulatorFEMWELL:
    There is also no limitation in this solver. You need only to input the material properties and it will work.

  • ChargeSimulatorSolcore:
    Solcore has been developed with solar cells in mind, and we have found that the internal library of material parameters was limiting for the purpose of this package.
    Therefore, we have made a connection between Solcore and openbandparams so that we can use arbitrary III–V alloys (excluding strain effects) in solving the Poisson–drift–diffusion equations.
    The limitation here is that we must work with III–V alloys only.
    Furthermore, the mobility values are calculated through Solcore via mobility_solcore, and we are therefore limited to:

    • InGaAs
    • InGaP
    • AlGaAs
    • InAlAs
    • InGaAsP
  • ChargeSimulatorNN:
    There isn’t really a limitation here. We only need to provide materials supported by NextNano.

  • ElectroOpticalModels:
    We have only included a model compatible with electro-optical effects that take place in InGaAsP alloys lattice-matched to InP. However, the software has been written to allow for any model, as long as we provide a

    formula

    function.


Where You Can Contribute

  • Generalization of openbandparams to include other semiconductor compounds such as Si and SiGe.
  • Generalization of mobility_solcore to include other mobility models explored in Sotoodeh et al., 2000.
    Alternatively, one could explore the inclusion of those models directly in openbandparams.
  • Include more electro-optic models.
  • Include surface impedance boundary conditions in the RF mode solver.
  • Include a 2D PDD solver based on sesame integrated with openbandparams
  • Improve the documentation (help wanted!).

If you have any questions please reach out to the Discussions tab and we can brainstorm some ideas.

Acknowledgements

This work was funded by the European Union through the QuGANTIC project and the Dutch National Growth Fund and PhotonDelta. Views and opinions expressed are however those of the author(s) only and do not necessarily reflect those of the European Union or the European Innovation Council. Neither the European Union nor the granting authority can be held responsible for them.

Contributors

  • Duarte Silva (Eindhoven University of Technology)
  • Ali Kaan Sünnetçioğlu (Eindhoven University of Technology)

Was this package useful for your work?

The DOI tracking for this project is handled by Zenodo, and a single DOI shall be generated per official release.

Version DOI
v1.0.1 DOI

When translating to a bibtex entry, please consider using the following formatting to display the author names properly:

@MISC{,
  title     = "Imodulator: Initial release",
  author    = "{Duarte J.F. da Silva, Ali Kaan Sünnetçioğlu}",
  abstract  = "Full Changelog:
               https://github.com/duarte-jfs/Imodulator/compare/v1.0.0...v1.0.1",
  publisher = "Zenodo",
  year      =  2025,
  url       = {https://github.com/duarte-jfs/Imodulator/releases/tag/v1.0.1},
  doi       = {https://doi.org/10.5281/zenodo.17633733}
}

In case you are using code stemming from a development branch, we advise to use the same DOI as the most recent release, but with the altered bibtex entry:

@MISC{,
  title     = "Imodulator: development",
  author    = "{Duarte J.F. da Silva, Ali Kaan Sünnetçioğlu}",
  abstract  = "Full Changelog:
               https://github.com/duarte-jfs/Imodulator/compare/v1.0.0...v1.0.1",
  publisher = "Zenodo",
  year      =  2025,
  url       = {https://github.com/duarte-jfs/Imodulator/tree/development},
  doi       = {https://doi.org/10.5281/zenodo.17633733}
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

imodulator-1.0.2.tar.gz (92.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

imodulator-1.0.2-py3-none-any.whl (96.6 kB view details)

Uploaded Python 3

File details

Details for the file imodulator-1.0.2.tar.gz.

File metadata

  • Download URL: imodulator-1.0.2.tar.gz
  • Upload date:
  • Size: 92.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.16

File hashes

Hashes for imodulator-1.0.2.tar.gz
Algorithm Hash digest
SHA256 dcd5804f16d51d4d5086cf8ee8b772380d9c4fdd88b3f88209120520b6839fe3
MD5 eed629102968e76cd2089c075cef60b6
BLAKE2b-256 ec0d0fc6d852375f6ddd9f3b441629e3ee8e01224aec6fb7582ab7ffe35943f2

See more details on using hashes here.

File details

Details for the file imodulator-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: imodulator-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 96.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.16

File hashes

Hashes for imodulator-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 a1b24563f48be681bf5467dc63a3771548dffadfa833b2aa2270276d6cededcd
MD5 d69ad16f91edfe81442ed0fd540a6d10
BLAKE2b-256 5b38b51deebf710490f84fd23539f2ada461a52ac0459e25663ef632e314ef41

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page