Changeset 35768 for trunk/psModules/src/objects/models/pmModel_GAUSS.c
- Timestamp:
- Jul 3, 2013, 2:37:22 PM (13 years ago)
- Location:
- trunk/psModules
- Files:
-
- 2 edited
-
. (modified) (1 prop)
-
src/objects/models/pmModel_GAUSS.c (modified) (7 diffs)
Legend:
- Unmodified
- Added
- Removed
-
trunk/psModules
- Property svn:mergeinfo changed
/branches/eam_branches/ipp-20130509/psModules (added) merged: 35594,35613,35628,35638-35639,35643-35648,35653,35657,35662,35750
- Property svn:mergeinfo changed
-
trunk/psModules/src/objects/models/pmModel_GAUSS.c
r35560 r35768 129 129 float q2 = NAN; 130 130 if (nParam == PM_PAR_SXY) { 131 float f1 = 1.0 / PS_SQR(params[PM_PAR_SYY]) + 1.0 / PS_SQR(params[PM_PAR_SXX]); 132 float f2 = 1.0 / PS_SQR(params[PM_PAR_SYY]) - 1.0 / PS_SQR(params[PM_PAR_SXX]); 131 // NOTE: the factor of 2 is needed to convert par[SXX,SYY] to shape.sx,sy 132 float f1 = 2.0 / PS_SQR(params[PM_PAR_SYY]) + 2.0 / PS_SQR(params[PM_PAR_SXX]); 133 float f2 = 2.0 / PS_SQR(params[PM_PAR_SYY]) - 2.0 / PS_SQR(params[PM_PAR_SXX]); 133 134 float q1 = PS_SQR(f1)*AR_RATIO - PS_SQR(f2); 134 135 q1 = (q1 < 0.0) ? 0.0 : q1; … … 200 201 201 202 // set the shape parameters 202 if (!pmModelSetShape(&PAR[PM_PAR_SXX], &PAR[PM_PAR_SXY], &PAR[PM_PAR_SYY], source->moments )) {203 if (!pmModelSetShape(&PAR[PM_PAR_SXX], &PAR[PM_PAR_SXY], &PAR[PM_PAR_SYY], source->moments, false)) { 203 204 return false; 204 205 } … … 219 220 psF64 PM_MODEL_FLUX (const psVector *params) 220 221 { 221 222 psEllipseShape shape;223 224 222 psF32 *PAR = params->data.F32; 225 223 226 shape.sx = PAR[PM_PAR_SXX] / M_SQRT2; 227 shape.sy = PAR[PM_PAR_SYY] / M_SQRT2; 228 shape.sxy = PAR[PM_PAR_SXY]; 224 psEllipseAxes axes; 225 pmModelParamsToAxes (&axes, PAR[PM_PAR_SXX], PAR[PM_PAR_SXY], PAR[PM_PAR_SYY], false); 229 226 230 227 // Area is equivalent to 2 pi sigma^2 231 // axes ratio < 20232 psEllipseAxes axes = psEllipseShapeToAxes (shape, 20.0);233 228 psF64 Area = 2.0 * M_PI * axes.major * axes.minor; 234 229 … … 242 237 psF64 PM_MODEL_RADIUS (const psVector *params, psF64 flux) 243 238 { 244 psEllipseShape shape;245 246 239 psF32 *PAR = params->data.F32; 247 240 … … 253 246 return (1.0); 254 247 255 shape.sx = PAR[PM_PAR_SXX] / M_SQRT2; 256 shape.sy = PAR[PM_PAR_SYY] / M_SQRT2; 257 shape.sxy = PAR[PM_PAR_SXY]; 258 259 psEllipseAxes axes = psEllipseShapeToAxes (shape, 20.0); 248 psEllipseAxes axes; 249 pmModelParamsToAxes (&axes, PAR[PM_PAR_SXX], PAR[PM_PAR_SXY], PAR[PM_PAR_SYY], false); 250 260 251 psF64 radius = axes.major * sqrt (2.0 * log(PAR[PM_PAR_I0] / flux)); 261 252 psAssert (isfinite(radius), "fix this code: radius should not be nan for Io = %f, flux = %f, major = %f (%f, %f, %f)", … … 285 276 } 286 277 287 // the OLD 2D model for SXY actually fitted SXY / (SXX^-2 + SYY^-2); correct here288 // out[PM_PAR_SXY] = pmPSF_SXYtoModel (out);289 290 278 // the 2D PSF model fits polarization terms (E0,E1,E2) 291 279 // convert to shape terms (SXX,SYY,SXY) 292 // XXX user-defined value for limit? 293 if (!pmPSF_FitToModel (out, 0.1)) { 294 // psError(PM_ERR_PSF, false, "Failed to fit object at (r,c) = (%.1f,%.1f)", in[PM_PAR_YPOS], in[PM_PAR_XPOS]); 280 bool useReff = pmModelUseReff (modelPSF->type); 281 if (!pmPSF_FitToModel (out, 0.1, useReff)) { 295 282 psTrace ("psModules.objects", 3, "Failed to fit object at (r,c) = (%.1f,%.1f)", in[PM_PAR_YPOS], in[PM_PAR_XPOS]); 296 283 return false; … … 343 330 // the 2D PSF model fits polarization terms (E0,E1,E2) 344 331 // convert to shape terms (SXX,SYY,SXY) 345 // XXX user-defined value for limit?346 if (!pmPSF_FitToModel (PAR, 0.1 )) {332 bool useReff = pmModelUseReff (model->type); 333 if (!pmPSF_FitToModel (PAR, 0.1, useReff)) { 347 334 psTrace ("psModules.objects", 3, "Failed to fit object at (r,c) = (%.1f,%.1f)", Xo, Yo); 348 335 return false;
Note:
See TracChangeset
for help on using the changeset viewer.
