Commit 5be0495
Cache expensive @Property on Fit classes as @cached_property
FitDataset, FitImaging, and FitInterferometer properties like
model_data, residual_map, chi_squared_map, and log_likelihood were
recomputing on every access despite depending only on immutable
constructor args. For Delaunay inversions model_data alone cost
5-20s — downstream properties accessed it redundantly, creating
a cascade of recomputation.
Changed @Property to @functools.cached_property. Safe because Fit
objects are constructed once and never mutated, and none of these
classes use __getstate__ or JAX pytree registration on the Fit
object itself.
Closes PyAutoArray#340
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>1 parent cbdbb69 commit 5be0495
1 file changed
Lines changed: 7 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
19 | 19 | | |
20 | 20 | | |
21 | 21 | | |
| 22 | + | |
22 | 23 | | |
23 | 24 | | |
24 | 25 | | |
| |||
94 | 95 | | |
95 | 96 | | |
96 | 97 | | |
97 | | - | |
| 98 | + | |
98 | 99 | | |
99 | 100 | | |
100 | 101 | | |
| |||
115 | 116 | | |
116 | 117 | | |
117 | 118 | | |
118 | | - | |
| 119 | + | |
119 | 120 | | |
120 | 121 | | |
121 | 122 | | |
| |||
155 | 156 | | |
156 | 157 | | |
157 | 158 | | |
158 | | - | |
| 159 | + | |
159 | 160 | | |
160 | 161 | | |
161 | 162 | | |
| |||
226 | 227 | | |
227 | 228 | | |
228 | 229 | | |
229 | | - | |
| 230 | + | |
230 | 231 | | |
231 | 232 | | |
232 | 233 | | |
| |||
249 | 250 | | |
250 | 251 | | |
251 | 252 | | |
252 | | - | |
| 253 | + | |
253 | 254 | | |
254 | 255 | | |
255 | 256 | | |
| |||
299 | 300 | | |
300 | 301 | | |
301 | 302 | | |
302 | | - | |
| 303 | + | |
303 | 304 | | |
304 | 305 | | |
305 | 306 | | |
| |||
0 commit comments