Describing observations using XML¶
Observations can be described in GammaLib using an ASCII file in XML format. The general format of this file is
<observation_list title="observation library">
<observation name="..." id="..." instrument="...">
...
</observation>
<observation name="..." id="..." instrument="...">
...
</observation>
...
</observation_list>
where each <observation>
tag describes one observation. Each observation
has a name
attribute, an id
(identifier) attribute and an
instrument
attribute. The latter decides which instrument specific
class will be allocated upon reading the XML file. For a given instrument,
observation identifiers must be unique.
The specific format of the XML file for a given instrument is defined by the relevant instrument specific GObservation class. For example, a CTA observation implemented by the GCTAObservation class is described by
<observation name="..." id="..." instrument="...">
<parameter name="EventList" file="..."/>
<parameter name="EffectiveArea" file="..."/>
<parameter name="PointSpreadFunction" file="..."/>
<parameter name="EnergyDispersion" file="..."/>
</observation>
for an unbinned observation and by
<observation name="..." id="..." instrument="...">
<parameter name="CountsCube" file="..."/>
<parameter name="EffectiveArea" file="..."/>
<parameter name="PointSpreadFunction" file="..."/>
<parameter name="EnergyDispersion" file="..."/>
</observation>
for a binned observation. Here, EventList
specifies a FITS file containing
an event list and CountsCube
specifies a FITS file containing a counts
cube.
The other tags specify the components of the instrumental response function
and are optional.
Similar definitions exist for the other instruments.
The code threads below show different variants of how observations can be loaded from or saved into an XML file.
C++
1 2 | GObservations obs("my_observations.xml"); // Construct observations from XML file
obs.save("my_copied_observations.xml"); // Save observations into XML file
|
1 2 3 | GObservations obs; // Construct empty observations
obs.load("my_observations.xml"); // Load observations from XML file
obs.save("my_copied_observations.xml"); // Save observations into XML file
|
1 2 3 4 5 6 | GObservations obs; // Construct empty observations
GXml xmlin("my_observations.xml"); // Construct GXml instance from XML file
GXml xmlout; // Construct empty GXml instance
obs.read(xmlin); // Read observations from GXml instance
obs.write(xmlout); // Write observations into GXml instance
xmlout.save("my_copied_observations.xml"); // Save GXml instance in XML file
|
Python
1 2 | obs = gammalib.GObservations('my_observations.xml') # Construct observations from XML file
obs.save('my_copied_observations.xml') # Save observations into XML file
|
1 2 3 | obs = gammalib.GObservations() # Construct empty observations
obs.load('my_observations.xml') # Load observations from XML file
obs.save('my_copied_observations.xml') # Save observations into XML file
|
1 2 3 4 5 6 | obs = gammalib.GObservations() # Construct empty observations
xmlin = gammalib.GXml('my_observations.xml') # Construct GXml instance from XML file
xmlout = gammalib.GXml() # Construct empty GXml instance
obs.read(xmlin) # Read observations from GXml instance
obs.write(xmlout) # Write observations into GXml instance
xmlout.save('my_copied_observations.xml') # Save GXml instance in XML file
|