Skip to content

Commit

Permalink
Define n_atoms_per_unit_cell for TB model method (#139)
Browse files Browse the repository at this point in the history
* Changed n_orbitals for 3 more complete quantities

* Add better descriptions
  • Loading branch information
JosePizarro3 authored Sep 27, 2024
1 parent 001ea5e commit 0b6c6cd
Showing 1 changed file with 32 additions and 7 deletions.
39 changes: 32 additions & 7 deletions src/nomad_simulations/schema_packages/model_method.py
Original file line number Diff line number Diff line change
Expand Up @@ -429,20 +429,39 @@ class TB(ModelMethodElectronic):
a_eln=ELNAnnotation(component='EnumEditQuantity'),
)

# ? these 2 quantities will change when `BasisSet` is defined
n_orbitals = Quantity(
# ? these 4 quantities will change when `BasisSet` is defined
n_orbitals_per_atom = Quantity(
type=np.int32,
description="""
Number of orbitals per atom in the unit cell used as a basis to obtain the `TB` model. This
quantity is resolved from `orbitals_ref` via normalization.
""",
)

n_atoms_per_unit_cell = Quantity(
type=np.int32,
description="""
Number of orbitals used as a basis to obtain the `TB` model.
Number of atoms per unit cell relevant for the `TB` model. This quantity is resolved from
`n_total_orbitals` and `n_orbitals_per_atom` via normalization.
""",
)

n_total_orbitals = Quantity(
type=np.int32,
description="""
Total number of orbitals used as a basis to obtain the `TB` model. This quantity is parsed by
the specific parsing code. This is related with `n_orbitals_per_atom` and `n_atoms_per_unit_cell` as:
`n_total_orbitals` = `n_orbitals_per_atom` * `n_atoms_per_unit_cell`
""",
)

orbitals_ref = Quantity(
type=OrbitalsState,
shape=['n_orbitals'],
shape=['n_orbitals_per_atom'],
description="""
References to the `OrbitalsState` sections that contain the orbitals information which are
relevant for the `TB` model.
References to the `OrbitalsState` sections that contain the orbitals per atom in the unit cell information which are
relevant for the `TB` model. This quantity is resolved from normalization when the active atoms sub-systems `model_system.model_system[*]`
are populated.
Example: hydrogenated graphene with 3 atoms in the unit cell. The full list of `AtomsState` would
be
Expand Down Expand Up @@ -560,9 +579,15 @@ def normalize(self, archive: 'EntryArchive', logger: 'BoundLogger') -> None:
model_systems=model_systems, logger=logger
)
if orbitals_ref is not None and len(orbitals_ref) > 0 and not self.orbitals_ref:
self.n_orbitals = len(orbitals_ref)
self.n_orbitals_per_atom = len(orbitals_ref)
self.orbitals_ref = orbitals_ref

# Resolve `n_atoms_per_unit_cell` from `n_total_orbitals` and `n_orbitals_per_atom`
if self.n_orbitals_per_atom is not None and self.n_total_orbitals is not None:
self.n_atoms_per_unit_cell = (
self.n_total_orbitals // self.n_orbitals_per_atom
)


class Wannier(TB):
"""
Expand Down

1 comment on commit 0b6c6cd

@github-actions
Copy link

Choose a reason for hiding this comment

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

Coverage

Coverage Report
FileStmtsMissCoverMissing
src/nomad_simulations
   __init__.py4250%3–4
   _version.py11282%5–6
src/nomad_simulations/schema_packages
   __init__.py15287%39–41
   atoms_state.py1902189%13–15, 201–204, 228, 283–284, 352–353, 355, 537, 549–550, 611–615, 630–634, 641
   basis_set.py2402888%8–9, 122–133, 172–185, 208, 391–395, 417–418, 462–465, 584, 615, 617
   general.py89891%4–7, 121, 185, 295–296, 306
   model_method.py2697871%10–12, 171–174, 177–184, 276–277, 297, 318–339, 355–381, 384–401, 587, 780, 791, 833–840, 878, 897, 977, 1034, 1109, 1223
   model_system.py2962392%25–27, 378, 572–575, 622–629, 803–804, 1025–1029, 1035–1036, 1044–1045, 1050, 1073
   numerical_settings.py2596176%12–14, 217, 219–220, 223–226, 230–231, 238–241, 250–253, 257–260, 262–265, 270–273, 279–282, 469–496, 571, 606–609, 633, 636, 681, 683–686, 690, 694, 741, 745–766, 821–822, 889
   outputs.py1201092%9–10, 252–255, 295–298, 323, 325, 362, 381
   physical_property.py102793%20–22, 202, 331–333
   variables.py861286%8–10, 98, 121, 145, 167, 189, 211, 233, 256, 276
src/nomad_simulations/schema_packages/properties
   band_gap.py51590%8–10, 135–136
   band_structure.py1232580%9–11, 232–265, 278, 285, 321–322, 325, 372–373, 378
   energies.py42979%7–9, 36, 57, 82, 103, 119, 134
   fermi_surface.py17476%7–9, 40
   forces.py22673%7–9, 36, 56, 79
   greens_function.py991387%7–9, 210–211, 214, 235–236, 239, 260–261, 264, 400
   hopping_matrix.py29583%7–9, 58, 94
   permittivity.py48883%7–9, 97–105
   spectral_profile.py26012851%9–11, 57–60, 95–98, 199–300, 356–368, 393–396, 416, 421–424, 466–502, 526, 573–576, 592–593, 598–604
   thermodynamics.py752764%7–9, 35, 56, 72, 81, 90, 101, 110, 137, 147, 157, 172–174, 177, 193, 213–215, 218, 234, 254–256, 259
src/nomad_simulations/schema_packages/utils
   utils.py701480%8–11, 65–74, 83–84, 89, 92
TOTAL252849880% 

Tests Skipped Failures Errors Time
401 0 💤 0 ❌ 0 🔥 5.753s ⏱️

Please sign in to comment.