-
Notifications
You must be signed in to change notification settings - Fork 82
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
[Feature Discussion] Comparing band structures on the same plot #219
Comments
Clearly this is a useful plot for research work, and it would be good if they could be produced conveniently. I do worry about the level of incompatibility between features: for example this will not play nicely with projected band structures. It will become very difficult to communicate which CLI options work together. (Already some of them are difficult to explain!) I wonder if instead this kind of plot would be a good case study for an improved Python API, and produced with user scripting. If we did do this with the CLI I would drop Perhaps the real answer is to separate orbital projected plots and line plots into separate CLI tools 🤔 @utf thoughts? |
This looks like a great feature! Personally, I would be very happy to accept a PR. Going on what @ajjackson said, I think allowing multiple options to Regarding support for projected band structures, I would just raise an error in the command line if the user tries to specify both multiple filenames and projected/DOS plots at the same time. |
Regarding projected band structures, I currently raise an exception if plotting multiple band structures from I don't raise an exception when comparing multiple band structures and doing a DOS plot simultaneously, I personally don't see a problem with that (obviously as long as the source of the DOS is clearly explained somewhere in the paper), but I can raise an exception too if you'd prefer. Comparing DOS from multiple calculations doesn't quite make sense, so I won't be adding anything to For the CLI, note that I think the best course of action when multiple
The reason I thought of I think the only thing missing for this feature is the CLI implementation, which shouldn't be too hard. I'll work on that when I get the chance and open a PR. |
There is still some ambiguity if they want to compare stitched band structures 😞 |
I hadn't even thought about comparing stitched band structures... If we restrict the feature to comparing single-file band structures then the convention above would work fine. But we could have situations where you want to compare two band structures where, e.g., the first 3 Maybe we could use spaces to separate files that need to be stitched together and commas for files to be compared? Sort of like the For example: # current behavior, nothing changes, just stitch them
sumo-bandplot --code vasp --filenames vr1.xml vr2.xml
# stitch first 2 files, compare to third file. All come from vasp.
sumo-bandplot --code vasp --filenames "vr1.xml vr2.xml, vr3.xml"
# stitch vr{1,2}.xml coming from VASP, stitch pw{1,2}.xml coming from QE,
# file 5 comes from wannier90, compare all 3 band structures
sumo-bandplot --code vasp espresso w90 --filenames "vr1.xml vr2.xml, pw1.xml pw2.xml, wannier_seed" With this approach, we wouldn't need |
There is a lot of this ad-hoc syntax in Sumo already and it is getting increasingly difficult to document and explain which combinations of features are allowed. I think the solution is probably to take a step back and stop trying to do so much with one CLI command. (That's not particularly a criticism of what you are going for here, it applies to Perhaps there should be subcommands that each have a limited set of options. One feature of e.g. sumo-bandplot stitch --code vasp --filename vr1.xml vr2.xml vr3.xml --to-json vasp-bands.json
sumo-bandplot compare --code json espresso w90 --filenames vasp-bands.json pw1.xml wannier_seed |
I am a bit doubtful whether there may always be corresponding CLI implementation for such complex and flexible (even higher) needs. |
Last issue/PR of the night, I promise! :)
I've recently needed to compare electronic band structures computed from the same structures/materials but with slightly different methods (e.g., VASP versus different pseudo potentials in Quantum ESPRESSO vs Wannier90). This work is available on my compare branch.
Currently Implemented:
SBSPlotter
an array of BandStructureSymmLine objects, like the baseBSPlotter
from pymatgen.bs_legend
argument toSBSPlotter.get_plot
. I don't think this comparison feature makes sense for projected band structures and don't plan to implement it.spin_legend
argument, which is currently enabled by default (I can change this).force_branches
now produces identical branches for VASP'sLine Mode
versus an identical path generated by, e.g.,sumo-kgen
(i.e., one that doesn't have those pesky duplicate points). This doesn't affect the operation of sumo whatsoever since it is smart enough to get rid of the ghost k-points. However, this fix makes it possible to compare such band structures since they now have the same branches, andBSPlotter.add_bs
won't throw an error.I still need to work on the CLI implementation. I was thinking of something like:
*
--code
can now also accept a list of codes, which enables comparison mode.* A
--compare
option forces comparison even if a single option is passed to--code
(e.g., for comparing 3 different VASP band structures instead of trying to stitch them into one. For example:--filenames vasprun1.xml,vasprun2.xml --code vasp --compare
).Any feedback is appreciated! Here's an example band structure comparing a VASP calculation with 3 Quantum ESPRESSO calculations using different pseudopotentials (a little excessive, it's just meant to show you can do this).
There's also an example comparing DFT and W90 in my Wannier90 discussion issue.
The text was updated successfully, but these errors were encountered: