LSSTApplications  8.0.0.0+107,8.0.0.1+13,9.1+18,9.2,master-g084aeec0a4,master-g0aced2eed8+6,master-g15627eb03c,master-g28afc54ef9,master-g3391ba5ea0,master-g3d0fb8ae5f,master-g4432ae2e89+36,master-g5c3c32f3ec+17,master-g60f1e072bb+1,master-g6a3ac32d1b,master-g76a88a4307+1,master-g7bce1f4e06+57,master-g8ff4092549+31,master-g98e65bf68e,master-ga6b77976b1+53,master-gae20e2b580+3,master-gb584cd3397+53,master-gc5448b162b+1,master-gc54cf9771d,master-gc69578ece6+1,master-gcbf758c456+22,master-gcec1da163f+63,master-gcf15f11bcc,master-gd167108223,master-gf44c96c709
LSSTDataManagementBasePackage
all.h
Go to the documentation of this file.
1 /*
2  * LSST Data Management System
3  * Copyright 2008, 2009, 2010 LSST Corporation.
4  *
5  * This product includes software developed by the
6  * LSST Project (http://www.lsst.org/).
7  *
8  * This program is free software: you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation, either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the LSST License Statement and
19  * the GNU General Public License along with this program. If not,
20  * see <http://www.lsstcorp.org/LegalNotices/>.
21  */
22 
23 /*
24  * Used In Most Places
25  */
26 #include <cmath>
27 #include <vector>
28 
29 #if !defined(NO_AFW)
30 #include "lsst/afw/image/Image.h"
31 #else
32 #include "Image.h"
33 #endif
34 
35 namespace afwImage = lsst::afw::image;
36 
37 struct FittedModel {
38  enum { PEAK = 0, SKY, X0, Y0, SIGMA, NPARAM };
39 
40  enum {
41  BAD_GUESS = -11,
42  TOO_FEW = -12,
43  CHI_SQUARED = -13,
44  RANGE = -14,
45  BAD_WIDTH = -15,
46  LOST = -16,
47  DIAGONAL = -17,
48  BAD_A = -18,
49  CONVERGE = 1,
50  ITERATE = 2,
51  ALMOST = 3,
52  POOR = 4
53  };
54 
55  FittedModel(int status_, std::vector<double> params_, int iter_=0, double flamd_=0, double chnew_=0) :
56  status(status_), params(params_), iter(iter_), flamd(flamd_), chnew(chnew_) { }
57  int status;
58  std::vector<double> params;
59  int iter;
60  double flamd;
61  double chnew;
62 };
63 
64 template<typename PixelT>
65 FittedModel twodg(afwImage::Image<PixelT> const& im, double x0, double y0);
66 
std::vector< double > params
Definition: all.h:58
FittedModel twodg(afwImage::Image< PixelT > const &im, double x0, double y0)
Definition: twodg.cc:456
table::Key< table::Array< Kernel::Pixel > > image
Definition: FixedKernel.cc:117
FittedModel(int status_, std::vector< double > params_, int iter_=0, double flamd_=0, double chnew_=0)
Definition: all.h:55
double chnew
Definition: all.h:61
int status
Definition: all.h:57
Support for 2-D images.
double flamd
Definition: all.h:60
A class to represent a 2-dimensional array of pixels.
Definition: Image.h:415
int iter
Definition: all.h:59