Changeset 30031 for trunk/psModules/src/objects
- Timestamp:
- Dec 14, 2010, 9:29:23 AM (15 years ago)
- Location:
- trunk/psModules/src/objects
- Files:
-
- 7 edited
-
. (modified) (1 prop)
-
pmPSF_IO.c (modified) (3 diffs)
-
pmPSFtry.h (modified) (2 diffs)
-
pmPSFtryMakePSF.c (modified) (9 diffs)
-
pmPSFtryModel.c (modified) (2 diffs)
-
pmTrend2D.c (modified) (4 diffs)
-
pmTrend2D.h (modified) (1 diff)
Legend:
- Unmodified
- Added
- Removed
-
trunk/psModules/src/objects
-
Property svn:mergeinfo
set to
/branches/eam_branches/ipp-20101103/psModules/src/objects merged eligible /branches/eam_branches/ipp-20101205/psModules/src/objects merged eligible
-
Property svn:mergeinfo
set to
-
trunk/psModules/src/objects/pmPSF_IO.c
r29004 r30031 62 62 #include "pmSourceIO.h" 63 63 64 bool pmPSFmodelReadPSFClump (psMetadata *analysis, psMetadata *header); 65 64 66 bool pmPSFmodelCheckDataStatusForView (const pmFPAview *view, const pmFPAfile *file) 65 67 { … … 851 853 852 854 // read the psf clump data for each region 855 status = false; 853 856 if (roAnalysis) { 854 int nRegions = psMetadataLookupS32 (&status, header, "PSF_CLN"); 855 if (!status) { 856 // read old-style psf clump data 857 858 char regionName[64]; 859 snprintf (regionName, 64, "PSF.CLUMP.REGION.000"); 860 psMetadataAddS32 (roAnalysis, PS_LIST_TAIL, "PSF.CLUMP.NREGIONS", PS_META_REPLACE, "psf clump regions", 1); 861 862 psMetadata *regionMD = psMetadataLookupPtr (&status, roAnalysis, regionName); 863 if (!regionMD) { 864 regionMD = psMetadataAlloc(); 865 psMetadataAddMetadata (roAnalysis, PS_LIST_TAIL, regionName, PS_META_REPLACE, "psf clump region", regionMD); 866 psFree (regionMD); 867 } 868 869 // psf clump data 870 pmPSFClump psfClump; 871 872 psfClump.X = psMetadataLookupF32 (&status, header, "PSF_CLX" ); assert(status); 873 psfClump.Y = psMetadataLookupF32 (&status, header, "PSF_CLY" ); assert(status); 874 psfClump.dX = psMetadataLookupF32 (&status, header, "PSF_CLDX"); assert(status); 875 psfClump.dY = psMetadataLookupF32 (&status, header, "PSF_CLDY"); assert(status); 876 877 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.X", PS_META_REPLACE, "psf clump center", psfClump.X); 878 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.Y", PS_META_REPLACE, "psf clump center", psfClump.Y); 879 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.DX", PS_META_REPLACE, "psf clump center", psfClump.dX); 880 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.DY", PS_META_REPLACE, "psf clump center", psfClump.dY); 881 } else { 882 psMetadataAddS32 (roAnalysis, PS_LIST_TAIL, "PSF.CLUMP.NREGIONS", PS_META_REPLACE, "psf clump regions", nRegions); 883 884 for (int i = 0; i < nRegions; i++) { 885 char key[10]; 886 char regionName[64]; 887 snprintf (regionName, 64, "PSF.CLUMP.REGION.%03d", i); 888 889 psMetadata *regionMD = psMetadataLookupPtr (&status, roAnalysis, regionName); 890 if (!regionMD) { 891 regionMD = psMetadataAlloc(); 892 psMetadataAddMetadata (roAnalysis, PS_LIST_TAIL, regionName, PS_META_REPLACE, "psf clump region", regionMD); 893 psFree (regionMD); 894 } 895 896 // psf clump data 897 pmPSFClump psfClump; 898 899 snprintf (key, 9, "CLX_%03d", i); 900 psfClump.X = psMetadataLookupF32 (&status, header, key); assert(status); 901 snprintf (key, 9, "CLY_%03d", i); 902 psfClump.Y = psMetadataLookupF32 (&status, header, key); assert(status); 903 snprintf (key, 9, "CLDX_%03d", i); 904 psfClump.dX = psMetadataLookupF32 (&status, header, key); assert(status); 905 snprintf (key, 9, "CLDY_%03d", i); 906 psfClump.dY = psMetadataLookupF32 (&status, header, key); assert(status); 907 908 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.X", PS_META_REPLACE, "psf clump center", psfClump.X); 909 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.Y", PS_META_REPLACE, "psf clump center", psfClump.Y); 910 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.DX", PS_META_REPLACE, "psf clump center", psfClump.dX); 911 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.DY", PS_META_REPLACE, "psf clump center", psfClump.dY); 912 } 913 } 857 status = pmPSFmodelReadPSFClump (roAnalysis, header); 858 if (!status) { 859 psMetadataAddS32 (roAnalysis, PS_LIST_TAIL, "PSF.CLUMP.NREGIONS", PS_META_REPLACE, "psf clump regions", 0); 860 } 861 } 862 if (!roAnalysis || !status) { 863 psWarning ("no PSF.CLUMP data available for PSF model"); 914 864 } 915 865 … … 1123 1073 } 1124 1074 1125 // XXX pmPSF to/from Metadata functions were defined for 1.22 and earlier, but were dropped 1075 bool pmPSFmodelReadPSFClump (psMetadata *analysis, psMetadata *header) { 1076 1077 bool status = false;; 1078 1079 int nRegions = psMetadataLookupS32 (&status, header, "PSF_CLN"); 1080 if (!status) { 1081 // read old-style psf clump data 1082 1083 char regionName[64]; 1084 snprintf (regionName, 64, "PSF.CLUMP.REGION.000"); 1085 psMetadata *regionMD = psMetadataLookupPtr (&status, analysis, regionName); 1086 1087 if (!regionMD) { 1088 regionMD = psMetadataAlloc(); 1089 psMetadataAddMetadata (analysis, PS_LIST_TAIL, regionName, PS_META_REPLACE, "psf clump region", regionMD); 1090 psFree (regionMD); 1091 } 1092 1093 // psf clump data 1094 pmPSFClump psfClump; 1095 psfClump.X = psMetadataLookupF32 (&status, header, "PSF_CLX" ); if (!status) return false; 1096 psfClump.Y = psMetadataLookupF32 (&status, header, "PSF_CLY" ); if (!status) return false; 1097 psfClump.dX = psMetadataLookupF32 (&status, header, "PSF_CLDX"); if (!status) return false; 1098 psfClump.dY = psMetadataLookupF32 (&status, header, "PSF_CLDY"); if (!status) return false; 1099 1100 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.X", PS_META_REPLACE, "psf clump center", psfClump.X); 1101 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.Y", PS_META_REPLACE, "psf clump center", psfClump.Y); 1102 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.DX", PS_META_REPLACE, "psf clump center", psfClump.dX); 1103 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.DY", PS_META_REPLACE, "psf clump center", psfClump.dY); 1104 psMetadataAddS32 (analysis, PS_LIST_TAIL, "PSF.CLUMP.NREGIONS", PS_META_REPLACE, "psf clump regions", 1); 1105 } else { 1106 for (int i = 0; i < nRegions; i++) { 1107 char key[10]; 1108 char regionName[64]; 1109 snprintf (regionName, 64, "PSF.CLUMP.REGION.%03d", i); 1110 1111 psMetadata *regionMD = psMetadataLookupPtr (&status, analysis, regionName); 1112 if (!regionMD) { 1113 regionMD = psMetadataAlloc(); 1114 psMetadataAddMetadata (analysis, PS_LIST_TAIL, regionName, PS_META_REPLACE, "psf clump region", regionMD); 1115 psFree (regionMD); 1116 } 1117 1118 // psf clump data 1119 pmPSFClump psfClump; 1120 1121 snprintf (key, 9, "CLX_%03d", i); 1122 psfClump.X = psMetadataLookupF32 (&status, header, key); if (!status) return false; 1123 snprintf (key, 9, "CLY_%03d", i); 1124 psfClump.Y = psMetadataLookupF32 (&status, header, key); if (!status) return false; 1125 snprintf (key, 9, "CLDX_%03d", i); 1126 psfClump.dX = psMetadataLookupF32 (&status, header, key); if (!status) return false; 1127 snprintf (key, 9, "CLDY_%03d", i); 1128 psfClump.dY = psMetadataLookupF32 (&status, header, key); if (!status) return false; 1129 1130 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.X", PS_META_REPLACE, "psf clump center", psfClump.X); 1131 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.Y", PS_META_REPLACE, "psf clump center", psfClump.Y); 1132 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.DX", PS_META_REPLACE, "psf clump center", psfClump.dX); 1133 psMetadataAddF32 (regionMD, PS_LIST_TAIL, "PSF.CLUMP.DY", PS_META_REPLACE, "psf clump center", psfClump.dY); 1134 } 1135 psMetadataAddS32 (analysis, PS_LIST_TAIL, "PSF.CLUMP.NREGIONS", PS_META_REPLACE, "psf clump regions", nRegions); 1136 } 1137 return true; 1138 } -
trunk/psModules/src/objects/pmPSFtry.h
r25754 r30031 100 100 bool pmPSFtryFitEXT (pmPSFtry *psfTry, pmPSFOptions *options, psImageMaskType maskVal, psImageMaskType markVal); 101 101 102 bool pmPSFtryMakePSF ( pmPSFtry *psfTry);102 bool pmPSFtryMakePSF (bool *goodFit, pmPSFtry *psfTry); 103 103 104 104 bool pmPSFtryFitPSF (pmPSFtry *psfTry, pmPSFOptions *options, psImageMaskType maskVal, psImageMaskType markVal); … … 123 123 ); 124 124 125 bool pmPSFFitShapeParams ( pmPSF *psf, psArray *sources, psVector *x, psVector *y, psVector *srcMask);125 bool pmPSFFitShapeParams (bool *goodFit, pmPSF *psf, psArray *sources, psVector *x, psVector *y, psVector *srcMask); 126 126 127 127 float psVectorSystematicError (psVector *residuals, psVector *errors, float clipFraction); -
trunk/psModules/src/objects/pmPSFtryMakePSF.c
r29004 r30031 50 50 Note: some of the array entries may be NULL (failed fits); ignore them. 51 51 *****************************************************************************/ 52 bool pmPSFtryMakePSF ( pmPSFtry *psfTry)52 bool pmPSFtryMakePSF (bool *goodFit, 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 ( psf, psfTry->sources, x, y, srcMask)) {76 if (!pmPSFFitShapeParams (goodFit, psf, psfTry->sources, x, y, srcMask)) { 77 77 psFree(x); 78 78 psFree(y); 79 79 return false; 80 } 81 if (!goodFit) { 82 psWarning ("poor fit to PSF shape parameters for trend order %d, %d, skipping\n", psf->trendNx, psf->trendNy); 83 psFree(x); 84 psFree(y); 85 return true; 80 86 } 81 87 … … 115 121 // the mask is carried from previous steps and updated with this operation 116 122 // the weight is either the flux error or NULL, depending on 'psf->poissonErrorParams' 117 if (!pmTrend2DFit ( trend, srcMask, 0xff, x, y, z, NULL)) {123 if (!pmTrend2DFit (goodFit, trend, srcMask, 0xff, x, y, z, NULL)) { 118 124 psError(PS_ERR_UNKNOWN, false, "failed to build psf model for parameter %d", i); 119 125 psFree(x); … … 122 128 return false; 123 129 } 130 if (!goodFit) { 131 // if we do not get a good fit (but do not actually hit an error), 132 // tell the calling program to try something else 133 psWarning ("poor fit to PSF parameter %d for trend order %d, %d, skipping\n", i, psf->trendNx, psf->trendNy); 134 psFree(x); 135 psFree(y); 136 psFree(z); 137 return true; 138 } 124 139 if (trend->mode == PM_TREND_MAP) { 125 140 // p_psImagePrint (2, trend->map->map, "param N Before"); // XXX TEST: … … 163 178 164 179 // fit the shape parameters using the supplied order (pmPSF->trendNx,trendNy) 165 bool pmPSFFitShapeParams ( pmPSF *psf, psArray *sources, psVector *x, psVector *y, psVector *srcMask) {180 bool pmPSFFitShapeParams (bool *goodFit, pmPSF *psf, psArray *sources, psVector *x, psVector *y, psVector *srcMask) { 166 181 167 182 // we are doing a robust fit. after each pass, we drop points which are more deviant than … … 219 234 trend = psf->params->data[PM_PAR_E0]; 220 235 trend->stats->clipIter = 1; // in allocation, this value is set to the value of nIter, but we should use 1 here 221 status &= pmTrend2DFit (trend, srcMask, 0xff, x, y, e0, NULL); 236 status &= pmTrend2DFit (goodFit, trend, srcMask, 0xff, x, y, e0, NULL); 237 if (!goodFit) { 238 psFree (e0); 239 psFree (e1); 240 psFree (e2); 241 return true; 242 } 222 243 mean = psStatsGetValue (trend->stats, meanOption); 223 244 stdev = psStatsGetValue (trend->stats, stdevOption); … … 228 249 trend = psf->params->data[PM_PAR_E1]; 229 250 trend->stats->clipIter = 1; // in allocation, this value is set to the value of nIter, but we should use 1 here 230 status &= pmTrend2DFit (trend, srcMask, 0xff, x, y, e1, NULL); 251 status &= pmTrend2DFit (goodFit, trend, srcMask, 0xff, x, y, e1, NULL); 252 if (!goodFit) { 253 psFree (e0); 254 psFree (e1); 255 psFree (e2); 256 return true; 257 } 231 258 mean = psStatsGetValue (trend->stats, meanOption); 232 259 stdev = psStatsGetValue (trend->stats, stdevOption); … … 237 264 trend = psf->params->data[PM_PAR_E2]; 238 265 trend->stats->clipIter = 1; // in allocation, this value is set to the value of nIter, but we should use 1 here 239 status &= pmTrend2DFit (trend, srcMask, 0xff, x, y, e2, NULL); 266 status &= pmTrend2DFit (goodFit, trend, srcMask, 0xff, x, y, e2, NULL); 267 if (!goodFit) { 268 psFree (e0); 269 psFree (e1); 270 psFree (e2); 271 return true; 272 } 240 273 mean = psStatsGetValue (trend->stats, meanOption); 241 274 stdev = psStatsGetValue (trend->stats, stdevOption); … … 246 279 if (!status) { 247 280 psError (PS_ERR_UNKNOWN, true, "failed to fit PSF shape params"); 281 psFree (e0); 282 psFree (e1); 283 psFree (e2); 248 284 return false; 249 285 } -
trunk/psModules/src/objects/pmPSFtryModel.c
r29004 r30031 136 136 137 137 // stage 2: construct a psf (pmPSF) from this collection of model fits, including the 2D variation 138 if (!pmPSFtryMakePSF (psfTry)) { 138 bool goodFit = false; 139 if (!pmPSFtryMakePSF (&goodFit, psfTry)) { 139 140 psError(PS_ERR_UNKNOWN, false, "failed to construct a psf model from collection of sources"); 140 141 psFree(psfTry); 141 142 return NULL; 142 143 } 144 if (!goodFit) { 145 psWarning ("poor psf fit for order %d, skipping\n", i); 146 continue; 147 } 143 148 144 149 // stage 3: refit with fixed shape parameters, measure pmPSFtry->metric … … 169 174 } 170 175 psFree (srcMask); 176 177 if (!minPSF) { 178 psError(PS_ERR_UNKNOWN, false, "failed to construct a valid psf model from the sources"); 179 psFree(psfTry); 180 return NULL; 181 } 171 182 172 183 // keep the ones matching the min systematic error: -
trunk/psModules/src/objects/pmTrend2D.c
r25754 r30031 179 179 } 180 180 181 bool pmTrend2DFit( pmTrend2D *trend, psVector *mask, psVectorMaskType maskVal, const psVector *x,181 bool pmTrend2DFit(bool *goodFit, pmTrend2D *trend, psVector *mask, psVectorMaskType maskVal, const psVector *x, 182 182 const psVector *y, const psVector *f, const psVector *df) 183 183 { … … 188 188 PS_ASSERT_VECTOR_NON_NULL(f, false); 189 189 190 bool status; 190 bool status = false; 191 *goodFit = false; 192 // for the psImageMap fit, it is possible to have valid data but no valid solution for 193 // example, an isolated cell may not be reached from other cells, making the solution 194 // degenerate. psImageMapFit should probably handle this case, but until it does, we allow 195 // it to fail on the result, but not yield an error (goodFit = false). 196 // psVectorClipFitPolynomial2D can not fail in this way (really?), so goodFit is always 197 // true 198 191 199 switch (trend->mode) { 192 200 case PM_TREND_POLY_ORD: … … 196 204 // of points in the image, and potentially based on the fractional range of the 197 205 // data? 206 *goodFit = true; 198 207 break; 199 208 … … 201 210 // XXX supply fraction from trend elements 202 211 // XXX need to add the API which adjusts the scale 203 status = psImageMapClipFit( trend->map, trend->stats, mask, maskVal, x, y, f, df);212 status = psImageMapClipFit(goodFit, trend->map, trend->stats, mask, maskVal, x, y, f, df); 204 213 break; 205 214 -
trunk/psModules/src/objects/pmTrend2D.h
r29004 r30031 76 76 ); 77 77 78 bool pmTrend2DFit(pmTrend2D *trend, 78 bool pmTrend2DFit(bool *goodFit, 79 pmTrend2D *trend, 79 80 psVector *mask, // Warning: mask is modified! 80 81 psVectorMaskType maskVal,
Note:
See TracChangeset
for help on using the changeset viewer.
