Last modified: December 2022

AHELP for CIAO 4.16


Context: Tools::Region


Make a field-of-view region in sky coordinates


skyfov  infile outfile [logfile] [kernel] [mskfile] [aspect] [geompar]
[method] [clobber] [verbose]


The skyfov program creates a region file that describes the edges of each instrument chip. This region file - which consists of a polygon per chip - can then be used to filter event files or images. The program can be run with only an event file, with the aspect solution and mask file of the observation as optional parameters.

The aspect solution

If an aspect solution is supplied, the dither of the telescope is taken into account, and so each polygon is a little larger than the physical chip. Without an aspect solution, the nominal aspect is used and fiducial light offsets are not taken into account.

The mask file

If a mask file is provided, active CHIP regions are taken into account, otherwise a full ccd region per chip is used.

The region file

Each chip is described by a polygon. When the output kernel is set to FITS, the region file will contain a CCD_ID column which can be used to select a single chip, or range of chips. For the ASCII kernel, each chip is written out on a separate line.


Example 1

skyfov evt2.fits region.fits

Makes a CXC-style FITS region file (region.fits) which describes the location of each chip (or HRC segment) in the input event file (evt2.fits).

Example 2

skyfov evt2.fits region.reg kernel=ascii

Makes a DS9-style ASCII region file describing the location of each chip (or HRC segment) in the input event file.

Example 3

skyfov evt2.fits region.fits
dmcopy "region.fits[ccd_id=3]" chip3.fits

A FITS region file is made, then dmcopy is used to extract the region of chip I3 (ccd_id=3) alone.

Example 4

skyfov evt2.fits region.reg kernel=ascii
dmmakereg "bounds(region(region.reg))" outfile=bounds.reg kernel=ascii
dmcopy "evt2.fits[sky=region(bounds.reg)][bin sky=::1]" img.fits

Here we create a region file (bounds.reg), in ASCII format, which describes the rectangular region which bounds all the chips present in evt2.fits. This region is then used to create an image of the data at full resolution.

Example 5

skyfov evt2.fits fov.fits
dmmakereg region="region(fov.fits[cols ra,dec,shape,component])"
outfile=fov_radec.fits kernel=fits

Create a field-of-view file (fov.fits), then convert it to WCS format with dmmakereg. This file cannot be displayed directly in ds9. To do that requires writing out the output as an ASCII region and tweaking the coordinate system information.

dmmakereg region="region(fov[cols ra,dec,shape,component])" outfile=fov.reg kernel=ascii
sed 's,^physical,fk5,' fov.reg > fov_fk5.reg 

The sed command is used to change the region coordinate system from 'physical' (now incorrect) with 'fk5'. The file 'fov_fk5.reg' can then be loaded into ds9.


name type ftype def min max reqd
infile file input       yes
outfile file output       yes
logfile file output STDOUT      
kernel string   FITS      
mskfile file input        
aspect file input        
geompar file   geom      
method string   minmax      
clobber boolean   no      
verbose integer   0 0 5  

Detailed Parameter Descriptions

Parameter=infile (file required filetype=input)

The name of a Chandra event file. Other missions are not supported.

Parameter=outfile (file required filetype=output)

The output region name.

Parameter=logfile (file filetype=output default=STDOUT)

Log file.

A log file only used for debugging; can be left blank.

Parameter=kernel (string default=FITS)

The output region format, FITS or ASCII.

The ascii region format is a variant supported by the DS9 imager, and is useable as a filter in the CIAO tools.

Parameter=mskfile (file filetype=input default=)

The mask file to contain active windows of instrument CCD.

The mask file (msk1.fits) for the observation. The mask file is needed in particular when a window or subarray was used. A value of "NONE" indicates that no mask file will be applied.

More information on the mask file is available in the CIAO Dictionary.

Parameter=aspect (file filetype=input default=)

The aspect solution

This should be a "pcad...asol1.fits" type file, or a stack of them. It may be omitted if you only need an approximate region of interest.

Parameter=geompar (file default=geom)

The name of the Pixlib Geometry parameter file.

Parameter=method (string default=minmax)

Algorithm used to determine FOV boundary.

The default "minmax" algorithm uses the set of coordinates corresponding to the minimum and maximum RA, Dec, and ROLL in the input aspect solution file. Depending on the roll angle, this can produce a FOV with a noticeable gap between the FOV boundary and the observed events.

A new method="convexhull" method was added in CIAO 4.12. This algorithm uses the set of points that create a convex hull (polygon) around the RA and Dec values together with the min and max ROLL to create a tighter fitting FOV. However, for observations where there are large changes in the boresight corrections (DY and DZ columns in the aspect solution file), this FOV can be too tight and may exclude valid pixels. As a result the default is to continue to create the looser fitting FOV.

This parameter is only applicable when an aspect solution file is supplied. Otherwise the tool uses the RA_PNT, DEC_PNT, and ROLL_PNT keyword values from the infile.

Parameter=clobber (boolean default=no)

Clobber existing output with the same name?

Boolean that specifies whether an existing output with the same name will be clobbered or not.

Parameter=verbose (integer default=0 min=0 max=5)

Verbosity level of terminal display information to user.

ACIS exclusion windows

If an ACIS observation was taken with an exclusion window, why isn't the window excluded from the FOV file?

Strictly speaking, ACIS doesn't support "exclusion windows". It supports a window that can have an arbitrary event sampling (SAMP_CYC). A setting of 0 happens to exclude all events, but settings > 1 also excludes events, but not all events (a "grey" filter). The windows also need not filter events based on rate-of-occurrence, but can filter events on energy/pulse height. None of this generality can be expressed in the simple FITS region exclude operator.

The CXC definition of the FOV is the outer-convex hull around the corners of the window at some set of RA/DEC/ROLLs. The regions are 'generous' and always bound the data, but don't necessarily bound it "tightly".

For regions with SAMP_CYC != 1, there are really 3 regions of interest: outside the region, the area covered by the dither pattern where some fraction of the SAMP_CYC is applied, and the area entirely inside the dither pattern. The skyfov output is the middle region. There are definitely events inside the region (and thus the 'include' is appropriate), but the full SAMP_CYC filter is seen at some distance from the edge.

From a footprint point of view, it's the inner region that's more of interest than the outer edge.




CIAO 4.12 has a new FOV algorithm which is available using method=convexhull which provides for a tighter fitting FOV. However, for observations where there are large changes in the boresite offsets (DY and DZ columns in the aspect solution file) the FOV may be too tight; the FOV may then inscribe the observed data.

The method=convexhull should only be used when the CONTENT of the aspect solution file is ASPOBISOL.

See Also

reproject_image, reproject_image_grid, sky2tdet