Skip to content

Commit

Permalink
adding kepler and tess specific TPF translators
Browse files Browse the repository at this point in the history
  • Loading branch information
bmorris3 committed Dec 20, 2023
1 parent 429888e commit 077e5a3
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 11 deletions.
14 changes: 8 additions & 6 deletions lcviz/parsers.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,13 @@
def light_curve_parser(app, file_obj, data_label=None, show_in_viewer=True, **kwargs):
time_viewer_reference_name = app._jdaviz_helper._default_time_viewer_reference_name

# load a LightCurve or TargetPixelFile object:
cls_with_translator = (
lightkurve.LightCurve,
lightkurve.targetpixelfile.KeplerTargetPixelFile,
lightkurve.targetpixelfile.TessTargetPixelFile
)

# load local FITS file from disk by its path:
if isinstance(file_obj, str) and os.path.exists(file_obj):
if data_label is None:
Expand All @@ -18,12 +25,7 @@ def light_curve_parser(app, file_obj, data_label=None, show_in_viewer=True, **kw
# read the light curve:
light_curve = lightkurve.read(file_obj)

# load a LightCurve object:
elif isinstance(file_obj, lightkurve.LightCurve):
light_curve = file_obj

# load a LightCurve object:
elif isinstance(file_obj, lightkurve.targetpixelfile.KeplerTargetPixelFile):
elif isinstance(file_obj, cls_with_translator):
light_curve = file_obj

# make a data label:
Expand Down
22 changes: 17 additions & 5 deletions lcviz/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,10 @@
from lightkurve import (
LightCurve, KeplerLightCurve, TessLightCurve, FoldedLightCurve
)
from lightkurve.targetpixelfile import KeplerTargetPixelFile, TargetPixelFileFactory
from lightkurve.utils import KeplerQualityFlags
from lightkurve.targetpixelfile import (
KeplerTargetPixelFile, TessTargetPixelFile, TargetPixelFileFactory
)
from lightkurve.utils import KeplerQualityFlags, TessQualityFlags

from astropy import units as u
from astropy.table import QTable
Expand Down Expand Up @@ -287,8 +289,8 @@ def to_object(self, data_or_subset):
return LightCurve(table, **kwargs)


@data_translator(KeplerTargetPixelFile)
class KeplerTPFHandler:
class TPFHandler:
quality_flag_cls = None
tpf_attrs = ['flux', 'flux_bkg', 'flux_bkg_err', 'flux_err']
meta_attrs = [
'cadenceno',
Expand Down Expand Up @@ -443,7 +445,7 @@ def to_object(self, data_or_subset):
if hasattr(tpf, attr) and getattr(getattr(tpf, attr), 'fset', None) is not None:
setattr(tpf, attr, data.meta[attr])

Check warning on line 446 in lcviz/utils.py

View check run for this annotation

Codecov / codecov/patch

lcviz/utils.py#L445-L446

Added lines #L445 - L446 were not covered by tests

tpf.quality_mask = KeplerQualityFlags.create_quality_mask(
tpf.quality_mask = self.quality_flag_cls.create_quality_mask(

Check warning on line 448 in lcviz/utils.py

View check run for this annotation

Codecov / codecov/patch

lcviz/utils.py#L448

Added line #L448 was not covered by tests
quality_array=tpf.hdu[1].data["QUALITY"], bitmask=tpf.quality_bitmask
)

Expand Down Expand Up @@ -482,6 +484,16 @@ class TessLightCurveHandler(LightCurveHandler):
pass


@data_translator(KeplerTargetPixelFile)
class KeplerTPFHandler(TPFHandler):
quality_flag_cls = KeplerQualityFlags


@data_translator(TessTargetPixelFile)
class TessTPFHandler(TPFHandler):
quality_flag_cls = TessQualityFlags


# plugin component filters
def data_not_folded(data):
return data.meta.get('_LCVIZ_EPHEMERIS', None) is None

0 comments on commit 077e5a3

Please sign in to comment.