#ifndef _H_I3_OPTIONS #define _H_I3_OPTIONS /* This code is auto-generated by the script tools/i3_build_options.py. There is no point in changing it. Adding new parameters is easy - just modify the top of that script. Adding new functions is a little more involved. */ #include "stdbool.h" #include "stdio.h" #include "stdlib.h" #include "ctype.h" #include "string.h" #define i3_options_max_line_length 1024 /* This is the main option structure that this code acts on.*/ typedef struct i3_options{ /* * Basic Options */ /* Name of model to use. */ char model_name[i3_options_max_line_length] ; /* Assumed noise standard deviation */ float noise_sigma; /* Image mask. If set, the weighting assigned to each pixel is scaled by the mask value (i.e. ignore any pixels with mask=0) */ char image_mask[i3_options_max_line_length] ; /* Whether to subtract off the mean of the edge pixels from the whole stamp */ bool background_subtract; /* Whether to rescale the whole postage stamp so flux is 1 */ bool rescale_stamp; /* Verbosity level [-1 to 4] */ int verbosity; /* Whether to save images of the model and fit in output_directory */ bool save_images; /* Whether to save im3shape output in output_directory */ bool save_output; /* Output directory in which to save model and data images. */ char output_directory[i3_options_max_line_length] ; /* Output filename in which to save im3shape results. */ char output_filename[i3_options_max_line_length] ; /* Use an Airy PSF instead of a Moffat. */ bool airy_psf; /* PSF truncation radius, in pixels (use 5.7 for GREAT08, or a large number e.g. 40 for no truncation) */ float psf_truncation_pixels; /* * Optimizer Options */ /* Use a computed starting position (if available). This (partially) overwrites ini settings. If not just use ini file settings. */ bool use_computed_start; /* Tolerance of the minimizer (for levmar it is eps2>||dp||_2) */ float minimizer_tolerance; /* Levmar stopping criterion: ||J^T e||_inf < eps1. Set to -1 if not used. */ float levmar_eps1; /* Levmar stopping criterion: ||dp||_2 < eps2. Set to -1 if not used. */ float levmar_eps2; /* Levmar stopping criterion: ||e||_2 < eps3. Set to -1 if not used. */ float levmar_eps3; /* Levmar stopping criterion: D||e||_2*n < eps4. Set to -1 if not used. */ float levmar_eps4; /* Levmar stopping criterion: ellipticty did not change by eps5 since last iteration. */ float levmar_eps5; /* Levmar size of the step used for finding finite difference derivatives. If <0 then use central differences. */ float levmar_tau; /* Levmar initial damping factor */ float levmar_LM_INIT_MU; /* The maximum number of iterations of the minimizer */ int minimizer_max_iterations; /* * Image Options */ /* The size of a postage-stamp patch with a single object in to analyze. */ int stamp_size; /* The upsampling to use when creating high-res models */ int upsampling; /* Whether to do extra upsampling in central pixels of galaxy image - N.B. Only implemented in milestone model */ bool central_pixel_upsampling; /* Factor by which to upsample the high-resolution pixels, in the center of the galaxy image. Odd number. */ int n_central_pixel_upsampling; /* If 1 it will upsample only central pixel, if 2 also its one neighbor on both sides, etc. */ int n_central_pixels_to_upsample; /* Padding to use when generating model (in low-res pixels), has to be even, 0 allowed */ int padding; /* Number of pixels at which to truncate sersic discs */ float sersics_disc_truncation; /* Number of pixels at which to truncate sersic bulge */ float sersics_bulge_truncation; /* * Options for model sersics */ /* Initial value of parameter x0 in model sersics */ float sersics_x0_start; /* Initial value of parameter y0 in model sersics */ float sersics_y0_start; /* Initial value of parameter e1 in model sersics */ float sersics_e1_start; /* Initial value of parameter e2 in model sersics */ float sersics_e2_start; /* Initial value of parameter radius in model sersics */ float sersics_radius_start; /* Initial value of parameter radius_ratio in model sersics */ float sersics_radius_ratio_start; /* Initial value of parameter bulge_A in model sersics */ float sersics_bulge_A_start; /* Initial value of parameter disc_A in model sersics */ float sersics_disc_A_start; /* Initial value of parameter bulge_index in model sersics */ float sersics_bulge_index_start; /* Initial value of parameter disc_index in model sersics */ float sersics_disc_index_start; /* Initial value of parameter delta_e_bulge in model sersics */ float sersics_delta_e_bulge_start; /* Initial value of parameter delta_theta_bulge in model sersics */ float sersics_delta_theta_bulge_start; /* Initial value of parameter x0 in model sersics */ float sersics_x0_width; /* Initial value of parameter y0 in model sersics */ float sersics_y0_width; /* Initial value of parameter e1 in model sersics */ float sersics_e1_width; /* Initial value of parameter e2 in model sersics */ float sersics_e2_width; /* Initial value of parameter radius in model sersics */ float sersics_radius_width; /* Initial value of parameter radius_ratio in model sersics */ float sersics_radius_ratio_width; /* Initial value of parameter bulge_A in model sersics */ float sersics_bulge_A_width; /* Initial value of parameter disc_A in model sersics */ float sersics_disc_A_width; /* Initial value of parameter bulge_index in model sersics */ float sersics_bulge_index_width; /* Initial value of parameter disc_index in model sersics */ float sersics_disc_index_width; /* Initial value of parameter delta_e_bulge in model sersics */ float sersics_delta_e_bulge_width; /* Initial value of parameter delta_theta_bulge in model sersics */ float sersics_delta_theta_bulge_width; /* Min value of parameter x0 in model sersics */ float sersics_x0_min; /* Min value of parameter y0 in model sersics */ float sersics_y0_min; /* Min value of parameter e1 in model sersics */ float sersics_e1_min; /* Min value of parameter e2 in model sersics */ float sersics_e2_min; /* Min value of parameter radius in model sersics */ float sersics_radius_min; /* Min value of parameter radius_ratio in model sersics */ float sersics_radius_ratio_min; /* Min value of parameter bulge_A in model sersics */ float sersics_bulge_A_min; /* Min value of parameter disc_A in model sersics */ float sersics_disc_A_min; /* Min value of parameter bulge_index in model sersics */ float sersics_bulge_index_min; /* Min value of parameter disc_index in model sersics */ float sersics_disc_index_min; /* Min value of parameter delta_e_bulge in model sersics */ float sersics_delta_e_bulge_min; /* Min value of parameter delta_theta_bulge in model sersics */ float sersics_delta_theta_bulge_min; /* Max value of parameter x0 in model sersics */ float sersics_x0_max; /* Max value of parameter y0 in model sersics */ float sersics_y0_max; /* Max value of parameter e1 in model sersics */ float sersics_e1_max; /* Max value of parameter e2 in model sersics */ float sersics_e2_max; /* Max value of parameter radius in model sersics */ float sersics_radius_max; /* Max value of parameter radius_ratio in model sersics */ float sersics_radius_ratio_max; /* Max value of parameter bulge_A in model sersics */ float sersics_bulge_A_max; /* Max value of parameter disc_A in model sersics */ float sersics_disc_A_max; /* Max value of parameter bulge_index in model sersics */ float sersics_bulge_index_max; /* Max value of parameter disc_index in model sersics */ float sersics_disc_index_max; /* Max value of parameter delta_e_bulge in model sersics */ float sersics_delta_e_bulge_max; /* Max value of parameter delta_theta_bulge in model sersics */ float sersics_delta_theta_bulge_max; /* Whether to fix the value of parameter x0 in model sersics */ bool sersics_x0_fixed; /* Whether to fix the value of parameter y0 in model sersics */ bool sersics_y0_fixed; /* Whether to fix the value of parameter e1 in model sersics */ bool sersics_e1_fixed; /* Whether to fix the value of parameter e2 in model sersics */ bool sersics_e2_fixed; /* Whether to fix the value of parameter radius in model sersics */ bool sersics_radius_fixed; /* Whether to fix the value of parameter radius_ratio in model sersics */ bool sersics_radius_ratio_fixed; /* Whether to fix the value of parameter bulge_A in model sersics */ bool sersics_bulge_A_fixed; /* Whether to fix the value of parameter disc_A in model sersics */ bool sersics_disc_A_fixed; /* Whether to fix the value of parameter bulge_index in model sersics */ bool sersics_bulge_index_fixed; /* Whether to fix the value of parameter disc_index in model sersics */ bool sersics_disc_index_fixed; /* Whether to fix the value of parameter delta_e_bulge in model sersics */ bool sersics_delta_e_bulge_fixed; /* Whether to fix the value of parameter delta_theta_bulge in model sersics */ bool sersics_delta_theta_bulge_fixed; /* * Options for model logsersics */ /* Initial value of parameter x0 in model logsersics */ float logsersics_x0_start; /* Initial value of parameter y0 in model logsersics */ float logsersics_y0_start; /* Initial value of parameter e1 in model logsersics */ float logsersics_e1_start; /* Initial value of parameter e2 in model logsersics */ float logsersics_e2_start; /* Initial value of parameter radius in model logsersics */ float logsersics_radius_start; /* Initial value of parameter radius_ratio in model logsersics */ float logsersics_radius_ratio_start; /* Initial value of parameter bulge_A in model logsersics */ float logsersics_bulge_A_start; /* Initial value of parameter disc_A in model logsersics */ float logsersics_disc_A_start; /* Initial value of parameter bulge_index in model logsersics */ float logsersics_bulge_index_start; /* Initial value of parameter disc_index in model logsersics */ float logsersics_disc_index_start; /* Initial value of parameter delta_e_bulge in model logsersics */ float logsersics_delta_e_bulge_start; /* Initial value of parameter delta_theta_bulge in model logsersics */ float logsersics_delta_theta_bulge_start; /* Initial value of parameter x0 in model logsersics */ float logsersics_x0_width; /* Initial value of parameter y0 in model logsersics */ float logsersics_y0_width; /* Initial value of parameter e1 in model logsersics */ float logsersics_e1_width; /* Initial value of parameter e2 in model logsersics */ float logsersics_e2_width; /* Initial value of parameter radius in model logsersics */ float logsersics_radius_width; /* Initial value of parameter radius_ratio in model logsersics */ float logsersics_radius_ratio_width; /* Initial value of parameter bulge_A in model logsersics */ float logsersics_bulge_A_width; /* Initial value of parameter disc_A in model logsersics */ float logsersics_disc_A_width; /* Initial value of parameter bulge_index in model logsersics */ float logsersics_bulge_index_width; /* Initial value of parameter disc_index in model logsersics */ float logsersics_disc_index_width; /* Initial value of parameter delta_e_bulge in model logsersics */ float logsersics_delta_e_bulge_width; /* Initial value of parameter delta_theta_bulge in model logsersics */ float logsersics_delta_theta_bulge_width; /* Min value of parameter x0 in model logsersics */ float logsersics_x0_min; /* Min value of parameter y0 in model logsersics */ float logsersics_y0_min; /* Min value of parameter e1 in model logsersics */ float logsersics_e1_min; /* Min value of parameter e2 in model logsersics */ float logsersics_e2_min; /* Min value of parameter radius in model logsersics */ float logsersics_radius_min; /* Min value of parameter radius_ratio in model logsersics */ float logsersics_radius_ratio_min; /* Min value of parameter bulge_A in model logsersics */ float logsersics_bulge_A_min; /* Min value of parameter disc_A in model logsersics */ float logsersics_disc_A_min; /* Min value of parameter bulge_index in model logsersics */ float logsersics_bulge_index_min; /* Min value of parameter disc_index in model logsersics */ float logsersics_disc_index_min; /* Min value of parameter delta_e_bulge in model logsersics */ float logsersics_delta_e_bulge_min; /* Min value of parameter delta_theta_bulge in model logsersics */ float logsersics_delta_theta_bulge_min; /* Max value of parameter x0 in model logsersics */ float logsersics_x0_max; /* Max value of parameter y0 in model logsersics */ float logsersics_y0_max; /* Max value of parameter e1 in model logsersics */ float logsersics_e1_max; /* Max value of parameter e2 in model logsersics */ float logsersics_e2_max; /* Max value of parameter radius in model logsersics */ float logsersics_radius_max; /* Max value of parameter radius_ratio in model logsersics */ float logsersics_radius_ratio_max; /* Max value of parameter bulge_A in model logsersics */ float logsersics_bulge_A_max; /* Max value of parameter disc_A in model logsersics */ float logsersics_disc_A_max; /* Max value of parameter bulge_index in model logsersics */ float logsersics_bulge_index_max; /* Max value of parameter disc_index in model logsersics */ float logsersics_disc_index_max; /* Max value of parameter delta_e_bulge in model logsersics */ float logsersics_delta_e_bulge_max; /* Max value of parameter delta_theta_bulge in model logsersics */ float logsersics_delta_theta_bulge_max; /* Whether to fix the value of parameter x0 in model logsersics */ bool logsersics_x0_fixed; /* Whether to fix the value of parameter y0 in model logsersics */ bool logsersics_y0_fixed; /* Whether to fix the value of parameter e1 in model logsersics */ bool logsersics_e1_fixed; /* Whether to fix the value of parameter e2 in model logsersics */ bool logsersics_e2_fixed; /* Whether to fix the value of parameter radius in model logsersics */ bool logsersics_radius_fixed; /* Whether to fix the value of parameter radius_ratio in model logsersics */ bool logsersics_radius_ratio_fixed; /* Whether to fix the value of parameter bulge_A in model logsersics */ bool logsersics_bulge_A_fixed; /* Whether to fix the value of parameter disc_A in model logsersics */ bool logsersics_disc_A_fixed; /* Whether to fix the value of parameter bulge_index in model logsersics */ bool logsersics_bulge_index_fixed; /* Whether to fix the value of parameter disc_index in model logsersics */ bool logsersics_disc_index_fixed; /* Whether to fix the value of parameter delta_e_bulge in model logsersics */ bool logsersics_delta_e_bulge_fixed; /* Whether to fix the value of parameter delta_theta_bulge in model logsersics */ bool logsersics_delta_theta_bulge_fixed; /* * Options for model quadratic_test */ /* Initial value of parameter x1 in model quadratic_test */ float quadratic_test_x1_start; /* Initial value of parameter x2 in model quadratic_test */ float quadratic_test_x2_start; /* Initial value of parameter x3 in model quadratic_test */ float quadratic_test_x3_start; /* Initial value of parameter x4 in model quadratic_test */ float quadratic_test_x4_start; /* Initial value of parameter x5 in model quadratic_test */ float quadratic_test_x5_start[3]; /* Initial value of parameter x1 in model quadratic_test */ float quadratic_test_x1_width; /* Initial value of parameter x2 in model quadratic_test */ float quadratic_test_x2_width; /* Initial value of parameter x3 in model quadratic_test */ float quadratic_test_x3_width; /* Initial value of parameter x4 in model quadratic_test */ float quadratic_test_x4_width; /* Initial value of parameter x5 in model quadratic_test */ float quadratic_test_x5_width[3]; /* Min value of parameter x1 in model quadratic_test */ float quadratic_test_x1_min; /* Min value of parameter x2 in model quadratic_test */ float quadratic_test_x2_min; /* Min value of parameter x3 in model quadratic_test */ float quadratic_test_x3_min; /* Min value of parameter x4 in model quadratic_test */ float quadratic_test_x4_min; /* Min value of parameter x5 in model quadratic_test */ float quadratic_test_x5_min[3]; /* Max value of parameter x1 in model quadratic_test */ float quadratic_test_x1_max; /* Max value of parameter x2 in model quadratic_test */ float quadratic_test_x2_max; /* Max value of parameter x3 in model quadratic_test */ float quadratic_test_x3_max; /* Max value of parameter x4 in model quadratic_test */ float quadratic_test_x4_max; /* Max value of parameter x5 in model quadratic_test */ float quadratic_test_x5_max[3]; /* Whether to fix the value of parameter x1 in model quadratic_test */ bool quadratic_test_x1_fixed; /* Whether to fix the value of parameter x2 in model quadratic_test */ bool quadratic_test_x2_fixed; /* Whether to fix the value of parameter x3 in model quadratic_test */ bool quadratic_test_x3_fixed; /* Whether to fix the value of parameter x4 in model quadratic_test */ bool quadratic_test_x4_fixed; /* Whether to fix the value of parameter x5 in model quadratic_test */ bool quadratic_test_x5_fixed; /* * Options for model multisersics */ /* Initial value of parameter ra_as in model multisersics */ float multisersics_ra_as_start; /* Initial value of parameter dec_as in model multisersics */ float multisersics_dec_as_start; /* Initial value of parameter e1 in model multisersics */ float multisersics_e1_start; /* Initial value of parameter e2 in model multisersics */ float multisersics_e2_start; /* Initial value of parameter radius in model multisersics */ float multisersics_radius_start; /* Initial value of parameter radius_ratio in model multisersics */ float multisersics_radius_ratio_start; /* Initial value of parameter bulge_A in model multisersics */ float multisersics_bulge_A_start; /* Initial value of parameter disc_A in model multisersics */ float multisersics_disc_A_start; /* Initial value of parameter bulge_index in model multisersics */ float multisersics_bulge_index_start; /* Initial value of parameter disc_index in model multisersics */ float multisersics_disc_index_start; /* Initial value of parameter ra_as in model multisersics */ float multisersics_ra_as_width; /* Initial value of parameter dec_as in model multisersics */ float multisersics_dec_as_width; /* Initial value of parameter e1 in model multisersics */ float multisersics_e1_width; /* Initial value of parameter e2 in model multisersics */ float multisersics_e2_width; /* Initial value of parameter radius in model multisersics */ float multisersics_radius_width; /* Initial value of parameter radius_ratio in model multisersics */ float multisersics_radius_ratio_width; /* Initial value of parameter bulge_A in model multisersics */ float multisersics_bulge_A_width; /* Initial value of parameter disc_A in model multisersics */ float multisersics_disc_A_width; /* Initial value of parameter bulge_index in model multisersics */ float multisersics_bulge_index_width; /* Initial value of parameter disc_index in model multisersics */ float multisersics_disc_index_width; /* Min value of parameter ra_as in model multisersics */ float multisersics_ra_as_min; /* Min value of parameter dec_as in model multisersics */ float multisersics_dec_as_min; /* Min value of parameter e1 in model multisersics */ float multisersics_e1_min; /* Min value of parameter e2 in model multisersics */ float multisersics_e2_min; /* Min value of parameter radius in model multisersics */ float multisersics_radius_min; /* Min value of parameter radius_ratio in model multisersics */ float multisersics_radius_ratio_min; /* Min value of parameter bulge_A in model multisersics */ float multisersics_bulge_A_min; /* Min value of parameter disc_A in model multisersics */ float multisersics_disc_A_min; /* Min value of parameter bulge_index in model multisersics */ float multisersics_bulge_index_min; /* Min value of parameter disc_index in model multisersics */ float multisersics_disc_index_min; /* Max value of parameter ra_as in model multisersics */ float multisersics_ra_as_max; /* Max value of parameter dec_as in model multisersics */ float multisersics_dec_as_max; /* Max value of parameter e1 in model multisersics */ float multisersics_e1_max; /* Max value of parameter e2 in model multisersics */ float multisersics_e2_max; /* Max value of parameter radius in model multisersics */ float multisersics_radius_max; /* Max value of parameter radius_ratio in model multisersics */ float multisersics_radius_ratio_max; /* Max value of parameter bulge_A in model multisersics */ float multisersics_bulge_A_max; /* Max value of parameter disc_A in model multisersics */ float multisersics_disc_A_max; /* Max value of parameter bulge_index in model multisersics */ float multisersics_bulge_index_max; /* Max value of parameter disc_index in model multisersics */ float multisersics_disc_index_max; /* Whether to fix the value of parameter ra_as in model multisersics */ bool multisersics_ra_as_fixed; /* Whether to fix the value of parameter dec_as in model multisersics */ bool multisersics_dec_as_fixed; /* Whether to fix the value of parameter e1 in model multisersics */ bool multisersics_e1_fixed; /* Whether to fix the value of parameter e2 in model multisersics */ bool multisersics_e2_fixed; /* Whether to fix the value of parameter radius in model multisersics */ bool multisersics_radius_fixed; /* Whether to fix the value of parameter radius_ratio in model multisersics */ bool multisersics_radius_ratio_fixed; /* Whether to fix the value of parameter bulge_A in model multisersics */ bool multisersics_bulge_A_fixed; /* Whether to fix the value of parameter disc_A in model multisersics */ bool multisersics_disc_A_fixed; /* Whether to fix the value of parameter bulge_index in model multisersics */ bool multisersics_bulge_index_fixed; /* Whether to fix the value of parameter disc_index in model multisersics */ bool multisersics_disc_index_fixed; /* * Options for model multixray */ /* Initial value of parameter alpha_arcsec in model multixray */ float multixray_alpha_arcsec_start; /* Initial value of parameter delta_arcsec in model multixray */ float multixray_delta_arcsec_start; /* Initial value of parameter e1 in model multixray */ float multixray_e1_start; /* Initial value of parameter e2 in model multixray */ float multixray_e2_start; /* Initial value of parameter rc in model multixray */ float multixray_rc_start; /* Initial value of parameter A in model multixray */ float multixray_A_start; /* Initial value of parameter beta in model multixray */ float multixray_beta_start; /* Initial value of parameter background in model multixray */ float multixray_background_start[30]; /* Initial value of parameter alpha_arcsec in model multixray */ float multixray_alpha_arcsec_width; /* Initial value of parameter delta_arcsec in model multixray */ float multixray_delta_arcsec_width; /* Initial value of parameter e1 in model multixray */ float multixray_e1_width; /* Initial value of parameter e2 in model multixray */ float multixray_e2_width; /* Initial value of parameter rc in model multixray */ float multixray_rc_width; /* Initial value of parameter A in model multixray */ float multixray_A_width; /* Initial value of parameter beta in model multixray */ float multixray_beta_width; /* Initial value of parameter background in model multixray */ float multixray_background_width[30]; /* Min value of parameter alpha_arcsec in model multixray */ float multixray_alpha_arcsec_min; /* Min value of parameter delta_arcsec in model multixray */ float multixray_delta_arcsec_min; /* Min value of parameter e1 in model multixray */ float multixray_e1_min; /* Min value of parameter e2 in model multixray */ float multixray_e2_min; /* Min value of parameter rc in model multixray */ float multixray_rc_min; /* Min value of parameter A in model multixray */ float multixray_A_min; /* Min value of parameter beta in model multixray */ float multixray_beta_min; /* Min value of parameter background in model multixray */ float multixray_background_min[30]; /* Max value of parameter alpha_arcsec in model multixray */ float multixray_alpha_arcsec_max; /* Max value of parameter delta_arcsec in model multixray */ float multixray_delta_arcsec_max; /* Max value of parameter e1 in model multixray */ float multixray_e1_max; /* Max value of parameter e2 in model multixray */ float multixray_e2_max; /* Max value of parameter rc in model multixray */ float multixray_rc_max; /* Max value of parameter A in model multixray */ float multixray_A_max; /* Max value of parameter beta in model multixray */ float multixray_beta_max; /* Max value of parameter background in model multixray */ float multixray_background_max[30]; /* Whether to fix the value of parameter alpha_arcsec in model multixray */ bool multixray_alpha_arcsec_fixed; /* Whether to fix the value of parameter delta_arcsec in model multixray */ bool multixray_delta_arcsec_fixed; /* Whether to fix the value of parameter e1 in model multixray */ bool multixray_e1_fixed; /* Whether to fix the value of parameter e2 in model multixray */ bool multixray_e2_fixed; /* Whether to fix the value of parameter rc in model multixray */ bool multixray_rc_fixed; /* Whether to fix the value of parameter A in model multixray */ bool multixray_A_fixed; /* Whether to fix the value of parameter beta in model multixray */ bool multixray_beta_fixed; /* Whether to fix the value of parameter background in model multixray */ bool multixray_background_fixed; /* * Advanced Options - THESE ARE EXPERIMENTAL - USE AT OWN RISK */ /* Whether to perform a full MCMC. If not, just get the maximum posterior solution. */ bool do_mcmc; /* Number of loops of the minimizer to perform */ int minimizer_loops; /* Whether to save images of the sersic image within the likelihood function */ bool save_sersics; /* Model of the PSF to use, currently supported "moffat_catalog", "psf_image_cube", "psf_image_single", "psfex" and "shapelet" */ char psf_input[i3_options_max_line_length] ; /* Whether to perform pixel integration during convolution. If effective PSF is provided, set this option to False. */ bool perform_pixel_integration; /* Whether to use a galaxy segmentation mask for fitting. */ bool use_segmentation_mask; /* Filename of galaxy segmentation mask. */ char segmentation_mask_filename[i3_options_max_line_length] ; /* Whether to use Hankel transform trick to speed up model generation */ bool use_hankel_transform; /* If yes, then constrain the amplitudes of bulge and disc to be positive, using beermat */ bool sersics_beermat_amplitudes_positive; /* Path to a data file containing a Sersic Fourier lookup table */ char sersic_lookup_file[i3_options_max_line_length] ; /* Use analytic gradients */ bool levmar_use_analytic_gradients; /* Check analytic gradients */ bool levmar_check_analytic_gradients; /* If im3generate creates high resolution images */ bool image_generator_resolution_high; /* Minimizer verbosity level [0-4] */ int minimizer_verbosity; /* Minimizer method 0=levmar 1=simplex 2=powell 3=praxis 4=golden */ int minimizer_method; /* Use Poisson errors for the xray model */ bool poisson_errors; /* Time parameter estimation time */ bool timeit; /* Make the post stamp circular by masking out pixels around the edge */ bool circularize_mask; /* * MCMC Options - EXPERIMENTAL */ /* The number of MCMC samples to generate */ int number_samples; /* The length of the MCMC burn-in phase. Must be < number_samples */ int burn_length; /* The length of the MCMC tuning phase. This comes after the burn period and tunes the covariance. */ int tuning_phase; /* The MCMC proposal scaling factor. */ float scaling; /* Whether or not to rotate proposals */ bool do_rotation; /* Periodically tune the proposal covariance during the tuning phase */ bool mcmc_tune_covmat; /* Initial temperature of annealing. */ float max_annealing_temperature; /* Fraction of the way through the chain that the temperature should reach one. Schedule is linear */ float annealing_one_point; /* Interval between adaptive metropolis calls */ int adaptive_metropolis_interval; /* Climb the hill only; reject jumps that reduce likelihood */ bool climbing_only; /* If set, must include a %ld somewhere. Save MCMC output to this with the galaxy identifier */ char mcmc_filename_base[i3_options_max_line_length] ; /* Whether to use the mean of the MCMC distribution instead of the maximum likelihood */ bool use_mcmc_mean; /* Whether to use the final sample of the MCMC instead of the maximum likelihood */ bool use_mcmc_sample; /* Print all the MCMC samples to stdout. */ bool print_mcmc_samples; /* * MEDS Options - Probably DES only */ /* Do not optimize; just use initial params. */ bool starting_params_only; /* Rescale the weights so that the edge pixels have the correct std dev. */ bool rescale_weight; /* Use the ubserseg masking algorithm. */ bool uberseg; /* Use the MEDS image flags to select exposures. */ bool use_image_flags; /* Use the ubserseg masking algorithm. */ bool reject_outliers; /* Replace the path in the PSF using this comma-separated pair old,new */ char replace_psf_path[i3_options_max_line_length] ; /* Use the Jarvis re-run PSF with this version */ char psfex_rerun_version[i3_options_max_line_length] ; /* Output to database instead of file */ bool database_output; } i3_options; i3_options * i3_options_default(); void i3_options_destroy(i3_options * options); /* Read an option list from the named file. Use after setting defaults. */ int i3_options_read(i3_options * options, char * filename); void i3_options_read_command_line(i3_options * options, int argc, int start, char *argv[]); /*Set default values for all the parameters.*/ void i3_options_set_defaults(i3_options * options); /* Print the option set to an already opened file. The file is saved such that it can be re-read directly. */ void i3_options_fprintf(i3_options * options, FILE * outfile); /* Print the option set to screen */ void i3_options_printf(i3_options * options); /*Save the option set to the named file. */ void i3_options_save(i3_options * options, char * filename); /*Internal: Called when a parameter value cannot be read.*/ void i3_options_report_parameter_fail(char * parameter,char * type); /* Internal: option value parser */ int i3_options_parse_int(char * parameter, int * status); /* Internal: option value parser */ float i3_options_parse_float(char * parameter, int * status); /* Internal: option value parser */ double i3_options_parse_double(char * parameter, int * status); /* Internal: option value parser */ bool i3_options_parse_bool(char * parameter, int * status); /* Internal: option value parser */ void i3_options_parse_float_array(float * array, char * text, int len, int * status); /* Internal: option value parser */ void i3_options_parse_double_array(double * array, char * text, int len, int * status); /*Internal: Split the line into two parts, stripping whitespace and comments*/ int i3_options_split_parts(char * line, char * parameter_name, char * parameter_value); /* Internal: Sets structure parameter from name and value */ int i3_options_handle_name_value(i3_options * options, char * name, char * value); int i3_options_handle_name_value_body(i3_options * options, char * name, char * value, bool try_model, int * status); #endif