Changeset 27427 for trunk/ppStack/src/ppStackReadout.c
- Timestamp:
- Mar 23, 2010, 9:02:41 PM (16 years ago)
- File:
-
- 1 edited
-
trunk/ppStack/src/ppStackReadout.c (modified) (8 diffs)
Legend:
- Unmodified
- Added
- Removed
-
trunk/ppStack/src/ppStackReadout.c
r27402 r27427 23 23 psVector *mask = options->inputMask; // Mask for inputs 24 24 psVector *weightings = options->weightings; // Weightings (1/noise^2) for each image 25 psVector *exposures = options->exposures; // Exposure times for each image 25 26 psVector *addVariance = options->matchChi2; // Additional variance when rejecting 26 27 27 28 job->results = ppStackReadoutInitial(config, outRO, thread->readouts, mask, 28 weightings, addVariance);29 weightings, exposures, addVariance); 29 30 thread->busy = false; 30 31 … … 37 38 38 39 psArray *args = job->args; // Arguments 39 pmReadout *target = args->data[0]; // Output readout 40 ppStackThread *thread = args->data[1]; // Thread 41 psArray *reject = args->data[2]; // Rejected pixels for each image 42 ppStackOptions *options = args->data[3]; // Options 43 pmConfig *config = args->data[4]; // Configuration 44 bool safety = PS_SCALAR_VALUE(args->data[5], U8); // Safety switch on? 45 bool normalise = PS_SCALAR_VALUE(args->data[6], U8); // Normalise images? 40 ppStackThread *thread = args->data[0]; // Thread 41 psArray *reject = args->data[1]; // Rejected pixels for each image 42 ppStackOptions *options = args->data[2]; // Options 43 pmConfig *config = args->data[3]; // Configuration 44 bool safety = PS_SCALAR_VALUE(args->data[4], U8); // Safety switch on? 45 bool normalise = PS_SCALAR_VALUE(args->data[5], U8); // Normalise images? 46 46 47 47 psVector *mask = options->inputMask; // Mask for inputs 48 48 psVector *weightings = options->weightings; // Weightings (1/noise^2) for each image 49 psVector *exposures = options->exposures; // Exposure times for each image 49 50 psVector *addVariance = options->matchChi2; // Additional variance when rejecting 50 51 psVector *norm = normalise ? options->norm : NULL; // Normalisations to apply to images 51 52 52 bool status = ppStackReadoutFinal(config, target, thread->readouts, mask, reject,53 weightings, addVariance, safety, norm); // Status of operation53 bool status = ppStackReadoutFinal(config, options->outRO, options->expRO, thread->readouts, mask, reject, 54 weightings, exposures, addVariance, safety, norm); // Status of operation 54 55 55 56 thread->busy = false; 57 58 psAssert(status, "Stacking failed."); 56 59 57 60 return status; … … 101 104 102 105 psArray *ppStackReadoutInitial(const pmConfig *config, pmReadout *outRO, const psArray *readouts, 103 const psVector *mask, const psVector *weightings, const psVector *addVariance) 106 const psVector *mask, const psVector *weightings, const psVector *exposures, 107 const psVector *addVariance) 104 108 { 105 109 assert(config); … … 149 153 } 150 154 151 stack->data[i] = pmStackDataAlloc(ro, weightings->data.F32[i], addVariance->data.F32[i]); 152 } 153 154 if (!pmStackCombine(outRO, stack, maskVal | maskBad, maskSuspect, maskBad, kernelSize, iter, 155 stack->data[i] = pmStackDataAlloc(ro, weightings->data.F32[i], exposures->data.F32[i], 156 addVariance->data.F32[i]); 157 } 158 159 if (!pmStackCombine(outRO, NULL, stack, maskVal | maskBad, maskSuspect, maskBad, kernelSize, iter, 155 160 combineRej, combineSys, combineDiscard, useVariance, safe, false)) { 156 161 psError(PS_ERR_UNKNOWN, false, "Unable to combine input readouts with rejection."); … … 187 192 188 193 189 bool ppStackReadoutFinal(const pmConfig *config, pmReadout *outRO, const psArray *readouts,194 bool ppStackReadoutFinal(const pmConfig *config, pmReadout *outRO, pmReadout *expRO, const psArray *readouts, 190 195 const psVector *mask, const psArray *rejected, const psVector *weightings, 191 const psVector *addVariance, bool safety, const psVector *norm) 196 const psVector *exposures, const psVector *addVariance, bool safety, 197 const psVector *norm) 192 198 { 193 199 assert(config); 194 200 assert(outRO); 201 assert(expRO); 195 202 assert(readouts); 196 203 assert(!rejected || readouts->n == rejected->n); … … 238 245 } 239 246 240 pmStackData *data = pmStackDataAlloc(ro, weightings->data.F32[i], 247 pmStackData *data = pmStackDataAlloc(ro, weightings->data.F32[i], exposures->data.F32[i], 241 248 addVariance ? addVariance->data.F32[i] : NAN); 242 249 data->reject = rejected ? psMemIncrRefCounter(rejected->data[i]) : NULL; … … 250 257 } 251 258 252 if (!pmStackCombine(outRO, stack, maskVal | maskBad, maskSuspect, maskBad, 0, iter, combineRej,259 if (!pmStackCombine(outRO, expRO, stack, maskVal | maskBad, maskSuspect, maskBad, 0, iter, combineRej, 253 260 combineSys, combineDiscard, useVariance, safe, rejected)) { 254 261 psError(PS_ERR_UNKNOWN, false, "Unable to combine input readouts."); … … 259 266 pmCell *outCell = outRO->parent; // Output cell 260 267 pmChip *outChip = outCell->parent; // Output chip 261 262 268 outRO->data_exists = true; 263 269 outCell->data_exists = true; 264 270 outChip->data_exists = true; 265 271 272 pmCell *expCell = expRO->parent; // Exposure cell 273 pmChip *expChip = expCell->parent; // Exposure chip 274 expRO->data_exists = true; 275 expCell->data_exists = true; 276 expChip->data_exists = true; 277 266 278 psFree(stack); 267 279
Note:
See TracChangeset
for help on using the changeset viewer.
