132def transform(self, *, outOffset=None, outFlipX=False, outFlipY=False):
133 """Transform an amplifier builder (in-place) by applying shifts and
134 flips.
135
136 Parameters
137 ----------
138 outOffset : `lsst.geom.Extent2I`, optional
139 Post-transformation return value for ``self.getRawXYOffset()``.
140 The default is ``(0, 0)``, which shifts the amplifier to its
141 position in the assembled (but still untrimmed) raw image.
142 outFlipX : `bool`, optional
143 Post-transformation return value for ``self.getRawFlipX()``. The
144 default is `False`, which flips the amplifier to its correct
145 X orientation in the assembled raw image.
146 outFlipX : `bool`, optional
147 Post-transformation return value for ``self.getRawFlipY()``. The
148 default is `False`, which flips the amplifier to its correct
149 Y orientation in the assembled raw image.
150
151 Returns
152 -------
153 self : `AmplifierBuilder`
154 Returned to enable method chaining, e.g.
155 ``amplifier.rebuild().transform().finish()``.
156 """
157 if outOffset is None:
158 outOffset = Extent2I(0, 0)
159 bbox = self.getRawBBox()
160 awidth, aheight = bbox.getDimensions()
161
162
163
164 boxMin0 = bbox.getMin()
165 if self.getRawFlipX() != outFlipX:
166 bbox.flipLR(awidth)
167 if self.getRawFlipY() != outFlipY:
168 bbox.flipTB(aheight)
169 shift = boxMin0 - bbox.getMin()
170
171 for bboxName in ("",
172 "HorizontalOverscan",
173 "Data",
174 "VerticalOverscan",
175 "Prescan"):
176 bbox = getattr(self, f"getRaw{bboxName}BBox")()
177 if self.getRawFlipX() != outFlipX:
178 bbox.flipLR(awidth)
179 if self.getRawFlipY() != outFlipY:
180 bbox.flipTB(aheight)
181 bbox.shift(self.getRawXYOffset() + shift - outOffset)
182
183 getattr(self, f"setRaw{bboxName}BBox")(bbox)
184
185
186 outReadoutCorner = self.getReadoutCorner()
187 if self.getRawFlipX() != outFlipX:
188 xFlipMapping = {ReadoutCorner.LL: ReadoutCorner.LR, ReadoutCorner.LR: ReadoutCorner.LL,
189 ReadoutCorner.UR: ReadoutCorner.UL, ReadoutCorner.UL: ReadoutCorner.UR}
190 outReadoutCorner = xFlipMapping[outReadoutCorner]
191 if self.getRawFlipY() != outFlipY:
192 yFlipMapping = {ReadoutCorner.LL: ReadoutCorner.UL, ReadoutCorner.LR: ReadoutCorner.UR,
193 ReadoutCorner.UR: ReadoutCorner.LR, ReadoutCorner.UL: ReadoutCorner.LL}
194 outReadoutCorner = yFlipMapping[outReadoutCorner]
195 if outReadoutCorner != self.getReadoutCorner():
196 self.setReadoutCorner(outReadoutCorner)
197
198
199
200
201 self.setRawXYOffset(outOffset)
202 self.setRawFlipX(outFlipX)
203 self.setRawFlipY(outFlipY)
204 return self