From 09a3414b83ca8136b8a63d27a3300f2754c09ef8 Mon Sep 17 00:00:00 2001
From: Pey Lian Lim <2090236+pllim@users.noreply.github.com>
Date: Tue, 5 May 2020 20:12:36 -0400
Subject: [PATCH] Refactor filters_to_fft_table internals.
Add NUMPY_LT_1_17 compat.
---
docs/synphot/filter_par.rst | 10 +++++---
synphot/compat.py | 6 +++--
synphot/filter_parameterization/filter_fft.py | 24 ++++++++++++-------
3 files changed, 26 insertions(+), 14 deletions(-)
diff --git a/docs/synphot/filter_par.rst b/docs/synphot/filter_par.rst
index 5883ca69..313d1837 100644
--- a/docs/synphot/filter_par.rst
+++ b/docs/synphot/filter_par.rst
@@ -59,7 +59,7 @@ By default, 10 FFT parameters are returned as complex numbers::
(38.635087381362396-13.02803811279449j)]
.. TODO: Only skipping the fft_pars comparison above because output is very
- different for Numpy 1.16. Unskip it and replace with +FLOAT_CMP when
+ different for NUMPY_LT_1_17. Unskip it and replace with +FLOAT_CMP when
Numpy minversion is 1.17.
It is up to you to decide how to store this data, though storing it in a
@@ -70,15 +70,19 @@ will store the results in a table for you::
>>> from synphot.filter_parameterization import filters_to_fft_table
>>> mapping = {'HST/ACS/HRC/F555W': (bp, None)}
>>> filter_pars_table = filters_to_fft_table(mapping)
- >>> filter_pars_table # doctest: +FLOAT_CMP +ELLIPSIS
+ >>> filter_pars_table # doctest: +SKIP
filter n_lambda ... fft_9
...
- str17 int32 ... complex128
+ str17 int... ... complex128
----------------- -------- ... ---------------------------------------
HST/ACS/HRC/F555W 10000 ... (38.635087381362396-13.02803811279449j)
>>> filter_pars_table.write('my_filter_pars.fits') # doctest: +SKIP
+.. TODO: Only skipping the filter_pars_table comparison above because output
+ is slightly different for NUMPY_LT_1_17. Unskip it and replace with
+ +FLOAT_CMP +ELLIPSIS when Numpy minversion is 1.17.
+
.. _filter_fft_construction:
Reconstructing Filter from FFT
diff --git a/synphot/compat.py b/synphot/compat.py
index c0a23d1e..6c5b2818 100644
--- a/synphot/compat.py
+++ b/synphot/compat.py
@@ -2,6 +2,7 @@
"""Module to handle backward-compatibility."""
import astropy
+import numpy
from astropy.utils.introspection import minversion
try:
@@ -19,8 +20,9 @@
HAS_DUST_EXTINCTION = True
-__all__ = ['ASTROPY_LT_4_1', 'ASTROPY_LT_4_0', 'HAS_SPECUTILS',
- 'HAS_DUST_EXTINCTION']
+__all__ = ['ASTROPY_LT_4_1', 'ASTROPY_LT_4_0', 'NUMPY_LT_1_17',
+ 'HAS_SPECUTILS', 'HAS_DUST_EXTINCTION']
ASTROPY_LT_4_1 = not minversion(astropy, '4.1')
ASTROPY_LT_4_0 = not minversion(astropy, '4.0')
+NUMPY_LT_1_17 = not minversion(numpy, '1.17')
diff --git a/synphot/filter_parameterization/filter_fft.py b/synphot/filter_parameterization/filter_fft.py
index 9e7a73af..909ec889 100644
--- a/synphot/filter_parameterization/filter_fft.py
+++ b/synphot/filter_parameterization/filter_fft.py
@@ -5,6 +5,7 @@
from astropy.modeling.models import custom_model, Sine1D
from astropy.table import Table
+from synphot.compat import NUMPY_LT_1_17
from synphot.models import Empirical1D
from synphot.spectrum import SpectralElement
from synphot.units import validate_quantity
@@ -210,18 +211,23 @@ def filters_to_fft_table(filters_mapping, n_terms=10):
""" # noqa
wave_unit = SpectralElement._internal_wave_unit
-
- fft_table = Table(names=['filter', 'n_lambda', 'lambda_0', 'delta_lambda',
- 'tr_max'] + [f'fft_{i}' for i in range(n_terms)],
- dtype=[np.str, np.int32, np.float32, np.float32,
- np.float32] + [np.complex] * n_terms)
- fft_table['lambda_0'].unit = wave_unit
- fft_table['delta_lambda'].unit = wave_unit
+ colnames = ['filter', 'n_lambda', 'lambda_0', 'delta_lambda',
+ 'tr_max'] + [f'fft_{i}' for i in range(n_terms)]
+ rows = []
for key, (bp, wavelengths) in filters_mapping.items():
n_lambda, lambda_0, delta_lambda, tr_max, fft_pars = filter_to_fft(
bp, wavelengths=wavelengths, n_terms=n_terms)
- fft_table.add_row(tuple(
- [key, n_lambda, lambda_0, delta_lambda, tr_max] + fft_pars))
+ if not NUMPY_LT_1_17:
+ rows.append(tuple(
+ [key, n_lambda, lambda_0, delta_lambda, tr_max] + fft_pars))
+ else: # Numpy 1.16 cannot handle unit here
+ rows.append(tuple(
+ [key, n_lambda, lambda_0.value, delta_lambda.value,
+ tr_max.value] + fft_pars))
+
+ fft_table = Table(rows=rows, names=colnames)
+ fft_table['lambda_0'].unit = wave_unit
+ fft_table['delta_lambda'].unit = wave_unit
return fft_table