LSST Applications g00274db5b6+edbf708997,g00d0e8bbd7+edbf708997,g199a45376c+5137f08352,g1fd858c14a+1d4b6db739,g262e1987ae+f4d9505c4f,g29ae962dfc+7156fb1a53,g2cef7863aa+73c82f25e4,g35bb328faa+edbf708997,g3e17d7035e+5b3adc59f5,g3fd5ace14f+852fa6fbcb,g47891489e3+6dc8069a4c,g53246c7159+edbf708997,g64539dfbff+9f17e571f4,g67b6fd64d1+6dc8069a4c,g74acd417e5+ae494d68d9,g786e29fd12+af89c03590,g7ae74a0b1c+a25e60b391,g7aefaa3e3d+536efcc10a,g7cc15d900a+d121454f8d,g87389fa792+a4172ec7da,g89139ef638+6dc8069a4c,g8d7436a09f+28c28d8d6d,g8ea07a8fe4+db21c37724,g92c671f44c+9f17e571f4,g98df359435+b2e6376b13,g99af87f6a8+b0f4ad7b8d,gac66b60396+966efe6077,gb88ae4c679+7dec8f19df,gbaa8f7a6c5+38b34f4976,gbf99507273+edbf708997,gc24b5d6ed1+9f17e571f4,gca7fc764a6+6dc8069a4c,gcc769fe2a4+97d0256649,gd7ef33dd92+6dc8069a4c,gdab6d2f7ff+ae494d68d9,gdbb4c4dda9+9f17e571f4,ge410e46f29+6dc8069a4c,geaed405ab2+e194be0d2b,w.2025.47
LSST Data Management Base Package
Loading...
Searching...
No Matches
blend_base.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 Any, ClassVar
6
7from numpy.typing import DTypeLike
8
9from ..bbox import Box
10from .utils import PersistenceError
11
12__all__ = ["ScarletBlendBaseData"]
13
14
15@dataclass(kw_only=True)
17 """Base data for a scarlet Blend data.
18
19 Attributes
20 ----------
21 blend_registry :
22 A registry of all known blend types used for deserialization.
23 blend_type :
24 The type of blend being stored.
25 metadata :
26 Metadata associated with the blend.
27 version :
28 The schema version of the exact data class.
29 """
30
31 blend_registry: ClassVar[dict[str, type[ScarletBlendBaseData]]] = {}
32 blend_type: str
33 metadata: dict[str, Any] | None = None
34 version: str
35
36 @property
37 @abstractmethod
38 def bbox(self) -> Box:
39 """The bounding box of the blend"""
40
41 @classmethod
42 def register(cls) -> None:
43 """Register a new Blend type"""
44 ScarletBlendBaseData.blend_registry[cls.blend_type] = cls
45
46 @abstractmethod
47 def as_dict(self) -> dict:
48 """Return the object encoded into a dict for JSON serialization
49
50 Returns
51 -------
52 result :
53 The object encoded as a JSON compatible dict
54 """
55
56 @staticmethod
57 def from_dict(data: dict, dtype: DTypeLike | None = None) -> ScarletBlendBaseData:
58 """Reconstruct `ScarletBlendBaseData` from JSON compatible dict.
59
60 Parameters
61 ----------
62 data :
63 Dictionary representation of the object
64 dtype :
65 Datatype of the resulting model.
66
67 Returns
68 -------
69 result :
70 The reconstructed object
71 """
72 # Default to "blend" for backwards compatibility
73 blend_type = data.get("blend_type", "blend")
74
75 if blend_type not in ScarletBlendBaseData.blend_registry:
76 raise PersistenceError(f"Unknown blend type: {blend_type}")
77
78 cls = ScarletBlendBaseData.blend_registry[blend_type]
79 return cls.from_dict(data, dtype=dtype)
ScarletBlendBaseData from_dict(dict data, DTypeLike|None dtype=None)
Definition blend_base.py:57