63 cpl_msg_info(__func__,
"**********************************************");
64 cpl_msg_info(__func__,
" Welcome to GRAVITY Pipeline release %s",
66 cpl_msg_info(__func__,
" Last rebuilt at %s %s",__DATE__,__TIME__);
67 cpl_msg_info(__func__,
"**********************************************");
79 cpl_ensure_code(set, CPL_ERROR_NULL_INPUT);
81 cpl_errorstate prestate = cpl_errorstate_get();
82 cpl_frame *frame = NULL;
84 nb_frame = cpl_frameset_get_size(set);
87 for (i = 0; i < nb_frame; i++) {
89 frame = cpl_frameset_get_position(set, i);
90 const char *tag = cpl_frame_get_tag(frame);
93 cpl_msg_warning(cpl_func,
"Frame %d has no tag", i);
122 cpl_frame_set_group(frame, CPL_FRAME_GROUP_RAW);
148 cpl_frame_set_group(frame, CPL_FRAME_GROUP_CALIB);
152 cpl_frame_set_group(frame, CPL_FRAME_GROUP_PRODUCT);
156 if (!cpl_errorstate_is_equal(prestate)) {
157 return cpl_error_set_message(cpl_func, cpl_error_get_code(),
158 "Could not identify RAW and CALIB "
162 return CPL_ERROR_NONE;
175 cpl_ensure_code (p, CPL_ERROR_NULL_INPUT);
176 cpl_parameter_disable (p, CPL_PARAMETER_MODE_CLI);
177 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
178 cpl_parameter_disable (p, CPL_PARAMETER_MODE_CFG);
179 return CPL_ERROR_NONE;
193 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
196 p = cpl_parameter_new_value (
"gravity.calib.bad-dark-threshold", CPL_TYPE_INT,
197 "the rms factor for "
198 "dark bad pixel threshold",
199 "gravity.calib", 10);
200 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"bad-dark-threshold");
201 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
202 cpl_parameterlist_append (self, p);
204 p = cpl_parameter_new_value (
"gravity.calib.lowflux-pixels-ft", CPL_TYPE_BOOL,
205 "Flag as bad pixels all pixels on the FT which "
206 "have a non-sgnificant flux "
207 "(less than 33% of neighbouring pixel)"
208 "to increase SNR on faint targets",
209 "gravity.calib", FALSE);
210 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"lowflux-pixels-ft");
211 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
212 cpl_parameterlist_append (self, p);
214 p = cpl_parameter_new_value (
"gravity.calib.bad-pixel-A-ft", CPL_TYPE_INT,
215 "flag a given pixel as bad on the FT detector"
216 "value is position of pixel (starting at 1)"
217 "a position of 0 means no pixel is flagged",
219 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"bad-pixel-A-ft");
220 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
221 cpl_parameterlist_append (self, p);
223 p = cpl_parameter_new_value (
"gravity.calib.bad-pixel-B-ft", CPL_TYPE_INT,
224 "flag a second pixel as bad on the FT detector"
225 "value is position of pixel (starting at 1)"
226 "a position of 0 means no pixel is flagged",
228 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"bad-pixel-B-ft");
229 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
230 cpl_parameterlist_append (self, p);
246 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
251 p = cpl_parameter_new_value(
"gravity.calib.pca-components", CPL_TYPE_INT,
252 "The number of PCA components to compute.",
254 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"pca-components");
255 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
256 cpl_parameterlist_append (self, p);
259 p = cpl_parameter_new_value(
"gravity.calib.pca-tracking-ratio", CPL_TYPE_INT,
260 "The minimum tracking ratio to accept calibration frames for.",
261 "gravity.calib", 90);
262 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"pca-tracking-ratio");
263 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
264 cpl_parameterlist_append (self, p);
267 p = cpl_parameter_new_value(
"gravity.calib.pca-clean-size", CPL_TYPE_INT,
268 "The window size to use for outlier cleaning.",
269 "gravity.calib", 20);
270 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"pca-clean-size");
271 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
272 cpl_parameterlist_append (self, p);
275 p = cpl_parameter_new_value(
"gravity.calib.pca-clean-nstd", CPL_TYPE_DOUBLE,
276 "The sigma-clip n_std for outlier cleaning.",
277 "gravity.calib", 5.0);
278 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"pca-clean-nstd");
279 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
280 cpl_parameterlist_append (self, p);
283 const char *PCA_FIT_TYPES[2] = {
"POLYNOMIAL",
"SPLINE"};
284 p = cpl_parameter_new_enum(
"gravity.calib.pca-fit-type", CPL_TYPE_STRING,
285 "The method to use for fitting the PCA components.",
287 PCA_FIT_TYPES[1], 2, PCA_FIT_TYPES[0], PCA_FIT_TYPES[1]
289 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"pca-fit-type");
290 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
291 cpl_parameterlist_append (self, p);
294 p = cpl_parameter_new_value(
"gravity.calib.pca-fit-degree", CPL_TYPE_INT,
295 "The polynomial fit degree, or number of spline coefficients.",
296 "gravity.calib", 20);
297 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"pca-fit-degree");
298 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
299 cpl_parameterlist_append (self, p);
302 p = cpl_parameter_new_value(
"gravity.calib.pca-save-residuals", CPL_TYPE_BOOL,
303 "Also save the residuals from the PCA fitting for inspection.",
304 "gravity.calib", CPL_FALSE);
305 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"pca-save-residuals");
306 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
307 cpl_parameterlist_append (self, p);
324 cpl_parameter *p = cpl_parameter_new_value (
"gravity.vis.flatten-visphi", CPL_TYPE_BOOL,
325 "Use the PCA calibrator to flatten the VISPHI.",
326 "gravity.vis", CPL_FALSE);
327 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"flatten-visphi");
328 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
329 cpl_parameterlist_append (self, p);
345 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
350 p = cpl_parameter_new_enum (
"gravity.calib.profile-mode", CPL_TYPE_STRING,
351 "Method to compute the extraction profile. "
352 "PROFILE corresponds to the pixel intensities measured in the "
353 "FLAT files (Gaussian like with FWHM of approx 1.5 pixel). "
354 "This is the AUTO option for the Low and Med spectral resolution. "
355 "GAUSS corresponds to a Gaussian fit of the (non-zero) pixel intensities measured "
356 "in the FLAT files. BOX corresponds to a box-card of 6 pixels centered "
357 "on the spectra measured in the FLAT files. This is the AUTO option for High "
358 "spectral resolution",
359 "gravity.calib",
"AUTO",
360 4,
"AUTO",
"PROFILE",
"GAUSS",
"BOX");
361 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"profile-mode");
362 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
363 cpl_parameterlist_append (self, p);
366 p = cpl_parameter_new_value (
"gravity.calib.force-badpix-to-zero", CPL_TYPE_BOOL,
367 "Force the badpixel to zero in profile",
368 "gravity.calib", TRUE);
369 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"force-badpix-to-zero");
370 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
371 cpl_parameterlist_append (self, p);
374 p = cpl_parameter_new_value (
"gravity.calib.profile-width", CPL_TYPE_INT,
375 "Width of the detector window extracted around the default "
376 "position of each spectrum, and on which the profile "
377 "will be applied to perform the extraction.",
379 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"profile-width");
380 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
381 cpl_parameterlist_append (self, p);
396 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
398 cpl_parameter *p = NULL;
422 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
427 p = cpl_parameter_new_value (
"gravity.calib.force-wave-ft-equal", CPL_TYPE_BOOL,
428 "Force the spatial order of the wavelength 2D fit for FT to "
429 "zero (so all region share the same calibration). "
430 "This is used to build the P2VM calibration of the TAC "
431 "real-time code running on the instrument ifself.",
432 "gravity.calib", FALSE);
433 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"force-wave-ft-equal");
434 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
435 cpl_parameterlist_append (self, p);
463 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
466 p = cpl_parameter_new_value (
"gravity.dfs.static-name", CPL_TYPE_BOOL,
467 "Use static names for the products (for ESO)",
468 "gravity.dfs", FALSE);
469 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"static-name");
470 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
471 cpl_parameterlist_append (self, p);
478 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
481 p = cpl_parameter_new_value (
"gravity.dfs.debug-file", CPL_TYPE_BOOL,
482 "Save additional debug file(s)",
483 "gravity.dfs", FALSE);
484 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"debug-file");
485 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
486 cpl_parameterlist_append (self, p);
493 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
496 p = cpl_parameter_new_value (
"gravity.dfs.bias-subtracted-file", CPL_TYPE_BOOL,
497 "Save the BIAS_SUBTRACTED intermediate product",
498 "gravity.dfs", FALSE);
499 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"bias-subtracted-file");
500 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
501 cpl_parameterlist_append (self, p);
508 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
511 p = cpl_parameter_new_value (
"gravity.dfs.spectrum-file", CPL_TYPE_BOOL,
512 "Save the SPECTRUM intermediate product",
513 "gravity.dfs", FALSE);
514 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"spectrum-file");
515 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
516 cpl_parameterlist_append (self, p);
523 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
526 p = cpl_parameter_new_value (
"gravity.dfs.preproc-file", CPL_TYPE_BOOL,
527 "Save the PREPROC intermediate product",
528 "gravity.dfs", FALSE);
529 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"preproc-file");
530 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
531 cpl_parameterlist_append (self, p);
538 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
541 p = cpl_parameter_new_value (
"gravity.dfs.p2vmred-file", CPL_TYPE_BOOL,
542 "Save the P2VMRED intermediate product",
543 "gravity.dfs", FALSE);
544 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"p2vmreduced-file");
545 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
546 cpl_parameterlist_append (self, p);
553 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
556 p = cpl_parameter_new_value (
"gravity.dfs.vis-file", CPL_TYPE_BOOL,
557 "Save the VIS intermediate product",
558 "gravity.dfs", FALSE);
559 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"vis-file");
560 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
561 cpl_parameterlist_append (self, p);
568 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
571 p = cpl_parameter_new_value (
"gravity.dfs.astro-file", CPL_TYPE_BOOL,
572 "Save the ASTROREDUCED intermediate product",
573 "gravity.dfs", FALSE);
574 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"astro-file");
575 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
576 cpl_parameterlist_append (self, p);
583 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
586 p = cpl_parameter_new_enum (
"gravity.preproc.bias-method", CPL_TYPE_STRING,
587 "Method to average the biaspixels when cleaning-up\n "
588 "the SC detector (only applied to MED and LOW). Ideally\n "
589 "the same value shall be used when reducing the DARK\n "
590 "with gravity_dark and the OBJECT with gravity_vis. \n"
591 "AUTO is equivalent to MASKED_MEDIAN_PER_COLUMN if the data\n"
592 "contains in the IMAGING_DETECTOR_SC extension the\n"
593 "LEFT, HALFLEFT, CENTER, HALFRIGHT and RIGHT columns.\n"
594 "Otherwise it is like MEDIAN.\n",
595 "gravity.preproc",
"AUTO",
596 4,
"AUTO",
"MEDIAN",
"MEDIAN_PER_COLUMN",
597 "MASKED_MEDIAN_PER_COLUMN");
598 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"bias-method");
599 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
600 cpl_parameterlist_append (self, p);
602 p = cpl_parameter_new_value (
"gravity.preproc.remove-cosmicrays", CPL_TYPE_BOOL,
603 "Remove the cosmicrays with the statiscal method",
604 "gravity.preproc", TRUE);
605 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"remove-cosmicrays");
606 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
607 cpl_parameterlist_append (self, p);
614 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
617 p = cpl_parameter_new_value (
"gravity.metrology.acq-correction-delay",
619 "Delay between the end of ACQ frame and correction\n "
620 "offset seen by the metrology diodes, in seconds.",
621 "gravity.metrology", 0.25);
622 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"acq-correction-delay");
623 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
624 cpl_parameterlist_append (self, p);
626 p = cpl_parameter_new_value (
"gravity.metrology.use-fiber-dxy", CPL_TYPE_BOOL,
627 "Use the fiber position when computing OPD_TEL_CORR.",
628 "gravity.metrology", FALSE);
629 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"use-fiber-dxy");
630 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
631 cpl_parameterlist_append (self, p);
633 p = cpl_parameter_new_value (
"gravity.metrology.use-met-rtc", CPL_TYPE_BOOL,
634 "Reduce metrology voltage with the real time algorithm\n"
635 "instead of using the pipeline’s algorithm.",
636 "gravity.metrology", FALSE);
637 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"use-met-rtc");
638 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
639 cpl_parameterlist_append (self, p);
642 p = cpl_parameter_new_value (
"gravity.metrology.use-faint-met", CPL_TYPE_BOOL,
643 "In FAINT also the faint parts of the metrology \n"
644 "are used, not only the bright periods.",
645 "gravity.metrology", TRUE);
646 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"use-faint-met");
647 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
648 cpl_parameterlist_append (self, p);
650 p = cpl_parameter_new_value (
"gravity.metrology.preswitch-delay", CPL_TYPE_INT,
651 "Delay where metrology values are ignored before\n"
652 "laser brightness is switched in faint mode, ms.",
653 "gravity.metrology", 60);
654 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"preswitch-delay");
655 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
656 cpl_parameterlist_append (self, p);
658 p = cpl_parameter_new_value (
"gravity.metrology.postswitch-delay", CPL_TYPE_INT,
659 "Delay where metrology values are ignored after\n"
660 "laser brightness is switched in faint mode, ms.",
661 "gravity.metrology", 320);
662 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"postswitch-delay");
663 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
664 cpl_parameterlist_append (self, p);
666 p = cpl_parameter_new_value (
"gravity.metrology.demodulate-metrology", CPL_TYPE_BOOL,
667 "Perform demodulation on the raw metrology data.",
668 "gravity.metrology", CPL_TRUE);
669 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"demodulate-metrology");
670 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
671 cpl_parameterlist_append (self, p);
673 p = cpl_parameter_new_value (
"gravity.metrology.use-dark-offsets", CPL_TYPE_BOOL,
674 "Use diode zeros measured from the DARK when demodulating metrology.",
675 "gravity.metrology", CPL_TRUE);
676 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"use-dark-offsets");
677 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
678 cpl_parameterlist_append (self, p);
685 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
688 p = cpl_parameter_new_value (
"gravity.preproc.ditshift-sc", CPL_TYPE_INT,
689 "Shift the time of SC DITs by an integer value to\n "
690 "account for lost frames in exposure (issue on the\n "
691 "instrument side, report to instrument team). The\n "
692 "time of all DITs in exposure are increased by\n "
693 "ditshift x PERIOD. ditshift can be 0,\n "
694 "positive (system has lost one SC DIT), or negative "
695 "(SC desynchronized).",
696 "gravity.preproc",0);
697 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"ditshift-sc");
698 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
699 cpl_parameterlist_append (self, p);
701 p = cpl_parameter_new_value (
"gravity.preproc.extra-pixel-ft", CPL_TYPE_BOOL,
702 "Include the 6th pixels ot the FT",
703 "gravity.preproc", TRUE);
704 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"extra-pixel-ft");
705 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
706 cpl_parameterlist_append (self, p);
713 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
715 p = cpl_parameter_new_value (
"gravity.postprocess.average-vis", CPL_TYPE_BOOL,
716 "Average the results from the different input files (if any)\n "
717 "in the output product, instead of simply appending them.",
718 "gravity.postprocess", FALSE);
719 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"average-vis");
720 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
721 cpl_parameterlist_append (self, p);
728 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
730 p = cpl_parameter_new_value (
"gravity.postprocess.copy-fluxdata", CPL_TYPE_BOOL,
731 "Duplicate FLUX into FLUXDATA for OIFITS2\n "
732 "gravity.postprocess", FALSE);
733 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"copy-fluxdata");
734 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
735 cpl_parameterlist_append (self, p);
742 cpl_ensure (self, CPL_ERROR_NULL_INPUT, NULL);
745 p = cpl_parameter_new_value (
"gravity.postprocess.fluxerr-sc", CPL_TYPE_DOUBLE,
746 "Force the uncertainty in FLUX of SC",
747 "gravity.postprocess", 0.0);
748 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"fluxerr-sc");
749 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
750 cpl_parameterlist_append (self, p);
752 p = cpl_parameter_new_value (
"gravity.postprocess.visamperr-sc", CPL_TYPE_DOUBLE,
753 "Force the uncertainty in VISAMP of SC",
754 "gravity.postprocess", 0.0);
755 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"visamperr-sc");
756 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
757 cpl_parameterlist_append (self, p);
759 p = cpl_parameter_new_value (
"gravity.postprocess.visphierr-sc", CPL_TYPE_DOUBLE,
760 "Force the uncertainty in VISPHI of SC",
761 "gravity.postprocess", 0.0);
762 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"visphierr-sc");
763 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
764 cpl_parameterlist_append (self, p);
766 p = cpl_parameter_new_value (
"gravity.postprocess.vis2err-sc", CPL_TYPE_DOUBLE,
767 "Force the uncertainty in VIS2 of SC",
768 "gravity.postprocess", 0.0);
769 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"vis2err-sc");
770 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
771 cpl_parameterlist_append (self, p);
778 cpl_ensure_code (self, CPL_ERROR_NULL_INPUT);
782 p = cpl_parameter_new_value (
"gravity.signal.chi2r-threshold", CPL_TYPE_DOUBLE,
783 "Threshold in chi2r of the fringe-fit to declare\n "
784 "a bad value. This is usefull to detect outliers\n "
785 "or cosmic in individual frames",
786 "gravity.signal", 50.0);
787 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"chi2r-threshold");
788 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
789 cpl_parameterlist_append (self, p);
791 p = cpl_parameter_new_value (
"gravity.signal.chi2r-sigma", CPL_TYPE_DOUBLE,
792 "Threshold in chi2r of the fringe-fit (in unit of the \n "
793 "the std of chi2r in the spectral direction) to declare\n "
794 "a bad value. This is usefull to detect outliers\n "
795 "or cosmic in individual frames",
796 "gravity.signal", 100.0);
797 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"chi2r-sigma");
798 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
799 cpl_parameterlist_append (self, p);
802 p = cpl_parameter_new_value (
"gravity.signal.nsmooth-snr-ft", CPL_TYPE_INT,
803 "Number of samples to average coherently when computing\n "
804 "the real-time SNR and GDELAY of the FT (shall correspond\n "
805 "to the atmospheric coherence time). The integration\n "
806 "window runs from -nsmooth -> +nsmooth.",
807 "gravity.signal", 5);
808 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"nsmooth-snr-ft");
809 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
810 cpl_parameterlist_append (self, p);
812 return CPL_ERROR_NONE;
817 cpl_ensure_code (self, CPL_ERROR_NULL_INPUT);
821 p = cpl_parameter_new_value (
"gravity.signal.phase-ref-sc-maxdeg", CPL_TYPE_INT,
822 "Maximum deg for the fit of PHASE_REF",
823 "gravity.signal", 3);
824 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"phase-ref-sc-maxdeg");
825 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
826 cpl_parameterlist_append (self, p);
829 p = cpl_parameter_new_value (
"gravity.signal.use-met-zero", CPL_TYPE_BOOL,
830 "Flag to add a constant value to OPD_DISP.\n "
831 "This constant value is taken from the header.",
832 "gravity.signal", FALSE);
833 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"use-met-zero");
834 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
835 cpl_parameterlist_append (self, p);
838 p = cpl_parameter_new_enum (
"gravity.signal.imaging-ref-met", CPL_TYPE_STRING,
839 "Metrology source used for IMAGING_REF calculation:\n "
840 "Use fibre coupler metrology (FC);\n "
841 "Use fibre coupler metrology corrected from pupil motion (FC_CORR);\n "
842 "Use telescope metrology (TEL).",
843 "gravity.signal",
"FC", 3,
844 "FC",
"FC_CORR",
"TEL");
845 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"imaging-ref-met");
846 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
847 cpl_parameterlist_append (self, p);
849 return CPL_ERROR_NONE;
863 cpl_ensure_code (self, CPL_ERROR_NULL_INPUT);
866 p = cpl_parameter_new_value (
"gravity.signal.snr-min-ft", CPL_TYPE_DOUBLE,
867 "SNR threshold to accept FT frames (>0). It raises the first bit (<<0)\n "
868 "of column REJECTION_FLAG of FT.",
869 "gravity.signal", isCalib ? 30.0 : 3.0);
870 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"snr-min-ft");
871 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
872 cpl_parameterlist_append (self, p);
875 p = cpl_parameter_new_value (
"gravity.signal.global-state-min-ft", CPL_TYPE_DOUBLE,
876 "Minimum OPDC state to accept FT frames (>=0) It raises the second bit\n "
877 "(<<1) of column REJECTION_FLAG of FT.",
878 "gravity.signal", 2.0);
879 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"global-state-min-ft");
880 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
881 cpl_parameterlist_append (self, p);
883 p = cpl_parameter_new_value (
"gravity.signal.global-state-max-ft", CPL_TYPE_DOUBLE,
884 "Maximum OPDC state to accept FT frames (>=0) It raises the second bit\n "
885 "(<<1) of column REJECTION_FLAG of FT.",
886 "gravity.signal", 4.0);
887 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"global-state-max-ft");
888 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
889 cpl_parameterlist_append (self, p);
892 p = cpl_parameter_new_value (
"gravity.signal.state-min-ft", CPL_TYPE_DOUBLE,
893 "Minimum OPDC state per baseline to accept FT frames (>=0) It raises\n "
894 "the second bit (<<1) of column REJECTION_FLAG of FT.",
895 "gravity.signal", 1.0);
896 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"state-min-ft");
897 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
898 cpl_parameterlist_append (self, p);
901 p = cpl_parameter_new_value (
"gravity.signal.tracking-min-sc", CPL_TYPE_DOUBLE,
902 "Minimum ratio of accepted FT frames in order to accept a SC frames (0..1),\n "
903 "that is, for each SC DIT, the fraction of the time the\n "
904 "REJECTION_FLAG of the FT is not 0.\n "
905 "It raises the first bit (<<0) of column REJECTION_FLAG of SC",
906 "gravity.signal", 0.8);
907 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"tracking-min-sc");
908 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
909 cpl_parameterlist_append (self, p);
912 p = cpl_parameter_new_value (
"gravity.signal.vfactor-min-sc", CPL_TYPE_DOUBLE,
913 "vFactor threshold to accept SC frame (0..1).\n ",
914 "It raises the second bit (<<1) of column REJECTION_FLAG of SC",
915 "gravity.signal", isCalib ? 0.8 : 0.1);
916 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"vfactor-min-sc");
917 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
918 cpl_parameterlist_append (self, p);
921 p = cpl_parameter_new_value (
"gravity.signal.opd-pupil-max-sc", CPL_TYPE_DOUBLE,
922 "Maximum OPD_PUPIL (abs) to accept SC frames. It raises the third bit\n "
923 "(<<2) of column REJECTION_FLAG of SC.",
924 "gravity.signal", 9999.0);
925 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"opd-pupil-max-sc");
926 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
927 cpl_parameterlist_append (self, p);
929 p = cpl_parameter_new_value (
"gravity.signal.opd-pupil-stddev-max-sc", CPL_TYPE_DOUBLE,
930 "Maximum OPD_PUPIL_STDDEV to accept SC frames. It\n "
931 "raises the fourth bit (<<3) of REJECTION_FLAG of SC.",
932 "gravity.signal", 2.9e-7);
933 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"opd-pupil-stddev-max-sc");
934 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
935 cpl_parameterlist_append (self, p);
937 return CPL_ERROR_NONE;
942 cpl_ensure_code (self, CPL_ERROR_NULL_INPUT);
946 p = cpl_parameter_new_value (
"gravity.vis.max-frame", CPL_TYPE_INT,
947 "Maximum number of frames to integrate \n "
948 "coherently into an OIFITS entry",
949 "gravity.vis", 10000);
950 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"max-frame");
951 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
952 cpl_parameterlist_append (self, p);
955 p = cpl_parameter_new_value (
"gravity.vis.force-same-time", CPL_TYPE_BOOL,
956 "Force all baseline/quantities to have\n "
957 "strictly the same TIME and MJD columns",
958 "gravity.vis", FALSE);
959 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"force-same-time");
960 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
961 cpl_parameterlist_append (self, p);
964 p = cpl_parameter_new_value (
"gravity.vis.debias-sc", CPL_TYPE_BOOL,
965 "Subtract the V2 bias from SC",
966 "gravity.vis", TRUE);
967 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"debias-sc");
968 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
969 cpl_parameterlist_append (self, p);
972 p = cpl_parameter_new_value (
"gravity.vis.debias-ft", CPL_TYPE_BOOL,
973 "Subtract the V2 bias from FT",
974 "gravity.vis", TRUE);
975 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"debias-ft");
976 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
977 cpl_parameterlist_append (self, p);
980 p = cpl_parameter_new_value (
"gravity.vis.nboot", CPL_TYPE_INT,
981 "Number of bootstraps to compute error (1..100)",
982 "gravity.vis", isCalib ? 1 : 20);
983 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"nboot");
984 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
985 cpl_parameterlist_append (self, p);
988 p = cpl_parameter_new_enum (
"gravity.vis.vis-correction-sc", CPL_TYPE_STRING,
989 "Correction of SC visibility from losses due to long integration,\n "
990 "using the measured visibility losses with the FT (VFACTOR\n "
991 "and/or PFACTOR) or by forcing\n "
992 "the SC visibilities to match those of the FT (FORCE). Possible\n "
995 isCalib ?
"NONE" :
"VFACTOR", 5,
"VFACTOR",
"PFACTOR",
996 "VFACTOR_PFACTOR",
"FORCE",
"NONE");
997 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"vis-correction-sc");
998 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
999 cpl_parameterlist_append (self, p);
1001 p = cpl_parameter_new_enum (
"gravity.vis.vis-correction-ft", CPL_TYPE_STRING,
1002 "Correction of FT visibility from losses due to long integration,\n "
1003 "using a sliding window P_FACTOR, or its square. Choices are:",
1004 "gravity.vis",
"NONE", 3,
"NONE",
"PFACTOR",
"PFACTOR_SQUARED");
1005 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"vis-correction-ft");
1006 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1007 cpl_parameterlist_append (self, p);
1010 p = cpl_parameter_new_value (
"gravity.vis.pfactor-window-length", CPL_TYPE_INT,
1011 "Length of the sliding window used to calculate the FT P_FACTOR.\n "
1012 "For each FT frame, the window will run from -window-length to +window-length inclusive.",
1014 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"pfactor-window-length");
1015 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1016 cpl_parameterlist_append (self, p);
1019 p = cpl_parameter_new_enum (
"gravity.vis.phase-ref-sc", CPL_TYPE_STRING,
1020 "Reference phase used to integrate the SC frames.\n "
1021 "Use a self-estimate of the phase, fitted by poly. (SELF_REF)\n "
1022 "Use the FT phase only, interpolated in lbd (PHASE_REF)\n "
1023 "Use the FT+MET-SEP.UV phase (IMAGING_REF).",
1024 "gravity.vis",
"AUTO", 5,
1025 "SELF_REF",
"PHASE_REF",
"IMAGING_REF",
"AUTO",
"NONE");
1026 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"phase-ref-sc");
1027 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1028 cpl_parameterlist_append (self, p);
1031 p = cpl_parameter_new_enum (
"gravity.vis.output-phase-sc", CPL_TYPE_STRING,
1032 "With DIFFERENTIAL, the mean group-delay and mean\n "
1033 "phases are removed from the output VISPHI in the\n "
1034 "final OIFITS file. With ABSOLUTE, the VISPHI is\n "
1035 "kept unmodified. With SELF_VISPHI, the internal differential\n "
1036 "phase between each spectral channel and a common \n "
1037 "reference channel is computed.\n",
1038 "gravity.vis",
"AUTO", 4,
1039 "DIFFERENTIAL",
"ABSOLUTE",
"AUTO",
"SELF_VISPHI");
1040 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"output-phase-sc");
1041 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1042 cpl_parameterlist_append (self, p);
1045 p = cpl_parameter_new_value (
"gravity.vis.output-phase-channels", CPL_TYPE_STRING,
1046 "range (string in the form [min,max]) of channels\n "
1047 "to use a SELF_VISPHI phase reference.\n",
1048 "gravity.vis",
"[0,0]");
1049 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"output-phase-channels");
1050 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1051 cpl_parameterlist_append (self, p);
1054 p = cpl_parameter_new_value (
"gravity.vis.outlier-fraction-threshold", CPL_TYPE_DOUBLE,
1055 "Flag channels with more than this fraction of the frames\n "
1056 "affected by outliers or cosmics. These are typically detected\n "
1057 "with the thresholds options in chi2 of the fringe-fit.",
1058 "gravity.vis", 0.5);
1059 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"outlier-fraction-threshold");
1060 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1061 cpl_parameterlist_append (self, p);
1063 return CPL_ERROR_NONE;
1068 cpl_ensure_code (self, CPL_ERROR_NULL_INPUT);
1073 p = cpl_parameter_new_value(
"gravity.astrometry.use-swap-fiber-pos", CPL_TYPE_BOOL,
1074 "use fiber position for swap rather than computing an astrometric solution.",
"gravity.astrometry", CPL_FALSE);
1075 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"use-swap-fiber-pos");
1076 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1077 cpl_parameterlist_append (self, p);
1080 p = cpl_parameter_new_value(
"gravity.astrometry.ra-lim-swap", CPL_TYPE_DOUBLE,
1081 "specify the RA range (in mas) over which to search for the astrometry of the swap. Default specifies entire field of view.",
"gravity.astrometry", -1.0);
1082 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"ra-lim-swap");
1083 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1084 cpl_parameterlist_append (self, p);
1086 p = cpl_parameter_new_value(
"gravity.astrometry.nra-swap", CPL_TYPE_INT,
1087 "number of points over the RA range for the swap.",
"gravity.astrometry", 50);
1088 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"nra-swap");
1089 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1090 cpl_parameterlist_append (self, p);
1093 p = cpl_parameter_new_value(
"gravity.astrometry.dec-lim-swap", CPL_TYPE_DOUBLE,
1094 "specify the dec range (in mas) over which to search for the astrometry of the swap. Default specifies entire field of view.",
"gravity.astrometry", -1.0);
1095 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"dec-lim-swap");
1096 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1097 cpl_parameterlist_append (self, p);
1099 p = cpl_parameter_new_value(
"gravity.astrometry.ndec-swap", CPL_TYPE_INT,
1100 "number of points over the dec range for the swap.",
"gravity.astrometry", 50);
1101 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"ndec-swap");
1102 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1103 cpl_parameterlist_append (self, p);
1106 p = cpl_parameter_new_value(
"gravity.astrometry.average-over-dits", CPL_TYPE_BOOL,
1107 "Average over DITs before reducing astrometry for speed.",
"gravity.astrometry", CPL_FALSE);
1108 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"average-over-dits");
1109 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1110 cpl_parameterlist_append (self, p);
1112 p = cpl_parameter_new_value(
"gravity.astrometry.zoom-factor", CPL_TYPE_DOUBLE,
1113 "Factor to magnify ra/dec limits by after initial fit to find precise solution.",
"gravity.astrometry", 1.0);
1114 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"zoom-factor");
1115 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1116 cpl_parameterlist_append (self, p);
1140 p = cpl_parameter_new_value(
"gravity.astrometry.ft-mean-flux", CPL_TYPE_DOUBLE,
1141 "remove all data with FT flux below this factor times the mean",
"gravity.astrometry", 0.2);
1142 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"ft-mean-flux");
1143 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1144 cpl_parameterlist_append (self, p);
1147 const char * calib_strategies[] = {
"NONE",
"ALL",
"SELF",
"SWAP",
"NEAREST"};
1148 p = cpl_parameter_new_enum_from_array(
"gravity.astrometry.calib-strategy", CPL_TYPE_STRING,
1149 "how to calculate the reference coherent flux\n"
1150 "\t'NONE': do not use an amplitude reference\n"
1151 "\t'ALL': use all files\n"
1152 "\t'SELF': calibrate each file individually\n"
1153 "\t'SWAP': use the swap files\n"
1154 "\t'NEAREST': use the nearest two (in time) files.",
1155 "gravity.astrometry", 0, 5, calib_strategies);
1156 cpl_parameter_set_alias (p, CPL_PARAMETER_MODE_CLI,
"calib-strategy");
1157 cpl_parameter_disable (p, CPL_PARAMETER_MODE_ENV);
1158 cpl_parameterlist_append (self, p);
1167 return CPL_ERROR_NONE;
1172 cpl_ensure_code (self, CPL_ERROR_NULL_INPUT);
1185 p = cpl_parameter_new_value(
"gravi.gravity_image.pixelsize",
1186 CPL_TYPE_DOUBLE,
"size of the pixel (milliarcseconds)",
1187 "gravi.gravity_image", 0.2);
1188 cpl_parameter_set_alias(p, CPL_PARAMETER_MODE_CLI,
"pixelsize");
1189 cpl_parameter_disable(p, CPL_PARAMETER_MODE_ENV);
1190 cpl_parameterlist_append(self, p);
1193 p = cpl_parameter_new_value(
"gravi.gravity_image.dim",
1194 CPL_TYPE_INT,
"number of pixels per side of the image",
1195 "gravi.gravity_image", 100);
1196 cpl_parameter_set_alias(p, CPL_PARAMETER_MODE_CLI,
"dim");
1197 cpl_parameter_disable(p, CPL_PARAMETER_MODE_ENV);
1198 cpl_parameterlist_append(self, p);
1201 p = cpl_parameter_new_value(
"gravi.gravity_image.regul",
1202 CPL_TYPE_STRING,
"name of regularization method",
1203 "gravi.gravity_image",
"totvar");
1204 cpl_parameter_set_alias(p, CPL_PARAMETER_MODE_CLI,
"regul");
1205 cpl_parameter_disable(p, CPL_PARAMETER_MODE_ENV);
1206 cpl_parameterlist_append(self, p);
1209 p = cpl_parameter_new_value(
"gravi.gravity_image.regul_mu",
1210 CPL_TYPE_DOUBLE,
"global regularization weight",
1211 "gravi.gravity_image", 1E4);
1212 cpl_parameter_set_alias(p, CPL_PARAMETER_MODE_CLI,
"regul_mu");
1213 cpl_parameter_disable(p, CPL_PARAMETER_MODE_ENV);
1214 cpl_parameterlist_append(self, p);
1217 p = cpl_parameter_new_value(
"gravi.gravity_image.maxeval",
1218 CPL_TYPE_INT,
"maximum number of evaluations of the objective function",
1219 "gravi.gravity_image", 2000);
1220 cpl_parameter_set_alias(p, CPL_PARAMETER_MODE_CLI,
"maxeval");
1221 cpl_parameter_disable(p, CPL_PARAMETER_MODE_ENV);
1222 cpl_parameterlist_append(self, p);
1225 p = cpl_parameter_new_value(
"gravi.gravity_image.timeout",
1226 CPL_TYPE_DOUBLE,
"Maximum execution time of Mira process (s)",
1227 "gravi.gravity_image", 60.);
1228 cpl_parameter_set_alias(p, CPL_PARAMETER_MODE_CLI,
"timeout");
1229 cpl_parameter_disable(p, CPL_PARAMETER_MODE_ENV);
1230 cpl_parameterlist_append(self, p);
1233 return CPL_ERROR_NONE;
1251 const char ** frame_tags,
1254 cpl_ensure (frameset, CPL_ERROR_NULL_INPUT, NULL);
1255 cpl_ensure (frame_tags, CPL_ERROR_NULL_INPUT, NULL);
1256 cpl_ensure (nb_tags>0, CPL_ERROR_ILLEGAL_INPUT, NULL);
1258 int nb_frame = cpl_frameset_get_size (frameset);
1259 cpl_frameset * output_frameset = cpl_frameset_new();
1262 for (
int i = 0; i < nb_frame; i++){
1264 cpl_frame * frame = cpl_frameset_get_position (frameset, i);
1265 const char * frame_tag = cpl_frame_get_tag (frame) ;
1268 for (
int j = 0; j < nb_tags; j++) {
1269 if (strcmp(frame_tag, frame_tags[j]) == 0) {
1270 cpl_frameset_insert (output_frameset, cpl_frame_duplicate(frame));
1277 return output_frameset;
1462 const cpl_parameter * tmp = cpl_parameterlist_find_const(parlist, name);
1465 return cpl_parameter_get_double (tmp);
1467 cpl_msg_info (cpl_func,
"Could not find the parameter '%s':, use %f", name, def);
1474 const cpl_parameter * tmp = cpl_parameterlist_find_const(parlist, name);
1477 return cpl_parameter_get_int (tmp);
1479 cpl_msg_info (cpl_func,
"Could not find the parameter '%s': use %i", name, def);
1486 const cpl_parameter * tmp = cpl_parameterlist_find_const(parlist, name);
1489 return cpl_parameter_get_bool (tmp);
1491 cpl_msg_info (cpl_func,
"Could not find the boolean parameter '%s': use %s", name, (def==0?
"FALSE":
"TRUE"));
1498 const cpl_parameter * tmp = cpl_parameterlist_find_const(parlist, name);
1501 return cpl_parameter_get_string (tmp);
1503 cpl_msg_info (cpl_func,
"Could not find the string parameter '%s': use %s", name, def);
1510 const cpl_parameter * tmp = cpl_parameterlist_find_const(parlist, name);
1514 return cpl_parameter_get_double (tmp);
1516 cpl_error_set_message (cpl_func, CPL_ERROR_ILLEGAL_INPUT,
"Could not find the parameter '%s':, use %f", name, def);
1523 const cpl_parameter * tmp = cpl_parameterlist_find_const(parlist, name);
1527 return cpl_parameter_get_int (tmp);
1529 cpl_error_set_message (cpl_func, CPL_ERROR_ILLEGAL_INPUT,
"Could not find the parameter '%s': use %i", name, def);
1536 const cpl_parameter * tmp = cpl_parameterlist_find_const(parlist, name);
1540 return cpl_parameter_get_bool (tmp);
1542 cpl_error_set_message (cpl_func, CPL_ERROR_ILLEGAL_INPUT,
"Could not find the boolean parameter '%s': use %s", name, (def==0?
"FALSE":
"TRUE"));
1549 const cpl_parameter * tmp = cpl_parameterlist_find_const(parlist, name);
1552 return cpl_parameter_get_string (tmp);
1554 cpl_error_set_message (cpl_func, CPL_ERROR_ILLEGAL_INPUT,
"Could not find the string parameter '%s': use UNKNOWN", name);
1562 int nf = cpl_frameset_count_tags (frameset, tag);
1563 char * msg = cpl_sprintf (
"Need %i<#<%i '%s' in frameset (%i provided)", min, max, tag, nf);
1565 if (nf < min || nf > max) {
1566 cpl_msg_error (cpl_func,
"%s",msg);
1567 cpl_error_set_message (cpl_func, CPL_ERROR_ILLEGAL_INPUT,
"%s", msg);
1574 return (flag) ? CPL_ERROR_ILLEGAL_INPUT : CPL_ERROR_NONE;
#define GRAVI_VISPHI_SINGLE_CALIB
#define GRAVI_P2VMRED_SINGLE_CALIB
#define GRAVI_TF_SINGLE_CALIB
#define GRAVI_SINGLE_SCIENCE_RAW
#define GRAVI_TF_DUAL_CALIB
#define GRAVI_PIEZOTF_MAP
#define GRAVI_SINGLE_SKY_RAW
#define GRAVI_ASTRO_TARGET
#define GRAVI_P2VMRED_DUAL_CALIB
#define GRAVI_DIODE_POSITION
#define GRAVI_VIS_DUAL_SCIENCE
#define GRAVI_VIS_SINGLE_SCIENCE
#define GRAVI_MIRA_OUTPUT_PROCATG
#define GRAVI_DUAL_CALIB_RAW
#define GRAVI_BIASMASK_MAP
#define GRAVI_P2VMRED_SINGLE_SCIENCE
#define GRAVI_DUAL_SKY_RAW
#define GRAVI_WAVELAMP_MAP
#define GRAVI_PIEZOTF_RAW
#define GRAVI_DIAMETER_CAT
#define GRAVI_STATIC_PARAM
#define GRAVI_SINGLE_CALIB_RAW
#define GRAVI_VIS_DUAL_CALIB
#define GRAVI_DUAL_SCIENCE_RAW
#define GRAVI_VIS_SINGLE_CALIBRATED
#define GRAVI_MIRA_INPUT_PROCATG
#define GRAVI_VIS_SINGLE_CALIB
#define GRAVI_TF_DUAL_SCIENCE
#define GRAVI_TF_SINGLE_SCIENCE
#define GRAVI_ASTRO_CAL_PHASEREF
#define GRAVI_WAVELAMP_RAW
#define GRAVI_P2VMRED_DUAL_SCIENCE
#define GRAVI_VISPHI_DUAL_CALIB
#define GRAVI_VISPHI_TF_DUAL_CALIB
#define GRAVI_VIS_DUAL_CALIBRATED
#define GRAVI_VISPHI_TF_SINGLE_CALIB
cpl_msg_info(cpl_func, "Compute WAVE_SCAN for %s", GRAVI_TYPE(type_data))
cpl_parameter * gravi_parameter_add_debug_file(cpl_parameterlist *self)
cpl_frameset * gravi_frameset_extract_wavesc_data(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_met_pos(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_add_astro_file(cpl_parameterlist *self)
cpl_frameset * gravi_frameset_extract_vis_calib(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_add_profile(cpl_parameterlist *self)
Add profile parameters to the input parameter list.
int gravi_param_get_bool(const cpl_parameterlist *parlist, const char *name)
cpl_parameter * gravi_parameter_add_static_name(cpl_parameterlist *self)
cpl_error_code gravi_parameter_add_astrometry(cpl_parameterlist *self)
cpl_parameter * gravi_parameter_add_p2vmred_file(cpl_parameterlist *self)
cpl_parameter * gravi_parameter_add_metrology(cpl_parameterlist *self)
cpl_error_code gravi_parameter_add_rejection(cpl_parameterlist *self, int isCalib)
Add rejection parameters to the input parameter list.
cpl_frameset * gravi_frameset_extract_vis_science(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_fringe_data(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_copy_fluxdata(cpl_parameterlist *self)
int gravi_param_get_bool_default(const cpl_parameterlist *parlist, const char *name, int def)
cpl_error_code gravi_parameter_add_image(cpl_parameterlist *self)
cpl_error_code gravi_parameter_add_compute_snr(cpl_parameterlist *self)
cpl_parameter * gravi_parameter_add_pcacalib(cpl_parameterlist *self)
Add pca calibration parameters to the input parameter list.
cpl_parameter * gravi_parameter_add_extract(cpl_parameterlist *self)
cpl_parameter * gravi_parameter_add_biasmethod(cpl_parameterlist *self)
cpl_frameset * gravi_frameset_extract_patch(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_astro_target(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_add_vis_file(cpl_parameterlist *self)
cpl_parameter * gravi_parameter_add_average_vis(cpl_parameterlist *self)
cpl_frameset * gravi_frameset_extract_wave_map(cpl_frameset *frameset)
const char * gravi_param_get_string(const cpl_parameterlist *parlist, const char *name)
cpl_frameset * gravi_frameset_extract_astro_swap(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_disp_data(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_dispvis_data(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_add_wave(cpl_parameterlist *self)
Add wavelength calibration parameters to the input parameter list.
cpl_frameset * gravi_frameset_extract_bad_map(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_add_pca(cpl_parameterlist *self)
Add pca parameters to the input parameter list.
cpl_error_code gravi_parameter_disable(cpl_parameter *p)
Disable a parameter.
cpl_frameset * gravi_frameset_extract_piezotf_data(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_tf_calib(cpl_frameset *frameset)
cpl_error_code gravi_check_frameset(cpl_frameset *frameset, const char *tag, int min, int max)
cpl_frameset * gravi_frameset_extract_science_data(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_flat_data(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_add_spectrum_file(cpl_parameterlist *self)
cpl_frameset * gravi_frameset_extract(cpl_frameset *frameset, const char **frame_tags, int nb_tags)
Extract a list of tags from a frameset.
int gravi_param_get_int(const cpl_parameterlist *parlist, const char *name)
cpl_frameset * gravi_frameset_extract_pca_calib(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_biasmask_map(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_wave_data(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_add_preproc(cpl_parameterlist *self)
Add preprocessing parameters to the input parameter list.
cpl_parameter * gravi_parameter_add_force_uncertainties(cpl_parameterlist *self)
int gravi_param_get_int_default(const cpl_parameterlist *parlist, const char *name, int def)
cpl_frameset * gravi_frameset_extract_dark_map(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_p2vm_data(cpl_frameset *frameset)
Extract P2VM_RAW frame from the input frameset.
const char * gravi_param_get_string_default(const cpl_parameterlist *parlist, const char *name, const char *def)
cpl_frameset * gravi_frameset_extract_wavelamp_map(cpl_frameset *frameset)
cpl_error_code gravi_dfs_set_groups(cpl_frameset *set)
Set the group as RAW or CALIB in a frameset.
cpl_parameter * gravi_parameter_add_preproc_file(cpl_parameterlist *self)
cpl_frameset * gravi_frameset_extract_p2vmred_data(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_p2vm_map(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_sky_data(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_add_badpix(cpl_parameterlist *self)
Add badpix parameters to the input parameter list.
cpl_frameset * gravi_frameset_extract_static_param(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_wave_param(cpl_frameset *frameset)
double gravi_param_get_double(const cpl_parameterlist *parlist, const char *name)
cpl_error_code gravi_parameter_add_compute_vis(cpl_parameterlist *self, int isCalib)
cpl_frameset * gravi_frameset_extract_wavelamp_data(cpl_frameset *frameset)
cpl_parameter * gravi_parameter_add_biassub_file(cpl_parameterlist *self)
cpl_frameset * gravi_frameset_extract_astro_phaseref(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_flat_map(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_eop_map(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_diamcat_map(cpl_frameset *frameset)
cpl_frameset * gravi_frameset_extract_disp_map(cpl_frameset *frameset)
void gravity_print_banner(void)
cpl_frameset * gravi_frameset_extract_dark_data(cpl_frameset *frameset)
Extract DARK_RAW frame from the input frameset.
cpl_error_code gravi_parameter_add_compute_signal(cpl_parameterlist *self)
double gravi_param_get_double_default(const cpl_parameterlist *parlist, const char *name, double def)
Get the parameter from the parameter list.