LSST Applications g042eb84c57+730a74494b,g04e9c324dd+8c5ae1fdc5,g134cb467dc+1f1e3e7524,g199a45376c+0ba108daf9,g1fd858c14a+fa7d31856b,g210f2d0738+f66ac109ec,g262e1987ae+83a3acc0e5,g29ae962dfc+d856a2cb1f,g2cef7863aa+aef1011c0b,g35bb328faa+8c5ae1fdc5,g3fd5ace14f+a1e0c9f713,g47891489e3+0d594cb711,g4d44eb3520+c57ec8f3ed,g4d7b6aa1c5+f66ac109ec,g53246c7159+8c5ae1fdc5,g56a1a4eaf3+fd7ad03fde,g64539dfbff+f66ac109ec,g67b6fd64d1+0d594cb711,g67fd3c3899+f66ac109ec,g6985122a63+0d594cb711,g74acd417e5+3098891321,g786e29fd12+668abc6043,g81db2e9a8d+98e2ab9f28,g87389fa792+8856018cbb,g89139ef638+0d594cb711,g8d7436a09f+80fda9ce03,g8ea07a8fe4+760ca7c3fc,g90f42f885a+033b1d468d,g97be763408+a8a29bda4b,g99822b682c+e3ec3c61f9,g9d5c6a246b+0d5dac0c3d,ga41d0fce20+9243b26dd2,gbf99507273+8c5ae1fdc5,gd7ef33dd92+0d594cb711,gdab6d2f7ff+3098891321,ge410e46f29+0d594cb711,geaed405ab2+c4bbc419c6,gf9a733ac38+8c5ae1fdc5,w.2025.38
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,
20 std::vector<int> const& group,
21 std::vector<int> const& degree,
22 bool pcexflag
23 )
24{
25 _names = names;
26 int const ndim = names.size();
27 int const ngroup = group.size();
28
29 std::vector<const char *> cnames(ndim);
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
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) {
69 throw LSST_EXCEPT(lsst::pex::exceptions::LengthError,
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
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
T begin(T... args)
T copy(T... args)
T end(T... args)
#define RETURN_IMAGE_FIELD(NAME, CNAME, SIZE)
Definition psfImpl.cc:7
T size(T... args)
T str(T... args)