LSST Applications g0b6bd0c080+a72a5dd7e6,g1182afd7b4+2a019aa3bb,g17e5ecfddb+2b8207f7de,g1d67935e3f+06cf436103,g38293774b4+ac198e9f13,g396055baef+6a2097e274,g3b44f30a73+6611e0205b,g480783c3b1+98f8679e14,g48ccf36440+89c08d0516,g4b93dc025c+98f8679e14,g5c4744a4d9+a302e8c7f0,g613e996a0d+e1c447f2e0,g6c8d09e9e7+25247a063c,g7271f0639c+98f8679e14,g7a9cd813b8+124095ede6,g9d27549199+a302e8c7f0,ga1cf026fa3+ac198e9f13,ga32aa97882+7403ac30ac,ga786bb30fb+7a139211af,gaa63f70f4e+9994eb9896,gabf319e997+ade567573c,gba47b54d5d+94dc90c3ea,gbec6a3398f+06cf436103,gc6308e37c7+07dd123edb,gc655b1545f+ade567573c,gcc9029db3c+ab229f5caf,gd01420fc67+06cf436103,gd877ba84e5+06cf436103,gdb4cecd868+6f279b5b48,ge2d134c3d5+cc4dbb2e3f,ge448b5faa6+86d1ceac1d,gecc7e12556+98f8679e14,gf3ee170dca+25247a063c,gf4ac96e456+ade567573c,gf9f5ea5b4d+ac198e9f13,gff490e6085+8c2580be5c,w.2022.27
LSST Data Management Base Package
Histo4d.h
Go to the documentation of this file.
1// -*- LSST-C++ -*-
2/*
3 * This file is part of jointcal.
4 *
5 * Developed for the LSST Data Management System.
6 * This product includes software developed by the LSST Project
7 * (https://www.lsst.org).
8 * See the COPYRIGHT file at the top-level directory of this distribution
9 * for details of code ownership.
10 *
11 * This program is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation, either version 3 of the License, or
14 * (at your option) any later version.
15 *
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License
22 * along with this program. If not, see <https://www.gnu.org/licenses/>.
23 */
24
25#ifndef LSST_JOINTCAL_HISTO4D_H
26#define LSST_JOINTCAL_HISTO4D_H
27
28namespace lsst {
29namespace jointcal {
30
34public:
35 SparseHisto4d() = default;
36 // obvious meanings. NEntries is used as the size of the primary allocation.
37 SparseHisto4d(int n1, double min1, double max1, int n2, double min2, double max2,
38 int n3, double min3, double max3, int n4, double min4, double max4,
39 int nEntries);
41 void fill(const double x[4]);
43 void fill(double x1, double x2, double x3, double x4);
45 int maxBin(double x[4]);
46
48 void zeroBin(double x[4]);
49
51 void binLimits(const double x[4], int idim, double &xMin, double &xMax) const;
52
54 int getNEntries() const { return _ndata; }
55
56 ~SparseHisto4d() = default;
57
58 // private:
59 int code_value(const double x[4]) const;
60 void inverse_code(int code, double x[4]) const;
61 void sort();
62 void print() const;
63
64private:
65 std::vector<int> _data;
66 int _ndata{};
67 int _dataSize{};
68 int _n[4]{};
69 double _minVal[4]{}, _maxVal[4]{};
70 double _scale[4]{};
71 bool _sorted{};
72};
73} // namespace jointcal
74} // namespace lsst
75
76#endif // LSST_JOINTCAL_HISTO4D_H
double x
A class to histogram in 4 dimensions.
Definition: Histo4d.h:33
void zeroBin(double x[4])
Definition: Histo4d.cc:136
int maxBin(double x[4])
Definition: Histo4d.cc:114
void inverse_code(int code, double x[4]) const
Definition: Histo4d.cc:77
void fill(const double x[4])
Definition: Histo4d.cc:92
void binLimits(const double x[4], int idim, double &xMin, double &xMax) const
return the bin limits of dimension idim (0<=idim<4), around point X.
Definition: Histo4d.cc:151
int code_value(const double x[4]) const
Definition: Histo4d.cc:67
A base class for image defects.