- Timestamp:
- Dec 17, 2010, 10:08:25 AM (15 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/eam_branches/ipp-20101205/psModules/src/objects/pmPSFtryMakePSF.c
r30029 r30107 50 50 Note: some of the array entries may be NULL (failed fits); ignore them. 51 51 *****************************************************************************/ 52 bool pmPSFtryMakePSF (bool * goodFit, pmPSFtry *psfTry)52 bool pmPSFtryMakePSF (bool *pGoodFit, pmPSFtry *psfTry) 53 53 { 54 54 PS_ASSERT_PTR_NON_NULL(psfTry, false); … … 74 74 75 75 // fit the shape parameters (SXX, SYY, SXY) as a function of position 76 if (!pmPSFFitShapeParams ( goodFit, psf, psfTry->sources, x, y, srcMask)) {76 if (!pmPSFFitShapeParams (pGoodFit, psf, psfTry->sources, x, y, srcMask)) { 77 77 psFree(x); 78 78 psFree(y); 79 79 return false; 80 80 } 81 if (! goodFit) {81 if (!*pGoodFit) { 82 82 psWarning ("poor fit to PSF shape parameters for trend order %d, %d, skipping\n", psf->trendNx, psf->trendNy); 83 83 psFree(x); … … 121 121 // the mask is carried from previous steps and updated with this operation 122 122 // the weight is either the flux error or NULL, depending on 'psf->poissonErrorParams' 123 if (!pmTrend2DFit ( goodFit, trend, srcMask, 0xff, x, y, z, NULL)) {123 if (!pmTrend2DFit (pGoodFit, trend, srcMask, 0xff, x, y, z, NULL)) { 124 124 psError(PS_ERR_UNKNOWN, false, "failed to build psf model for parameter %d", i); 125 125 psFree(x); … … 128 128 return false; 129 129 } 130 if (! goodFit) {130 if (!*pGoodFit) { 131 131 // if we do not get a good fit (but do not actually hit an error), 132 132 // tell the calling program to try something else … … 154 154 155 155 pmModel *modelPSF = pmModelFromPSF (source->modelEXT, psf); 156 if (!modelPSF) { 157 fprintf(f, "modelPSF is NULL\n"); 158 break; 159 } 160 if (!source->modelEXT) { 161 fprintf(f, "source->modelEXT is NULL\n"); 162 break; 163 } 156 164 157 165 fprintf (f, "%f %f : ", source->modelEXT->params->data.F32[PM_PAR_XPOS], source->modelEXT->params->data.F32[PM_PAR_YPOS]); … … 178 186 179 187 // fit the shape parameters using the supplied order (pmPSF->trendNx,trendNy) 180 bool pmPSFFitShapeParams (bool * goodFit, pmPSF *psf, psArray *sources, psVector *x, psVector *y, psVector *srcMask) {188 bool pmPSFFitShapeParams (bool *pGoodFit, pmPSF *psf, psArray *sources, psVector *x, psVector *y, psVector *srcMask) { 181 189 182 190 // we are doing a robust fit. after each pass, we drop points which are more deviant than … … 234 242 trend = psf->params->data[PM_PAR_E0]; 235 243 trend->stats->clipIter = 1; // in allocation, this value is set to the value of nIter, but we should use 1 here 236 status &= pmTrend2DFit ( goodFit, trend, srcMask, 0xff, x, y, e0, NULL);237 if (! goodFit) {244 status &= pmTrend2DFit (pGoodFit, trend, srcMask, 0xff, x, y, e0, NULL); 245 if (!*pGoodFit) { 238 246 psFree (e0); 239 247 psFree (e1); … … 249 257 trend = psf->params->data[PM_PAR_E1]; 250 258 trend->stats->clipIter = 1; // in allocation, this value is set to the value of nIter, but we should use 1 here 251 status &= pmTrend2DFit ( goodFit, trend, srcMask, 0xff, x, y, e1, NULL);252 if (! goodFit) {259 status &= pmTrend2DFit (pGoodFit, trend, srcMask, 0xff, x, y, e1, NULL); 260 if (!*pGoodFit) { 253 261 psFree (e0); 254 262 psFree (e1); … … 264 272 trend = psf->params->data[PM_PAR_E2]; 265 273 trend->stats->clipIter = 1; // in allocation, this value is set to the value of nIter, but we should use 1 here 266 status &= pmTrend2DFit ( goodFit, trend, srcMask, 0xff, x, y, e2, NULL);267 if (! goodFit) {274 status &= pmTrend2DFit (pGoodFit, trend, srcMask, 0xff, x, y, e2, NULL); 275 if (!*pGoodFit) { 268 276 psFree (e0); 269 277 psFree (e1);
Note:
See TracChangeset
for help on using the changeset viewer.
