Skip to content
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

Enable spin orbit calculation #35

Merged
merged 4 commits into from
Dec 15, 2023
Merged

Conversation

jiang-yuha0
Copy link
Contributor

@jiang-yuha0 jiang-yuha0 commented Nov 16, 2023

We made the following changes to enable spin-orbit coupling in the workflows

  1. Adjust the selection of bands and semicores in get_wannier_number_of_bands and get_semicore_list respectively, when spin_type is set to SpinType.SPIN_ORBIT.
  2. Add support for PseudoDojo/0.4/PBE/FR/standard/upf, and PSlibrary (should be installed by user).
  3. Add tests for spin_type=SpinType.SPIN_ORBIT.
  4. Other minor fixes
    a. In Wannier90WorkChain: Set overrides from None to an empty dict {} to avoid errors in recursive_merge.
    b. In Wannier90BandsWorkChain: Fix mismatch between type and value.

@jiang-yuha0 jiang-yuha0 force-pushed the add_soc branch 2 times, most recently from e47b1db to 181b13f Compare November 28, 2023 16:34
@jiang-yuha0 jiang-yuha0 marked this pull request as ready for review December 12, 2023 14:07
Yuhao Jiang added 2 commits December 13, 2023 15:21
Main changes include:
* Adjust the selection of bands and semicores in `get_wannier_number_of_bands` and `get_semicore_list` respectively, when `spin_type` is set to `SpinType.SPIN_ORBIT`.
* Add support for `PseudoDojo/0.4/PBE/FR/standard/upf`, and `PSlibrary` (should be installed by user).
2. minor fix in `Wannier90WorkChain` and `Wannier90BandsWorkChain`.
@@ -132,7 +140,8 @@ def get_semicore_list(structure: orm.StructureData, pseudo_orbitals: dict) -> li
site_semicores = deepcopy(pseudo_orbitals[site.kind_name]["semicores"])

for orb in site_pswfcs:
num_orbs = label2num[orb[-1]]
nspin = 2 if spin_orbit_coupling else 1
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

you can move this line outside of the for loop, after the comment line at 132, to avoid repeated assignments

@@ -0,0 +1,1456 @@
{
"H": {
"filename": "pseudo_install/H.rel-pbe-kjpaw_psl.1.0.0.UPF",
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is the path pseudo_install/ really needed? If not, should be removed

Copy link
Collaborator

@qiaojunfeng qiaojunfeng left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks, all look good! I think this can be merged once the previous two comments are resolved.

Yuhao Jiang and others added 2 commits December 15, 2023 10:29
1. Update the pslibrary installation script and the pslibrary semicore file. Now the 'filename' in the semicore file is pure filename without path information.
2. Change the location where values are assigned to nspin to avoid repeat assignments.
Update for reviewer's comment
@qiaojunfeng qiaojunfeng merged commit 2e8c912 into aiidateam:main Dec 15, 2023
6 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants