#!/usr/bin/env python # this script requires Python3, numpy, scipy, matplotlib, and xraydb modules. Use: # pip install xraydb matplotlib import numpy as np import matplotlib.pyplot as plt import xraydb # X-ray monochromator Darwin Width calculations # inputs from web form # filename: xrayweb_darwinwidth.py xtal = 'Si' h, k, l = (1, 1, 1) polarization = 's' energy = 10000 dw = xraydb.darwin_width(energy, xtal, (h, k, l), polarization=polarization) print('Mono Angle: %.5f deg' % (dw.theta*180/np.pi)) print('Angular width : %.5f microrad' % (dw.theta_width*1.e6)) print('Rocking Curve width : %.5f microrad' % (dw.rocking_theta_fwhm*1.e6)) print('Energy width : %.5f eV' % (dw.energy_width)) plt.plot(dw.denergy, dw.intensity, label='1 bounce') plt.plot(dw.denergy, dw.rocking_curve, label='rocking curve') plt.xlabel('Energy (eV)') plt.ylabel('reflectivity') plt.legend() plt.title(f'{xtal} {(h, k, l)}, "{polarization}" polar, E={energy} eV') plt.show() plt.plot(dw.dtheta*1e6, dw.intensity, label='1 bounce') plt.plot(dw.dtheta*1e6, dw.rocking_curve, label='rocking curve') plt.xlabel('Angle (microrad)') plt.ylabel('reflectivity') plt.legend() plt.title(f'{xtal} {(h, k, l)}, "{polarization}" polar, E={energy} eV') plt.show()