Neutron Powder Diffraction#
In this tutorial demonstrates how neutron-scattering data can be loaded, visualized, and manipulated with generic functionality from scipp
as well as neutron-specific functionality from scippneutron
. It focuses on reducing data from the ORNL POWGEN neutron diffractometer.
[1]:
import numpy as np
import scipp as sc
import scippneutron as scn
import scippneutron.data
Loading Nexus files#
Loading Nexus files requires Mantid. See, e.g., Installation on how to install scipp and Mantid with conda
.
We start by loading two files: the sample and the vanadium runs.
[2]:
raw_sample = scn.load_with_mantid(
scn.data.get_path('PG3_4844_event.nxs'),
load_pulse_times=False,
mantid_args={'LoadMonitors': True},
)
raw_vanadium = scn.load_with_mantid(
scn.data.get_path('PG3_4866_event.nxs'), load_pulse_times=False
)
FrameworkManager-[Notice] Welcome to Mantid 6.11.0
FrameworkManager-[Notice] Please cite: http://dx.doi.org/10.1016/j.nima.2014.07.029 and this release: http://dx.doi.org/10.5286/Software/Mantid6.11
DownloadInstrument-[Notice] All instrument definitions up to date
Load-[Notice] Load started
Load-[Notice] Load successful, Duration 1.59 seconds
ExtractSpectra-[Notice] ExtractSpectra started
ExtractSpectra-[Notice] ExtractSpectra successful, Duration 0.00 seconds
DeleteWorkspace-[Notice] DeleteWorkspace started
DeleteWorkspace-[Notice] DeleteWorkspace successful, Duration 0.00 seconds
DeleteWorkspace-[Notice] DeleteWorkspace started
DeleteWorkspace-[Notice] DeleteWorkspace successful, Duration 0.00 seconds
DeleteWorkspace-[Notice] DeleteWorkspace started
DeleteWorkspace-[Notice] DeleteWorkspace successful, Duration 0.00 seconds
Load-[Notice] Load started
Load-[Notice] Load successful, Duration 4.21 seconds
DeleteWorkspace-[Notice] DeleteWorkspace started
DeleteWorkspace-[Notice] DeleteWorkspace successful, Duration 0.00 seconds
The optional mantid_args
dict is forwarded to the Mantid algorithm used for loading the files – in this case LoadEventNexus – and can be used to control, e.g., which part of a file to load. Here we request loading monitors, which Mantid does not load by default. The resulting dataset looks as follows:
[3]:
raw_sample
[3]:
- datascippDataArray(spectrum: 24794, tof: 1)DataArrayViewbinned data [len=0, len=0, ..., len=0, len=0]
- samplescippVariable()PyObject<mantid.api._api.Sample object at 0x7f9c919c4970>
- instrument_namestr()POWGEN
- start_timescippVariable()string𝟙2011-08-12T15:50:17
- end_timescippVariable()string𝟙2011-08-12T17:22:05
- ChopperStatus1scippDataArray(time: 2)float64𝟙4.0, 4.0
- ChopperStatus2scippDataArray(time: 2)float64𝟙4.0, 4.0
- ChopperStatus3scippDataArray(time: 2)float64𝟙4.0, 4.0
- CurrentSPscippDataArray(time: 2)float64𝟙300.0, 300.0
- EnergyRequestscippDataArray(time: 2)float64meV287.955, 287.955
- LKSRampRatescippDataArray(time: 2)float64𝟙0.0, 0.0
- LambdaRequestscippDataArray(time: 2)float64Å0.533, 0.533
- Phase1scippDataArray(time: 1794)float64µs8166.720, 8165.158, ..., 8163.853, 8163.853
- Phase2scippDataArray(time: 1793)float64µs8335.626, 8334.088, ..., 8332.859, 8332.859
- Phase3scippDataArray(time: 1777)float64µs1.400e+04, 1.400e+04, ..., 1.400e+04, 1.400e+04
- PhaseRequest1scippDataArray(time: 2)float64µs8164.075, 8164.075
- PhaseRequest2scippDataArray(time: 2)float64µs8332.893, 8332.893
- PhaseRequest3scippDataArray(time: 2)float64µs1.400e+04, 1.400e+04
- SampleTempscippDataArray(time: 467)float64𝟙299.352, 299.446, ..., 300.0, 300.0
- Speed1scippDataArray(time: 2)float64Hz60.0, 60.0
- Speed2scippDataArray(time: 2)float64Hz60.0, 60.0
- Speed3scippDataArray(time: 2)float64Hz60.0, 60.0
- SpeedRequest1scippDataArray(time: 2)float64Hz60.0, 60.0
- SpeedRequest2scippDataArray(time: 2)float64Hz60.0, 60.0
- SpeedRequest3scippDataArray(time: 2)float64Hz60.0, 60.0
- TolRequestscippDataArray(time: 2)float64𝟙20.0, 20.0
- currentsamplescippDataArray(time: 2)float64𝟙4.0, 4.0
- fernsstatusscippDataArray(time: 2)float64𝟙3.0, 3.0
- frequencyscippDataArray(time: 330473)float64Hz0.0, 60.024, ..., 60.002, 59.999
- proton_chargescippDataArray(time: 330473)float64pC1.484e+07, 1.484e+07, ..., 1.487e+07, 1.484e+07
- samplerequestscippDataArray(time: 2)float64𝟙4.0, 4.0
- S1HCenterscippDataArray(time: 2)float64mm0.0, 0.0
- S1HCenterOffsetscippDataArray(time: 2)float64𝟙0.0, 0.0
- S1HWidthscippDataArray(time: 2)float64mm10.0, 10.0
- S1VCenterscippDataArray(time: 2)float64mm5.0, 5.0
- S1VCenterOffsetscippDataArray(time: 2)float64𝟙0.0, 0.0
- S1VHeightscippDataArray(time: 2)float64mm30.0, 30.0
- commErrsscippDataArray(time: 2)float64𝟙0.0, 0.0
- guidescippDataArray(time: 2)float64mm-55.463, -55.463
- s1bscippDataArray(time: 2)float64mm20.0, 20.0
- s1lscippDataArray(time: 2)float64mm5.0, 5.0
- s1rscippDataArray(time: 2)float64mm-5.0, -5.0
- s1tscippDataArray(time: 2)float64mm-10.0, -10.0
- vGuidescippDataArray(time: 2)float64𝟙2.0, 2.0
- veto_pulse_timescippDataArray(time: 1)float64𝟙0.0
- gd_prtn_chrgscippVariable()float64µAh1171.953902925
- run_startscippVariable()string𝟙2011-08-12T15:50:17
- run_titlescippVariable()string𝟙diamond cw0.533 4.22e12 60Hz [10x30]
- file_notesscippVariable()string𝟙NONE
- run_numberscippVariable()string𝟙4844
- experiment_identifierscippVariable()string𝟙IPTS-2767
- durationscippVariable()float64s5508.0
- runningscippDataArray(time: 1)bool𝟙True
- FilenamescippVariable()string𝟙/home/runner/.cache/scippneutron/5/PG3_4844_event.nxs
- scippDataGroup(tof: 200001)
- scippDataGroup(tof: 200001)
- datascippDataArray(tof: 200001)float64counts25.0, 10.0, ..., 0.0, 0.0
- instrument_namestr()POWGEN
Extract the actual events.
[4]:
sample = raw_sample['data']
vanadium = raw_vanadium['data']
[5]:
sc.plot(sample.hist(spectrum=500, tof=400))
[5]:
Instrument view#
Scipp provides a simple 3D instrument view inspired by Mantid’s own instrument view, which can be used to take a quick look at the neutron counts on the detector panels in 3D space or using various cylindrical and spherical projections
[6]:
scn.instrument_view(sample.hist())
[6]:
Plot against scattering angle \(\theta\) using bin
#
This is not an essential step and can be skipped.
Plotting raw data directly yields a hard-to-interpret figure. We can obtain something more useful by binning the spectrum axis based on its \(\theta\) value:
[7]:
sample.coords['two_theta'] = scn.two_theta(sample)
vanadium.coords['two_theta'] = scn.two_theta(vanadium)
two_theta = sc.linspace(dim='two_theta', unit='rad', start=0.0, stop=np.pi, num=2001)
We concatenate events lists from different spectra that fall into a given \(2\theta\) range into longer combined lists:
[8]:
theta_sample = sample.bin(two_theta=two_theta)
[9]:
theta_sample
[9]:
- tof: 1
- two_theta: 2000
- sample_position()vector3m[0. 0. 0.]
Values:
array([0., 0., 0.]) - source_position()vector3m[ 0. 0. -60.]
Values:
array([ 0., 0., -60.]) - tof(tof [bin-edge])float64µs20.0, 1.669e+04
Values:
array([ 20. , 16694.30078125]) - two_theta(two_theta [bin-edge])float64rad0.0, 0.002, ..., 3.140, 3.142
Values:
array([0.00000000e+00, 1.57079633e-03, 3.14159265e-03, ..., 3.13845106e+00, 3.14002186e+00, 3.14159265e+00])
- (tof, two_theta)DataArrayViewbinned data [len=0, len=0, ..., len=0, len=0]
dim='event', content=DataArray( dims=(event: 17926980), data=float32[counts], coords={'tof':float64[µs]})
[10]:
sc.plot(theta_sample.hist(tof=400))
[10]:
Coordinate transformation#
Note: We are back to working with ``sample``, not ``theta_sample``.
scippneutron
provides building blocks for scipp.transform_coords to convert between coordinates related to time-of-flight. The loaded raw data has dimension tof
, and we convert to interplanar lattice spacing (dspacing):
[11]:
dspacing_graph = {
**scn.conversion.graph.beamline.beamline(scatter=True),
**scn.conversion.graph.tof.elastic_dspacing('tof'),
}
[12]:
dspacing_vanadium = vanadium.transform_coords('dspacing', graph=dspacing_graph)
dspacing_sample = sample.transform_coords('dspacing', graph=dspacing_graph)
dspacing_sample
[12]:
- spectrum: 24794
- dspacing: 1
- L1()float64m60.0
Values:
array(60.) - L2(spectrum)float64m2.560, 2.556, ..., 4.251, 4.252
Values:
array([2.56027902, 2.55590928, 2.55268677, ..., 4.25113991, 4.25116338, 4.25188 ]) - Ltotal(spectrum)float64m62.560, 62.556, ..., 64.251, 64.252
Values:
array([62.56027902, 62.55590928, 62.55268677, ..., 64.25113991, 64.25116338, 64.25188 ]) - dspacing(spectrum, dspacing [bin-edge])float64Å0.001, 0.557, ..., 0.003, 2.343
Values:
array([[6.67304240e-04, 5.57008884e-01], [6.65984677e-04, 5.55907426e-01], [6.64723343e-04, 5.54854571e-01], ..., [2.81392374e-03, 2.34882446e+00], [2.81147797e-03, 2.34678294e+00], [2.80685687e-03, 2.34292565e+00]]) - incident_beam()vector3m[ 0. 0. 60.]
Values:
array([ 0., 0., 60.]) - position(spectrum)vector3m[ 1.17451004 -1.01106149 -2.03796699], [ 1.18147634 -0.95946649 -2.05334117], ..., [1.81428985 0.09565841 3.84338287], [1.81375055 0.1499371 3.84269584]
Values:
array([[ 1.17451004, -1.01106149, -2.03796699], [ 1.18147634, -0.95946649, -2.05334117], [ 1.18844265, -0.90787149, -2.06871534], ..., [ 1.81482915, 0.04137972, 3.8440699 ], [ 1.81428985, 0.09565841, 3.84338287], [ 1.81375055, 0.1499371 , 3.84269584]]) - sample_position()vector3m[0. 0. 0.]
Values:
array([0., 0., 0.]) - scattered_beam(spectrum)vector3m[ 1.17451004 -1.01106149 -2.03796699], [ 1.18147634 -0.95946649 -2.05334117], ..., [1.81428985 0.09565841 3.84338287], [1.81375055 0.1499371 3.84269584]
Values:
array([[ 1.17451004, -1.01106149, -2.03796699], [ 1.18147634, -0.95946649, -2.05334117], [ 1.18844265, -0.90787149, -2.06871534], ..., [ 1.81482915, 0.04137972, 3.8440699 ], [ 1.81428985, 0.09565841, 3.84338287], [ 1.81375055, 0.1499371 , 3.84269584]]) - source_position()vector3m[ 0. 0. -60.]
Values:
array([ 0., 0., -60.]) - spectrum(spectrum)int321, 2, ..., 24793, 24794
Values:
array([ 1, 2, 3, ..., 24792, 24793, 24794], dtype=int32) - tof(dspacing [bin-edge])float64µs20.0, 1.669e+04
Values:
array([ 20. , 16694.30078125]) - two_theta(spectrum)float64rad2.491, 2.504, ..., 0.442, 0.442
Values:
array([2.49144445, 2.50372965, 2.51564288, ..., 0.44118918, 0.44157918, 0.44231324])
- (spectrum, dspacing)DataArrayViewbinned data [len=0, len=0, ..., len=0, len=0]
dim='event', content=DataArray( dims=(event: 17926980), data=float32[counts], coords={'tof':float64[µs], 'dspacing':float64[Å]})
Neutron monitors#
This is an optional section. The next section does not use the monitor-normalized data produced here. This section could thus be skipped.
If available, neutron monitors are stored as attributes of a data array:
[13]:
mon = raw_sample['monitors']['monitor1']['data']
mon
[13]:
- tof: 200001
- position()vector3m[ 0. 0. -1.]
Values:
array([ 0., 0., -1.]) - sample_position()vector3m[0. 0. 0.]
Values:
array([0., 0., 0.]) - source_position()vector3m[ 0. 0. -60.]
Values:
array([ 0., 0., -60.]) - spectrum()int321
Values:
array(1, dtype=int32) - tof(tof [bin-edge])float64µs0.0, 1.0, ..., 2.000e+05, 2.000e+05
Values:
array([0.00000e+00, 1.00000e+00, 2.00000e+00, ..., 1.99999e+05, 2.00000e+05, 2.00001e+05])
- (tof)float64counts25.0, 10.0, ..., 0.0, 0.0σ = 5.0, 3.162, ..., 0.0, 0.0
Values:
array([25., 10., 12., ..., 0., 0., 0.])
Variances (σ²):
array([25., 10., 12., ..., 0., 0., 0.])
The monitor could, e.g., be used to normalize the data. To do so, both data and monitor need to be converted to a unit that accounts for differing flight paths, e.g., wavelength or energy:
[14]:
wavelength_graph = {
**scn.conversion.graph.beamline.beamline(scatter=True),
**scn.conversion.graph.tof.elastic_wavelength('tof'),
}
wavelength_graph_monitor = {
**scn.conversion.graph.beamline.beamline(scatter=False),
**scn.conversion.graph.tof.elastic_wavelength('tof'),
}
[15]:
sample_lambda = sample.transform_coords('wavelength', graph=wavelength_graph)
mon = mon.transform_coords('wavelength', graph=wavelength_graph_monitor)
The sample data is in event-mode, i.e., is not histogrammed. Event data can be divided by a histogram (such as mon
in this case), using a specialized function for scaling (see Binned data). First we rebin the monitor since the original binning is very fine:
[16]:
edges = sc.linspace(dim='wavelength', unit='Angstrom', start=0.0, stop=1.0, num=1001)
mon = sc.rebin(mon, wavelength=edges)
mon
[16]:
- wavelength: 1000
- Ltotal()float64m59.0
Values:
array(59.) - position()vector3m[ 0. 0. -1.]
Values:
array([ 0., 0., -1.]) - sample_position()vector3m[0. 0. 0.]
Values:
array([0., 0., 0.]) - source_position()vector3m[ 0. 0. -60.]
Values:
array([ 0., 0., -60.]) - spectrum()int321
Values:
array(1, dtype=int32) - wavelength(wavelength [bin-edge])float64Å0.0, 0.001, ..., 0.999, 1.0
Values:
array([0. , 0.001, 0.002, ..., 0.998, 0.999, 1. ])
- (wavelength)float64counts194.397, 214.709, ..., 206.055, 193.213σ = 13.943, 14.653, ..., 14.355, 13.900
Values:
array([194.39748479, 214.70889599, 215.31141119, 221.66343675, 195.61509123, 184.13926399, 210.3442944 , 204.17987836, 202.92165755, 221.50386558, 224.95938564, 219.86073601, 204.61024636, 226.93907846, 215.93423358, 224.13926399, 225.8965055 , 214.28337286, 191.96711679, 228.35975671, 261.99711372, 196.54447994, 218.12957424, 205.6731265 , 227.49128955, 199.62282239, 200.59478405, 198.88104319, 193.9119678 , 217.1034945 , 214.63251214, 218.10442219, 201.85496345, 194.31141119, 194.24853105, 238.97969282, 229.67405418, 198.44778891, 212.49324814, 195.1527677 , 225.12576028, 204.21853412, 205.05999386, 191.28821773, 209.86362229, 180.46902377, 199.70889599, 214.97196166, 190.09864963, 223.87815691, 201.05607667, 210.87042576, 233.69240277, 207.6905474 , 191.67889906, 231.44294403, 239.33367697, 222.01453462, 192.3268735 , 212.64024329, 195.73013085, 225.54447994, 197.52705904, 196.09772194, 217.38099158, 217.1741058 , 226.09576335, 214.34718068, 232.00288628, 203.68374393, 226.62282239, 193.41201942, 208.68374393, 226.40325735, 213.72538921, 214.05607667, 212.33944953, 198.02607974, 217.73600664, 233.88104319, 198.79692818, 201.08122873, 180.75621059, 196.50108252, 208.58602199, 213.16245745, 214.35295324, 193.81146281, 224.55994225, 202.69539228, 198.89351599, 222.45655097, 207.79012471, 197.07256989, 221.69920624, 187.82878048, 200.53674879, 197.2776003 , 205.96618911, 208.93701663, 216.43335751, 220.74662407, 223.72528598, 199.42944032, 223.81620445, 214.37521902, 200.87042576, 228.73497573, 251.89269153, 229.2407999 , 219.94784052, 218.57829083, 203.70023715, 197.3268735 , 211.25626221, 193.94289242, 225.3955262 , 236.8945469 , 209.77672423, 221.08019782, 204.53674879, 219.03576949, 200.38593968, 210.24667569, 210.03381089, 235.74373779, 187.63725378, 246.67405418, 219.43325428, 215.77765191, 219.50190698, 218.51932788, 212.79496959, 212.3288321 , 200.12091541, 209.22915156, 221.08514592, 223.21080297, 215.00958652, 228.42944032, 227.53674879, 227.7592001 , 212.62282239, 214.41201942, 214.31429747, 217.14215027, 215.23409966, 212.79486636, 212.01453462, 221.18090927, 232.90124714, 181.77765191, 217.47201328, 205.37326042, 209.17400257, 223.88578484, 224.66467411, 205.60045338, 216.65178841, 198.45067519, 215.73992383, 205.0492732 , 224.77280704, 214.28533145, 208.0124728 , 209.28533145, 191.88104319, 199.19812372, 220.83176999, 231.61323587, 187.59962893, 191.35779812, 232.12277077, 213.32800764, 209.99701049, 189.32790441, 224.08390855, 215.55241755, 201.96711679, 205.95361308, 180.87722923, 183.07050807, 226.97299258, 203.44861336, 208.40336058, 201.02412115, 210.60344289, 205.16833324, 199.07731154, 213.62282239, 198.18276463, 187.79806232, 194.88764021, 181.41593661, 195.5358211 , 203.08287764, 188.23915098, 200.05319039, 213.31048351, 220.01061743, 227.93608895, 201.79496959, 257.74085151, 208.17204398, 186.76218961, 204.96711679, 187.88093996, 219.24667569, 230.79496959, 195.56860109, 223.18286786, 194.63343982, 186.46232353, 200.44861336, 206.97979604, 203.43242983, 187.00762793, 201.61880197, 202.31543161, 190.83950114, 204.938872 , 202.01463785, 196.9089783 , 184.13359466, 189.50087607, 214.62282239, 193.70023715, 206.17018861, 199.28718682, 212.92753334, 188.14596423, 208.44397494, 211.46407567, 237.98464092, 163.84537693, 171.76600357, 207.71363764, 228.56849786, 208.5089169 , 191.87795046, 197.91310194, 193.98824843, 216.36656018, 194.54850036, 202.9651582 , 216.92248201, 208.53211037, 176.715493 , 191.40140198, 201.70889599, 208.31336979, 206.41387479, 204.39944339, 194.25811758, 225.00597901, 211.0019586 , 188.53685201, 195.36253976, 202.03649072, 185.89774286, 214.57148736, 169.81146281, 204.96897216, 184.79311422, 184.88104319, 200.29873194, 170.37161151, 204.76961108, 196.23801685, 185.56839463, 216.3880015 , 200.35697366, 170.55509737, 185.96711679, 199.31831789, 187.61591569, 175.91279226, 193.16451927, 217.85310808, 190.23378998, 205.41810166, 187.94763407, 194.01041098, 187.53128591, 195.10143268, 204.88104319, 164.28729005, 188.10720524, 199.24863428, 199.07432203, 197.87743568, 197.42438899, 181.70889599, 175.32017326, 176.09761872, 171.23111015, 196.3144007 , 189.93124407, 192.30285558, 184.76486943, 202.15781903, 184.24265527, 189.20801992, 187.05896295, 149.40150521, 203.50736986, 199.11215334, 187.96134423, 185.55303555, 191.88609452, 202.09112493, 187.8915574 , 160.84919089, 172.00371074, 192.3880015 , 164.02607974, 188.7099269 , 181.71157581, 160.08133195, 198.33646002, 150.33852184, 191.51066905, 184.28636236, 174.36357067, 177.96711679, 181.08710451, 179.26285922, 177.7835277 , 181.73497573, 190.17998158, 171.67714692, 163.46778641, 168.55602506, 174.70322666, 209.55715919, 197.54922159, 175.03958345, 162.50953491, 182.78940348, 173.93433681, 157.69528905, 169.03948023, 177.41119496, 160.22533759, 179.92072987, 180.18554769, 178.83465627, 184.8676427 , 172.15936472, 154.75528291, 178.21863735, 169.4566542 , 155.24554155, 169.13926399, 177.47087914, 182.88104319, 172.60931867, 163.41016405, 157.92237878, 178.56880754, 173.2414179 , 189.16874614, 170.49118632, 158.30553541, 169.04556246, 167.56200407, 176.54437671, 178.3781053 , 163.2059581 , 174.3393463 , 152.35604597, 143.06401428, 170.1865786 , 168.03381089, 164.30646309, 186.97206489, 177.23976899, 154.5745801 , 168.469127 , 168.85764328, 167.79094917, 155.90351542, 183.00402042, 160.22224486, 170.05319039, 159.72642012, 159.00092768, 175.43222337, 162.08792897, 170.88104319, 148.88104319, 167.36274622, 169.18781596, 156.39655711, 163.57241505, 162.88568161, 174.88104319, 159.62375007, 181.07813599, 194.37068382, 172.45160287, 174.88104319, 160.63168768, 167.90413342, 161.10730847, 174.61045281, 179.24750014, 184.95897273, 167.29904162, 176.28924864, 146.26729255, 175.95711736, 157.61230818, 141.59086686, 159.977631 , 153.75384045, 157.793629 , 163.90454633, 148.33151192, 167.92351292, 160.29017633, 160.20090677, 181.21368925, 157.50798922, 136.37831175, 187.73013085, 145.81826628, 144.24904583, 167.1646225 , 166.00206182, 154.93217176, 161.70229897, 162.15245802, 182.5381926 , 147.12761565, 156.25883881, 157.79496959, 174.19544389, 144.53973829, 178.75641705, 160.52211094, 145.96113778, 149.0561799 , 181.88372302, 152.16977706, 152.40315413, 162.36161208, 157.13926399, 159.49221723, 135.58694967, 152.78507339, 163.59808324, 163.28594946, 158.47438478, 169.0791669 , 142.5627253 , 177.72446152, 145.22533759, 182.70198929, 181.34254226, 160.63148123, 147.45933402, 143.54757267, 142.10205069, 149.6954955 , 150.54283102, 152.6119985 , 148.18297109, 139.92340969, 155.14400564, 145.88104319, 141.3880015 , 157.51252441, 150.73703755, 142.31141119, 161.28244517, 145.82640898, 133.39583588, 154.36542604, 153.31759666, 161.47654847, 161.07823922, 146.45459238, 117.98824843, 150.9287707 , 152.98433124, 164.63849115, 160.30357681, 134.22925478, 142.57746638, 156.08679483, 148.01175157, 153.05391162, 164.43748115, 138.97175521, 149.43820238, 159.22533759, 124.81929719, 136.8284708 , 154.91784359, 149.45861279, 126.89351599, 149.3193488 , 150.43479997, 147.1964748 , 152.6064324 , 151.97515762, 135.85259195, 131.02443082, 136.90980276, 157.9507268 , 161.47129205, 160.63508874, 143.02051363, 167.39748479, 152.49963871, 140.79517604, 142.96701356, 137.32811086, 133.63921238, 145.93402713, 129.34089335, 158.64281989, 149.12277077, 163.13926399, 134.86454997, 141.77476563, 153.11906004, 140.19987586, 126.97608531, 149.90124714, 153.30388649, 130.72909994, 135.42150271, 155.44820181, 116.65817897, 168.49623765, 139.53293482, 156.52406953, 128.65951956, 136.31646252, 164.44180989, 149.40129876, 154.5253069 , 125.95186094, 153.70910109, 166.6974541 , 145.22389513, 141.95711736, 148.32903855, 152.31141119, 159.33666648, 145.4835584 , 159.11400871, 142.85310808, 144.34048044, 147.02566683, 147.96825093, 154.25440684, 141.22533759, 135.22533759, 143.85197394, 142.97701299, 130.30151499, 144.87609509, 151.24945874, 144.11462807, 131.75765306, 151.67436386, 141.28729005, 131.86733302, 130.45778833, 152.92928548, 162.3662505 , 153.45943725, 130.63158445, 152.80373165, 146.22317254, 141.0641175 , 128.38872273, 151.22533759, 138.22533759, 126.76806539, 143.4835584 , 122.4835584 , 139.53138778, 136.284507 , 139.52200771, 157.80692761, 170.78899058, 143.4030509 , 140.18132217, 142.85053013, 149.98330168, 119.41459602, 131.95278862, 151.53953184, 136.13926399, 149.11648208, 137.45036686, 128.77187935, 153.85094303, 139.09236094, 149.55355168, 121.28832096, 120.79321745, 135.08957788, 150.72219325, 140.31594774, 136.14101613, 124.21554462, 145.5482939 , 144.61302941, 142.36388035, 122.24667569, 135.31213242, 154.73095531, 148.56891076, 128.30058731, 135.07483816, 156.13895431, 129.26935437, 133.91258581, 133.84919089, 139.02133809, 148.8397076 , 141.87867169, 137.05319039, 159.63230568, 115.51139163, 149.07854755, 138.18606382, 137.24976842, 120.80239106, 148.53881061, 154.68343425, 140.94041905, 134.90877185, 126.05628312, 162.96299315, 149.83300735, 141.10122623, 123.34841805, 143.29161879, 145.3312036 , 131.10431896, 141.38078512, 131.77620945, 127.98433124, 151.41573015, 143.20709223, 152.43139891, 151.98536215, 147.22533759, 134.09071202, 140.82424529, 147.66034402, 142.50747309, 150.93392526, 117.29244325, 144.84682074, 133.60818454, 147.92990348, 129.55932424, 137.46428212, 137.03628427, 164.29780425, 135.10864906, 145.63642933, 126.13132639, 141.39181546, 133.05319039, 142.12565705, 134.93990291, 126.59241391, 135.55478769, 160.86867361, 115.66931254, 129.72940962, 143.29512307, 152.55179954, 146.50262821, 137.69673287, 128.86052955, 126.22533759, 134.31831789, 137.73466605, 133.84166619, 147.56901264, 143.8814561 , 158.09947409, 134.0069067 , 151.75517968, 153.3512011 , 136.51664806, 127.58973272, 137.02638942, 153.76249793, 124.53613078, 138.13926399, 152.47685815, 155.64900535, 160.27244575, 162.58385694, 156.35037664, 158.19915463, 164.29718625, 140.10555632, 152.24038699, 146.10555632, 136.6481809 , 143.74260366, 160.13926399, 179.31306011, 150.2212153 , 150.7400257 , 158.42707017, 140.59663942, 132.42449222, 155.44139699, 169.65488114, 146.41861643, 153.15524243, 137.04298586, 163.6220998 , 147.71044303, 169.05906618, 144.6001437 , 144.81022544, 150.62869817, 191.72064756, 151.05319039, 138.05319039, 149.05319039, 128.9018665 , 149.60519503, 150.34377827, 155.83960437, 168.00907174, 160.78641398, 157.98371188, 175.42232853, 138.35017019, 153.97969146, 175.48809494, 161.35017019, 142.71023658, 130.97433181, 147.39882538, 174.7075554 , 154.69446459, 150.3213074 , 128.51695638, 163.5795282 , 166.16812678, 158.68054797, 167.19998044, 176.77703255, 150.20049522, 149.39346438, 172.53911893, 151.5076809 , 140.78692876, 152.18018803, 164.02247223, 135.21513171, 139.08390855, 121.50819567, 155.01628676, 157.94866498, 132.86475642, 154.41377156, 152.13926399, 175.38119803, 142.31141119, 143.93206853, 146.56994168, 137.95330204, 163.58499243, 139.51675128, 166.5235534 , 159.17060151, 163.24007867, 162.34800514, 156.57148736, 175.39934016, 170.66673594, 145.74548993, 169.01669832, 164.43768761, 153.30584509, 145.31141119, 136.02958402, 167.22348222, 176.2526547 , 140.16699265, 154.88104319, 156.9412435 , 154.36645695, 161.77095167, 156.11524607, 162.33542911, 154.34243903, 171.12411136, 154.34171645, 164.46582781, 157.8525933 , 188.77280704, 152.41078205, 172.49242369, 143.97412536, 190.80125828, 142.87846659, 156.4392333 , 158.58365049, 176.14740805, 147.43108924, 175.09823672, 167.21461693, 171.26564363, 161.31141119, 158.30141177, 152.48283716, 154.07463171, 153.31171952, 176.09607303, 167.50458681, 171.33285251, 166.67714692, 154.69817533, 174.94454133, 164.70889599, 171.10751492, 167.88104319, 155.7241532 , 154.82558452, 159.13699572, 166.3561492 , 166.00958652, 171.53561465, 192.35501506, 172.10524665, 156.80136151, 175.3146058 , 152.52716226, 168.15410829, 154.22533759, 142.26368368, 156.1869915 , 164.06277691, 154.89609259, 172.37831175, 170.9849506 , 157.77713578, 195.69518582, 161.74590284, 153.79249622, 157.99288685, 166.24152113, 187.81826628, 148.09978377, 190.0987515 , 185.85218175, 161.20863792, 172.05319039, 185.5134521 , 173.84455247, 175.5134521 , 188.73518218, 168.00721502, 190.58571366, 200.11658531, 173.5403563 , 170.16555019, 178.50984459, 191.25461329, 174.87867169, 157.45366469, 185.62581189, 180.79795909, 179.9701063 , 191.97309445, 177.47459123, 184.60488535, 181.32336922, 185.2283271 , 164.48417775, 156.62220303, 179.5726215 , 194.13926399, 181.52242062, 175.31254398, 208.85537636, 214.11771945, 175.85238685, 193.44345881, 184.45490206, 180.67302327, 201.88104319, 170.94856175, 171.02278191, 170.75662215, 181.52066847, 167.58818704, 204.82909016, 168.50139085, 178.08731096, 176.44892304, 172.31141119, 207.65745774, 210.55231432, 202.22533759, 185.64014006, 192.46799286, 204.7811562 , 206.42129626, 198.23915098, 184.61550278, 186.31048486, 173.76383852, 171.33604847, 171.95804505, 175.49912393, 194.07524971, 181.58519753, 200.94072737, 182.58519753, 199.25213856, 181.54757267, 186.18255954, 191.13833495, 166.72580211, 194.82651221, 215.49438228, 211.44459295, 174.18771274, 200.35985994, 174.21719489, 187.37274429, 180.70415434, 189.86681825, 186.56994032, 217.53674879, 222.28326963, 212.46933345, 183.11390684, 193.79218518, 187.01391662, 195.76095089, 175.17328269, 169.83115063, 205.21894703, 173.90753584, 199.99711237, 192.48026056, 198.64952013, 210.94041905, 172.62900785, 197.96093133, 238.74971545, 201.84022373, 185.99216562, 184.04226328, 182.3755287 , 231.95299507, 186.34738714, 198.45850957, 193.11895546, 189.90918611, 191.50077149, 167.13926535, 209.57117768, 182.13452099, 205.4491295 , 196.21595752, 198.74806789, 183.38800014, 208.99061993, 201.17678562, 214.70590784, 192.87320881, 173.70106161, 171.52891441, 191.96392083, 196.57746638, 214.66962086, 210.91104147, 210.85887928, 222.07030161, 192.89537271, 203.77785837, 198.06432396, 195.85877606, 189.0374184 , 210.31007196, 209.508504 , 184.24110958, 196.03865441, 206.05525357, 193.21286479])
Variances (σ²):
array([194.39748479, 214.70889599, 215.31141119, 221.66343675, 195.61509123, 184.13926399, 210.3442944 , 204.17987836, 202.92165755, 221.50386558, 224.95938564, 219.86073601, 204.61024636, 226.93907846, 215.93423358, 224.13926399, 225.8965055 , 214.28337286, 191.96711679, 228.35975671, 261.99711372, 196.54447994, 218.12957424, 205.6731265 , 227.49128955, 199.62282239, 200.59478405, 198.88104319, 193.9119678 , 217.1034945 , 214.63251214, 218.10442219, 201.85496345, 194.31141119, 194.24853105, 238.97969282, 229.67405418, 198.44778891, 212.49324814, 195.1527677 , 225.12576028, 204.21853412, 205.05999386, 191.28821773, 209.86362229, 180.46902377, 199.70889599, 214.97196166, 190.09864963, 223.87815691, 201.05607667, 210.87042576, 233.69240277, 207.6905474 , 191.67889906, 231.44294403, 239.33367697, 222.01453462, 192.3268735 , 212.64024329, 195.73013085, 225.54447994, 197.52705904, 196.09772194, 217.38099158, 217.1741058 , 226.09576335, 214.34718068, 232.00288628, 203.68374393, 226.62282239, 193.41201942, 208.68374393, 226.40325735, 213.72538921, 214.05607667, 212.33944953, 198.02607974, 217.73600664, 233.88104319, 198.79692818, 201.08122873, 180.75621059, 196.50108252, 208.58602199, 213.16245745, 214.35295324, 193.81146281, 224.55994225, 202.69539228, 198.89351599, 222.45655097, 207.79012471, 197.07256989, 221.69920624, 187.82878048, 200.53674879, 197.2776003 , 205.96618911, 208.93701663, 216.43335751, 220.74662407, 223.72528598, 199.42944032, 223.81620445, 214.37521902, 200.87042576, 228.73497573, 251.89269153, 229.2407999 , 219.94784052, 218.57829083, 203.70023715, 197.3268735 , 211.25626221, 193.94289242, 225.3955262 , 236.8945469 , 209.77672423, 221.08019782, 204.53674879, 219.03576949, 200.38593968, 210.24667569, 210.03381089, 235.74373779, 187.63725378, 246.67405418, 219.43325428, 215.77765191, 219.50190698, 218.51932788, 212.79496959, 212.3288321 , 200.12091541, 209.22915156, 221.08514592, 223.21080297, 215.00958652, 228.42944032, 227.53674879, 227.7592001 , 212.62282239, 214.41201942, 214.31429747, 217.14215027, 215.23409966, 212.79486636, 212.01453462, 221.18090927, 232.90124714, 181.77765191, 217.47201328, 205.37326042, 209.17400257, 223.88578484, 224.66467411, 205.60045338, 216.65178841, 198.45067519, 215.73992383, 205.0492732 , 224.77280704, 214.28533145, 208.0124728 , 209.28533145, 191.88104319, 199.19812372, 220.83176999, 231.61323587, 187.59962893, 191.35779812, 232.12277077, 213.32800764, 209.99701049, 189.32790441, 224.08390855, 215.55241755, 201.96711679, 205.95361308, 180.87722923, 183.07050807, 226.97299258, 203.44861336, 208.40336058, 201.02412115, 210.60344289, 205.16833324, 199.07731154, 213.62282239, 198.18276463, 187.79806232, 194.88764021, 181.41593661, 195.5358211 , 203.08287764, 188.23915098, 200.05319039, 213.31048351, 220.01061743, 227.93608895, 201.79496959, 257.74085151, 208.17204398, 186.76218961, 204.96711679, 187.88093996, 219.24667569, 230.79496959, 195.56860109, 223.18286786, 194.63343982, 186.46232353, 200.44861336, 206.97979604, 203.43242983, 187.00762793, 201.61880197, 202.31543161, 190.83950114, 204.938872 , 202.01463785, 196.9089783 , 184.13359466, 189.50087607, 214.62282239, 193.70023715, 206.17018861, 199.28718682, 212.92753334, 188.14596423, 208.44397494, 211.46407567, 237.98464092, 163.84537693, 171.76600357, 207.71363764, 228.56849786, 208.5089169 , 191.87795046, 197.91310194, 193.98824843, 216.36656018, 194.54850036, 202.9651582 , 216.92248201, 208.53211037, 176.715493 , 191.40140198, 201.70889599, 208.31336979, 206.41387479, 204.39944339, 194.25811758, 225.00597901, 211.0019586 , 188.53685201, 195.36253976, 202.03649072, 185.89774286, 214.57148736, 169.81146281, 204.96897216, 184.79311422, 184.88104319, 200.29873194, 170.37161151, 204.76961108, 196.23801685, 185.56839463, 216.3880015 , 200.35697366, 170.55509737, 185.96711679, 199.31831789, 187.61591569, 175.91279226, 193.16451927, 217.85310808, 190.23378998, 205.41810166, 187.94763407, 194.01041098, 187.53128591, 195.10143268, 204.88104319, 164.28729005, 188.10720524, 199.24863428, 199.07432203, 197.87743568, 197.42438899, 181.70889599, 175.32017326, 176.09761872, 171.23111015, 196.3144007 , 189.93124407, 192.30285558, 184.76486943, 202.15781903, 184.24265527, 189.20801992, 187.05896295, 149.40150521, 203.50736986, 199.11215334, 187.96134423, 185.55303555, 191.88609452, 202.09112493, 187.8915574 , 160.84919089, 172.00371074, 192.3880015 , 164.02607974, 188.7099269 , 181.71157581, 160.08133195, 198.33646002, 150.33852184, 191.51066905, 184.28636236, 174.36357067, 177.96711679, 181.08710451, 179.26285922, 177.7835277 , 181.73497573, 190.17998158, 171.67714692, 163.46778641, 168.55602506, 174.70322666, 209.55715919, 197.54922159, 175.03958345, 162.50953491, 182.78940348, 173.93433681, 157.69528905, 169.03948023, 177.41119496, 160.22533759, 179.92072987, 180.18554769, 178.83465627, 184.8676427 , 172.15936472, 154.75528291, 178.21863735, 169.4566542 , 155.24554155, 169.13926399, 177.47087914, 182.88104319, 172.60931867, 163.41016405, 157.92237878, 178.56880754, 173.2414179 , 189.16874614, 170.49118632, 158.30553541, 169.04556246, 167.56200407, 176.54437671, 178.3781053 , 163.2059581 , 174.3393463 , 152.35604597, 143.06401428, 170.1865786 , 168.03381089, 164.30646309, 186.97206489, 177.23976899, 154.5745801 , 168.469127 , 168.85764328, 167.79094917, 155.90351542, 183.00402042, 160.22224486, 170.05319039, 159.72642012, 159.00092768, 175.43222337, 162.08792897, 170.88104319, 148.88104319, 167.36274622, 169.18781596, 156.39655711, 163.57241505, 162.88568161, 174.88104319, 159.62375007, 181.07813599, 194.37068382, 172.45160287, 174.88104319, 160.63168768, 167.90413342, 161.10730847, 174.61045281, 179.24750014, 184.95897273, 167.29904162, 176.28924864, 146.26729255, 175.95711736, 157.61230818, 141.59086686, 159.977631 , 153.75384045, 157.793629 , 163.90454633, 148.33151192, 167.92351292, 160.29017633, 160.20090677, 181.21368925, 157.50798922, 136.37831175, 187.73013085, 145.81826628, 144.24904583, 167.1646225 , 166.00206182, 154.93217176, 161.70229897, 162.15245802, 182.5381926 , 147.12761565, 156.25883881, 157.79496959, 174.19544389, 144.53973829, 178.75641705, 160.52211094, 145.96113778, 149.0561799 , 181.88372302, 152.16977706, 152.40315413, 162.36161208, 157.13926399, 159.49221723, 135.58694967, 152.78507339, 163.59808324, 163.28594946, 158.47438478, 169.0791669 , 142.5627253 , 177.72446152, 145.22533759, 182.70198929, 181.34254226, 160.63148123, 147.45933402, 143.54757267, 142.10205069, 149.6954955 , 150.54283102, 152.6119985 , 148.18297109, 139.92340969, 155.14400564, 145.88104319, 141.3880015 , 157.51252441, 150.73703755, 142.31141119, 161.28244517, 145.82640898, 133.39583588, 154.36542604, 153.31759666, 161.47654847, 161.07823922, 146.45459238, 117.98824843, 150.9287707 , 152.98433124, 164.63849115, 160.30357681, 134.22925478, 142.57746638, 156.08679483, 148.01175157, 153.05391162, 164.43748115, 138.97175521, 149.43820238, 159.22533759, 124.81929719, 136.8284708 , 154.91784359, 149.45861279, 126.89351599, 149.3193488 , 150.43479997, 147.1964748 , 152.6064324 , 151.97515762, 135.85259195, 131.02443082, 136.90980276, 157.9507268 , 161.47129205, 160.63508874, 143.02051363, 167.39748479, 152.49963871, 140.79517604, 142.96701356, 137.32811086, 133.63921238, 145.93402713, 129.34089335, 158.64281989, 149.12277077, 163.13926399, 134.86454997, 141.77476563, 153.11906004, 140.19987586, 126.97608531, 149.90124714, 153.30388649, 130.72909994, 135.42150271, 155.44820181, 116.65817897, 168.49623765, 139.53293482, 156.52406953, 128.65951956, 136.31646252, 164.44180989, 149.40129876, 154.5253069 , 125.95186094, 153.70910109, 166.6974541 , 145.22389513, 141.95711736, 148.32903855, 152.31141119, 159.33666648, 145.4835584 , 159.11400871, 142.85310808, 144.34048044, 147.02566683, 147.96825093, 154.25440684, 141.22533759, 135.22533759, 143.85197394, 142.97701299, 130.30151499, 144.87609509, 151.24945874, 144.11462807, 131.75765306, 151.67436386, 141.28729005, 131.86733302, 130.45778833, 152.92928548, 162.3662505 , 153.45943725, 130.63158445, 152.80373165, 146.22317254, 141.0641175 , 128.38872273, 151.22533759, 138.22533759, 126.76806539, 143.4835584 , 122.4835584 , 139.53138778, 136.284507 , 139.52200771, 157.80692761, 170.78899058, 143.4030509 , 140.18132217, 142.85053013, 149.98330168, 119.41459602, 131.95278862, 151.53953184, 136.13926399, 149.11648208, 137.45036686, 128.77187935, 153.85094303, 139.09236094, 149.55355168, 121.28832096, 120.79321745, 135.08957788, 150.72219325, 140.31594774, 136.14101613, 124.21554462, 145.5482939 , 144.61302941, 142.36388035, 122.24667569, 135.31213242, 154.73095531, 148.56891076, 128.30058731, 135.07483816, 156.13895431, 129.26935437, 133.91258581, 133.84919089, 139.02133809, 148.8397076 , 141.87867169, 137.05319039, 159.63230568, 115.51139163, 149.07854755, 138.18606382, 137.24976842, 120.80239106, 148.53881061, 154.68343425, 140.94041905, 134.90877185, 126.05628312, 162.96299315, 149.83300735, 141.10122623, 123.34841805, 143.29161879, 145.3312036 , 131.10431896, 141.38078512, 131.77620945, 127.98433124, 151.41573015, 143.20709223, 152.43139891, 151.98536215, 147.22533759, 134.09071202, 140.82424529, 147.66034402, 142.50747309, 150.93392526, 117.29244325, 144.84682074, 133.60818454, 147.92990348, 129.55932424, 137.46428212, 137.03628427, 164.29780425, 135.10864906, 145.63642933, 126.13132639, 141.39181546, 133.05319039, 142.12565705, 134.93990291, 126.59241391, 135.55478769, 160.86867361, 115.66931254, 129.72940962, 143.29512307, 152.55179954, 146.50262821, 137.69673287, 128.86052955, 126.22533759, 134.31831789, 137.73466605, 133.84166619, 147.56901264, 143.8814561 , 158.09947409, 134.0069067 , 151.75517968, 153.3512011 , 136.51664806, 127.58973272, 137.02638942, 153.76249793, 124.53613078, 138.13926399, 152.47685815, 155.64900535, 160.27244575, 162.58385694, 156.35037664, 158.19915463, 164.29718625, 140.10555632, 152.24038699, 146.10555632, 136.6481809 , 143.74260366, 160.13926399, 179.31306011, 150.2212153 , 150.7400257 , 158.42707017, 140.59663942, 132.42449222, 155.44139699, 169.65488114, 146.41861643, 153.15524243, 137.04298586, 163.6220998 , 147.71044303, 169.05906618, 144.6001437 , 144.81022544, 150.62869817, 191.72064756, 151.05319039, 138.05319039, 149.05319039, 128.9018665 , 149.60519503, 150.34377827, 155.83960437, 168.00907174, 160.78641398, 157.98371188, 175.42232853, 138.35017019, 153.97969146, 175.48809494, 161.35017019, 142.71023658, 130.97433181, 147.39882538, 174.7075554 , 154.69446459, 150.3213074 , 128.51695638, 163.5795282 , 166.16812678, 158.68054797, 167.19998044, 176.77703255, 150.20049522, 149.39346438, 172.53911893, 151.5076809 , 140.78692876, 152.18018803, 164.02247223, 135.21513171, 139.08390855, 121.50819567, 155.01628676, 157.94866498, 132.86475642, 154.41377156, 152.13926399, 175.38119803, 142.31141119, 143.93206853, 146.56994168, 137.95330204, 163.58499243, 139.51675128, 166.5235534 , 159.17060151, 163.24007867, 162.34800514, 156.57148736, 175.39934016, 170.66673594, 145.74548993, 169.01669832, 164.43768761, 153.30584509, 145.31141119, 136.02958402, 167.22348222, 176.2526547 , 140.16699265, 154.88104319, 156.9412435 , 154.36645695, 161.77095167, 156.11524607, 162.33542911, 154.34243903, 171.12411136, 154.34171645, 164.46582781, 157.8525933 , 188.77280704, 152.41078205, 172.49242369, 143.97412536, 190.80125828, 142.87846659, 156.4392333 , 158.58365049, 176.14740805, 147.43108924, 175.09823672, 167.21461693, 171.26564363, 161.31141119, 158.30141177, 152.48283716, 154.07463171, 153.31171952, 176.09607303, 167.50458681, 171.33285251, 166.67714692, 154.69817533, 174.94454133, 164.70889599, 171.10751492, 167.88104319, 155.7241532 , 154.82558452, 159.13699572, 166.3561492 , 166.00958652, 171.53561465, 192.35501506, 172.10524665, 156.80136151, 175.3146058 , 152.52716226, 168.15410829, 154.22533759, 142.26368368, 156.1869915 , 164.06277691, 154.89609259, 172.37831175, 170.9849506 , 157.77713578, 195.69518582, 161.74590284, 153.79249622, 157.99288685, 166.24152113, 187.81826628, 148.09978377, 190.0987515 , 185.85218175, 161.20863792, 172.05319039, 185.5134521 , 173.84455247, 175.5134521 , 188.73518218, 168.00721502, 190.58571366, 200.11658531, 173.5403563 , 170.16555019, 178.50984459, 191.25461329, 174.87867169, 157.45366469, 185.62581189, 180.79795909, 179.9701063 , 191.97309445, 177.47459123, 184.60488535, 181.32336922, 185.2283271 , 164.48417775, 156.62220303, 179.5726215 , 194.13926399, 181.52242062, 175.31254398, 208.85537636, 214.11771945, 175.85238685, 193.44345881, 184.45490206, 180.67302327, 201.88104319, 170.94856175, 171.02278191, 170.75662215, 181.52066847, 167.58818704, 204.82909016, 168.50139085, 178.08731096, 176.44892304, 172.31141119, 207.65745774, 210.55231432, 202.22533759, 185.64014006, 192.46799286, 204.7811562 , 206.42129626, 198.23915098, 184.61550278, 186.31048486, 173.76383852, 171.33604847, 171.95804505, 175.49912393, 194.07524971, 181.58519753, 200.94072737, 182.58519753, 199.25213856, 181.54757267, 186.18255954, 191.13833495, 166.72580211, 194.82651221, 215.49438228, 211.44459295, 174.18771274, 200.35985994, 174.21719489, 187.37274429, 180.70415434, 189.86681825, 186.56994032, 217.53674879, 222.28326963, 212.46933345, 183.11390684, 193.79218518, 187.01391662, 195.76095089, 175.17328269, 169.83115063, 205.21894703, 173.90753584, 199.99711237, 192.48026056, 198.64952013, 210.94041905, 172.62900785, 197.96093133, 238.74971545, 201.84022373, 185.99216562, 184.04226328, 182.3755287 , 231.95299507, 186.34738714, 198.45850957, 193.11895546, 189.90918611, 191.50077149, 167.13926535, 209.57117768, 182.13452099, 205.4491295 , 196.21595752, 198.74806789, 183.38800014, 208.99061993, 201.17678562, 214.70590784, 192.87320881, 173.70106161, 171.52891441, 191.96392083, 196.57746638, 214.66962086, 210.91104147, 210.85887928, 222.07030161, 192.89537271, 203.77785837, 198.06432396, 195.85877606, 189.0374184 , 210.31007196, 209.508504 , 184.24110958, 196.03865441, 206.05525357, 193.21286479])
Normalizing by (that is dividing by) the monitor would introduce correlations between different detector pixels if the monitor has variances. This is because the same monitor bin is applied to many detector bins. Scipp would reject such an operation. To work around this, we drop the variances of the monitor. In practice, we have to carefully examine the uncertainties to find out if they really can be neglected!
[17]:
mon = sc.values(mon)
We intend to normalize each event to the relative monitor counts (compared to the total monitor counts). We use sum
to compute the total monitor counts and obtain the relative counts using division:
[18]:
mon /= mon.sum('wavelength')
The sample data is event data in bins and the monitor is a histogram. Multiplication and division operations for such cases are supported by modifying the weights (values) for each event using the operators of the bins
property, in combination with the sc.lookup
helper, a wrapper for a discrete “function”, given by the monitor:
[19]:
sample_over_mon = sample_lambda.bins / sc.lookup(func=mon, dim='wavelength')
sample_over_mon
[19]:
- spectrum: 24794
- wavelength: 1
- L1()float64m60.0
Values:
array(60.) - L2(spectrum)float64m2.560, 2.556, ..., 4.251, 4.252
Values:
array([2.56027902, 2.55590928, 2.55268677, ..., 4.25113991, 4.25116338, 4.25188 ]) - Ltotal(spectrum)float64m62.560, 62.556, ..., 64.251, 64.252
Values:
array([62.56027902, 62.55590928, 62.55268677, ..., 64.25113991, 64.25116338, 64.25188 ]) - incident_beam()vector3m[ 0. 0. 60.]
Values:
array([ 0., 0., 60.]) - position(spectrum)vector3m[ 1.17451004 -1.01106149 -2.03796699], [ 1.18147634 -0.95946649 -2.05334117], ..., [1.81428985 0.09565841 3.84338287], [1.81375055 0.1499371 3.84269584]
Values:
array([[ 1.17451004, -1.01106149, -2.03796699], [ 1.18147634, -0.95946649, -2.05334117], [ 1.18844265, -0.90787149, -2.06871534], ..., [ 1.81482915, 0.04137972, 3.8440699 ], [ 1.81428985, 0.09565841, 3.84338287], [ 1.81375055, 0.1499371 , 3.84269584]]) - sample_position()vector3m[0. 0. 0.]
Values:
array([0., 0., 0.]) - scattered_beam(spectrum)vector3m[ 1.17451004 -1.01106149 -2.03796699], [ 1.18147634 -0.95946649 -2.05334117], ..., [1.81428985 0.09565841 3.84338287], [1.81375055 0.1499371 3.84269584]
Values:
array([[ 1.17451004, -1.01106149, -2.03796699], [ 1.18147634, -0.95946649, -2.05334117], [ 1.18844265, -0.90787149, -2.06871534], ..., [ 1.81482915, 0.04137972, 3.8440699 ], [ 1.81428985, 0.09565841, 3.84338287], [ 1.81375055, 0.1499371 , 3.84269584]]) - source_position()vector3m[ 0. 0. -60.]
Values:
array([ 0., 0., -60.]) - spectrum(spectrum)int321, 2, ..., 24793, 24794
Values:
array([ 1, 2, 3, ..., 24792, 24793, 24794], dtype=int32) - tof(wavelength [bin-edge])float64µs20.0, 1.669e+04
Values:
array([ 20. , 16694.30078125]) - two_theta(spectrum)float64rad2.491, 2.504, ..., 0.442, 0.442
Values:
array([2.49144445, 2.50372965, 2.51564288, ..., 0.44118918, 0.44157918, 0.44231324]) - wavelength(spectrum, wavelength [bin-edge])float64Å0.001, 1.056, ..., 0.001, 1.028
Values:
array([[0.00126471, 1.05567339], [0.0012648 , 1.05574713], [0.00126486, 1.05580152], ..., [0.00123143, 1.02789183], [0.00123143, 1.02789145], [0.00123141, 1.02787999]])
- (spectrum, wavelength)DataArrayViewbinned data [len=0, len=0, ..., len=0, len=0]
dim='event', content=DataArray( dims=(event: 17926980), data=float64[counts], coords={'tof':float64[µs], 'wavelength':float64[Å]})
Finally, we can plot the data, which needs to be histogrammed before being plotted. By default, .hist()
uses the coordinates of the binned data to define histogram edges, which, in this case, would give a single bin along the 'wavelength'
dimension. For a better representation of the data, we supply a finer binning, yielding a more meaningful figure:
[20]:
sc.plot(sample_over_mon.hist(wavelength=400, dim='wavelength').hist(spectrum=500).transpose())
[20]:
[21]:
del sample_lambda
del sample_over_mon
del sample
del vanadium
From events to histogram#
Note: We are continuing here with data that has not been normalized to the monitors.
We histogram the event data:
[22]:
dspacing = sc.arange(dim='dspacing', start=0.3, stop=2.0, step=0.001, unit='Angstrom')
hist = sc.Dataset(
data={
'sample': dspacing_sample.hist(dspacing=dspacing, dim='dspacing'),
'vanadium': dspacing_vanadium.hist(dspacing=dspacing, dim='dspacing'),
}
)
sc.show(hist['spectrum', 0:3]['dspacing', 0:7])
[23]:
sc.plot(hist['sample'].hist(spectrum=500).transpose())
[23]:
Summing (focussing) and normalizing#
After conversion to 'dspacing'
, generic sum
and /
operations can be used to “focus” and normalize the diffraction data to the vanadium run:
[24]:
summed = sc.sum(hist, 'spectrum')
sc.plot(summed)
[24]:
[25]:
normalized = summed['sample'] / summed['vanadium']
sc.plot(normalized)
[25]:
Focussing with \(\theta\) dependence in event-mode#
The approach used above combines reflections from all crystallographic planes and is therefore of limited use. We can use bin
to focus each of multiple groups of spectra into a distinct output spectrum. Here we define groups based on a range of scattering angles – a simple \(\theta\)-dependent binning. This also demonstrates how we can postpone histogramming until after the focussing step.
[26]:
two_theta = sc.linspace(dim='two_theta', unit='rad', start=0.0, stop=np.pi, num=16)
focussed_sample = dspacing_sample.bin(two_theta=two_theta)
focussed_vanadium = dspacing_vanadium.bin(two_theta=two_theta)
norm = focussed_vanadium.hist(dspacing=dspacing)
Similarly as when normalizing by monitor, we have to drop the variances of the normalization term. Otherwise, the normalization would be broadcast to focussed_sample
which would introduce correlations. In practice, we have to make sure that the uncertainties of the vanadium measurement can be neglected!
[27]:
norm = sc.values(norm)
[28]:
focussed_sample.bins /= sc.lookup(func=norm, dim='dspacing')
normalized = focussed_sample.hist(dspacing=dspacing)
The normalized output looks as follows:
[29]:
normalized.plot(vmin=sc.scalar(0), vmax=sc.scalar(0.4))
[29]:
As a bonus, we can use slicing and a dict-comprehension to quickly create of plot comparing the spectra for different scattering angle bins:
[30]:
# compute centers of theta bins
angle = normalized.coords['two_theta'].values
angle = 0.5 * (angle[1:] + angle[:-1])
results = {
f'{round(angle[group], 3)} rad': normalized['dspacing', 300:500]['two_theta', group]
for group in range(2, 6)
}
sc.plot(results)
[30]: