From f8e9aaab37e4983de9da9ff7943910f642aa5970 Mon Sep 17 00:00:00 2001 From: Edan Bainglass Date: Sat, 28 Dec 2024 07:28:12 +0000 Subject: [PATCH] Implement warning for tagged magnetic structures --- .../app/configuration/basic/basic.py | 34 +++++++++++++++++++ .../app/configuration/basic/model.py | 9 ++--- src/aiidalab_qe/common/mixins.py | 7 ++++ 3 files changed, 46 insertions(+), 4 deletions(-) diff --git a/src/aiidalab_qe/app/configuration/basic/basic.py b/src/aiidalab_qe/app/configuration/basic/basic.py index 3fe5adb42..bdba108bd 100644 --- a/src/aiidalab_qe/app/configuration/basic/basic.py +++ b/src/aiidalab_qe/app/configuration/basic/basic.py @@ -45,6 +45,10 @@ def render(self): (self._model, "spin_type"), (self.spin_type, "value"), ) + self.spin_type.observe( + self._on_spin_type_change, + "value", + ) # Spin-Orbit calculation self.spin_orbit = ipw.ToggleButtons(style={"description_width": "initial"}) @@ -68,6 +72,29 @@ def render(self): (self.protocol, "value"), ) + self.warning = ipw.HTML( + value=""" +
+

+ Warning: detected multiples atoms with different tags. + You may be interested in an antiferromagnetic system. Note that + default starting magnetic moments do not distinguish tagged + atoms and are set to the same value. +

+

+ Please go to Advanced settings and override the default + values, specifying appropriate starting magnetization for each + species (e.g. with different signs for an antiferromagnetic + configuration). +

+
+ """, + layout=ipw.Layout(display="none"), + ) + self.children = [ InAppGuide(identifier="basic-settings"), ipw.HTML(""" @@ -140,9 +167,16 @@ def render(self): (at the price of longer/costlier calculations). """), + self.warning, ] self.rendered = True def _on_input_structure_change(self, _): self.refresh(specific="structure") + + def _on_spin_type_change(self, _): + if self._model.spin_type == "collinear" and self._model.has_tags: + self.warning.layout.display = "flex" + else: + self.warning.layout.display = "none" diff --git a/src/aiidalab_qe/app/configuration/basic/model.py b/src/aiidalab_qe/app/configuration/basic/model.py index 1ac6f6b8f..c3b243674 100644 --- a/src/aiidalab_qe/app/configuration/basic/model.py +++ b/src/aiidalab_qe/app/configuration/basic/model.py @@ -1,13 +1,16 @@ import traitlets as tl -from aiida import orm from aiidalab_qe.app.parameters import DEFAULT_PARAMETERS +from aiidalab_qe.common.mixins import HasInputStructure from aiidalab_qe.common.panel import ConfigurationSettingsModel DEFAULT: dict = DEFAULT_PARAMETERS # type: ignore -class BasicConfigurationSettingsModel(ConfigurationSettingsModel): +class BasicConfigurationSettingsModel( + ConfigurationSettingsModel, + HasInputStructure, +): title = "Basic settings" identifier = "workchain" @@ -15,8 +18,6 @@ class BasicConfigurationSettingsModel(ConfigurationSettingsModel): "input_structure", ] - input_structure = tl.Union([tl.Instance(orm.StructureData)], allow_none=True) - protocol_options = tl.List( trait=tl.Unicode(), default_value=[ diff --git a/src/aiidalab_qe/common/mixins.py b/src/aiidalab_qe/common/mixins.py index fa43a1632..e6629a3e4 100644 --- a/src/aiidalab_qe/common/mixins.py +++ b/src/aiidalab_qe/common/mixins.py @@ -26,6 +26,13 @@ def has_structure(self): def has_pbc(self): return not self.has_structure or any(self.input_structure.pbc) + @property + def has_tags(self): + return any( + not kind_name.isalpha() + for kind_name in self.input_structure.get_kind_names() + ) + class HasModels(t.Generic[T]): def __init__(self):