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

Cube filter tool. More...

#include <ctcubemask.hpp>

Inheritance diagram for ctcubemask:
ctobservation ctool GApplication

Public Member Functions

 ctcubemask (void)
 Void constructor.
 
 ctcubemask (const GObservations &obs)
 Observations constructor.
 
 ctcubemask (int argc, char *argv[])
 Command line constructor.
 
 ctcubemask (const ctcubemask &app)
 Copy constructor.
 
virtual ~ctcubemask (void)
 Destructor.
 
ctcubemaskoperator= (const ctcubemask &app)
 Assignment operator.
 
void clear (void)
 Clear ctcubemask tool.
 
void process (void)
 Mask data cube.
 
void save (void)
 Save the masked event cube(s)
 
void publish (const std::string &name="")
 Publish counts cube.
 
- 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 ctcubemask &app)
 Copy class members.
 
void free_members (void)
 Delete class members.
 
void get_parameters (void)
 Get application parameters.
 
void apply_mask (GCTAObservation *obs)
 Apply mask to event cube.
 
std::string region_string (const GSkyRegion &region) const
 Return region string.
 
std::string set_outfile_name (const std::string &filename) const
 Set output file name.
 
void save_fits (void)
 Save counts cube in FITS format.
 
void save_xml (void)
 Save counts cube(s) in XML format.
 
- 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

GFilename m_outcube
 Output event list or XML file.
 
std::string m_prefix
 Prefix for multiple counts maps.
 
double m_emin
 Lower energy.
 
double m_emax
 Upper energy.
 
bool m_publish
 Publish counts cube?
 
std::vector< std::string > m_infiles
 Input event filenames.
 
bool m_select_energy
 Perform energy selection.
 
- 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

Cube filter tool.

Definition at line 47 of file ctcubemask.hpp.

Constructor & Destructor Documentation

◆ ctcubemask() [1/4]

ctcubemask::ctcubemask ( void )

Void constructor.

Definition at line 53 of file ctcubemask.cpp.

References init_members().

◆ ctcubemask() [2/4]

ctcubemask::ctcubemask ( const GObservations & obs)
explicit

Observations constructor.

param[in] obs Observation container.

This constructor creates an instance of the class that is initialised from an observation container.

Definition at line 71 of file ctcubemask.cpp.

References init_members().

◆ ctcubemask() [3/4]

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

Command line constructor.

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

Definition at line 90 of file ctcubemask.cpp.

References init_members().

◆ ctcubemask() [4/4]

ctcubemask::ctcubemask ( const ctcubemask & app)

Copy constructor.

Parameters
[in]appApplication.

Definition at line 106 of file ctcubemask.cpp.

References copy_members(), and init_members().

◆ ~ctcubemask()

ctcubemask::~ctcubemask ( void )
virtual

Destructor.

Definition at line 122 of file ctcubemask.cpp.

References free_members().

Member Function Documentation

◆ apply_mask()

void ctcubemask::apply_mask ( GCTAObservation * obs)
protected

Apply mask to event cube.

Parameters
[in]obsCTA observation.

Apply mask to an event cube. The mask sets content of event bins outside the region of interest or the energy of interest to -1. These pixels will be ignored in likelihood fitting.

Definition at line 478 of file ctcubemask.cpp.

References ctool::get_roi(), m_emax, m_emin, m_select_energy, ctobservation::obs(), and region_string().

Referenced by process().

◆ clear()

void ctcubemask::clear ( void )
virtual

Clear ctcubemask tool.

Clears ctcubemask tool.

Implements ctobservation.

Definition at line 179 of file ctcubemask.cpp.

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

◆ copy_members()

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

Copy class members.

Parameters
[in]appApplication.

Definition at line 389 of file ctcubemask.cpp.

References m_emax, m_emin, m_infiles, m_outcube, m_prefix, m_publish, and m_select_energy.

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

◆ free_members()

void ctcubemask::free_members ( void )
protected

Delete class members.

Definition at line 410 of file ctcubemask.cpp.

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

◆ get_parameters()

void ctcubemask::get_parameters ( void )
protected

Get application parameters.

Get all task parameters from parameter file or (if required) by querying the user.

This method also loads observations if no observations are yet allocated. Observations are either loaded from a single CTA even cube, or from a XML file using the metadata information that is stored in that file.

Definition at line 427 of file ctcubemask.cpp.

References ctool::get_roi(), ctool::log_parameters(), m_emax, m_emin, ctobservation::m_obs, m_publish, m_select_energy, ctool::read_ahead(), and ctool::setup_observations().

Referenced by process().

◆ init_members()

void ctcubemask::init_members ( void )
protected

Initialise class members.

Definition at line 366 of file ctcubemask.cpp.

References m_emax, m_emin, m_infiles, m_outcube, m_prefix, m_publish, and m_select_energy.

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

◆ operator=()

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

Assignment operator.

Parameters
[in]appApplication.
Returns
Application.

Definition at line 144 of file ctcubemask.cpp.

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

◆ process()

void ctcubemask::process ( void )
virtual

Mask data cube.

This method reads in the application parameters and loops over all observations that were found to apply a mask on the event cube.

Implements ctobservation.

Definition at line 208 of file ctcubemask.cpp.

References apply_mask(), ctool::get_obs_header(), get_parameters(), ctool::log_observations(), m_infiles, ctobservation::m_obs, m_publish, ctool::m_use_xml, ctobservation::obs(), and publish().

◆ publish()

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

Publish counts cube.

Parameters
[in]nameCounts cube name.

Publishes the first counts cube in the observation container on the VO Hub.

Definition at line 324 of file ctcubemask.cpp.

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

Referenced by cscripts.cslightcrv.cslightcrv::process(), cscripts.csphasecrv.csphasecrv::process(), cscripts.csresmap.csresmap::process(), cscripts.csspec.csspec::process(), cscripts.csviscube.csviscube::process(), and process().

◆ region_string()

std::string ctcubemask::region_string ( const GSkyRegion & region) const
protected

Return region string.

Parameters
[in]regionSky region.

Returns a formatted region string for logging.

Definition at line 622 of file ctcubemask.cpp.

Referenced by apply_mask().

◆ save()

void ctcubemask::save ( void )
virtual

Save the masked event cube(s)

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

If m_use_xml is true, all masked event cube(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 cube 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 masked event cube(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 masked event cubes will be saved into a FITS file.

Implements ctobservation.

Definition at line 288 of file ctcubemask.cpp.

References ctobservation::m_obs, m_outcube, m_prefix, ctool::m_use_xml, save_fits(), and save_xml().

◆ save_fits()

void ctcubemask::save_fits ( void )
protected

Save counts cube in FITS format.

Save the counts cube as a FITS file. The filename of the FITS file is specified by the m_outfile member.

Definition at line 671 of file ctcubemask.cpp.

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

Referenced by save().

◆ save_xml()

void ctcubemask::save_xml ( void )
protected

Save counts cube(s) in XML format.

Save the counts cube(s) into FITS files and write the file path information into an XML file. The filename of the XML file is specified by the m_outfile member, the filename(s) of the counts cube(s) are built by prepending the prefix given by the m_prefix member to the input counts cube(s) filenames. Any path present in the input filename will be stripped, i.e. the counts cube(s) will be written in the local working directory (unless a path is specified in the m_prefix member).

Definition at line 711 of file ctcubemask.cpp.

References m_infiles, ctobservation::m_obs, m_outcube, ctobservation::obs(), set_outfile_name(), and ctool::warn_xml_suffix().

Referenced by save().

◆ set_outfile_name()

std::string ctcubemask::set_outfile_name ( const std::string & filename) const
protected

Set output file name.

Parameters
[in]filenameInput file name.

This converts an input filename into an output filename by prepending a prefix to the input filename. Any path will be stripped from the input filename.

Definition at line 652 of file ctcubemask.cpp.

References m_prefix.

Referenced by save_xml().

Member Data Documentation

◆ m_emax

double ctcubemask::m_emax
protected

Upper energy.

Definition at line 82 of file ctcubemask.hpp.

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

◆ m_emin

double ctcubemask::m_emin
protected

Lower energy.

Definition at line 81 of file ctcubemask.hpp.

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

◆ m_infiles

std::vector<std::string> ctcubemask::m_infiles
protected

Input event filenames.

Definition at line 86 of file ctcubemask.hpp.

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

◆ m_outcube

GFilename ctcubemask::m_outcube
protected

Output event list or XML file.

Definition at line 79 of file ctcubemask.hpp.

Referenced by copy_members(), init_members(), save(), save_fits(), and save_xml().

◆ m_prefix

std::string ctcubemask::m_prefix
protected

Prefix for multiple counts maps.

Definition at line 80 of file ctcubemask.hpp.

Referenced by copy_members(), init_members(), save(), and set_outfile_name().

◆ m_publish

bool ctcubemask::m_publish
protected

Publish counts cube?

Definition at line 83 of file ctcubemask.hpp.

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

◆ m_select_energy

bool ctcubemask::m_select_energy
protected

Perform energy selection.

Definition at line 87 of file ctcubemask.hpp.

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


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