Skip to content

Commit

Permalink
Support beam spectra in NeXus
Browse files Browse the repository at this point in the history
Uses the unofficial key incident_wavelength_calculated, but otherwise implements nexusformat/definitions#717
  • Loading branch information
phyy-nx committed May 28, 2020
1 parent 4e02a48 commit 1865c2a
Showing 1 changed file with 43 additions and 18 deletions.
61 changes: 43 additions & 18 deletions format/nexus.py
Original file line number Diff line number Diff line change
Expand Up @@ -550,28 +550,53 @@ def load_model(self, index=None):

# Get the items from the NXbeam class
wavelength = self.obj.handle["incident_wavelength"]
wavelength_weights = self.obj.handle.get("incident_wavelength_weights")
if wavelength.shape in (tuple(), (1,)):
wavelength_value = wavelength[()]
elif len(wavelength.shape) == 1:
if wavelength_weights is None:
if index is None:
index = 0
wavelength_value = wavelength[index]
wavelength_value = None
wavelength_weights = self.obj.handle.get("incident_wavelength_weight")
wavelength_calculated = self.obj.handle.get("incident_wavelength_calculated")

if index is None:
index = 0
self.index = index

def get_wavelength(wavelength):
if wavelength.shape in (tuple(), (1,)):
wavelength_value = wavelength[()]
else:
raise NotImplementedError("Spectra not implemented")
wavelength_value = wavelength[index]
wavelength_units = wavelength.attrs["units"]
wavelength_value = float(
convert_units(wavelength_value, wavelength_units, "angstrom")
)
return wavelength_value

if wavelength_calculated is not None:
wavelength_value = get_wavelength(wavelength_calculated)
elif wavelength_weights is None:
wavelength_value = get_wavelength(wavelength)

if wavelength_weights is None:
# Construct the beam model
self.model = Beam(direction=(0, 0, 1), wavelength=wavelength_value)
else:
raise NotImplementedError("Spectra not implemented")
wavelength_units = wavelength.attrs["units"]
self.model = Beam()
self.model.set_direction((0, 0, 1))

# Convert wavelength to Angstroms
wavelength_value = float(
convert_units(wavelength_value, wavelength_units, "angstrom")
)
wavelength_units = wavelength.attrs["units"]

# Construct the beam model
self.index = index
self.model = Beam(direction=(0, 0, 1), wavelength=wavelength_value)
if len(wavelength.shape) > 1:
wavelength = wavelength[index]
wavelength_weights = wavelength_weights[index]

spectrum_wavelengths = convert_units(
wavelength, wavelength_units, "angstrom"
)
spectrum_energies = 12398.4187 / spectrum_wavelengths
spectrum_weights = wavelength_weights
self.model.set_spectrum(spectrum_energies, spectrum_weights)
if wavelength_value:
self.model.set_wavelength(wavelength_value)
else:
self.model.set_wavelength(self.model.get_weighted_wavelength())
return self.model


Expand Down

0 comments on commit 1865c2a

Please sign in to comment.