LSST Applications 27.0.0,g0265f82a02+469cd937ee,g02d81e74bb+21ad69e7e1,g1470d8bcf6+cbe83ee85a,g2079a07aa2+e67c6346a6,g212a7c68fe+04a9158687,g2305ad1205+94392ce272,g295015adf3+81dd352a9d,g2bbee38e9b+469cd937ee,g337abbeb29+469cd937ee,g3939d97d7f+72a9f7b576,g487adcacf7+71499e7cba,g50ff169b8f+5929b3527e,g52b1c1532d+a6fc98d2e7,g591dd9f2cf+df404f777f,g5a732f18d5+be83d3ecdb,g64a986408d+21ad69e7e1,g858d7b2824+21ad69e7e1,g8a8a8dda67+a6fc98d2e7,g99cad8db69+f62e5b0af5,g9ddcbc5298+d4bad12328,ga1e77700b3+9c366c4306,ga8c6da7877+71e4819109,gb0e22166c9+25ba2f69a1,gb6a65358fc+469cd937ee,gbb8dafda3b+69d3c0e320,gc07e1c2157+a98bf949bb,gc120e1dc64+615ec43309,gc28159a63d+469cd937ee,gcf0d15dbbd+72a9f7b576,gdaeeff99f8+a38ce5ea23,ge6526c86ff+3a7c1ac5f1,ge79ae78c31+469cd937ee,gee10cc3b42+a6fc98d2e7,gf1cff7945b+21ad69e7e1,gfbcc870c63+9a11dc8c8f
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Static Public Attributes | Protected Attributes | Static Protected Attributes | List of all members
lsst.pipe.tasks.dataFrameActions._baseDataFrameActions.DataFrameAction Class Reference
Inheritance diagram for lsst.pipe.tasks.dataFrameActions._baseDataFrameActions.DataFrameAction:
lsst.pex.config.configurableActions._configurableAction.ConfigurableAction lsst.pex.config.config.Config lsst.pex.config.config.ConfigMeta lsst.pipe.tasks.dataFrameActions._actions.AddColumn lsst.pipe.tasks.dataFrameActions._actions.MultiColumnAction lsst.pipe.tasks.dataFrameActions._actions.SingleColumnAction lsst.pipe.tasks.dataFrameActions._actions.CoordColumn lsst.pipe.tasks.dataFrameActions._actions.MagColumnDN lsst.pipe.tasks.dataFrameActions._actions.MagColumnNanoJansky lsst.pipe.tasks.dataFrameActions._actions.NanoJansky lsst.pipe.tasks.dataFrameActions._actions.NanoJanskyErr

Public Member Functions

None __init_subclass__ (cls, **kwargs)
 
Iterable[Any] __call__ (self, dataFrame, **kwargs)
 
Iterable[str] columns (self)
 

Static Public Attributes

 cache
 
 cacheArgs
 

Protected Attributes

 _actionCache
 

Static Protected Attributes

Mapping _actionCache [int, Any]
 

Detailed Description

Definition at line 11 of file _baseDataFrameActions.py.

Member Function Documentation

◆ __call__()

Iterable[Any] lsst.pipe.tasks.dataFrameActions._baseDataFrameActions.DataFrameAction.__call__ ( self,
dataFrame,
** kwargs )
This method should return the result of an action performed on a
dataframe

Reimplemented from lsst.pex.config.configurableActions._configurableAction.ConfigurableAction.

Reimplemented in lsst.pipe.tasks.dataFrameActions._actions.CoordColumn, lsst.pipe.tasks.dataFrameActions._actions.SingleColumnAction, lsst.pipe.tasks.dataFrameActions._actions.NanoJansky, lsst.pipe.tasks.dataFrameActions._actions.AddColumn, lsst.pipe.tasks.dataFrameActions._actions.NanoJanskyErr, lsst.pipe.tasks.dataFrameActions._actions.MagColumnDN, and lsst.pipe.tasks.dataFrameActions._actions.MagColumnNanoJansky.

Definition at line 47 of file _baseDataFrameActions.py.

47 def __call__(self, dataFrame, **kwargs) -> Iterable[Any]:
48 """This method should return the result of an action performed on a
49 dataframe
50 """
51 raise NotImplementedError("This method should be overloaded in a subclass")
52

◆ __init_subclass__()

None lsst.pipe.tasks.dataFrameActions._baseDataFrameActions.DataFrameAction.__init_subclass__ ( cls,
** kwargs )
Run initialization for every subclass.

Specifically registers the subclass with a YAML representer
and YAML constructor (if pyyaml is available)

Reimplemented from lsst.pex.config.config.Config.

Definition at line 21 of file _baseDataFrameActions.py.

21 def __init_subclass__(cls, **kwargs) -> None:
22 cls._actionCache = {}
23
24 def call_wrapper(function):
25 def inner_wrapper(self, dataFrame, **kwargs):
26 dfId = id(dataFrame)
27 extra = []
28 for name in (self.cacheArgs or tuple()):
29 if name not in kwargs:
30 raise ValueError(f"{name} is not part of call signature and cant be used for "
31 "caching")
32 extra.append(kwargs[name])
33 extra.append(dfId)
34 key = tuple(extra)
35 if self.cache and self._frozen:
36 # look up to see if the value is in cache already
37 if result := self._actionCache.get(key):
38 return result
39 result = function(self, dataFrame, **kwargs)
40 if self.cache and self._frozen:
41 self._actionCache[key] = result
42 return result
43 return inner_wrapper
44 cls.__call__ = call_wrapper(cls.__call__)
45 super().__init_subclass__(**kwargs)
46
table::Key< int > id
Definition Detector.cc:162

◆ columns()

Iterable[str] lsst.pipe.tasks.dataFrameActions._baseDataFrameActions.DataFrameAction.columns ( self)
This property should return an iterable of columns needed by this action

Reimplemented in lsst.pipe.tasks.dataFrameActions._actions.SingleColumnAction, lsst.pipe.tasks.dataFrameActions._actions.MultiColumnAction, lsst.pipe.tasks.dataFrameActions._actions.NanoJanskyErr, and lsst.pipe.tasks.dataFrameActions._actions.AddColumn.

Definition at line 54 of file _baseDataFrameActions.py.

54 def columns(self) -> Iterable[str]:
55 """This property should return an iterable of columns needed by this action
56 """
57 raise NotImplementedError("This method should be overloaded in a subclass")

Member Data Documentation

◆ _actionCache [1/2]

Mapping lsst.pipe.tasks.dataFrameActions._baseDataFrameActions.DataFrameAction._actionCache [int, Any]
staticprotected

Definition at line 12 of file _baseDataFrameActions.py.

◆ _actionCache [2/2]

lsst.pipe.tasks.dataFrameActions._baseDataFrameActions.DataFrameAction._actionCache
protected

Definition at line 22 of file _baseDataFrameActions.py.

◆ cache

lsst.pipe.tasks.dataFrameActions._baseDataFrameActions.DataFrameAction.cache
static
Initial value:
= Field(doc="Controls if the results of this action should be cached,"
" only works on frozen actions",
dtype=bool, default=False)

Definition at line 14 of file _baseDataFrameActions.py.

◆ cacheArgs

lsst.pipe.tasks.dataFrameActions._baseDataFrameActions.DataFrameAction.cacheArgs
static
Initial value:
= ListField(doc="If cache is True, this is a list of argument keys that will be used to "
"compute the cache key in addition to the DataFrameId",
dtype=str, optional=True)

Definition at line 17 of file _baseDataFrameActions.py.


The documentation for this class was generated from the following file: