LSST Applications g00d0e8bbd7+edbf708997,g03191d30f7+9ce8016dbd,g1955dfad08+0bd186d245,g199a45376c+5137f08352,g1fd858c14a+a888a50aa2,g262e1987ae+45f9aba685,g29ae962dfc+1c7d47a24f,g2cef7863aa+73c82f25e4,g35bb328faa+edbf708997,g3fd5ace14f+eed17d2c67,g47891489e3+6dc8069a4c,g53246c7159+edbf708997,g64539dfbff+c4107e45b5,g67b6fd64d1+6dc8069a4c,g74acd417e5+f452e9c21a,g786e29fd12+af89c03590,g7ae74a0b1c+a25e60b391,g7aefaa3e3d+2025e9ce17,g7cc15d900a+2d158402f9,g87389fa792+a4172ec7da,g89139ef638+6dc8069a4c,g8d4809ba88+c4107e45b5,g8d7436a09f+e96c132b44,g8ea07a8fe4+db21c37724,g98df359435+aae6d409c1,ga2180abaac+edbf708997,gac66b60396+966efe6077,gb632fb1845+88945a90f8,gbaa8f7a6c5+38b34f4976,gbf99507273+edbf708997,gca7fc764a6+6dc8069a4c,gd7ef33dd92+6dc8069a4c,gda68eeecaf+7d1e613a8d,gdab6d2f7ff+f452e9c21a,gdbb4c4dda9+c4107e45b5,ge410e46f29+6dc8069a4c,ge41e95a9f2+c4107e45b5,geaed405ab2+e194be0d2b,w.2025.47
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