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
psfexAdaptors.cc File Reference
#include "boost/format.hpp"
#include "lsst/pex/exceptions.h"
#include "lsst/meas/extensions/psfex/Field.hh"
#include "globals.h"
#include "context.h"
#include "prefs.h"
#include "sample.h"

Go to the source code of this file.

Namespaces

namespace  lsst
 
namespace  lsst::meas
 
namespace  lsst::meas::extensions
 
namespace  lsst::meas::extensions::psfex
 

Functions

setstruct * load_samples (char **filenames, int catindex, int ncat, int ext, int next, contextstruct *context)
 
void lsst::meas::extensions::psfex::makeit (std::vector< std::shared_ptr< Field > > &fields_, std::vector< std::shared_ptr< Set > > const &sets)
 

Function Documentation

◆ load_samples()

setstruct * load_samples ( char ** filenames,
int catindex,
int ncat,
int ext,
int next,
contextstruct * context )

Definition at line 14 of file psfexAdaptors.cc.

16{
17 /*
18 * The C version of this is called two ways:
19 * catindex == 0, ncat == ncat Read all catalogues
20 * catindex == c, ncat == 1 Read only catalogue c
21 */
22 setstruct *completeSet = reinterpret_cast<setstruct *>(filenames[catindex + 0]);
23 /*
24 * Make a new set, which may be a subset of the completeSet
25 */
26 setstruct *set = init_set(context);
27 set->fwhm = completeSet->fwhm;
28 for (int i = 0; i != completeSet->vigdim; ++i) {
29 set->vigsize[i] = completeSet->vigsize[i];
30 }
31 for (int i = 0; i != completeSet->ncontext; ++i) {
32 strcpy(set->contextname[i], completeSet->contextname[i]);
33 set->contextoffset[i] = completeSet->contextoffset[i];
34 set->contextscale[i] = completeSet->contextscale[i];
35 }
36 /*
37 * Count how many samples we'll be including
38 */
39 int nsample_keep = 0;
40 for (int i = 0; i != ncat; ++i) {
41 setstruct *s = reinterpret_cast<setstruct *>(filenames[catindex + i]);
42 for (int j = 0; j != completeSet->nsample; ++j) {
43 samplestruct const *samp = s->sample[j];
44 if (ext == ALL_EXTENSIONS || ext == samp->extindex) {
45 ++nsample_keep;
46 }
47 }
48 }
49
50 set->samples_owner = 0;
51 malloc_samples(set, nsample_keep);
52 for (int i = 0; i != ncat; ++i) {
53 setstruct *s = reinterpret_cast<setstruct *>(filenames[catindex + i]);
54 for (int j = 0; j != completeSet->nsample; ++j) {
55 samplestruct *samp = s->sample[j];
56 if (ext == ALL_EXTENSIONS || ext == samp->extindex) {
57 set->sample[set->nsample++] = samp;
58 }
59 }
60 }
61
62 return set;
63}
T strcpy(T... args)