Mercurial > repos > muon-spectroscopy-computational-project > larch_athena
comparison larch_athena.xml @ 1:2b3115342fef draft
planemo upload for repository https://github.com/MaterialsGalaxy/larch-tools/tree/main/larch_athena commit 1cf6d7160497ba58fe16a51f00d088a20934eba6
author | muon-spectroscopy-computational-project |
---|---|
date | Wed, 06 Dec 2023 13:03:55 +0000 |
parents | ae2f265ecf8e |
children | a1e26990131c |
comparison
equal
deleted
inserted
replaced
0:ae2f265ecf8e | 1:2b3115342fef |
---|---|
2 <description>generate Athena projects from XAFS data</description> | 2 <description>generate Athena projects from XAFS data</description> |
3 <macros> | 3 <macros> |
4 <!-- version of underlying tool (PEP 440) --> | 4 <!-- version of underlying tool (PEP 440) --> |
5 <token name="@TOOL_VERSION@">0.9.71</token> | 5 <token name="@TOOL_VERSION@">0.9.71</token> |
6 <!-- version of this tool wrapper (integer) --> | 6 <!-- version of this tool wrapper (integer) --> |
7 <token name="@WRAPPER_VERSION@">0</token> | 7 <token name="@WRAPPER_VERSION@">1</token> |
8 <!-- citation should be updated with every underlying tool version --> | 8 <!-- citation should be updated with every underlying tool version --> |
9 <!-- typical fields to update are version, month, year, and doi --> | 9 <!-- typical fields to update are version, month, year, and doi --> |
10 <token name="@TOOL_CITATION@">10.1088/1742-6596/430/1/012007</token> | 10 <token name="@TOOL_CITATION@">10.1088/1742-6596/430/1/012007</token> |
11 <xml name="format"> | 11 <xml name="format"> |
12 <param name="format" type="select" display="radio" label="Input format" help="Whether data is in plaintext or already saved as an Athena project"> | 12 <param name="format" type="select" display="radio" label="Input format" help="Whether data is in plaintext or already saved as an Athena project"> |
13 <option value="plaintext" selected="true">Plaintext</option> | 13 <option value="plaintext" selected="true">Plaintext</option> |
14 <option value="athena">Athena project</option> | 14 <option value="athena">Athena project</option> |
15 </param> | 15 </param> |
16 </xml> | 16 </xml> |
17 <xml name="extract_group"> | 17 <xml name="extract_group"> |
18 <param name="extract_group" type="text" optional="true" label="Extract group" help="Which group to extract and process from the Athena project (will use first group in file if unset)"/> | 18 <conditional name="extract_group"> |
19 <param name="extract_group" type="select" label="Group extraction" help="Method of handling group extraction. Extracting all or multiple named groups will result in multiple outputs, unless merging groups is also true."> | |
20 <option value="single" selected="true">Extract single</option> | |
21 <option value="multiple">Extract multiple</option> | |
22 <option value="all">Extract all</option> | |
23 </param> | |
24 <when value="single"> | |
25 <param name="group_name" type="text" optional="true" label="Group label" help="Which group to extract and process from the Athena project (will use first group in file if unset)"/> | |
26 </when> | |
27 <when value="multiple"> | |
28 <repeat name="multiple" min="1" default="1" title="Groups"> | |
29 <param name="group_name" type="text" label="Group label" help="Which group to extract and process from the Athena project (will use first group in file if unset)"/> | |
30 </repeat> | |
31 </when> | |
32 <when value="all"/> | |
33 </conditional> | |
19 </xml> | 34 </xml> |
20 <xml name="columns"> | 35 <xml name="columns"> |
21 <param name="energy_column" type="text" optional="true" label="Energy column" help="If set, this column we be used as 'energy'. Otherwise, will identify columns ending with 'energy' or labelled 'col1'."/> | 36 <param name="energy_column" type="text" optional="true" label="Energy column" help="If set, this column we be used as 'energy'. Otherwise, will identify the first column ending with 'energy' or labelled 'col1' 'Ef'."/> |
22 <param name="mu_column" type="text" optional="true" label="μ column" help="If set, this column we be used as 'mu'. Otherwise, will identify the first column labelled as either 'col2', 'xmu', 'lni0it' or 'FFI0'."/> | 37 <param name="mu_column" type="text" optional="true" label="μ column" help="If set, this column we be used as 'mu'. Otherwise, will identify the first column labelled as either 'col2', 'xmu', 'lni0it', 'FFI0' or 'FF/I1'."/> |
23 </xml> | 38 </xml> |
24 <xml name="is_zipped"> | 39 <xml name="is_zipped"> |
25 <param name="is_zipped" type="select" display="radio" label="Inputs Zipped" help="Whether plaintext input files are zipped together into one directory, or not."> | 40 <param name="is_zipped" type="select" display="radio" label="Inputs Zipped" help="Whether plaintext input files are zipped together into one directory, or not."> |
26 <option value="" selected="true">No</option> | 41 <option value="" selected="true">No</option> |
27 <option value="true">Yes</option> | 42 <option value="true">Yes</option> |
38 <requirement type="package" version="3.0">zip</requirement> | 53 <requirement type="package" version="3.0">zip</requirement> |
39 <requirement type="package" version="6.0">unzip</requirement> | 54 <requirement type="package" version="6.0">unzip</requirement> |
40 </requirements> | 55 </requirements> |
41 <required_files> | 56 <required_files> |
42 <include type="literal" path="larch_athena.py"/> | 57 <include type="literal" path="larch_athena.py"/> |
58 <include type="literal" path="common.py"/> | |
43 </required_files> | 59 </required_files> |
44 <command detect_errors="exit_code"><![CDATA[ | 60 <command detect_errors="exit_code"><![CDATA[ |
45 mkdir prj edge flat derivative | 61 mkdir prj edge flat derivative |
46 #if $merge_inputs.format.format=="plaintext": | 62 #if $merge_inputs.format.format=="plaintext": |
47 #if $merge_inputs.format.is_zipped.is_zipped=="true": | 63 #if $merge_inputs.format.is_zipped.is_zipped=="true": |
109 </when> | 125 </when> |
110 </conditional> | 126 </conditional> |
111 </when> | 127 </when> |
112 </conditional> | 128 </conditional> |
113 <param name="annotation" type="text" label="Annotation" optional="true" help="If set, will annotate the output project(s) with this string. This will be used to generate legends when plotting data."/> | 129 <param name="annotation" type="text" label="Annotation" optional="true" help="If set, will annotate the output project(s) with this string. This will be used to generate legends when plotting data."/> |
114 <section name="variables" title="Processing Options"> | 130 <section name="processing" expanded="true" title="Processing Options" help="By default, the following processing steps will be performed either with default values, or those contained in the input Athena project (if used). If specified here, these values will be used instead for process in sequence."> |
115 <param name="energy_0" type="float" label="Edge energy (eV)" optional="true" help="If set, data will be calibrated so that the edge occurs at this energy (after merging, if relevant)."/> | 131 <conditional name="calibrate"> |
116 <expand macro="energy_limits"/> | 132 <param name="calibrate" type="select" label="Calibrate energy" help="If set, will shift the spectrum so that its (automatically determined) edge occurs at the specified value, and any values outside the range will be discarded."> |
117 <param name="pre1" type="float" label="Pre-edge fit lower energy (eV)" optional="true" help="The lower edge of the region used for the pre-edge fitting, if unset will either use existing value or a default based on the data."/> | 133 <option value="" selected="true">False</option> |
118 <param name="pre2" type="float" label="Pre-edge fit upper energy (eV)" optional="true" help="The upper edge of the region used for the pre-edge fitting, if unset will either use existing value or a default based on the data."/> | 134 <option value="true">True</option> |
119 <section name="xftf" title="XFTF"> | 135 </param> |
120 <expand macro="xftf_params"/> | 136 <when value=""/> |
121 </section> | 137 <when value="true"> |
138 <param name="calibration_e0" type="float" label="Calibration energy (eV)" optional="true" help="If set, data will be calibrated so that the edge occurs at this energy (after merging, if relevant). Note that this is different from specifying E0 in the pre-edge normalization, as this will the x-axis of the data (so that the Nth x point will no longer align with the Nth y point)."/> | |
139 <param name="energy_min" type="float" label="Minimum energy (eV)" optional="true" help="If set, data will be cropped below this value in electron volts (after re-calibrating)."/> | |
140 <param name="energy_max" type="float" label="Maximum energy (eV)" optional="true" help="If set, data will be cropped above this value in electron volts (after re-calibrating)."/> | |
141 </when> | |
142 </conditional> | |
143 <param name="rebin" type="boolean" label="Re-bin data" help="Whether to re-bin along the energy axis to automatically ensure appropriate levels of precision in the pre-edge, near-edge and extended region of the spectrum."/> | |
144 <conditional name="pre_edge"> | |
145 <param name="pre_edge" type="select" label="Pre-edge normalization" help="If set, will (re)perform forward pre-edge normalization using provided values."> | |
146 <option value="" selected="true">False</option> | |
147 <option value="true">True</option> | |
148 </param> | |
149 <when value=""/> | |
150 <when value="true"> | |
151 <param argument="e0" type="float" label="Edge energy (eV)" optional="true" help="If set, normalization will use this as the location of the edge rather than automatically determining it."/> | |
152 <param argument="pre1" type="float" max="0" label="Pre-edge fit lower energy (eV)" optional="true" help="The lower end of the region used for the pre-edge fitting, relative to the edge energy (and therefore negative)."/> | |
153 <param argument="pre2" type="float" max="0" label="Pre-edge fit upper energy (eV)" optional="true" help="The upper end of the region used for the pre-edge fitting, relative to the edge energy (and therefore negative)."/> | |
154 <param argument="nvict" type="integer" label="Energy exponent" optional="true" help="Edge fitting will be performed against μ*E**n where n is defined here. This is 0 by default."/> | |
155 </when> | |
156 </conditional> | |
157 <conditional name="xftf"> | |
158 <param name="xftf" type="select" label="XFTF" help="If set, will (re)perform forward Fourier Transform using provided values."> | |
159 <option value="" selected="true">False</option> | |
160 <option value="true">True</option> | |
161 </param> | |
162 <when value=""/> | |
163 <when value="true"> | |
164 <param argument="kmin" type="float" optional="true" min="0.0" help="Minimum k value."/> | |
165 <param argument="kmax" type="float" optional="true" min="0.0" help="Maximum k value."/> | |
166 <param argument="kweight" type="float" optional="true" help="Exponent for weighting spectra by raising k to this power."/> | |
167 <param argument="dk" type="float" optional="true" help="Tapering parameter for Fourier Transform window."/> | |
168 <param argument="window" type="select" optional="true" help="Fourier Transform window type."> | |
169 <option value="hanning">Hanning (cosine-squared taper)</option> | |
170 <option value="parzen">Parzen (linear taper)</option> | |
171 <option value="welch">Welch (quadratic taper)</option> | |
172 <option value="gaussian">Gaussian function window</option> | |
173 <option value="sine">Sine function window</option> | |
174 <option value="kaiser">Kaiser-Bessel function-derived window</option> | |
175 </param> | |
176 </when> | |
177 </conditional> | |
122 </section> | 178 </section> |
123 <param name="rebin" type="boolean" label="Re-bin data" help="Whether to re-bin along the energy axis to ensure appropriate levels of precision in the pre-edge, near-edge and extended region of the spectrum."/> | |
124 <param name="plot_graph" type="boolean" label="Plot graph" help="Whether to plot the pre/post edge fitting and the normalised xμ data."/> | 179 <param name="plot_graph" type="boolean" label="Plot graph" help="Whether to plot the pre/post edge fitting and the normalised xμ data."/> |
125 <param name="zip_outputs" type="boolean" label="Zip outputs" help="Whether to zip all outputs into one dataset."/> | 180 <param name="zip_outputs" type="boolean" label="Zip outputs" help="Whether to zip all outputs into one dataset."/> |
126 </inputs> | 181 </inputs> |
127 <outputs> | 182 <outputs> |
128 <!-- Single output if zipping outputs --> | 183 <!-- Single output if zipping outputs --> |
129 <data name="out_zip" format="zip" from_work_dir="out_zip.zip" label="Zipped Athena project(s) ${annotation} ${on_string}"> | 184 <data name="out_zip" format="zip" from_work_dir="out_zip.zip" label="Zipped Athena project(s) ${annotation} ${on_string}"> |
130 <filter>zip_outputs</filter> | 185 <filter>zip_outputs</filter> |
131 </data> | 186 </data> |
132 <!-- Single outputs of differnt types if merging, or not using a zip --> | 187 <!-- Single outputs of different types if merging, or not using a zip --> |
133 <data name="athena_project_file" format="prj" from_work_dir="prj/out.prj" label="Athena project ${annotation} ${on_string}"> | 188 <data name="athena_project_file" format="prj" from_work_dir="prj/out.prj" label="Athena project ${annotation} ${on_string}"> |
134 <filter>not zip_outputs</filter> | 189 <filter>not zip_outputs</filter> |
135 <filter>merge_inputs["merge_inputs"] or (merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"] == "")</filter> | 190 <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> |
136 </data> | 191 </data> |
137 <data name="edge_plot" format="png" from_work_dir="edge/out.png" label="Edge fitting ${annotation} ${on_string}"> | 192 <data name="edge_plot" format="png" from_work_dir="edge/out.png" label="Edge fitting ${annotation} ${on_string}"> |
138 <filter>plot_graph</filter> | 193 <filter>plot_graph</filter> |
139 <filter>not zip_outputs</filter> | 194 <filter>not zip_outputs</filter> |
140 <filter>merge_inputs["merge_inputs"] or (merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"] == "")</filter> | 195 <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> |
141 </data> | 196 </data> |
142 <data name="flat_plot" format="png" from_work_dir="flat/out.png" label="Flattened plot ${annotation} ${on_string}"> | 197 <data name="flat_plot" format="png" from_work_dir="flat/out.png" label="Flattened plot ${annotation} ${on_string}"> |
143 <filter>plot_graph</filter> | 198 <filter>plot_graph</filter> |
144 <filter>not zip_outputs</filter> | 199 <filter>not zip_outputs</filter> |
145 <filter>merge_inputs["merge_inputs"] or (merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"] == "")</filter> | 200 <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> |
146 </data> | 201 </data> |
147 <data name="derivative_plot" format="png" from_work_dir="derivative/out.png" label="Derivative plot ${annotation} ${on_string}"> | 202 <data name="derivative_plot" format="png" from_work_dir="derivative/out.png" label="Derivative plot ${annotation} ${on_string}"> |
148 <filter>plot_graph</filter> | 203 <filter>plot_graph</filter> |
149 <filter>not zip_outputs</filter> | 204 <filter>not zip_outputs</filter> |
150 <filter>merge_inputs["merge_inputs"] or merge_inputs["format"]["dat_file"].extension != "zip"</filter> | 205 <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> |
151 <filter>merge_inputs["merge_inputs"] or (merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"] == "")</filter> | |
152 </data> | 206 </data> |
153 <!-- Directories of outputs if using single, non-merged zip as input --> | 207 <!-- Directories of outputs if using single, non-merged zip as input or extracting multiple/all Athena groups --> |
154 <collection name="athena_project_file_collection" format="prj" type="list" label="Athena projects ${annotation} ${on_string}"> | 208 <collection name="athena_project_file_collection" format="prj" type="list" label="Athena projects ${annotation} ${on_string}"> |
155 <discover_datasets pattern="__name_and_ext__" directory="prj"/> | 209 <discover_datasets pattern="__name_and_ext__" directory="prj"/> |
156 <filter>not zip_outputs</filter> | 210 <filter>not zip_outputs</filter> |
157 <filter>merge_inputs["merge_inputs"] == "" and merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]</filter> | 211 <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> |
158 </collection> | 212 </collection> |
159 <collection name="edge_plot_collection" format="png" type="list" label="Edge fittings ${annotation} ${on_string}"> | 213 <collection name="edge_plot_collection" format="png" type="list" label="Edge fittings ${annotation} ${on_string}"> |
160 <discover_datasets pattern="__name_and_ext__" directory="edge"/> | 214 <discover_datasets pattern="__name_and_ext__" directory="edge"/> |
161 <filter>plot_graph</filter> | 215 <filter>plot_graph</filter> |
162 <filter>not zip_outputs</filter> | 216 <filter>not zip_outputs</filter> |
163 <filter>merge_inputs["merge_inputs"] == "" and merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]</filter> | 217 <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> |
164 </collection> | 218 </collection> |
165 <collection name="flat_plot_collection" format="png" type="list" label="Flattened plots ${annotation} ${on_string}"> | 219 <collection name="flat_plot_collection" format="png" type="list" label="Flattened plots ${annotation} ${on_string}"> |
166 <discover_datasets pattern="__name_and_ext__" directory="flat"/> | 220 <discover_datasets pattern="__name_and_ext__" directory="flat"/> |
167 <filter>plot_graph</filter> | 221 <filter>plot_graph</filter> |
168 <filter>not zip_outputs</filter> | 222 <filter>not zip_outputs</filter> |
169 <filter>merge_inputs["merge_inputs"] == "" and merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]</filter> | 223 <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> |
170 </collection> | 224 </collection> |
171 <collection name="derivative_plot_collection" format="png" type="list" label="Derivative plots ${annotation} ${on_string}"> | 225 <collection name="derivative_plot_collection" format="png" type="list" label="Derivative plots ${annotation} ${on_string}"> |
172 <discover_datasets pattern="__name_and_ext__" directory="derivative"/> | 226 <discover_datasets pattern="__name_and_ext__" directory="derivative"/> |
173 <filter>plot_graph</filter> | 227 <filter>plot_graph</filter> |
174 <filter>not zip_outputs</filter> | 228 <filter>not zip_outputs</filter> |
175 <filter>merge_inputs["merge_inputs"] == "" and merge_inputs["format"]["format"] == "plaintext" and merge_inputs["format"]["is_zipped"]["is_zipped"]</filter> | 229 <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> |
176 </collection> | 230 </collection> |
177 </outputs> | 231 </outputs> |
178 <tests> | 232 <tests> |
233 <!-- 1 --> | |
179 <test expect_num_outputs="1"> | 234 <test expect_num_outputs="1"> |
180 <param name="dat_file" value="test.xmu"/> | 235 <param name="dat_file" value="test.xmu"/> |
181 <output name="athena_project_file"> | 236 <output name="athena_project_file"> |
182 <assert_contents> | 237 <assert_contents> |
183 <has_size value="5405" delta="10"/> | 238 <has_size value="5405" delta="10"/> |
184 </assert_contents> | 239 </assert_contents> |
185 </output> | 240 </output> |
186 </test> | 241 </test> |
242 <!-- 2 --> | |
187 <test expect_num_outputs="1"> | 243 <test expect_num_outputs="1"> |
188 <param name="dat_file" value="ffi0.tabular"/> | 244 <param name="dat_file" value="ffi0.tabular"/> |
189 <output name="athena_project_file"> | 245 <output name="athena_project_file"> |
190 <assert_contents> | 246 <assert_contents> |
191 <has_size value="34400" delta="100"/> | 247 <has_size value="34400" delta="100"/> |
192 </assert_contents> | 248 </assert_contents> |
193 </output> | 249 </output> |
194 </test> | 250 </test> |
251 <!-- 3 --> | |
252 <test expect_num_outputs="1"> | |
253 <param name="dat_file" value="ffi1.tabular"/> | |
254 <output name="athena_project_file"> | |
255 <assert_contents> | |
256 <has_size value="4400" delta="100"/> | |
257 </assert_contents> | |
258 </output> | |
259 </test> | |
260 <!-- 4 --> | |
195 <test expect_num_outputs="4"> | 261 <test expect_num_outputs="4"> |
196 <param name="dat_file" value="test.xmu"/> | 262 <param name="dat_file" value="test.xmu"/> |
197 <param name="plot_graph" value="true"/> | 263 <param name="plot_graph" value="true"/> |
198 <output name="athena_project_file"> | 264 <output name="athena_project_file"> |
199 <assert_contents> | 265 <assert_contents> |
200 <has_size value="5405" delta="10"/> | 266 <has_size value="5400" delta="100"/> |
201 </assert_contents> | 267 </assert_contents> |
202 </output> | 268 </output> |
203 <output name="edge_plot"> | 269 <output name="edge_plot"> |
204 <assert_contents> | 270 <assert_contents> |
205 <has_size value="54036" delta="20"/> | 271 <has_size value="54036" delta="20"/> |
214 <assert_contents> | 280 <assert_contents> |
215 <has_size value="42435" delta="20"/> | 281 <has_size value="42435" delta="20"/> |
216 </assert_contents> | 282 </assert_contents> |
217 </output> | 283 </output> |
218 </test> | 284 </test> |
285 <!-- 5 --> | |
219 <test expect_num_outputs="4"> | 286 <test expect_num_outputs="4"> |
220 <param name="is_zipped" value="true"/> | 287 <param name="is_zipped" value="true"/> |
221 <param name="dat_file" value="test.zip"/> | 288 <param name="dat_file" value="test.zip"/> |
222 <param name="plot_graph" value="true"/> | 289 <param name="plot_graph" value="true"/> |
223 <output_collection name="athena_project_file_collection" type="list" count="2"/> | 290 <output_collection name="athena_project_file_collection" type="list" count="2"/> |
224 <output_collection name="edge_plot_collection" type="list" count="2"/> | 291 <output_collection name="edge_plot_collection" type="list" count="2"/> |
225 <output_collection name="flat_plot_collection" type="list" count="2"/> | 292 <output_collection name="flat_plot_collection" type="list" count="2"/> |
226 <output_collection name="derivative_plot_collection" type="list" count="2"/> | 293 <output_collection name="derivative_plot_collection" type="list" count="2"/> |
227 </test> | 294 </test> |
295 <!-- 6 --> | |
228 <test expect_num_outputs="1"> | 296 <test expect_num_outputs="1"> |
229 <param name="is_zipped" value="true"/> | 297 <param name="is_zipped" value="true"/> |
230 <param name="dat_file" value="h5.zip"/> | 298 <param name="dat_file" value="h5.zip"/> |
231 <param name="plot_graph" value="true"/> | 299 <param name="plot_graph" value="true"/> |
232 <param name="zip_outputs" value="true"/> | 300 <param name="zip_outputs" value="true"/> |
234 <assert_contents> | 302 <assert_contents> |
235 <has_size value="312000" delta="500"/> | 303 <has_size value="312000" delta="500"/> |
236 </assert_contents> | 304 </assert_contents> |
237 </output> | 305 </output> |
238 </test> | 306 </test> |
239 <test expect_num_outputs="1"> | 307 <!-- 7 --> |
240 <param name="dat_file" value="test.xmu"/> | 308 <test expect_num_outputs="1"> |
241 <param name="energy_format" value="absolute"/> | 309 <param name="dat_file" value="test.xmu"/> |
310 <param name="calibrate" value="true"/> | |
242 <param name="energy_min" value="7000"/> | 311 <param name="energy_min" value="7000"/> |
243 <output name="athena_project_file"> | 312 <output name="athena_project_file"> |
244 <assert_contents> | 313 <assert_contents> |
245 <has_size value="5300" delta="100"/> | 314 <has_size value="5300" delta="100"/> |
246 </assert_contents> | 315 </assert_contents> |
247 </output> | 316 </output> |
248 </test> | 317 </test> |
318 <!-- 8 --> | |
249 <test expect_num_outputs="4"> | 319 <test expect_num_outputs="4"> |
250 <param name="dat_file" value="test.xmu"/> | 320 <param name="dat_file" value="test.xmu"/> |
251 <param name="energy_format" value="absolute"/> | 321 <param name="calibrate" value="true"/> |
252 <param name="energy_min" value="7000"/> | 322 <param name="energy_min" value="7000"/> |
253 <param name="energy_max" value="7200"/> | 323 <param name="energy_max" value="7200"/> |
254 <param name="plot_graph" value="true"/> | 324 <param name="plot_graph" value="true"/> |
255 <output name="athena_project_file"> | 325 <output name="athena_project_file"> |
256 <assert_contents> | 326 <assert_contents> |
257 <has_size value="3300" delta="50"/> | 327 <has_size value="3300" delta="50"/> |
258 </assert_contents> | 328 </assert_contents> |
259 </output> | 329 </output> |
260 <output name="edge_plot"> | 330 <output name="edge_plot"> |
261 <assert_contents> | 331 <assert_contents> |
262 <has_size value="44430" delta="10"/> | 332 <has_size value="44900" delta="100"/> |
263 </assert_contents> | 333 </assert_contents> |
264 </output> | 334 </output> |
265 <output name="flat_plot"> | 335 <output name="flat_plot"> |
266 <assert_contents> | 336 <assert_contents> |
267 <has_size value="37310" delta="10"/> | 337 <has_size value="39400" delta="100"/> |
268 </assert_contents> | 338 </assert_contents> |
269 </output> | 339 </output> |
270 <output name="derivative_plot"> | 340 <output name="derivative_plot"> |
271 <assert_contents> | 341 <assert_contents> |
272 <has_size value="46390" delta="10"/> | 342 <has_size value="45900" delta="100"/> |
273 </assert_contents> | 343 </assert_contents> |
274 </output> | 344 </output> |
275 </test> | 345 </test> |
276 <test expect_num_outputs="1"> | 346 <!-- 9 --> |
277 <param name="dat_file" value="test.xmu"/> | 347 <test expect_num_outputs="1"> |
278 <param name="energy_format" value="absolute"/> | 348 <param name="dat_file" value="test.xmu"/> |
279 <param name="energy_0" value="7050"/> | 349 <param name="calibrate" value="true"/> |
350 <param name="calibration_e0" value="7050"/> | |
280 <param name="energy_min" value="7000"/> | 351 <param name="energy_min" value="7000"/> |
281 <param name="energy_max" value="7200"/> | 352 <param name="energy_max" value="7200"/> |
282 <output name="athena_project_file"> | 353 <output name="athena_project_file"> |
283 <assert_contents> | 354 <assert_contents> |
284 <has_size value="3300" delta="50"/> | 355 <has_size value="3600" delta="100"/> |
285 </assert_contents> | 356 </assert_contents> |
286 </output> | 357 </output> |
287 </test> | 358 </test> |
359 <!-- 10 --> | |
288 <test expect_num_outputs="1"> | 360 <test expect_num_outputs="1"> |
289 <param name="dat_file" value="test.xmu"/> | 361 <param name="dat_file" value="test.xmu"/> |
290 <param name="rebin" value="true"/> | 362 <param name="rebin" value="true"/> |
291 <output name="athena_project_file"> | 363 <output name="athena_project_file"> |
292 <assert_contents> | 364 <assert_contents> |
293 <has_size value="8413" delta="10"/> | 365 <has_size value="8413" delta="10"/> |
294 </assert_contents> | 366 </assert_contents> |
295 </output> | 367 </output> |
296 </test> | 368 </test> |
369 <!-- 11 --> | |
297 <test expect_num_outputs="1"> | 370 <test expect_num_outputs="1"> |
298 <param name="merge_inputs" value="true"/> | 371 <param name="merge_inputs" value="true"/> |
299 <param name="dat_file" value="262875_PtSn_OCO_Abu_1.nxs,262876_PtSn_OCO_Abu_2.nxs"/> | 372 <param name="dat_file" value="262875_PtSn_OCO_Abu_1.nxs,262876_PtSn_OCO_Abu_2.nxs"/> |
300 <output name="athena_project_file"> | 373 <output name="athena_project_file"> |
301 <assert_contents> | 374 <assert_contents> |
302 <has_size value="37550" delta="50"/> | 375 <has_size value="37550" delta="50"/> |
303 </assert_contents> | 376 </assert_contents> |
304 </output> | 377 </output> |
305 </test> | 378 </test> |
379 <!-- 12 --> | |
306 <test expect_num_outputs="1"> | 380 <test expect_num_outputs="1"> |
307 <param name="merge_inputs" value="true"/> | 381 <param name="merge_inputs" value="true"/> |
308 <param name="is_zipped" value="true"/> | 382 <param name="is_zipped" value="true"/> |
309 <param name="dat_file" value="test.zip"/> | 383 <param name="dat_file" value="test.zip"/> |
310 <output name="athena_project_file"> | 384 <output name="athena_project_file"> |
311 <assert_contents> | 385 <assert_contents> |
312 <has_size value="18000" delta="50"/> | 386 <has_size value="18000" delta="50"/> |
313 </assert_contents> | 387 </assert_contents> |
314 </output> | 388 </output> |
315 </test> | 389 </test> |
390 <!-- 13 --> | |
316 <test expect_num_outputs="1"> | 391 <test expect_num_outputs="1"> |
317 <param name="format" value="athena"/> | 392 <param name="format" value="athena"/> |
318 <param name="dat_file" value="test.prj"/> | 393 <param name="dat_file" value="test.prj"/> |
319 <output name="athena_project_file"> | 394 <output name="athena_project_file"> |
320 <assert_contents> | 395 <assert_contents> |
321 <has_size value="5400" delta="200"/> | 396 <has_size value="5400" delta="200"/> |
322 </assert_contents> | 397 </assert_contents> |
323 </output> | 398 </output> |
399 </test> | |
400 <!-- 14: Extract multiple groups from Athena .prj --> | |
401 <test expect_num_outputs="1"> | |
402 <param name="format" value="athena"/> | |
403 <param name="extract_group" value="multiple"/> | |
404 <param name="group_name" value="merge"/> | |
405 <param name="group_name" value="d__Ref_PtSn_OC_MERGE_CALIBRATE"/> | |
406 <param name="dat_file" value="multiple.prj"/> | |
407 <output_collection name="athena_project_file_collection" type="list" count="2"/> | |
408 </test> | |
409 <!-- 15: Extract all groups from Athena .prj --> | |
410 <test expect_num_outputs="1"> | |
411 <param name="format" value="athena"/> | |
412 <param name="extract_group" value="all"/> | |
413 <param name="dat_file" value="multiple.prj"/> | |
414 <output_collection name="athena_project_file_collection" type="list" count="9"/> | |
324 </test> | 415 </test> |
325 </tests> | 416 </tests> |
326 <help><![CDATA[ | 417 <help><![CDATA[ |
327 Using Larch, create an Athena project file from the input X-ray Absorption Fine Structure (XAFS) data file. | 418 Using Larch, create an Athena project file from the input X-ray Absorption Fine Structure (XAFS) data file. |
328 | 419 |