Mercurial > repos > muon-spectroscopy-computational-project > larch_athena
view common.py @ 0:ae2f265ecf8e draft
planemo upload for repository https://github.com/MaterialsGalaxy/larch-tools/tree/main/larch_athena commit 5be486890442dedfb327289d597e1c8110240735
author | muon-spectroscopy-computational-project |
---|---|
date | Tue, 14 Nov 2023 15:34:40 +0000 |
parents | |
children | 2b3115342fef |
line wrap: on
line source
from typing import Iterable from larch.io import extract_athenagroup, read_athena from larch.io.athena_project import AthenaGroup from larch.symboltable import Group from larch.xafs import autobk, pre_edge, xftf def get_group(athena_group: AthenaGroup, key: str = None) -> Group: if key is None: group_keys = list(athena_group._athena_groups.keys()) key = group_keys[0] return extract_athenagroup(athena_group._athena_groups[key]) def read_group(dat_file: str, key: str = None, xftf_params: dict = None): athena_group = read_athena(dat_file) group = get_group(athena_group, key) bkg_parameters = group.athena_params.bkg print(group.athena_params.fft) print(group.athena_params.fft.__dict__) pre_edge( group, e0=bkg_parameters.e0, pre1=bkg_parameters.pre1, pre2=bkg_parameters.pre2, norm1=bkg_parameters.nor1, norm2=bkg_parameters.nor2, nnorm=bkg_parameters.nnorm, make_flat=bkg_parameters.flatten, ) autobk(group) if xftf_params is None: xftf(group) else: print(xftf_params) xftf(group, **xftf_params) xftf_details = Group() setattr(xftf_details, "call_args", xftf_params) group.xftf_details = xftf_details return group def read_groups(dat_files: "list[str]", key: str = None) -> Iterable[Group]: for dat_file in dat_files: yield read_group(dat_file=dat_file, key=key)