Source code for est.core.process.larch.mback
"""wrapper to the larch mback process"""
import logging
import warnings
from importlib.metadata import version as get_version
from typing import Any
from typing import Callable
from typing import Dict
from typing import Optional
from typing import Sequence
from typing import Union
import numpy
from larch.symboltable import Group
from larch.xafs.mback import mback
from ...types.spectrum import Spectrum
from ...types.xasobject import XASObject
from ..base import Process
from ..handle_nan import array_undo_mask
_logger = logging.getLogger(__name__)
[docs]
def process_spectr_mback(
spectrum: Spectrum,
configuration: Dict[str, Any],
overwrite: bool = True,
callbacks: Optional[Sequence[Callable[[], None]]] = None,
) -> Spectrum:
"""
:param spectrum: spectrum to process.
:param configuration: configuration of the pymca normalization.
:param overwrite: `False` if we want to return a new Spectrum instance.
:param callbacks: callbacks to execute after processing.
:return: processed spectrum
"""
_logger.debug("start mback on spectrum (%s, %s)", spectrum.x, spectrum.y)
mback_kwargs = {}
spectrum.e0 = configuration.get("e0", spectrum.e0)
for config_key in (
"z",
"edge",
"pre1",
"pre2",
"norm1",
"norm2",
"order",
"leexiang",
"tables",
"fit_erfc",
):
if config_key in configuration:
mback_kwargs[config_key] = configuration[config_key]
if "z" not in mback_kwargs:
raise ValueError("atomic number of the absorber is not specify")
res_group = Group()
mask = numpy.isfinite(spectrum.mu)
with warnings.catch_warnings():
# Note: when lmfit>1.3.3 is released this warnings catch can be removed
warnings.filterwarnings(
"ignore",
message="Using UFloat objects with std_dev==0 may give unexpected results.",
category=UserWarning,
module="uncertainties.core",
)
mback(
spectrum.energy[mask],
spectrum.mu[mask],
group=res_group,
e0=spectrum.e0,
**mback_kwargs,
)
if not overwrite:
spectrum = spectrum.model_copy(deep=True)
spectrum.normalized_mu = array_undo_mask(res_group.norm, mask)
if callbacks:
for callback in callbacks:
callback()
return spectrum
[docs]
def larch_mback(
xas_obj: Union[XASObject, dict], **optional_inputs
) -> Optional[XASObject]:
process = Larch_mback(inputs={"xas_obj": xas_obj, **optional_inputs})
process.run()
return process.get_output_value("xas_obj", None)
[docs]
class Larch_mback(
Process,
input_names=["xas_obj"],
optional_input_names=["mback_config"],
output_names=["xas_obj"],
):
[docs]
def run(self):
xas_obj = self.getXasObject(xas_obj=self.inputs.xas_obj)
self.progress = 0.0
self._pool_process(xas_obj=xas_obj)
self.progress = 100.0
self.outputs.xas_obj = xas_obj
def _pool_process(self, xas_obj: XASObject):
mback_config = self.get_input_value("mback_config", dict())
n_s = len(xas_obj.spectra.data.flat)
for i_s, spectrum in enumerate(xas_obj.spectra):
process_spectr_mback(
spectrum=spectrum,
configuration=mback_config,
callbacks=self.callbacks,
overwrite=True,
)
self.progress = i_s / n_s * 100.0
[docs]
def definition(self) -> str:
return "mback calculation"
[docs]
def program_version(self) -> str:
return get_version("larch")
[docs]
@staticmethod
def program_name() -> str:
return "larch_mback"