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

Event probability computation tool. More...

#include <ctprob.hpp>

Inheritance diagram for ctprob:
ctobservation ctool GApplication

Public Member Functions

 ctprob (void)
 Void constructor.
 
 ctprob (const GObservations &obs)
 Observations constructor.
 
 ctprob (int argc, char *argv[])
 Command line constructor.
 
 ctprob (const ctprob &app)
 Copy constructor.
 
virtual ~ctprob (void)
 Destructor.
 
ctproboperator= (const ctprob &app)
 Assignment operator.
 
void clear (void)
 Clear ctprob tool.
 
void process (void)
 Process the ctprob tool.
 
void save (void)
 Save the selected event list(s)
 
void publish (const std::string &name="")
 Publish event lists.
 
- 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 ctprob &app)
 Copy class members.
 
void free_members (void)
 Delete class members.
 
void get_parameters (void)
 Get application parameters.
 
void evaluate_probability (GCTAObservation *obs)
 Evaluate probability for events.
 
- 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

bool m_apply_edisp
 Apply energy dispersion?
 
bool m_publish
 Publish event list?
 
GChatter m_chatter
 Chattiness.
 
- 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

Event probability computation tool.

Definition at line 46 of file ctprob.hpp.

Constructor & Destructor Documentation

◆ ctprob() [1/4]

ctprob::ctprob ( void )

Void constructor.

Definition at line 52 of file ctprob.cpp.

References init_members().

◆ ctprob() [2/4]

ctprob::ctprob ( const GObservations & obs)
explicit

Observations constructor.

param[in] obs Observation container.

Creates an instance of the class that is initialised using the information provided in an observation container.

Definition at line 70 of file ctprob.cpp.

References init_members().

◆ ctprob() [3/4]

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

Command line constructor.

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

Definition at line 89 of file ctprob.cpp.

References init_members().

◆ ctprob() [4/4]

ctprob::ctprob ( const ctprob & app)

Copy constructor.

Parameters
[in]appApplication.

Definition at line 105 of file ctprob.cpp.

References copy_members(), and init_members().

◆ ~ctprob()

ctprob::~ctprob ( void )
virtual

Destructor.

Definition at line 121 of file ctprob.cpp.

References free_members().

Member Function Documentation

◆ clear()

void ctprob::clear ( void )
virtual

Clear ctprob tool.

Clears ctprob tool.

Implements ctobservation.

Definition at line 178 of file ctprob.cpp.

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

◆ copy_members()

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

Copy class members.

Parameters
[in]appApplication.

Definition at line 379 of file ctprob.cpp.

References m_apply_edisp, m_chatter, and m_publish.

Referenced by ctprob(), and operator=().

◆ evaluate_probability()

void ctprob::evaluate_probability ( GCTAObservation * obs)
protected

Evaluate probability for events.

Parameters
[in,out]obsCTA observation.
Exceptions
GException::invalid_valueObservation does not contain an event list.

Computes for all events the probability that an event arises from a specific model component. The computation is done by by evaluating the differential event probability for a given model and normalizing these probabilities so that the sum of the probabilities for all model components is unity for each event.

The method appends for each model component a single precision column to the event list that contains the event probabilities. The name of the column is build from the model name prefixed with PROB_.

Definition at line 463 of file ctprob.cpp.

References G_EVALUATE_PROB, ctobservation::m_obs, and ctobservation::obs().

Referenced by process().

◆ free_members()

void ctprob::free_members ( void )
protected

Delete class members.

Definition at line 394 of file ctprob.cpp.

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

◆ get_parameters()

void ctprob::get_parameters ( void )
protected

Get application parameters.

Get all application parameters by either querying the parameters or by retrieving the parameters for the parameter file.

Definition at line 407 of file ctprob.cpp.

References ctool::log_parameters(), m_apply_edisp, m_chatter, ctobservation::m_obs, m_publish, ctool::read_ahead(), and ctool::setup_observations().

Referenced by process().

◆ init_members()

void ctprob::init_members ( void )
protected

Initialise class members.

Definition at line 362 of file ctprob.cpp.

References m_apply_edisp, m_chatter, and m_publish.

Referenced by clear(), ctprob(), ctprob(), ctprob(), ctprob(), and operator=().

◆ operator=()

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

Assignment operator.

Parameters
[in]appApplication.
Returns
Application.

Definition at line 143 of file ctprob.cpp.

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

◆ process()

void ctprob::process ( void )
virtual

Process the ctprob tool.

This method reads in the application parameters and loops over all unbinned observations to compute the probability for each event that it comes from one of the model components.

Implements ctobservation.

Definition at line 208 of file ctprob.cpp.

References evaluate_probability(), ctobservation::first_unbinned_observation(), get_parameters(), ctool::log_observations(), m_apply_edisp, ctobservation::m_obs, ctool::m_use_xml, ctobservation::next_unbinned_observation(), ctobservation::obs(), publish(), ctool::restore_edisp(), and ctool::set_edisp().

◆ publish()

void ctprob::publish ( const std::string & name = "")

◆ save()

void ctprob::save ( void )
virtual

Save the selected event list(s)

This method saves the selected event list(s) into FITS file(s). There are two modes, depending on the m_use_xml flag.

If m_use_xml is true, all selected event list(s) will be saved into FITS files, where the output filenames are constructued from the input filenames by prepending the m_prefix string to name. Any path information will be stripped form the input name, hence event files will be written into the local working directory (unless some path information is present in the prefix). In addition, an XML file will be created that gathers the filename information for the selected event list(s). If an XML file was present on input, all metadata information will be copied from this input file.

If m_use_xml is false, the selected event list will be saved into a FITS file.

Implements ctobservation.

Definition at line 279 of file ctprob.cpp.

References ctobservation::m_obs, ctool::m_use_xml, ctobservation::save_events_fits(), and ctobservation::save_events_xml().

Member Data Documentation

◆ m_apply_edisp

bool ctprob::m_apply_edisp
protected

Apply energy dispersion?

Definition at line 74 of file ctprob.hpp.

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

◆ m_chatter

GChatter ctprob::m_chatter
protected

Chattiness.

Definition at line 76 of file ctprob.hpp.

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

◆ m_publish

bool ctprob::m_publish
protected

Publish event list?

Definition at line 75 of file ctprob.hpp.

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


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