LSST Applications g0f08755f38+51082c0d4d,g1653933729+a905cd61c3,g168dd56ebc+a905cd61c3,g1a2382251a+29afb38aec,g20f6ffc8e0+51082c0d4d,g217e2c1bcf+ab9ba0d5ca,g28da252d5a+81b6c2f226,g2bbee38e9b+cc7bbd92cc,g2bc492864f+cc7bbd92cc,g32e5bea42b+4321971e9a,g347aa1857d+cc7bbd92cc,g35bb328faa+a905cd61c3,g3a166c0a6a+cc7bbd92cc,g3bd4b5ce2c+e795d60641,g3e281a1b8c+2bff41ced5,g414038480c+4de324692b,g41af890bb2+f80cf72528,g43bc871e57+a73212ffc0,g78460c75b0+4ae99bb757,g80478fca09+dbf4c199e3,g82479be7b0+84a80b86d5,g8365541083+a905cd61c3,g858d7b2824+51082c0d4d,g9125e01d80+a905cd61c3,ga5288a1d22+379478ca77,gb58c049af0+84d1b6ec45,gc28159a63d+cc7bbd92cc,gc5452a3dca+b82ec7cc4c,gcab2d0539d+4a1e53d2eb,gcf0d15dbbd+a702646d8b,gda6a2b7d83+a702646d8b,gdaeeff99f8+686ef0dd99,ge79ae78c31+cc7bbd92cc,gef2f8181fd+c1889b0e42,gf0baf85859+f9edac6842,gf1e97e5484+bcd3814849,gfa517265be+51082c0d4d,gfa999e8aa5+d85414070d,w.2025.01
LSST Data Management Base Package
Loading...
Searching...
No Matches
psfImpl.cc
Go to the documentation of this file.
1// -*- lsst-C++ -*-
2#include "boost/format.hpp"
4#include "lsst/meas/extensions/psfex/psf.hh"
5#include "ndarray.h"
6
7#define RETURN_IMAGE_FIELD(NAME, CNAME, SIZE) \
8 ndarray::Array<float,2,2> \
9 NAME() const \
10 { \
11 ndarray::Array<float,2,2>::Index shape = ndarray::makeVector(SIZE[0], SIZE[1]); \
12 ndarray::Array<float,2,2>::Index strides = ndarray::makeVector(1, SIZE[0]); \
13 \
14 return ndarray::external(impl->CNAME, shape, strides); \
15 }
16
17namespace lsst { namespace meas { namespace extensions { namespace psfex {
18
19Context::Context(std::vector<std::string> const& names,
22 bool pcexflag
23 )
24{
25 _names = names;
26 int const ndim = names.size();
27 int const ngroup = group.size();
28
30 for (int i = 0; i != ndim; ++i) {
31 cnames[i] = names[i].c_str();
32 }
33
34 impl = context_init(const_cast<char **>(&cnames[0]),
35 const_cast<int *>(&group[0]),
36 ndim,
37 const_cast<int *>(&degree[0]),
38 ngroup, (pcexflag ? 1 : 0));
39 _pc_vectors.resize(impl->npc);
40}
41
42Context::~Context() {
43 context_end(impl);
44}
45
46std::vector<double> & Context::getPc(int const i) const
47{
48 if (i < 0 || i >= impl->npc) {
50 s1 << "Index " << i << " is out of range 0.." << impl->npc - 1;
51 throw std::out_of_range(s1.str());
52 }
53 if (_pc_vectors[i].empty()) {
54 _pc_vectors[i].reserve(impl->npc);
55 for (int j = 0; j != impl->npc; ++j) {
56 _pc_vectors[i][j] = impl->pc[i*impl->npc + j];
57 }
58 }
59 return _pc_vectors[i];
60}
61
62/************************************************************************************************************/
63
64void Sample::setVig(ndarray::Array<float,2,2> const& img)
65{
66 int const w = img.getSize<0>(), h = img.getSize<1>();
67
68 if (_vigsize[0]*_vigsize[1] != w*h) {
70 str(boost::format("Expected %dx%d array, but was passed %dx%d")
71 % _vigsize[0] % _vigsize[1] % w % h));
72 }
73
74 ndarray::Array<float,1,1> flattened = ndarray::flatten<1>(img);
75 std::copy(flattened.begin(), flattened.end(), impl->vig);
76}
77
78RETURN_IMAGE_FIELD(Sample::getVig, vig, _vigsize)
79RETURN_IMAGE_FIELD(Sample::getVigResi, vigresi, _vigsize)
80RETURN_IMAGE_FIELD(Sample::getVigChi, vigchi, _vigsize)
81RETURN_IMAGE_FIELD(Sample::getVigWeight, vigweight, _vigsize)
82
83/************************************************************************************************************/
84
85Set::Set(Context &c) {
86 impl = init_set(c.impl);
87 impl->nsample = impl->nsamplemax = 0;
88}
89Set::~Set() {
90 end_set(impl);
91}
92
93Sample
94Set::newSample()
95{
96 if (impl->nsample >= impl->nsamplemax) {
97 if (impl->nsamplemax == 0) {
98 malloc_samples(impl, LSAMPLE_DEFSIZE);
99 } else {
100 realloc_samples(impl, (int)(1.62*impl->nsamplemax + 1));
101 }
102 }
103 return Sample(impl->sample[impl->nsample], _recentroid, impl->vigsize);
104}
105
106void
107Set::trimMemory() const
108{
109 setstruct *mutable_impl = const_cast<setstruct *>(impl);
110 realloc_samples(mutable_impl, impl->nsample);
111}
112
113void
114Set::finiSample(Sample const& sample)
115{
116 ++impl->nsample;
117 make_weights(impl, sample.impl);
118 if (sample._recentroid) {
119 recenter_sample(sample.impl, impl, sample._fluxrad);
120 }
121}
122
123/************************************************************************************************************/
124
125Psf::~Psf() {
126#if 0 // we don't own impl
127 psf_end(impl);
128#endif
129}
130
131void
132Psf::build(double x, double y,
133 std::vector<double> const& other)
134{
135 if (!impl->contextoffset) { // we never set context{offset,scale}
136 throw std::out_of_range("psf.contextoffset not set (probably no valid stars) so I can't index it");
137 }
138
139 std::vector<double> pos(2);
140 pos[0] = x; pos[1] = y;
141
142 pos.insert(pos.end(), other.begin(), other.end());
143
144 for (unsigned int i = 0; i != pos.size(); ++i) {
145 pos[i] = (pos[i] - impl->contextoffset[i])/impl->contextscale[i];
146 }
147
148 psf_build(impl, &pos[0]);
149}
150
151RETURN_IMAGE_FIELD(Psf::getLoc, loc, impl->size)
152RETURN_IMAGE_FIELD(Psf::getResi, resi, impl->size)
153
154}}}}
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition Exception.h:48
int y
Definition SpanSet.cc:48
T begin(T... args)
Reports attempts to exceed implementation-defined length limits for some classes.
Definition Runtime.h:76
T copy(T... args)
T end(T... args)
#define RETURN_IMAGE_FIELD(NAME, CNAME, SIZE)
Definition psfImpl.cc:7
T size(T... args)
double w
Definition CoaddPsf.cc:70
table::Key< int > ndim
Definition PsfexPsf.cc:329
table::Key< int > ngroup
Definition PsfexPsf.cc:330
table::Key< table::Array< int > > degree
Definition PsfexPsf.cc:364
table::Key< table::Array< int > > group
Definition PsfexPsf.cc:363
T str(T... args)