-
Notifications
You must be signed in to change notification settings - Fork 640
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Working and verified version of multilevel atom susceptibility. #500
Conversation
…definition of alpha of /scheme/structure.cpp. Fixed a bug in how the E*(n2-n1) term in updating the multilevel polarization was working. Rewrote most of the multilevel-atom.ctl example to be more transparent with agreement with SALT. Still having trouble getting multilevel-atom.ctl to yield non-zero fields, I think this is a field initialization issue.
…ns for gain media in MEEP. The results have been verified against my personal implementation of the oscillator equations in 1D.
…sing, including the two ~0 terms not normally written in the oscillator model equations. Candidate to be merged back into the master branch.
The multilevel atom susceptibility is now working and verified against independent code.
Great! Ideally you can also include documentation in the PR, including specification of precisely what equations are implemented and the definitions of the parameters. (Note that the markdown documentation can include LaTeX equations.) |
We also need a PR for a regression test to make sure that this doesn't bit-rot. That could be as simple as running one of your 1d test cases and adding a check for the numbers that you have already validated. |
I'm working on the documentation now, and I can put together a separate PR, sure. it took a while to get mkdocs running correctly. I understand conceptually what you want by a regression test, but I'll need a bit more guidance as to where this goes in the package. Can you point me in the direction of the other tests? |
The C++ tests are in tests/ and the Python tests in python/tests/. A Python test would be sufficient but we need to add the front end first (which we are working on now). @ChristopherHogan can help you port the existing Scheme multilevel example to Python as a unit test. |
For reference, here are the commands to install and run
|
For the documentation, I've written the general theory along with some verification plots into Materials.md. Are there additional locations where you'd like for me to provide documentation? Will you be writing documentation for the scheme and python interfaces? |
Please also update the Scheme tutorial example as necessary with additional information based on the recent changes. We will port this tutorial to Python and also provide documentation for the interface. |
…Comp#500) * First commit by AWC to multilevel atom branch. Fixed 2*pi bug in the definition of alpha of /scheme/structure.cpp. Fixed a bug in how the E*(n2-n1) term in updating the multilevel polarization was working. Rewrote most of the multilevel-atom.ctl example to be more transparent with agreement with SALT. Still having trouble getting multilevel-atom.ctl to yield non-zero fields, I think this is a field initialization issue. * Completely working version of the unmodified Oscillator Model Equations for gain media in MEEP. The results have been verified against my personal implementation of the oscillator equations in 1D. * Working and verified version of multilevel atom susceptibility for lasing, including the two ~0 terms not normally written in the oscillator model equations. Candidate to be merged back into the master branch.
This is the version of the code that is verified with SALT, as we discussed in the issue.