File: orso_integration.rst

package info (click to toggle)
genx 3.8.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 39,152 kB
  • sloc: python: 79,013; makefile: 153; sh: 92; xml: 7
file content (248 lines) | stat: -rw-r--r-- 9,352 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
.. _tutorial-orso:

****************
ORSO Integration
****************

Introduction
============

The Open Reflectometry Standards Organization (ORSO) has defined file types for reflectometry that
allow standardized header information to be reat programmatically. GenX integrates these capabilities
when exporting the simulated data (:menuselection:`File-->Export-->Export ORSO...`). The text format `*.ort`
allows to export all datasets into a single file and includes the GenX model, parameters and script. This makes
it the perfect format to submit as supplement for publications, as the metadata makes it easier to replicate
and check the results.

.. note::
    The ORSO export only works, if the header information is confirm with the standard.

Metadata Dialog
===============

GenX keeps track of metadata from imported measurements. Depending on the data loader, different
amount of information is available. You can browse through the metadata using the Data panel,
selecting one dataset and clicking the information button:

.. image:: _attachments/orso_integration/info_button.png

This will open the `Dataset information` dialog with a hirachical structure on the left and text display
on the right hand side.
When opening the SiO layer neutron example, you can see such structure:

.. image:: _attachments/orso_integration/dataset_information.png

This can be quite useful in reviewing some instrument parameters or finding the sample a certain
measurement corresponds to.

It is possible to edit the leaf notes directly by double-click. A right click on a parent node
allows to insert new items accoring to ORSO specification.

New Model from File
===================

For a proper ORSO datafile it is possible to create a new reflectivity model, making use of existing
information from the header. For this use the menu :menuselection:`File-->New from file...`.

By default this defines the instrument parameters (neutron/x-ray etc.).
If a model according to the `ORSO model language <https://www.reflectometry.org/advanced_and_expert_level/file_format/simple_model>`__
has been provided by the user, GenX will already use the information to buid the sample.

If this options is used to with a `*.ort` file exported by GenX, the model is directly loaded and parameters
arc configured accoring to the specification.


Exported Fit
============

When exporting data for publication using the ORSO format, a typical header would look like this.
In addition to all header data from the imported measurement, GenX adds the **analysis** section.
It includes not only the fit script but all fit parameters, uncertainties as well as a model
accoring to the `ORSO model language <https://www.reflectometry.org/advanced_and_expert_level/file_format/simple_model>`__.

(In this example, a full statistical analysis accoring to :ref:`tutorial-error-statistics` was performed.)

.. code:: yaml

    # ORSO reflectivity data file | 1.1 standard | YAML encoding | https://www.reflectometry.org/
    data_source:
      owner:
        name: GenX
        affiliation: Paul Scherrer Institut
      experiment:
        title: Example
        instrument: SuperAdam
        start_date: null
        probe: neutron
      sample:
        name: SiO on Si
      measurement:
        instrument_settings:
          incident_angle: {min: 0.01, max: 4.2, unit: deg}
          wavelength: {magnitude: 4.4, unit: angstrom}
          polarization: unpolarized
        data_files: []
      file_name: for_import.ort
    reduction:
      software: {name: null}
    data_set: SiO ref
    analysis:
      software:
        name: GenX
        version: 3.6.26
      model:
        stack: ambient | surf | substrate
        origin: GenX model
        sub_stacks:
          surf:
            repetitions: 1
            stack: SiO
        layers:
          SiO:
            thickness: 1212.22800714822
            roughness: 4.306906302304505
            material:
              sld: {real: 4.2969154511952156e-07, imag: 0.0}
        materials:
          ambient:
            sld: {real: 0.0, imag: 0.0}
          substrate:
            sld: {real: 2.0583957958990535e-07, imag: 0.0}
        globals:
          roughness: {magnitude: 0.3, unit: nm}
          length_unit: angstrom
          mass_density_unit: g/cm^3
          number_density_unit: 1/nm^3
          sld_unit: 1/angstrom^2
          magnetic_moment_unit: muB
      script: "import models.spec_nx as model\nfrom models.utils import UserVars, fp,\
        \ fw, bc, bw\nfrom numpy import *\n\n# BEGIN Instrument DO NOT CHANGE\nfrom models.utils\
        \ import create_fp, create_fw\ninst = model.Instrument(probe='neutron', wavelength=4.4,\
        \ coords='q', I0=14.998640637081689, res=0.001, restype='full conv and varying\
        \ res.', respoints=9, resintrange=3, beamw=1.361494002150504, footype='gauss beam',\
        \ samplelen=50.0, incangle=0.0, pol='uu', Ibkg=3.9351064727954855e-06, tthoff=0.0,)\n\
        inst_fp = create_fp(inst.wavelength); inst_fw = create_fw(inst.wavelength)\n\n\
        fp.set_wavelength(inst.wavelength); fw.set_wavelength(inst.wavelength)\n# END\
        \ Instrument\n\n# BEGIN Sample DO NOT CHANGE\nAmb = model.Layer(sigma=0.0, dens=1.0,\
        \ d=0.0, f=(1e-20+1e-20j), b=0, xs_ai=0.0, magn=0.0, magn_ang=0.0)\nSiO = model.Layer(sigma=2,\
        \ dens=0.026, d=1205, f=(1e-20+1e-20j), b=bc.Si + bc.O*2, xs_ai=0.0, magn=0.0,\
        \ magn_ang=0.0)\nSub = model.Layer(sigma=2, dens=8/5.443**3, d=0.0, f=(1e-20+1e-20j),\
        \ b=bc.Si, xs_ai=0.0, magn=0.0, magn_ang=0.0)\n\nsurf = model.Stack(Layers=[SiO],\
        \ Repetitions = 1)\n\nsample = model.Sample(Stacks = [surf], Ambient = Amb, Substrate\
        \ = Sub)\n# END Sample\n\n# BEGIN Parameters DO NOT CHANGE\ncp = UserVars()\n\
        cp.new_var('dtheta', 0.04)\ncp.new_var('dlol', 0.007)\ncp.new_sys_err('tth0',\
        \ 0.0, 0.0035)\n# END Parameters\n\nSLD = []\ndef Sim(data):\n    I = []\n   \
        \ SLD[:] = []\n    # BEGIN Dataset 0 DO NOT CHANGE\n    inst.setTthoff(cp.getTth0())\n\
        \    inst.setRes(sqrt((cp.dlol*data[0].x)**2 + (4*3.1415/4.4*cp.dtheta*pi/360)**2))\n\
        \    d = data[0]\n    I.append(sample.SimSpecular(d.x, inst))\n    if _sim: SLD.append(sample.SimSLD(None,
        \ None, inst))\n    # END Dataset 0\n    return I"
      parameters:
      - Parameter: SiO.setD
        Value: 1212.22800714822
        Fit: true
        Min: 903.75
        Max: 1506.25
        Error: (-4.222e-01, 4.558e-01)
      - Parameter: SiO.setB
        Value: 16.52659788921237
        Fit: true
        Min: 11.816324999999999
        Max: 19.693875
        Error: (-5.753e-02, 5.761e-02)
      - Parameter: SiO.setSigma
        Value: 4.306906302304505
        Fit: true
        Min: 1.5
        Max: 15.0
        Error: (-1.975e-01, 3.629e-01)
      - Parameter: Sub.setSigma
        Value: 4.563155140343594
        Fit: true
        Min: 1.5
        Max: 15.0
        Error: (-1.311e+00, 7.008e-01)
      - Parameter: inst.setI0
        Value: 5.8056171439193776
        Fit: false
        Min: 1.5
        Max: 15.0
        Error: '-'
      - Parameter: inst.setIbkg
        Value: 2.1398201626854554e-06
        Fit: false
        Min: 0.0
        Max: 1.0e-05
        Error: '-'
      - Parameter: cp.setTth0
        Value: -0.00014253852631751873
        Fit: false
        Min: -0.05
        Max: 0.05
        Error: '-'
      - Parameter: inst.setBeamw
        Value: 0.6
        Fit: false
        Min: 0.15000000000000002
        Max: 1.5
        Error: '-'
      - Parameter: cp.setDlol
        Value: 0.005
        Fit: false
        Min: 0.004
        Max: 0.008
        Error: '-'
      - Parameter: cp.setDtheta
        Value: 0.033
        Fit: false
        Min: 0.03
        Max: 0.05
        Error: '-'
      statistics_mcmc:
        library: bumps
        version: 0.9.3
        settings:
          pop: 8
          burn: 200
          samples: 100000
        parameters:
        - name: SiO_B
          value: 16.52659788921237
          error: 0.05757321442536423
          cross_correlations:
            SiO_B: 0.003169740268471557
            SiO_D: 0.0039037691554475317
            SiO_Sigma: 0.0010288173799339142
            Sub_Sigma: 0.013075369118058998
        - name: SiO_D
          value: 1212.22800714822
          error: 0.43902018031155876
          cross_correlations:
            SiO_B: 0.0039037691554475317
            SiO_D: 0.18902683733024617
            SiO_Sigma: 0.006523187144176223
            Sub_Sigma: 0.001940201735574769
        - name: SiO_Sigma
          value: 4.306906302304505
          error: 0.28023314693246926
          cross_correlations:
            SiO_B: 0.001028817379933914
            SiO_D: 0.006523187144176223
            SiO_Sigma: 0.06652948247714746
            Sub_Sigma: -0.19488424544167524
        - name: Sub_Sigma
          value: 4.563155140343594
          error: 1.0059575457738956
          cross_correlations:
            SiO_B: 0.013075369118058998
            SiO_D: 0.001940201735574769
            SiO_Sigma: -0.19488424544167524
            Sub_Sigma: 0.7994400246403878
      operator:
        name: glavic_a
      timestamp: '2024-07-23T14:56:01'
    columns:
    - {name: Qz, unit: 1/angstrom}
    - {name: R}
    - {error_of: R}
    - {name: Rsim}
    - {name: FOM}