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:
Solcorehas 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 betweenSolcoreandopenbandparamsso 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 throughSolcorevia 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 afunction.
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 inopenbandparams. - 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 |
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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dcd5804f16d51d4d5086cf8ee8b772380d9c4fdd88b3f88209120520b6839fe3
|
|
| MD5 |
eed629102968e76cd2089c075cef60b6
|
|
| BLAKE2b-256 |
ec0d0fc6d852375f6ddd9f3b441629e3ee8e01224aec6fb7582ab7ffe35943f2
|
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a1b24563f48be681bf5467dc63a3771548dffadfa833b2aa2270276d6cededcd
|
|
| MD5 |
d69ad16f91edfe81442ed0fd540a6d10
|
|
| BLAKE2b-256 |
5b38b51deebf710490f84fd23539f2ada461a52ac0459e25663ef632e314ef41
|