Mercurial > repos > muon-spectroscopy-computational-project > larch_athena
changeset 3:82e9dd980916 draft
planemo upload for repository https://github.com/MaterialsGalaxy/larch-tools/tree/main/larch_athena commit d4c7e090dc5c94395d7e1574845ac2c76f2e4f5f
author | muon-spectroscopy-computational-project |
---|---|
date | Fri, 22 Mar 2024 14:23:27 +0000 (10 months ago) |
parents | a1e26990131c |
children | a0d3b0fe0fa3 |
files | common.py larch_athena.py larch_athena.xml |
diffstat | 3 files changed, 86 insertions(+), 114 deletions(-) [+] |
line wrap: on
line diff
--- a/common.py Mon Mar 04 11:43:19 2024 +0000 +++ b/common.py Fri Mar 22 14:23:27 2024 +0000 @@ -73,7 +73,11 @@ ) for key, parameters_key, default in keys: extract_attribute( - merged_settings, key, bkg_parameters, parameters_key, default + merged_settings=merged_settings, + key=key, + parameters_group=bkg_parameters, + parameters_key=parameters_key, + default=default, ) if settings: @@ -116,7 +120,11 @@ ) for key, parameters_key, default in keys: extract_attribute( - merged_settings, key, fft_parameters, parameters_key, default + merged_settings=merged_settings, + key=key, + parameters_group=fft_parameters, + parameters_key=parameters_key, + default=default, ) if settings:
--- a/larch_athena.py Mon Mar 04 11:43:19 2024 +0000 +++ b/larch_athena.py Fri Mar 22 14:23:27 2024 +0000 @@ -5,7 +5,10 @@ import sys from common import ( - pre_edge_with_defaults, read_all_groups, read_group, xftf_with_defaults + pre_edge_with_defaults, + read_all_groups, + read_group, + xftf_with_defaults, ) from larch.io import ( @@ -45,12 +48,14 @@ ) -> "dict[str, Group]": if merge_inputs: out_group = self.merge_files( - dat_files=dat_file, is_zipped=is_zipped + dat_files=dat_file, + is_zipped=is_zipped, ) return {"out": out_group} else: return self.load_single_file( - filepath=dat_file, is_zipped=is_zipped + filepath=dat_file, + is_zipped=is_zipped, ) def merge_files( @@ -258,7 +263,7 @@ pre_edge_settings: dict, do_xftf: bool, xftf_settings: dict, - plot_graph: bool, + plot_graph: list, annotation: str, path_key: str = "out", ): @@ -287,9 +292,11 @@ xftf_with_defaults(xas_data, xftf_settings) if plot_graph: - plot_edge_fits(f"edge/{path_key}.png", xas_data) - plot_flattened(f"flat/{path_key}.png", xas_data) - plot_derivative(f"derivative/{path_key}.png", xas_data) + plot_graphs( + plot_path=f"plot/{path_key}.png", + xas_data=xas_data, + plot_keys=plot_graph, + ) xas_project = create_athena(f"prj/{path_key}.prj") xas_project.add_group(xas_data) @@ -302,36 +309,43 @@ gc.collect() -def plot_derivative(plot_path: str, xafs_group: Group): - plt.figure() - plt.plot(xafs_group.energy, xafs_group.dmude) - plt.grid(color="r", linestyle=":", linewidth=1) - plt.xlabel("Energy (eV)") - plt.ylabel("Derivative normalised to x$\mu$(E)") # noqa: W605 - plt.savefig(plot_path, format="png") - plt.close("all") - +def plot_graphs( + plot_path: str, + xas_data: Group, + plot_keys: list, +) -> None: + nrows = len(plot_keys) + index = 1 + plt.figure(figsize=(6.4, nrows * 4.8)) + if "edge" in plot_keys: + plt.subplot(nrows, 1, index) + plt.plot(xas_data.energy, xas_data.pre_edge, "g", label="pre-edge") + plt.plot(xas_data.energy, xas_data.post_edge, "r", label="post-edge") + plt.plot(xas_data.energy, xas_data.mu, "b", label="fit data") + plt.grid(color="r", linestyle=":", linewidth=1) + plt.xlabel("Energy (eV)") + plt.ylabel("x$\mu$(E)") # noqa: W605 + plt.title("Pre-edge and post_edge fitting to $\mu$") # noqa: W605 + plt.legend() + index += 1 -def plot_edge_fits(plot_path: str, xafs_group: Group): - plt.figure() - plt.plot(xafs_group.energy, xafs_group.pre_edge, "g", label="pre-edge") - plt.plot(xafs_group.energy, xafs_group.post_edge, "r", label="post-edge") - plt.plot(xafs_group.energy, xafs_group.mu, "b", label="fit data") - plt.grid(color="r", linestyle=":", linewidth=1) - plt.xlabel("Energy (eV)") - plt.ylabel("x$\mu$(E)") # noqa: W605 - plt.title("pre-edge and post_edge fitting to $\mu$") # noqa: W605 - plt.legend() - plt.savefig(plot_path, format="png") - plt.close("all") + if "flat" in plot_keys: + plt.subplot(nrows, 1, index) + plt.plot(xas_data.energy, xas_data.flat) + plt.grid(color="r", linestyle=":", linewidth=1) + plt.xlabel("Energy (eV)") + plt.ylabel("Flattened x$\mu$(E)") # noqa: W605 + index += 1 + if "dmude" in plot_keys: + plt.subplot(nrows, 1, index) + plt.plot(xas_data.energy, xas_data.dmude) + plt.grid(color="r", linestyle=":", linewidth=1) + plt.xlabel("Energy (eV)") + plt.ylabel("Derivative normalised to x$\mu$(E)") # noqa: W605 + index += 1 -def plot_flattened(plot_path: str, xafs_group: Group): - plt.figure() - plt.plot(xafs_group.energy, xafs_group.flat) - plt.grid(color="r", linestyle=":", linewidth=1) - plt.xlabel("Energy (eV)") - plt.ylabel("normalised x$\mu$(E)") # noqa: W605 + plt.tight_layout(rect=(0, 0, 0.88, 1)) plt.savefig(plot_path, format="png") plt.close("all")
--- a/larch_athena.xml Mon Mar 04 11:43:19 2024 +0000 +++ b/larch_athena.xml Fri Mar 22 14:23:27 2024 +0000 @@ -4,7 +4,7 @@ <!-- version of underlying tool (PEP 440) --> <token name="@TOOL_VERSION@">0.9.74</token> <!-- version of this tool wrapper (integer) --> - <token name="@WRAPPER_VERSION@">0</token> + <token name="@WRAPPER_VERSION@">1</token> <!-- citation should be updated with every underlying tool version --> <!-- typical fields to update are version, month, year, and doi --> <token name="@TOOL_CITATION@">10.1088/1742-6596/430/1/012007</token> @@ -58,7 +58,7 @@ <include type="literal" path="common.py"/> </required_files> <command detect_errors="exit_code"><![CDATA[ - mkdir prj edge flat derivative + mkdir prj plot #if $merge_inputs.format.format=="plaintext": #if $merge_inputs.format.is_zipped.is_zipped=="true": && echo Unzipping '$merge_inputs.format.is_zipped.dat_file.name' @@ -90,7 +90,7 @@ <conditional name="is_zipped" > <expand macro="is_zipped"/> <when value=""> - <param name="dat_file" type="data" format="h5,txt" label="XAFS data file" help="X-ray Absorption Fine Structure (XAFS) data, either in h5 or plaintext."/> + <param name="dat_file" type="data" format="h5,tabular" label="XAFS data file" help="X-ray Absorption Fine Structure (XAFS) data, either in h5 or plaintext."/> </when> <when value="true"> <param name="dat_file" type="data" format="zip" label="Zipped XAFS data files" help="Zipped X-ray Absorption Fine Structure (XAFS) data, either in h5 or plaintext."/> @@ -180,7 +180,11 @@ </when> </conditional> </section> - <param name="plot_graph" type="boolean" label="Plot graph" help="Whether to plot the pre/post edge fitting and the normalised xμ data."/> + <param name="plot_graph" type="select" multiple="true" display="checkboxes" label="Plot graphs"> + <option value="edge">Pre/post edge fitting</option> + <option value="flat">Flattened xμ</option> + <option value="dmude">Derivative of xμ</option> + </param> <param name="zip_outputs" type="boolean" label="Zip outputs" help="Whether to zip all outputs into one dataset."/> </inputs> <outputs> @@ -193,17 +197,7 @@ <filter>not zip_outputs</filter> <filter>not (merge_inputs["merge_inputs"] == "" and ((merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]) or (merge_inputs["format"]["format"] == "athena" and merge_inputs["format"]["extract_group"]["extract_group"] != "single")))</filter> </data> - <data name="edge_plot" format="png" from_work_dir="edge/out.png" label="Edge fitting ${annotation} ${on_string}"> - <filter>plot_graph</filter> - <filter>not zip_outputs</filter> - <filter>not (merge_inputs["merge_inputs"] == "" and ((merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]) or (merge_inputs["format"]["format"] == "athena" and merge_inputs["format"]["extract_group"]["extract_group"] != "single")))</filter> - </data> - <data name="flat_plot" format="png" from_work_dir="flat/out.png" label="Flattened plot ${annotation} ${on_string}"> - <filter>plot_graph</filter> - <filter>not zip_outputs</filter> - <filter>not (merge_inputs["merge_inputs"] == "" and ((merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]) or (merge_inputs["format"]["format"] == "athena" and merge_inputs["format"]["extract_group"]["extract_group"] != "single")))</filter> - </data> - <data name="derivative_plot" format="png" from_work_dir="derivative/out.png" label="Derivative plot ${annotation} ${on_string}"> + <data name="plot" format="png" from_work_dir="plot/out.png" label="Plot of ${annotation} ${on_string}"> <filter>plot_graph</filter> <filter>not zip_outputs</filter> <filter>not (merge_inputs["merge_inputs"] == "" and ((merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]) or (merge_inputs["format"]["format"] == "athena" and merge_inputs["format"]["extract_group"]["extract_group"] != "single")))</filter> @@ -214,20 +208,8 @@ <filter>not zip_outputs</filter> <filter>merge_inputs["merge_inputs"] == "" and ((merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]) or (merge_inputs["format"]["format"] == "athena" and merge_inputs["format"]["extract_group"]["extract_group"] != "single"))</filter> </collection> - <collection name="edge_plot_collection" format="png" type="list" label="Edge fittings ${annotation} ${on_string}"> - <discover_datasets pattern="__name_and_ext__" directory="edge"/> - <filter>plot_graph</filter> - <filter>not zip_outputs</filter> - <filter>merge_inputs["merge_inputs"] == "" and ((merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]) or (merge_inputs["format"]["format"] == "athena" and merge_inputs["format"]["extract_group"]["extract_group"] != "single"))</filter> - </collection> - <collection name="flat_plot_collection" format="png" type="list" label="Flattened plots ${annotation} ${on_string}"> - <discover_datasets pattern="__name_and_ext__" directory="flat"/> - <filter>plot_graph</filter> - <filter>not zip_outputs</filter> - <filter>merge_inputs["merge_inputs"] == "" and ((merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]) or (merge_inputs["format"]["format"] == "athena" and merge_inputs["format"]["extract_group"]["extract_group"] != "single"))</filter> - </collection> - <collection name="derivative_plot_collection" format="png" type="list" label="Derivative plots ${annotation} ${on_string}"> - <discover_datasets pattern="__name_and_ext__" directory="derivative"/> + <collection name="plot_collection" format="png" type="list" label="Plots of ${annotation} ${on_string}"> + <discover_datasets pattern="__name_and_ext__" directory="plot"/> <filter>plot_graph</filter> <filter>not zip_outputs</filter> <filter>merge_inputs["merge_inputs"] == "" and ((merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]) or (merge_inputs["format"]["format"] == "athena" and merge_inputs["format"]["extract_group"]["extract_group"] != "single"))</filter> @@ -262,49 +244,37 @@ </output> </test> <!-- 4 --> - <test expect_num_outputs="4"> + <test expect_num_outputs="2"> <param name="dat_file" value="test.xmu"/> - <param name="plot_graph" value="true"/> + <param name="plot_graph" value="edge,flat,dmude"/> <output name="athena_project_file"> <assert_contents> <has_size value="5400" delta="100"/> </assert_contents> </output> - <output name="edge_plot"> - <assert_contents> - <has_size value="54036" delta="20"/> - </assert_contents> - </output> - <output name="flat_plot"> + <output name="plot"> <assert_contents> - <has_size value="39266" delta="20"/> - </assert_contents> - </output> - <output name="derivative_plot"> - <assert_contents> - <has_size value="42435" delta="20"/> + <has_size value="134972" delta="20"/> </assert_contents> </output> </test> <!-- 5 --> - <test expect_num_outputs="4"> + <test expect_num_outputs="2"> <param name="is_zipped" value="true"/> <param name="dat_file" value="test.zip"/> - <param name="plot_graph" value="true"/> + <param name="plot_graph" value="edge,flat,dmude"/> <output_collection name="athena_project_file_collection" type="list" count="2"/> - <output_collection name="edge_plot_collection" type="list" count="2"/> - <output_collection name="flat_plot_collection" type="list" count="2"/> - <output_collection name="derivative_plot_collection" type="list" count="2"/> + <output_collection name="plot_collection" type="list" count="2"/> </test> <!-- 6 --> <test expect_num_outputs="1"> <param name="is_zipped" value="true"/> <param name="dat_file" value="h5.zip"/> - <param name="plot_graph" value="true"/> + <param name="plot_graph" value="edge,flat,dmude"/> <param name="zip_outputs" value="true"/> <output name="out_zip"> <assert_contents> - <has_size value="312000" delta="500"/> + <has_size value="75500" delta="500"/> </assert_contents> </output> </test> @@ -320,30 +290,20 @@ </output> </test> <!-- 8 --> - <test expect_num_outputs="4"> + <test expect_num_outputs="2"> <param name="dat_file" value="test.xmu"/> <param name="calibrate" value="true"/> <param name="energy_min" value="7000"/> <param name="energy_max" value="7200"/> - <param name="plot_graph" value="true"/> + <param name="plot_graph" value="edge,flat,dmude"/> <output name="athena_project_file"> <assert_contents> <has_size value="3300" delta="50"/> </assert_contents> </output> - <output name="edge_plot"> - <assert_contents> - <has_size value="44900" delta="100"/> - </assert_contents> - </output> - <output name="flat_plot"> + <output name="plot"> <assert_contents> - <has_size value="39400" delta="100"/> - </assert_contents> - </output> - <output name="derivative_plot"> - <assert_contents> - <has_size value="45900" delta="100"/> + <has_size value="134700" delta="100"/> </assert_contents> </output> </test> @@ -392,29 +352,19 @@ </output> </test> <!-- 13: Test merging and plotting multiple prj inputs --> - <test expect_num_outputs="4"> + <test expect_num_outputs="2"> <param name="merge_inputs" value="true"/> <param name="format" value="athena"/> <param name="dat_file" value="test.prj,test.prj"/> - <param name="plot_graph" value="true"/> + <param name="plot_graph" value="edge,flat,dmude"/> <output name="athena_project_file"> <assert_contents> <has_size value="4500" delta="100"/> </assert_contents> </output> - <output name="edge_plot"> - <assert_contents> - <has_size value="54200" delta="100"/> - </assert_contents> - </output> - <output name="flat_plot"> + <output name="plot"> <assert_contents> - <has_size value="39400" delta="100"/> - </assert_contents> - </output> - <output name="derivative_plot"> - <assert_contents> - <has_size value="41800" delta="100"/> + <has_size value="135000" delta="100"/> </assert_contents> </output> </test>