Skip to content

Commit

Permalink
Allow template correlation for spectrum with no uncertainty (#1118)
Browse files Browse the repository at this point in the history
* Allow template correlation for spectrum with no uncertainty

* Add changelog
  • Loading branch information
rosteen authored Jan 16, 2024
1 parent fb5bd08 commit 4723206
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 3 deletions.
3 changes: 3 additions & 0 deletions CHANGES.rst
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ New Features
Bug Fixes
^^^^^^^^^

- ``template_correlate`` no longer errors when used on a ``Spectrum1D`` that lacks an
``uncertainty`` array. [#1118]

Other Changes and Additions
^^^^^^^^^^^^^^^^^^^^^^^^^^^

Expand Down
10 changes: 7 additions & 3 deletions specutils/analysis/correlation.py
Original file line number Diff line number Diff line change
Expand Up @@ -253,8 +253,12 @@ def _normalize(observed_spectrum, template_spectrum):
A float which will normalize the template spectrum's flux so that it
can be compared to the observed spectrum.
"""
unc = observed_spectrum.uncertainty.represent_as(StdDevUncertainty)
num = np.nansum((observed_spectrum.flux*template_spectrum.flux)/(unc.array**2))
denom = np.nansum((template_spectrum.flux/unc.array)**2)
if hasattr(observed_spectrum, "uncertainty") and observed_spectrum.uncertainty is not None:
unc = observed_spectrum.uncertainty.represent_as(StdDevUncertainty)
num = np.nansum((observed_spectrum.flux*template_spectrum.flux)/(unc.array**2))
denom = np.nansum((template_spectrum.flux/unc.array)**2)
else:
num = np.nansum(observed_spectrum.flux*template_spectrum.flux)
denom = np.nansum(template_spectrum.flux**2)

return num/denom
11 changes: 11 additions & 0 deletions specutils/tests/test_correlation.py
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,17 @@ def test_autocorrelation():
maximum = np.argmax(corr)
assert maximum == midpoint

# Test that this works without uncertainty
spec1 = Spectrum1D(spectral_axis=spec_axis,
flux=flux1,
velocity_convention='optical',
rest_value=5020.*u.AA)

corr, lag = correlation.template_correlate(spec1, spec2)

assert corr.unit == u.dimensionless_unscaled
assert lag.unit == u.km / u.s


def test_correlation():
"""
Expand Down

0 comments on commit 4723206

Please sign in to comment.