ctools 2.1.0.dev
Loading...
Searching...
No Matches
ctulimit Class Reference

Upper limit calculation tool. More...

#include <ctulimit.hpp>

Inheritance diagram for ctulimit:
ctlikelihood ctobservation ctool GApplication

Public Member Functions

 ctulimit (void)
 Void constructor.
 
 ctulimit (const GObservations &obs)
 Observations constructor.
 
 ctulimit (int argc, char *argv[])
 Command line constructor.
 
 ctulimit (const ctulimit &app)
 Copy constructor.
 
virtual ~ctulimit (void)
 Destructor.
 
ctulimitoperator= (const ctulimit &app)
 Assignment operator.
 
void clear (void)
 Clear ctulimit tool.
 
void process (void)
 Compute upper limit.
 
void save (void)
 Save upper limits.
 
const double & diff_ulimit (void) const
 Return differential upper limit.
 
const double & flux_ulimit (void) const
 Return flux upper limit.
 
const double & eflux_ulimit (void) const
 return energy flux upper limit
 
- Public Member Functions inherited from ctlikelihood
 ctlikelihood (const std::string &name, const std::string &version)
 Name constructor.
 
 ctlikelihood (const std::string &name, const std::string &version, const GApplicationPars &pars)
 Application parameters constructor.
 
 ctlikelihood (const std::string &name, const std::string &version, int argc, char *argv[])
 Command line constructor.
 
 ctlikelihood (const std::string &name, const std::string &version, const GObservations &obs)
 Observations constructor.
 
 ctlikelihood (const ctlikelihood &app)
 Copy constructor.
 
virtual ~ctlikelihood (void)
 Destructor.
 
ctlikelihoodoperator= (const ctlikelihood &app)
 Assignment operator.
 
void opt (const GOptimizer *opt)
 Set optimizer.
 
const GOptimizer * opt (void) const
 Return optimizer.
 
- Public Member Functions inherited from ctobservation
 ctobservation (const std::string &name, const std::string &version)
 Name constructor.
 
 ctobservation (const std::string &name, const std::string &version, const GApplicationPars &pars)
 Application parameters constructor.
 
 ctobservation (const std::string &name, const std::string &version, int argc, char *argv[])
 Command line constructor.
 
 ctobservation (const std::string &name, const std::string &version, const GObservations &obs)
 Observations constructor.
 
 ctobservation (const ctobservation &app)
 Copy constructor.
 
virtual ~ctobservation (void)
 Destructor.
 
ctobservationoperator= (const ctobservation &app)
 Assignment operator.
 
void obs (const GObservations &obs)
 Set observation container.
 
const GObservations & obs (void) const
 Return observation container.
 
- Public Member Functions inherited from ctool
 ctool (const std::string &name, const std::string &version)
 Name constructor.
 
 ctool (const std::string &name, const std::string &version, const GApplicationPars &pars)
 Application parameter constructor.
 
 ctool (const std::string &name, const std::string &version, int argc, char *argv[])
 Command line constructor.
 
 ctool (const ctool &app)
 Copy constructor.
 
virtual ~ctool (void)
 Destructor.
 
ctooloperator= (const ctool &app)
 Assignment operator.
 
virtual void run (void)
 Run ctool.
 
virtual void execute (void)
 Execute ctool.
 

Protected Member Functions

void init_members (void)
 Initialise class members.
 
void copy_members (const ctulimit &app)
 Copy class members.
 
void free_members (void)
 Delete class members.
 
void get_parameters (void)
 Get application parameters.
 
void get_model_parameter (void)
 Get model parameter.
 
void get_parameter_brackets (double &parmin, double &parmax)
 Determine parameter brackets.
 
void ulimit_bisection (const double &parmin, const double &parmax)
 Calculate upper limit using a bisection method.
 
void compute_ulimit (void)
 Compute upper limit intensity and fluxes.
 
- Protected Member Functions inherited from ctlikelihood
double evaluate (GModelPar &par, const double &value)
 Evaluates the log-likelihood function.
 
void init_members (void)
 Initialise class members.
 
void copy_members (const ctlikelihood &app)
 Copy class members.
 
void free_members (void)
 Delete class members.
 
- Protected Member Functions inherited from ctobservation
GCTAObservation * first_unbinned_observation (void)
 Return first unbinned CTA observation.
 
GCTAObservation * next_unbinned_observation (void)
 Return next unbinned CTA observation.
 
const GCTAObservation * first_unbinned_observation (void) const
 Return first unbinned CTA observation (const version)
 
const GCTAObservation * next_unbinned_observation (void) const
 Return next unbinned CTA observation (const version)
 
void read_ogip_keywords (GFitsHDU *hdu) const
 Read OGIP keywords from FITS HDU.
 
void write_ogip_keywords (GFitsHDU *hdu) const
 Write OGIP keywords in FITS HDU.
 
void set_obs_statistic (const std::string &statistic)
 Set fit statistic for CTA observations.
 
void set_obs_bounds ()
 Set observation boundaries for CTA observations.
 
void save_events_fits (void)
 Save event list in FITS format.
 
void save_events_xml (void)
 Save event list(s) in XML format.
 
void init_members (void)
 Initialise class members.
 
void copy_members (const ctobservation &app)
 Copy class members.
 
void free_members (void)
 Delete class members.
 
- Protected Member Functions inherited from ctool
void init_members (void)
 Initialise class members.
 
void copy_members (const ctool &app)
 Copy class members.
 
void free_members (void)
 Delete class members.
 
void sync_pfiles (void)
 Synchronise parameter files.
 
const bool & read_ahead (void) const
 Signal whether parameters should be read ahead.
 
void setup_observations (GObservations &obs, const bool &response=true, const bool &list=true, const bool &cube=true)
 Setup observation container.
 
void setup_models (GObservations &obs, const std::string &name="")
 Setup model container.
 
GEbounds create_ebounds (void)
 Create energy boundaries from user parameters.
 
GEnergies create_energies (void)
 Create energies from user parameters.
 
GSkyMap create_map (const GObservations &obs)
 Create a skymap from user parameters.
 
GCTAEventCube create_cube (const GObservations &obs)
 Create a CTA event cube from user parameters.
 
GCTAObservation create_cta_obs (void)
 Create a CTA observation from User parameters.
 
void require_inobs (const std::string &method)
 Throws exception if inobs parameter is not valid.
 
void require_inobs_nolist (const std::string &method)
 
void require_inobs_nocube (const std::string &method)
 Throws exception if inobs parameter is a counts cube.
 
GCTARoi get_roi (const GCTAPointing &pnt=GCTAPointing())
 Return RoI from User parameters.
 
GEbounds get_ebounds (void)
 Return energy boundaries from User parameters.
 
GGti get_gti (const GTimeReference &ref)
 Return Good Time Intervals from User parameter.
 
GCTAPointing get_pointing (void)
 Return CTA pointing from User parameters.
 
GSkyDir get_skydir (void)
 Return sky direction from User parameters.
 
std::string set_outfile_name (const std::string &filename)
 Set output file name.
 
bool is_stacked (void)
 Query user parameters for stacked analysis.
 
bool is_onoff (void)
 Query user parameters for On/Off analysis.
 
void log_parameters (const GChatter &chatter)
 Log application parameters.
 
void log_observations (const GChatter &chatter, const GObservations &obs, const std::string &what="Observation")
 Log observation container.
 
void log_models (const GChatter &chatter, const GModels &models, const std::string &what="Model")
 Log model container.
 
void set_response (GObservations &obs)
 Set response for all CTA observations in container.
 
std::vector< bool > set_edisp (GObservations &obs, const bool &edisp) const
 Set energy dispersion to CTA observations.
 
void restore_edisp (GObservations &obs, const std::vector< bool > &edisp) const
 Restore energy dispersion flags of CTA observations.
 
void set_obs_response (GCTAObservation *obs)
 Set response for CTA observation.
 
GObservations get_observations (const bool &get_response=true)
 Get observation container.
 
GSkyDir get_mean_pointing (const GObservations &obs)
 Derives mean pointing from CTA observations.
 
size_t get_current_rss (void)
 Get current resident set size (physical memory use) in Bytes.
 
std::string get_obs_header (const GObservation *obs) const
 Return observation header string.
 
GEnergies insert_energy_boundaries (const GEnergies &energies, const GCTAObservation &obs)
 Insert observation energy boundaries into list of energies.
 
std::vector< bool > cube_layer_usage (const GEbounds &cube_ebounds, const GEbounds &list_ebounds) const
 Determine the counts cube layer usage.
 
std::string get_gtiname (const std::string &filename, const std::string &evtname) const
 Get Good Time Intervals extension name.
 
void save_event_list (const GCTAObservation *obs, const std::string &infile, const std::string &evtname, const std::string &gtiname, const std::string &outfile) const
 Save event list into FITS file.
 
std::string warn_too_few_energies (const GEnergies &energies) const
 Set warning string if there are too few energies.
 
std::string warn_xml_suffix (const GFilename &filename) const
 Set warning string if file has no .xml suffix.
 
void provide_help (void) const
 Dump help text in the console.
 

Protected Attributes

std::string m_srcname
 Name of source for upper limit computation.
 
std::string m_parname
 Name of parameter for upper limit computation.
 
double m_confidence
 Confidence level.
 
double m_sigma_min
 Starting value minimum (multiple fit errors above fit values)
 
double m_sigma_max
 Starting value maximum (multiple fit errors above fit values)
 
double m_eref
 Reference energy for flux limits (TeV)
 
double m_emin
 Minimum energy for flux limits (TeV)
 
double m_emax
 Maximum energy for flux limits (TeV)
 
double m_tol
 Tolerance for limit determination.
 
int m_max_iter
 Maximum number of iterations.
 
bool m_apply_edisp
 Apply energy dispersion?
 
GChatter m_chatter
 Chattiness.
 
double m_dlogL
 Likelihood difference for upper limit computation.
 
double m_best_logL
 Best fit log likelihood of given model.
 
double m_best_value
 Best parameter value factor.
 
double m_best_error
 Best parameter value error.
 
double m_diff_ulimit
 Differential upper limit value.
 
double m_flux_ulimit
 Flux upper limit value.
 
double m_eflux_ulimit
 Energy flux upper limits.
 
GModelSky * m_skymodel
 Pointer to sky model.
 
GModelPar * m_model_par
 Pointer to model parameter.
 
bool m_is_spatial
 Signal that model parameter is spatial parameter.
 
- Protected Attributes inherited from ctlikelihood
GOptimizerLM m_opt
 Optimizer.
 
- Protected Attributes inherited from ctobservation
GObservations m_obs
 Observation container.
 
- Protected Attributes inherited from ctool
bool m_read_ahead
 Read ahead output parameters.
 
bool m_use_xml
 Use XML file instead of FITS file for observations.
 

Detailed Description

Upper limit calculation tool.

This class computes and upper limit for a given source.

The class operates on predefined observation containers, an individual event list or an observation definition XML file.

During the computation the likelihood function is inspected to find the best value for the upper limit.

Definition at line 50 of file ctulimit.hpp.

Constructor & Destructor Documentation

◆ ctulimit() [1/4]

ctulimit::ctulimit ( void )

Void constructor.

Constructs an empty ctulimit tool.

Definition at line 58 of file ctulimit.cpp.

References init_members().

◆ ctulimit() [2/4]

ctulimit::ctulimit ( const GObservations & obs)
explicit

Observations constructor.

param[in] obs Observation container.

Constructs ctulimit tool from an observations container.

Definition at line 75 of file ctulimit.cpp.

References init_members().

◆ ctulimit() [3/4]

ctulimit::ctulimit ( int argc,
char * argv[] )

Command line constructor.

Parameters
[in]argcNumber of arguments in command line.
[in]argvArray of command line arguments.

Constructs an instance of the ctulimit tool that will parse user parameters that are provided as command line arguments.

Definition at line 96 of file ctulimit.cpp.

References init_members().

◆ ctulimit() [4/4]

ctulimit::ctulimit ( const ctulimit & app)

Copy constructor.

Parameters
[in]appApplication.

Constructs an instance of the ctulimit tool by copying information from another ctulimit tool.

Definition at line 115 of file ctulimit.cpp.

References copy_members(), and init_members().

◆ ~ctulimit()

ctulimit::~ctulimit ( void )
virtual

Destructor.

Destructs the ctulimit tool.

Definition at line 133 of file ctulimit.cpp.

References free_members().

Member Function Documentation

◆ clear()

void ctulimit::clear ( void )
virtual

Clear ctulimit tool.

Resets the ctulimit tool to a clean initial state.

Implements ctlikelihood.

Definition at line 192 of file ctulimit.cpp.

References ctlikelihood::free_members(), ctobservation::free_members(), ctool::free_members(), free_members(), ctlikelihood::init_members(), ctobservation::init_members(), ctool::init_members(), and init_members().

◆ compute_ulimit()

void ctulimit::compute_ulimit ( void )
protected

Compute upper limit intensity and fluxes.

Compute upper limit intensity and fluxes, including a correct computation for the diffuse map cube models.

Definition at line 834 of file ctulimit.cpp.

References m_diff_ulimit, m_eflux_ulimit, m_emax, m_emin, m_eref, m_flux_ulimit, and m_skymodel.

Referenced by process().

◆ copy_members()

void ctulimit::copy_members ( const ctulimit & app)
protected

◆ diff_ulimit()

const double & ctulimit::diff_ulimit ( void ) const
inline

Return differential upper limit.

Returns
Differential upper flux limit.

Definition at line 116 of file ctulimit.hpp.

References m_diff_ulimit.

◆ eflux_ulimit()

const double & ctulimit::eflux_ulimit ( void ) const
inline

return energy flux upper limit

Returns
Upper energy flux limit.

Definition at line 140 of file ctulimit.hpp.

References m_eflux_ulimit.

◆ flux_ulimit()

const double & ctulimit::flux_ulimit ( void ) const
inline

Return flux upper limit.

Returns
Upper flux limit.

Definition at line 128 of file ctulimit.hpp.

References m_flux_ulimit.

◆ free_members()

void ctulimit::free_members ( void )
protected

Delete class members.

Definition at line 434 of file ctulimit.cpp.

Referenced by clear(), operator=(), and ~ctulimit().

◆ get_model_parameter()

void ctulimit::get_model_parameter ( void )
protected

Get model parameter.

Exceptions
GException::invalid_valueDid not find a valid model or model parameter

Extracts a pointer to the sky model (m_skymodel) and a pointer to the model parameter (m_model_par) that should be varied for the upper limit determination from the model container.

Definition at line 510 of file ctulimit.cpp.

References G_GET_MODEL_PARAMETER, m_is_spatial, m_model_par, ctobservation::m_obs, m_parname, m_skymodel, and m_srcname.

Referenced by copy_members(), and get_parameters().

◆ get_parameter_brackets()

void ctulimit::get_parameter_brackets ( double & parmin,
double & parmax )
protected

Determine parameter brackets.

Parameters
[out]parminMinimum parameter value.
[out]parmaxMaximum parameter value.
Exceptions
GException::invalid_valueExceeded maximum number of iterations in the bracket search.

Determines the brackets for the parameter of interest.

Definition at line 620 of file ctulimit.cpp.

References ctlikelihood::evaluate(), G_GET_PARAMETER_BRACKETS, m_best_error, m_best_logL, m_best_value, m_dlogL, m_is_spatial, m_max_iter, m_model_par, ctobservation::m_obs, m_sigma_max, m_sigma_min, and m_srcname.

Referenced by process().

◆ get_parameters()

void ctulimit::get_parameters ( void )
protected

◆ init_members()

◆ operator=()

ctulimit & ctulimit::operator= ( const ctulimit & app)

Assignment operator.

Parameters
[in]appApplication.
Returns
Application.

Assigns a ctulimit tool.

Definition at line 157 of file ctulimit.cpp.

References copy_members(), free_members(), init_members(), and ctlikelihood::operator=().

◆ process()

◆ save()

void ctulimit::save ( void )
virtual

Save upper limits.

Saves the upper limit to an ASCII file in comma-separated value format.

Todo
No yet implemented as we have no clear use case yet for saving the result.

Implements ctlikelihood.

Definition at line 344 of file ctulimit.cpp.

◆ ulimit_bisection()

void ctulimit::ulimit_bisection ( const double & parmin,
const double & parmax )
protected

Calculate upper limit using a bisection method.

Parameters
[in]parminMinimum parameter value
[in]parmaxMaximum parameter value
Exceptions
GException::invalid_valueExceeded maximum number of iterations in the upper limit search.

Calculates the upper limit using a bisection method. The bisection is stopped if the log-likelihood value is within the tolerance of the target value. The bisection is also stopped putting a warning in the log file if the parameter interval becomes smaller than a tolerance of 1.0e-6. The method stops with an exception if the maximum number of iterations is exhausted.

Definition at line 709 of file ctulimit.cpp.

References ctlikelihood::evaluate(), G_UL_BISECTION, m_best_logL, m_best_value, m_dlogL, m_is_spatial, m_max_iter, m_model_par, ctobservation::m_obs, m_srcname, and m_tol.

Referenced by process().

Member Data Documentation

◆ m_apply_edisp

bool ctulimit::m_apply_edisp
protected

Apply energy dispersion?

Definition at line 93 of file ctulimit.hpp.

Referenced by copy_members(), get_parameters(), init_members(), and process().

◆ m_best_error

double ctulimit::m_best_error
protected

Best parameter value error.

Definition at line 100 of file ctulimit.hpp.

Referenced by copy_members(), get_parameter_brackets(), and init_members().

◆ m_best_logL

double ctulimit::m_best_logL
protected

Best fit log likelihood of given model.

Definition at line 98 of file ctulimit.hpp.

Referenced by copy_members(), get_parameter_brackets(), init_members(), process(), and ulimit_bisection().

◆ m_best_value

double ctulimit::m_best_value
protected

Best parameter value factor.

Definition at line 99 of file ctulimit.hpp.

Referenced by copy_members(), get_parameter_brackets(), init_members(), process(), and ulimit_bisection().

◆ m_chatter

GChatter ctulimit::m_chatter
protected

Chattiness.

Definition at line 94 of file ctulimit.hpp.

Referenced by copy_members(), get_parameters(), init_members(), and process().

◆ m_confidence

double ctulimit::m_confidence
protected

Confidence level.

Definition at line 85 of file ctulimit.hpp.

Referenced by copy_members(), get_parameters(), init_members(), and process().

◆ m_diff_ulimit

double ctulimit::m_diff_ulimit
protected

Differential upper limit value.

Definition at line 101 of file ctulimit.hpp.

Referenced by compute_ulimit(), copy_members(), diff_ulimit(), init_members(), and process().

◆ m_dlogL

double ctulimit::m_dlogL
protected

Likelihood difference for upper limit computation.

Definition at line 97 of file ctulimit.hpp.

Referenced by copy_members(), get_parameter_brackets(), get_parameters(), init_members(), process(), and ulimit_bisection().

◆ m_eflux_ulimit

double ctulimit::m_eflux_ulimit
protected

Energy flux upper limits.

Definition at line 103 of file ctulimit.hpp.

Referenced by compute_ulimit(), copy_members(), eflux_ulimit(), init_members(), and process().

◆ m_emax

double ctulimit::m_emax
protected

Maximum energy for flux limits (TeV)

Definition at line 90 of file ctulimit.hpp.

Referenced by compute_ulimit(), copy_members(), get_parameters(), init_members(), and process().

◆ m_emin

double ctulimit::m_emin
protected

Minimum energy for flux limits (TeV)

Definition at line 89 of file ctulimit.hpp.

Referenced by compute_ulimit(), copy_members(), get_parameters(), init_members(), and process().

◆ m_eref

double ctulimit::m_eref
protected

Reference energy for flux limits (TeV)

Definition at line 88 of file ctulimit.hpp.

Referenced by compute_ulimit(), copy_members(), get_parameters(), init_members(), and process().

◆ m_flux_ulimit

double ctulimit::m_flux_ulimit
protected

Flux upper limit value.

Definition at line 102 of file ctulimit.hpp.

Referenced by compute_ulimit(), copy_members(), flux_ulimit(), init_members(), and process().

◆ m_is_spatial

bool ctulimit::m_is_spatial
protected

Signal that model parameter is spatial parameter.

Definition at line 106 of file ctulimit.hpp.

Referenced by get_model_parameter(), get_parameter_brackets(), init_members(), and ulimit_bisection().

◆ m_max_iter

int ctulimit::m_max_iter
protected

Maximum number of iterations.

Definition at line 92 of file ctulimit.hpp.

Referenced by copy_members(), get_parameter_brackets(), get_parameters(), init_members(), and ulimit_bisection().

◆ m_model_par

GModelPar* ctulimit::m_model_par
protected

Pointer to model parameter.

Definition at line 105 of file ctulimit.hpp.

Referenced by get_model_parameter(), get_parameter_brackets(), init_members(), process(), and ulimit_bisection().

◆ m_parname

std::string ctulimit::m_parname
protected

Name of parameter for upper limit computation.

Definition at line 84 of file ctulimit.hpp.

Referenced by copy_members(), get_model_parameter(), get_parameters(), and init_members().

◆ m_sigma_max

double ctulimit::m_sigma_max
protected

Starting value maximum (multiple fit errors above fit values)

Definition at line 87 of file ctulimit.hpp.

Referenced by copy_members(), get_parameter_brackets(), get_parameters(), and init_members().

◆ m_sigma_min

double ctulimit::m_sigma_min
protected

Starting value minimum (multiple fit errors above fit values)

Definition at line 86 of file ctulimit.hpp.

Referenced by copy_members(), get_parameter_brackets(), get_parameters(), and init_members().

◆ m_skymodel

GModelSky* ctulimit::m_skymodel
protected

Pointer to sky model.

Definition at line 104 of file ctulimit.hpp.

Referenced by compute_ulimit(), get_model_parameter(), init_members(), and process().

◆ m_srcname

std::string ctulimit::m_srcname
protected

Name of source for upper limit computation.

Definition at line 83 of file ctulimit.hpp.

Referenced by copy_members(), get_model_parameter(), get_parameter_brackets(), get_parameters(), init_members(), and ulimit_bisection().

◆ m_tol

double ctulimit::m_tol
protected

Tolerance for limit determination.

Definition at line 91 of file ctulimit.hpp.

Referenced by copy_members(), get_parameters(), init_members(), and ulimit_bisection().


The documentation for this class was generated from the following files: