File: examples.rst

package info (click to toggle)
xraydb 4.5.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 50,668 kB
  • sloc: python: 3,317; makefile: 75; sh: 18
file content (570 lines) | stat: -rw-r--r-- 26,522 bytes parent folder | download
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
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
.. _example_calcs:

Example Calculations of X-ray properties of materials
=========================================================

.. _XrayDB Web App (xrayabsorption.org):  https://xraydb.xrayabsorption.org/

.. module:: xraydb
   :noindex:

A few detailed examples of using the `xraydb.sqlite` to calculate the X-ray
properties of materials are presented here.  These all use the functions in the
python `xraydb` module, which is describe in more detail in the next chapter,
:ref:`python_api`.  The examples will explore some aspects of X-ray physics,
but will not give a complete tutorial on the concepts here.  For a good
reference on X-ray physics, see :cite:`AlsNielson_McMorrow2011`.

Many of these calculations are also available at `XrayDB Web App (xrayabsorption.org)`_.



X-ray attenuation by elements
-----------------------------------------------

The XrayDB database tabulates values of the X-ray mass attenuation
coefficient, :math:`\mu/\rho`, for each element.  In most of the X-ray
regime used in materials characterization (say, up to 150 keV), the
photo-electric effect is the main process that causes X-ray attenuation.
When the photo-electric process is dominant, the values for
:math:`\mu/\rho` depends strongly on *Z* of the atom and on X-ray energy
*E*.  In addition to these strong dependencies, sharp increases --
so-called absorption edges -- with be see at energies of bound core
electron levels of atoms.  To illustrate these characteristics, the
following script will plot :math:`\mu/\rho` for selected elements:

.. literalinclude:: ../python/examples/mu_elements.py

.. _fig_mu_depth:

.. figure::  _images/mu_elements.png
    :target: _images/mu_elements.png
    :width: 75%
    :align: center

    X-ray mass attenuation coefficient for C, Cu, and Au.

As you can see in Figure from this figure, the attenuation drops very
strongly with :math:`E` -- approximately as :math:`E^3`. :math:`\mu` also
depends strongly with *Z*, though the sharp absorption edges make this more
complicated.

You can also observe that at relatively high energies for relatively low-Z
elements (such as C above about 20 keV) that the attenuation levels off.
This is because the coherent (Rayleigh) and incoherent (Compton) scattering
processes dominate, so that the photo-electric absorption is no longer the
dominant X-ray scattering process.  This can be illustrated by plotting the
different components of :math:`\mu/\rho` for C, as with the following script:

.. literalinclude:: ../python/examples/mu_components_C.py

which will generate the following plot:

.. _fig_mu_components_C:

.. figure::  _images/mu_components_C.png
    :target: _images/mu_components_C.png
    :width: 75%
    :align: center

    X-ray scattering and attenuation factors for C.

Note that above 20 keV, the photo-electric absorption and incoherent
Compton contributions are about equal, and that the Compton scattering
dominates above 50 keV.  As shown above, the photo-electric scattering will
be much higher for heavier elements. The Rayleigh and Compton scattering
have a much weaker dependence on *Z*, so that the photo-electric process
dominates to higher energies.  Replacing 'C' with 'Fe' in the script above
will generate the following plot:

.. _fig_mu_components_Fe:

.. figure::  _images/mu_components_Fe.png
    :target: _images/mu_components_Fe.png
    :width: 75%
    :align: center

    X-ray scattering and attenuation factors for Fe.

which shows that the Compton scattering reaching about 0.1 to 0.25
:math:`\rm cm^2/gr` for Fe, about the same value as it was for C, while the
photo-electric cross-section dominates past 100 keV.

:math:`\mu` calculations for materials
------------------------------------------

While one can use the above values for :math:`\mu/\rho` to calculate the
attenuation of X-rays by multi-element materials, the :func:`material_mu`
function is available to do the more convenient calculation of the X-ray
absorption coefficient :math:`\mu` in units of 1/cm for a material and
energy value and density (which are known for several common materials).
This gives the length for which X-ray intensity is reduced by a factor of
*e*, and so can be used to calculate the fraction of the X-rays transmitted
through a material of known thickness, as :math:`\exp(-t\mu)` for a
material of thickness *t*.  As a first example, we calculate the the
fraction of X-ray transmitted through 1 mm of the water as a function of
X-ray energy:

.. literalinclude:: ../python/examples/mu_water.py

.. _fig_mu_water:

.. figure::  _images/mu_water.png
    :target: _images/mu_water.png
    :width: 75%
    :align: center

    Fraction of X-rays absorbed and transmitted by water


replacing::

    mu = material_mu('H2O', energy)

with::

    mu = material_mu('CaCO3', energy, density=2.71)

would generate the following plot

.. _fig_mu_calcite:

.. figure::  _images/mu_calcite.png
    :target: _images/mu_calcite.png
    :width: 75%
    :align: center

    Fraction of X-rays absorbed and transmitted by calcite


For many X-ray experiments, selecting the size of a material size so that
its thickness is approximately 1 to 2 absorption length is convenient so
that X-ray scattering and emission can be observed strongly, with neither
all primary and scattered X-rays being absorbed by the material itself, but
also not simply passing through the material without any interaction.  For
example, one can simply do::

  >>> from xraydb import material_mu
  >>> mu_20kev = xraydb.material_mu('CaCO3', 20000, density=2.71)
  >>> print("CaCO3 1/e depth at 20keV = {:.3f} mm".format(10/mu_20kev))
  CaCO3 1/e depth at 20keV = 0.648 mm



X-ray flux calculations for ionization chambers and photodiodes
---------------------------------------------------------------------

Gas-filled ionization chambers are widely used as X-ray detectors. They are
simple to use, inexpensive, and can be highly linear in estimating the
photon flux over many orders of magnitude.  X-rays entering a chamber
filled with an inert gas (typically He, N2, or one of the noble gases, or a
mixture of these) will be partially absorbed by the gas, with the strong
energy dependence shown above.  By adjusting the composition of the gas,
nearly any fraction of the incident X-ray beam can be absorbed at a
particular X-ray energy, making these ideal detectors to sample the
intensity of an X-ray beam incident on a sample, while attenuating only a
fraction of the beam.

Some of the X-rays in the gas will be absorbed by the photo-electric effect
which will *ionize* the gas, generating free electrons and energetic ions.  Te
first ionization event will generate an electron-ion pair with the energy of
the X-ray minus the binding energy of the core electron. The high-energy
electron and ion pair will further ionize other gas molecules.  With an
electric potential (typically on the order of 1 kV /cm) across the plates of
the chamber, a current can be measured that is proportional to the X-ray
energy and fluence of the X-rays.

In addition to the photo-electric absorption, X-rays can be attenuated by gas
molecules in an ion chamber by incoherent (Compton) or coherent (Rayleigh)
scattering processes.  The coherent scattering will not generate any electrons
in the gas, but will elastically scatter X-rays out of the main beam.
Incoherent scattering will generate some current, though not all (and
typically only a small portion) of the incident X-ray energy is given to an
electron to generate a current.  Compton scattering gives a distribution of
energies to the scattered electron depending on the angle of scattering.  The
median energy of electrons generated by Compton scattering X-rays of energy
:math:`E` at 90 degrees will be

.. math::
    E_{median} = E / (1 + m_ec^2 / E)

For X-rays of 10 keV, :math:`E_{median}` is about 192 eV. For 20 keV X-rays,
it will be 750 eV, and for 50 keV X-rays, it will be 4.5 keV.  Because the
angular distribution of Compton scattering is not uniform, these median values
over-estimate the amount of energy transferred to the scattered electron by a
small amount that increases with energy.  The mean energy of the
Compton-scattered electron can be found by integrating the Klein-Nishina
distribution. Since these values depend only on the incident X-ray energy,
these calculations have been done and the values tabulated in the
`Compton_energies` table in the XrayDB sqlite database.

Although the energy transferred to the electron by Compton scattering is much
less than by the photo-electric process the contribution can be important.
This is especially true for low-Z gas molecules such as He and N2 at
relatively high energies (10 keV and above) for which incoherent scattering
becomes much more important than photo-electric absorption, as shown above
for C. That is, for accurate estimates of fluxes from ion chamber currents at
energies about 20 keV or so, the contribution from Compton scattering should
be included.  For photo-diodes (typically made of Si), the Compton scattering
cross-section exceeds the photo-electric cross-section about 56 keV.

Effective Ionization Potentials of gases and semiconductors
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The process of converting the X-ray generated current into X-ray fluence
involves several steps. The energy from a single X-ray-generated
electron is converted into a number of electron-ion pairs given by the
*effective ionization potential* of the gas.  These are reasonably
well-known values (see :cite:`Knoll2010`) that are all between 20 and 40
eV, given in the :ref:`Table of Effective Ionization Potentials
<xray_ionpot_table>`.

.. index:: Table of Effective Ionization Potentials
.. _xray_ionpot_table:

   Table of Effective Ionization Potentials. Many of these are taken from
   :cite:`Knoll2010`, while others appear to come from International Commission
   on Radiation Units & Measurement, Report 31, 1979.  The names given are
   those supported by the functions :func:`ionization_potential` and
   :func:`ionchamber_fluxes`.

           +----------------------+----------------+
           | gas/materia name(s)  | potential (eV) |
           +======================+================+
           | hydrogen, H          |   36.5         |
           +----------------------+----------------+
           | helium, He           |   41.3         |
           +----------------------+----------------+
           | nitrogen, N, N2      |   34.8         |
           +----------------------+----------------+
           | oxygen, O, O2        |   30.8         |
           +----------------------+----------------+
           | neon, Ne             |   35.4         |
           +----------------------+----------------+
           | argon, Ar            |   26.4         |
           +----------------------+----------------+
           | krypton, Kr          |   24.4         |
           +----------------------+----------------+
           | xenon, Xe            |   22.1         |
           +----------------------+----------------+
           | air                  |   33.8         |
           +----------------------+----------------+
           | methane, CH4         |   27.3         |
           +----------------------+----------------+
           | carbondioxide, CO2   |   33.0         |
           +----------------------+----------------+
           | silicon, Si          |    3.68        |
           +----------------------+----------------+
           | germanium, Ge        |    2.97        |
           +----------------------+----------------+

From this table, we can see that the absorption (by photo-electric effect) of 1
X-ray of energy 10 keV will eventually generate about 300 electron-ion pairs.
That is not much current, but if :math:`10^8 \,\rm Hz` X-rays are absorbed per
second, then the current generated will be around 5 nA.  Of course, the
thickness of the gas or more precisely the length of gas under ionizing
potential will have an impact on how much current is generated.  The
photo-current will then be amplified and converted to a voltage using a current
amplifier, and that voltage will then recorded by a number of possible means.
Note that while the ion chamber itself will be linear over many orders of
magnitude of X-ray flux (provided the potential between the plates is high
enough - typically in the 1 kV/cm range to efficiently collect all the charged
particles before the recombine), a current amplifier at a particular setting of
sensitivity will be linear only over a couple orders of magnitude (typically
between output voltage of 0.05 to 5 V).  Because of this, the sensitivity of
the current amplifier used with an ion chamber needs careful attention.

A photo-diode works in much the same way as an ionization chamber.  X-rays
incident on the diode (typically Si or Ge) will be absorbed and generate a
photo-current that can be collected.  Typically PIN diodes are used, and
with a small reverse bias voltage.  Because the electrons do not need to
escape the material but generate a current transported in the
semiconductor, the effective ionization potential is much lower - a few
times the semiconductor band gap instead of a few time the lowest
core-level ionization potential.  The current generated per X-ray will be
larger than for an ion chamber, but still amplified with a current
amplifier in the same way as is used for an ion chamber.  Generally, diodes
are thick enough that they absorb all incident X-rays.


Ion Chamber Flux calculations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The conversion of incident flux at a particular energy to generated current is
not too difficult if considering only the photo-electric effect of a single
gas, but can be somewhat subtle in the more general case.  For the discussion
here, we assume that the potential across the plates of the ion chamber is high
enough to prevent any recombination of charged particles.

For a given gas at an incident X-ray energy :math:`E`, we calculate the total,
photo-electric, incoherent (Compton), and coherent (Rayleigh) values of
:math:`\mu`.  If more than one gas is used, the weighted sum is calculated, so
that we have :math:`\mu_{\rm total}`, :math:`\mu_{\rm photo}`,
:math:`\mu_{\rm incoh}`, and :math:`\mu_{\rm coh}` for the gas in the
chamber or diode material.

The flux transmitted out of the chamber is

.. math::
    I_{\rm trans} = I_0 e^{-t \mu_{\rm total}}

where :math:`t` is the length of the chamber and :math:`I_{0}` is the incident
flux.  These two intensities are the quantity we are most interested in.  The
attenuated flux (in number per second, or Hz) is

.. math::
    I_{\rm atten} = I_0 (1 - e^{-t \mu_{\rm total}})

can be separated into the various source of attenuation as

.. math::
   :nowrap:

   \begin{eqnarray*}
      & I_{\rm photo} & =  I_{\rm atten} \, \mu_{\rm photo} / \mu_{\rm total} \\
      & I_{\rm incoh} & =  I_{\rm atten} \, \mu_{\rm incoh} / \mu_{\rm total} \\
      & I_{\rm coh}   & =  I_{\rm atten} \, \mu_{\rm coh}   / \mu_{\rm total} \\
   \end{eqnarray*}

The photo-electric effect converts all of the X-ray energy into a current of
both electrons and ions using the effective ionization potential above:

.. math::
   C_{\rm photo} = 2 q_e E I_{\rm photo} / V_{\rm eff}

where :math:`q_{e}` is the electron charge (1.6e-19 C), :math:`E` is the incident
X-ray energy (in eV), :math:`I_{\rm photo}` is the flux (in Hz), and
:math:`V_{\rm eff}` is the effective ionization potential for the gas.  The
leading 2 comes because both electrons and ions are typically counted for the
current from an ion chamber.  It is sometimes useful to add a Frisch mesh grid
to collect the slower ions and shunt them so as to not count that portion of
the current, and thereby give the ion chamber a faster time response.  In that
case, the current will be half of the value given above.

The coherent (Rayleigh) scattering produces no electrons, but the incoherent
(Compton) scattering does. The energy of the Compton-scattered electron varies
with both X-ray energy and scattering angle, as does the probability of
scattering. Integrating over all angles gives the mean electron energy, which
we use to obtain the current from the incoherent scattering:

.. math::
   C_{\rm incoh} = 2 q_e E_{\rm mean}  I_{\rm incoh} / V_{\rm eff}

where :math:`E_{\rm mean}` is the mean energy of Compton-scattered
electron (approximately, but slightly less than the :math:`E_{\rm median}`
value above.


The current from an ion_chamber is typically measured as a voltage generated by
a current-to-voltage amplifier. The measured voltage will have a gain or
sensitivity in units of `A/V`.  The goal is typically to calculate the flux
:math:`I_0` from the measured voltage and knowledge of the sensitivity as well
as the gas(es), ion chamber length :math:`t`, and X-ray energy :math:`E`.  The
measured voltage is given by

.. math::
   V  = I_0 ( C_{\rm photo} + C_{\rm incoh} ) / S

where :math:`S` is the amplifier sensitivity in A/V.  From this, :math:`I_0`
and :math:`I_{\rm trans}` can be calculated.


:func:`ionchamber_fluxes`
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The function :func:`ionchamber_fluxes` will calculate X-ray fluxes
for an ion chamber as described above the following inputs:

  * `gas`: the gas, or mixture of gases used or 'Si' or 'Ge' for diodes.
  * `length`: the length of the ion chamber, in cm.
  * `energy`: the X-ray energy, in eV.
  * `volts`: the output voltage of the current amplifier
  * `sensitivity` and `sensitivity_units`: the sensitivity or gain of the
    amplifier used to convert the photo-current to the recorded voltage.
  * `with_compton`:  whether to include the current generated by
    Compton-scattered electrons [True]
  * `both_carriers`:  whether to include the current generated by both positive
    and negative charged particles [True]

The default `sensitivity_units` is 'A/V' but can be set to any of the
common SI prefixes such as 'p', 'pico', 'n', 'nano', :math:`\mu`,
(unicode '03bc'), 'u', 'micro', 'm', or 'milli', so that::


    >>> fluxes = ionchamber_fluxes('N2', volts=1, energy=10000, length=10,
                                   sensitivity=1.e-9)
    >>> fluxes = ionchamber_fluxes('N2', volts=1, energy=10000, length=10,
                                   sensitivity=1, sensitivity_units='nA/V')

will give the same results.

The output from  :func:`ionchamber_fluxes` is a named tuple with 4 fields:

  * `photo`  -  the flux absorbed by the photo-electric effect, in Hz.
  * `incoherent`  -  the flux scattered by the Compton effects, in Hz.
  * `incident` - the flux incident on the ion chamber, in Hz.
  * `transmitted` - the flux beam leaving the ion chamber, in Hz.

As described above, the current in the ion chamber or photo-diode is generated
by electrons and ions produced by both the photo-electric and incoherent or
Compton scattering.  The photo-electric cross-section will dominate for heavy
elements and relatively low X-ray energies, but does not necessarily dominate
at high X-ray energies. The photo-electric cross-section with the incident
X-ray energy and the incoherent cross-section with the ***mean***
Compton-scattering energy, using the calculated and tabulated mean energies of
the Compton-scattered electrons are used to estimate the incident flux from
the photo-current. The total attenuation cross-section, including the coherent
cross-sections, is used to calculate the transmitted flu from the incident
flux.

As an example calculation of ion chamber currents::

   >>> fl = ionchamber_fluxes(gas='nitrogen', volts=1.25, energy=18000,
                                  length=10.0, sensitivity=1.e-6)
   >>> print(f"Incident= {fl.incident:g} Hz, Transmitted flux= {fl.transmitted:g} Hz")
   Incident= 2.2358e+12 Hz, Transmitted flux= 2.214e+12 Hz

It is not uncommon for an ion chamber to be filled with a mixture of 2 or
more gases so as to better control the fraction of X-rays absorbed in a
chamber of fixed length. This can be specified by passing in a dictionary
of gas name and fractional density, as with::

   >>> fl = ionchamber_fluxes(gas={'Kr':0.5, 'Ar': 0.5}, volts=1.25,
                              energy=18000, length=10,
                              sensitivity=1, sensitivity_units='microA/V')
   >>> print(f"Incident= {fl.incident:g} Hz, Transmitted flux= {fl.transmitted:g} Hz")
   Incident= 1.43737e+10 Hz, Transmitted flux= 3.28986e+09 Hz

Finally, the pressure of the gas is sometimes adjusted to alter the
fraction of the beam absorbed.  The calculations here all use the densities
at STP, but changes in gas density will be exactly linear to changing the
length of the ion chamber.


X-ray mirror reflectivities
-------------------------------------------

At very shallow angles of incidence X-rays can be reflected by total
external reflection from a material. The reflectivity can be very high
at relatively low energies and shallow angles, but drops off dramatically
with increasing energy, increasing angle, and decreasing electron density.
Still, this reflectivity is one of the few ways to steer X-ray beams and so
is widely used in synchrotron radiation sources.

The reflectivity can be calculated with the :func:`mirror_reflectivity`
function which takes X-ray energy, incident angle, and mirror material as
arguments.

An example script, comparing the energy-dependence of the reflectivity for
a few common mirror materials is given as

.. literalinclude:: ../python/examples/mirror_comparison.py


.. _fig_mirrors:

.. figure::  _images/mirrors.png
    :target: _images/mirrors.png
    :width: 75%
    :align: center

    X-ray mirror reflectivity at :math:`\theta = 2\mathrm{mrad}` for
    selected mirror surfaces and coatings used for mirrors.



Darwin widths of monochromator crystals
-------------------------------------------

Bragg's law describes X-ray diffraction from crystals as

.. math::
    m \lambda = 2 d \sin(\theta)

where :math:`\lambda` is the X-ray wavelength, :math:`d` the d-spacing of
the crystal lattice plane, :math:`\theta` the incident angle, and :math:`m`
the order of the reflection.  For imperfect crystals, in which the lattice
planes are not stacked perfectly over extended distances, the angular width
of any particular reflection is dominated by the spread in d-spacing and
the mosaicity inherent in the crystal.  For perfect crystals, however, the
angular width of a reflection is dominated by the fact that effectively all
of the X-rays will scatter from the lattice well before any attenuation of
the X-ray beam occurs. This *dynamical* diffraction gives a small but
finite offset from the Bragg angle, and gives a broadened angular width to
reflection.  This is usually called the Darwin width (named for
Charles G. Darwin, grandson of the more famous Charles R. Darwin).  In
addition, the refraction and in particular the absorption effects that give
anomalous scattering (as calculated with :func:`xray_delta_beta`) make the
"rocking curve" of reflected intensity as a function of angle an asymmetric
shape.

All of these effects are included in the :func:`darwin_width` function,
which follows very closely the description from chapter 6.4 in
:cite:`AlsNielson_McMorrow2011`.  The function takes inputs of

  * `energy`: the X-ray energy, in eV.
  * `crystal`: the atomic symbol for the crystal: 'Si', 'Ge', or 'C'. ['Si']
  * `hkl`: a tuple with (h, k, l) of the reflection used. [(1, 1, 1)]
  * `a`: lattice constant [`None` - use nominal value for crystal]
  * `polarization`: `s`, `p`, or `u` to specify the X-ray polarization relative to the crystal [`s`]
  * `m`: the order of the reflection. [1]
  * `ignore_f1`: whether to ignore `f1`. [False]
  * `ignore_f2`: whether to ignore `f2`. [False]

Polarization of `s` should be used for vertically deflecting monochromators
at most synchrotron sources (which will normally be horizontally
polarized), and `p` should be used for horizontally deflecting
monochromators.  For crystals used to analyzed unpolarized X-ray emission,
use `u`, which will give the average of `s` and `p` polarization.

As with :func:`ionchamber_fluxes`, the output here is complicated enough
that it is put into a named `DarwinWidth` tuple that will contain the
following fields:

   * `theta` - the nominal Bragg angle, in rad
   * `theta_offset` - the offset from the nominal Bragg angle, in rad.
   * `theta_width` - estimated angular Darwin width, in rad
   * `theta_fwhm` - estimated FWHM of the angular reflectivity curve, in rad
   * `energy_width` - estimated energy Darwin width, in eV
   * `energy_fwhm` - estimated FWHM energy reflectivity curve, in eV
   * `zeta` -  nd-array of :math:`\zeta = \Delta\lambda/\lambda`.
   * `dtheta`  - nd-array of angles around from Bragg angle, in rad
   * `denergy` -  nd-array of energies around from Bragg energy, in eV
   * `intensity` - nd-array of reflected intensity at `zeta` values.

Here, `dtheta` will be given by :math:`\Delta\theta = \zeta \tan(\theta)`,
and `denergy` will be given by :math:`\Delta{E} = \zeta E`.  All of the
nd-arrays will be the same size, so that plots of reflectivity can be
readily made.  An example usage, printing the predicted energy and angular
widths and plotting the intensity profile or "rocking curve" is

.. literalinclude:: ../python/examples/darwin_widths.py

which will print out values of::

  Darwin Width for Si(111) at 10 keV: 26.96 microrad,  1.34 eV
  Darwin Width for Si(333) at 30 keV:  1.81 microrad,  0.27 eV

and generates a plot of

.. _fig_darwin:

.. figure::  _images/darwin_widths.png
    :target: _images/darwin_widths.png
    :width: 75%
    :align: center

    X-ray monochromator diffracted intensities around the Si(111)
    reflection. Here, :math:`i` represents the intensity of a single
    reflection, and :math:`i^2` the intensity from 2 bounces, as for a
    double-crystal monochromator.  The intensity and angular offset of the
    third harmonic is also shown.


Note that the values reported for `theta_fwhm` and `energy_fwhm` will be
about 6% larger than the reported values for `theta_width` and
`energy_width`.  The `width` values closely follow the region of the curve
where the reflectivity ignoring absorption would be 1 - the flat top of the
curve.  Since a double-crystal monochromator will suppress the tails of the
reflectivity, this smaller value is the one typically reported as "the
Darwin width", though some sources will report this smaller value as "FWHM".