LSST Applications g013ef56533+63812263fb,g083dd6704c+a047e97985,g199a45376c+0ba108daf9,g1fd858c14a+fde7a7a78c,g210f2d0738+db0c280453,g262e1987ae+abed931625,g29ae962dfc+058d1915d8,g2cef7863aa+aef1011c0b,g35bb328faa+8c5ae1fdc5,g3fd5ace14f+64337f1634,g47891489e3+f459a6810c,g53246c7159+8c5ae1fdc5,g54cd7ddccb+890c8e1e5d,g5a60e81ecd+d9e514a434,g64539dfbff+db0c280453,g67b6fd64d1+f459a6810c,g6ebf1fc0d4+8c5ae1fdc5,g7382096ae9+36d16ea71a,g74acd417e5+c70e70fbf6,g786e29fd12+668abc6043,g87389fa792+8856018cbb,g89139ef638+f459a6810c,g8d7436a09f+1b779678e3,g8ea07a8fe4+81eaaadc04,g90f42f885a+34c0557caf,g97be763408+9583a964dd,g98a1a72a9c+028271c396,g98df359435+530b675b85,gb8cb2b794d+4e54f68785,gbf99507273+8c5ae1fdc5,gc2a301910b+db0c280453,gca7fc764a6+f459a6810c,gd7ef33dd92+f459a6810c,gdab6d2f7ff+c70e70fbf6,ge410e46f29+f459a6810c,ge41e95a9f2+db0c280453,geaed405ab2+e3b4b2a692,gf9a733ac38+8c5ae1fdc5,w.2025.43
LSST Data Management Base Package
Loading...
Searching...
No Matches
component.py
Go to the documentation of this file.
1from __future__ import annotations
2
3from abc import ABC, abstractmethod
4from dataclasses import dataclass
5from typing import ClassVar
6
7from numpy.typing import DTypeLike
8
9from ..component import Component
10from ..observation import Observation
11from .utils import PersistenceError
12
13__all__ = ["ScarletComponentBaseData"]
14
15
16@dataclass(kw_only=True)
18 """Base data for a scarlet component
19
20 Attributes
21 ----------
22 component_registry :
23 A registry of all known component types used for deserialization.
24 component_type :
25 The type of component being stored.
26 version :
27 The schema version of the exact data class.
28 """
29
30 component_registry: ClassVar[dict[str, type[ScarletComponentBaseData]]] = {}
31 component_type: str
32 version: str
33
34 @classmethod
35 def register(cls) -> None:
36 """Register a new component type"""
37 ScarletComponentBaseData.component_registry[cls.component_type] = cls
38
39 @abstractmethod
40 def to_component(self, observation: Observation) -> Component:
41 """Convert the storage data model into a scarlet Component
42
43 Parameters
44 ----------
45 observation :
46 The observation that the component is associated with
47
48 Returns
49 -------
50 component :
51 A scarlet component extracted from persisted data.
52 """
53
54 @abstractmethod
55 def as_dict(self) -> dict:
56 """Return the object encoded into a dict for JSON serialization
57
58 Returns
59 -------
60 result :
61 The object encoded as a JSON compatible dict
62 """
63
64 @staticmethod
65 def from_dict(data: dict, dtype: DTypeLike | None = None) -> ScarletComponentBaseData:
66 """Reconstruct `ScarletComponentBaseData` from JSON compatible
67 dict.
68
69 Parameters
70 ----------
71 data :
72 Dictionary representation of the object
73 dtype :
74 Datatype of the resulting model.
75
76 Returns
77 -------
78 result :
79 The reconstructed object
80 """
81 component_type = data.get("component_type", "factorized")
82 # Fix legacy naming
83 if component_type == "component":
84 component_type = "cube"
85 if component_type not in ScarletComponentBaseData.component_registry:
86 raise PersistenceError(f"Unknown component type: {component_type}")
87 cls = ScarletComponentBaseData.component_registry[component_type]
88 return cls.from_dict(data, dtype=dtype)
Component to_component(self, Observation observation)
Definition component.py:40
ScarletComponentBaseData from_dict(dict data, DTypeLike|None dtype=None)
Definition component.py:65