LSST Applications g00d0e8bbd7+8c5ae1fdc5,g013ef56533+603670b062,g083dd6704c+2e189452a7,g199a45376c+0ba108daf9,g1c5cce2383+bc9f6103a4,g1fd858c14a+cd69ed4fc1,g210f2d0738+c4742f2e9e,g262e1987ae+612fa42d85,g29ae962dfc+83d129e820,g2cef7863aa+aef1011c0b,g35bb328faa+8c5ae1fdc5,g3fd5ace14f+5eaa884f2a,g47891489e3+e32160a944,g53246c7159+8c5ae1fdc5,g5b326b94bb+dcc56af22d,g64539dfbff+c4742f2e9e,g67b6fd64d1+e32160a944,g74acd417e5+c122e1277d,g786e29fd12+668abc6043,g87389fa792+8856018cbb,g88cb488625+47d24e4084,g89139ef638+e32160a944,g8d7436a09f+d14b4ff40a,g8ea07a8fe4+b212507b11,g90f42f885a+e1755607f3,g97be763408+34be90ab8c,g98df359435+ec1fa61bf1,ga2180abaac+8c5ae1fdc5,ga9e74d7ce9+43ac651df0,gbf99507273+8c5ae1fdc5,gc2a301910b+c4742f2e9e,gca7fc764a6+e32160a944,gd7ef33dd92+e32160a944,gdab6d2f7ff+c122e1277d,gdb1e2cdc75+1b18322db8,ge410e46f29+e32160a944,ge41e95a9f2+c4742f2e9e,geaed405ab2+0d91c11c6d,w.2025.44
LSST Data Management Base Package
Loading...
Searching...
No Matches
lsst.scarlet.lite.source.Source Class Reference
Inheritance diagram for lsst.scarlet.lite.source.Source:
lsst.scarlet.lite.source.SourceBase

Public Member Functions

 __init__ (self, list[Component] components, dict|None metadata=None)
 
int n_components (self)
 
tuple[int, int]|None center (self)
 
tuple[int, int]|None source_center (self)
 
bool is_null (self)
 
Box bbox (self)
 
tuple bands (self)
 
Image get_model (self, bool use_flux=False)
 
 parameterize (self, Callable parameterization)
 
ScarletSourceData to_data (self)
 
 __str__ (self)
 
 __repr__ (self)
 

Public Attributes

 components = components
 
Image|None flux_weighted_image = None
 
int n_components = 0
 
 is_null
 

Static Public Attributes

dict metadata = None
 

Detailed Description

A container for components associated with the same astrophysical object

A source can have a single component, or multiple components,
and each can be contained in different bounding boxes.

Parameters
----------
components:
    The components contained in the source.

Definition at line 57 of file source.py.

Constructor & Destructor Documentation

◆ __init__()

lsst.scarlet.lite.source.Source.__init__ ( self,
list[Component] components,
dict | None metadata = None )

Definition at line 69 of file source.py.

69 def __init__(self, components: list[Component], metadata: dict | None = None):
70 self.components = components
71 self.flux_weighted_image: Image | None = None
72 self.metadata = metadata
73

Member Function Documentation

◆ __repr__()

lsst.scarlet.lite.source.Source.__repr__ ( self)

Definition at line 183 of file source.py.

183 def __repr__(self):
184 return f"Source(components={repr(self.components)})>"

◆ __str__()

lsst.scarlet.lite.source.Source.__str__ ( self)

Definition at line 180 of file source.py.

180 def __str__(self):
181 return f"Source<{len(self.components)}>"
182

◆ bands()

tuple lsst.scarlet.lite.source.Source.bands ( self)
The bands in the full source model.

Definition at line 118 of file source.py.

118 def bands(self) -> tuple:
119 """The bands in the full source model."""
120 if self.is_null:
121 return ()
122 return self.components[0].bands
123

◆ bbox()

Box lsst.scarlet.lite.source.Source.bbox ( self)
The minimal bounding box to contain all of this sources components

Null sources have a bounding box with shape `(0,0,0)`

Definition at line 105 of file source.py.

105 def bbox(self) -> Box:
106 """The minimal bounding box to contain all of this sources components
107
108 Null sources have a bounding box with shape `(0,0,0)`
109 """
110 if self.n_components == 0:
111 return Box((0, 0))
112 bbox = self.components[0].bbox
113 for component in self.components[1:]:
114 bbox = bbox | component.bbox
115 return bbox
116

◆ center()

tuple[int, int] | None lsst.scarlet.lite.source.Source.center ( self)
The center of the source in the full Blend.

Definition at line 80 of file source.py.

80 def center(self) -> tuple[int, int] | None:
81 """The center of the source in the full Blend."""
82 if not self.is_null and hasattr(self.components[0], "peak"):
83 return self.components[0].peak # type: ignore
84 return None
85

◆ get_model()

Image lsst.scarlet.lite.source.Source.get_model ( self,
bool use_flux = False )
Build the model for the source

This is never called during optimization and is only used
to generate a model of the source for investigative purposes.

Parameters
----------
use_flux:
    Whether to use the re-distributed flux associated with the source
    instead of the component models.

Returns
-------
model:
    The full-color model.

Definition at line 124 of file source.py.

124 def get_model(self, use_flux: bool = False) -> Image:
125 """Build the model for the source
126
127 This is never called during optimization and is only used
128 to generate a model of the source for investigative purposes.
129
130 Parameters
131 ----------
132 use_flux:
133 Whether to use the re-distributed flux associated with the source
134 instead of the component models.
135
136 Returns
137 -------
138 model:
139 The full-color model.
140 """
141 if self.n_components == 0:
142 return 0 # type: ignore
143
144 if use_flux:
145 # Return the redistributed flux
146 # (calculated by scarlet.lite.measure.weight_sources)
147 return self.flux_weighted_image # type: ignore
148
149 model = self.components[0].get_model()
150 for component in self.components[1:]:
151 model = model + component.get_model()
152 return model
153

◆ is_null()

bool lsst.scarlet.lite.source.Source.is_null ( self)
True if the source does not have any components

Definition at line 100 of file source.py.

100 def is_null(self) -> bool:
101 """True if the source does not have any components"""
102 return self.n_components == 0
103

◆ n_components()

int lsst.scarlet.lite.source.Source.n_components ( self)
The number of components in this source

Definition at line 75 of file source.py.

75 def n_components(self) -> int:
76 """The number of components in this source"""
77 return len(self.components)
78

◆ parameterize()

lsst.scarlet.lite.source.Source.parameterize ( self,
Callable parameterization )
Convert the component parameter arrays into Parameter instances

Parameters
----------
parameterization:
    A function to use to convert parameters of a given type into
    a `Parameter` in place. It should take a single argument that
    is the `Component` or `Source` that is to be parameterized.

Definition at line 154 of file source.py.

154 def parameterize(self, parameterization: Callable):
155 """Convert the component parameter arrays into Parameter instances
156
157 Parameters
158 ----------
159 parameterization:
160 A function to use to convert parameters of a given type into
161 a `Parameter` in place. It should take a single argument that
162 is the `Component` or `Source` that is to be parameterized.
163 """
164 for component in self.components:
165 component.parameterize(parameterization)
166

◆ source_center()

tuple[int, int] | None lsst.scarlet.lite.source.Source.source_center ( self)
The center of the source in its local bounding box.

Definition at line 87 of file source.py.

87 def source_center(self) -> tuple[int, int] | None:
88 """The center of the source in its local bounding box."""
89 _center = self.center
90 _origin = self.bbox.origin
91 if _center is not None:
92 center = (
93 _center[0] - _origin[0],
94 _center[1] - _origin[1],
95 )
96 return center
97 return None
98

◆ to_data()

ScarletSourceData lsst.scarlet.lite.source.Source.to_data ( self)
Convert to a `ScarletSourceData` for serialization

Returns
-------
source_data:
    The `ScarletSourceData` representation of this source.

Reimplemented from lsst.scarlet.lite.source.SourceBase.

Definition at line 167 of file source.py.

167 def to_data(self) -> ScarletSourceData:
168 """Convert to a `ScarletSourceData` for serialization
169
170 Returns
171 -------
172 source_data:
173 The `ScarletSourceData` representation of this source.
174 """
175 from .io import ScarletSourceData
176
177 component_data = [c.to_data() for c in self.components]
178 return ScarletSourceData(components=component_data, metadata=self.metadata)
179

Member Data Documentation

◆ components

lsst.scarlet.lite.source.Source.components = components

Definition at line 70 of file source.py.

◆ flux_weighted_image

Image | None lsst.scarlet.lite.source.Source.flux_weighted_image = None

Definition at line 71 of file source.py.

◆ is_null

lsst.scarlet.lite.source.Source.is_null

Definition at line 120 of file source.py.

◆ metadata

dict lsst.scarlet.lite.source.SourceBase.metadata = None
staticinherited

Definition at line 44 of file source.py.

◆ n_components

int lsst.scarlet.lite.source.Source.n_components = 0

Definition at line 102 of file source.py.


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