LSST Applications g0265f82a02+0e5473021a,g02d81e74bb+0dd8ce4237,g1470d8bcf6+3ea6592b6f,g2079a07aa2+86d27d4dc4,g2305ad1205+5ca4c0b359,g295015adf3+d10818ec9d,g2a9a014e59+6f9be1b9cd,g2bbee38e9b+0e5473021a,g337abbeb29+0e5473021a,g3ddfee87b4+703ba97ebf,g487adcacf7+4fa16da234,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+ffa42b374e,g5a732f18d5+53520f316c,g64a986408d+0dd8ce4237,g858d7b2824+0dd8ce4237,g8a8a8dda67+585e252eca,g99cad8db69+d39438377f,g9ddcbc5298+9a081db1e4,ga1e77700b3+15fc3df1f7,ga8c6da7877+f1d96605c8,gb0e22166c9+60f28cb32d,gb6a65358fc+0e5473021a,gba4ed39666+c2a2e4ac27,gbb8dafda3b+e5339d463f,gc120e1dc64+da31e9920e,gc28159a63d+0e5473021a,gcf0d15dbbd+703ba97ebf,gdaeeff99f8+f9a426f77a,ge6526c86ff+889fc9d533,ge79ae78c31+0e5473021a,gee10cc3b42+585e252eca,gf18bd8381d+7268b93478,gff1a9f87cc+0dd8ce4237,w.2024.16
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Public Attributes | List of all members
lsst::jointcal::FastFinder::Iterator Class Reference

Iterator meant to traverse objects within some limiting distance. More...

#include <FastFinder.h>

Public Member Functions

void check () const
 
 Iterator (const FastFinder &f, const Point &where, double maxDist)
 
void operator++ ()
 
stars_element operator* () const
 

Public Attributes

const FastFinderfinder
 
int currentSlice
 
int endSlice
 
double yStart
 
double yEnd
 
pstar current
 
pstar pend
 
pstar null_value
 

Detailed Description

Iterator meant to traverse objects within some limiting distance.

Initializer is beginScan and end condition is (*it == NULL). Used by findClosest & co.

Definition at line 90 of file FastFinder.h.

Constructor & Destructor Documentation

◆ Iterator()

lsst::jointcal::Iterator::Iterator ( const FastFinder & f,
const Point & where,
double maxDist )

Definition at line 180 of file FastFinder.cc.

181 : finder(F), null_value(F.stars.end()) {
182 current = pend = null_value; // does not iterate
183 int startSlice = 0;
184 if (finder.xstep != 0) // means we have several slices
185 {
186 startSlice = std::max(0, int((where.x - maxDist - finder.xmin) / finder.xstep));
187 /* obviously, endSlice (and starSlice) can be negative.
188 This is why slice indices are "int" rather than "unsigned". */
189 endSlice = std::min(int(finder.nslice), int((where.x + maxDist - finder.xmin) / finder.xstep) + 1);
190 } else {
191 startSlice = 0;
192 endSlice = 1;
193 }
194 // beyond limits:
195 if (startSlice >= int(finder.nslice) || endSlice < 0) return;
196 // we are inside in x, so, we setup the y range:
197 yStart = where.y - maxDist;
198 yEnd = where.y + maxDist;
199 /* rather than initializing here, we step back one
200 slice and let "++" do its job */
201 currentSlice = startSlice - 1; // again, this requires "int" slices
202 ++(*this);
203}
T max(T... args)
T min(T... args)

Member Function Documentation

◆ check()

void lsst::jointcal::FastFinder::Iterator::check ( ) const

Definition at line 225 of file FastFinder.cc.

225 {
226 if (current != null_value &&
227 (current < finder.stars.begin() || current >= finder.stars.begin() + finder.count)) {
228 LOGLS_ERROR(_log, "Error in FastFinder " << *current << " " << *(finder.stars.begin()) << ' '
229 << *(finder.stars.begin() + finder.count));
230 }
231}
#define LOGLS_ERROR(logger, message)
Log a error-level message using an iostream-based interface.
Definition Log.h:679
std::vector< std::shared_ptr< const BaseStar > > stars
Definition FastFinder.h:64

◆ operator*()

FastFinder::stars_element lsst::jointcal::Iterator::operator* ( ) const

Definition at line 205 of file FastFinder.cc.

205 {
206 if (current != null_value) return *current;
207 return nullptr;
208}

◆ operator++()

void lsst::jointcal::Iterator::operator++ ( )

Definition at line 210 of file FastFinder.cc.

210 {
211 if (current != pend) {
212 current++;
213 } else
214 do {
215 currentSlice++;
216 if (currentSlice >= endSlice) {
218 return;
219 }
221 } while (current == null_value);
222 check();
223}
void findRangeInSlice(int iSlice, double yStart, double yEnd, pstar &start, pstar &end) const

Member Data Documentation

◆ current

pstar lsst::jointcal::FastFinder::Iterator::current

Definition at line 97 of file FastFinder.h.

◆ currentSlice

int lsst::jointcal::FastFinder::Iterator::currentSlice

Definition at line 93 of file FastFinder.h.

◆ endSlice

int lsst::jointcal::FastFinder::Iterator::endSlice

Definition at line 93 of file FastFinder.h.

◆ finder

const FastFinder& lsst::jointcal::FastFinder::Iterator::finder

Definition at line 92 of file FastFinder.h.

◆ null_value

pstar lsst::jointcal::FastFinder::Iterator::null_value

Definition at line 98 of file FastFinder.h.

◆ pend

pstar lsst::jointcal::FastFinder::Iterator::pend

Definition at line 97 of file FastFinder.h.

◆ yEnd

double lsst::jointcal::FastFinder::Iterator::yEnd

Definition at line 94 of file FastFinder.h.

◆ yStart

double lsst::jointcal::FastFinder::Iterator::yStart

Definition at line 94 of file FastFinder.h.


The documentation for this class was generated from the following files: