Calculate source count rates and fluxes for combined datasets
CIAO 4.17 Science Threads
Overview
Synopsis:
In this thread users will learn how to use srcflux to compute net count rates and fluxes for sources imaged in multiple observations (multi-obi, multi-obsid, aka merged).
Many parts of the sky have been observed by Chandra multiple times. Early in the mission these repeat pointings were often for large programs or for monitoring observations. More recently many observations are now also split into multiple shorter exposures due to thermal constraints. This has increased the need to easily obtain estimates of source properties from multiple observations.
The srcflux tool has been updated to produce estimates of the count rates, photon fluxes, and model-dependent fluxes by combining data from multiple observations. srcflux uses the aprates tool to estimate the uncertainties on these quantities similar to the approach taken in Version 1 of the Chandra Source Catalog.
It can be easy to obtain misleading results when this tool is used blindly. For example, source variability is not considered when estimating fluxes.
Run this thread if:
you want to compute counts, rates, photon fluxes, and model fluxes by combining data from multiple observations.
Related Links:
- Calculate source count rates and fluxes
- Correcting Absolute Astrometry
- Using merge_obs to combine observations and create exposure-corrected images
- Running wavdetect
- Why combine data?
- Caveat: Extracting Spectra from Merged Datasets
- Evans, I. N., et al. 2010, ApJS, 189, 37
Last Update: 17 Sep 2024 - Updated example to use updated aspect solution file names created by chandra_repro.
Contents
- Simple Case I: Single source, two observations
- Simple Case II: Applying Astrometric Offsets
- Multiple Sources in Multiple Observations
- Final Summary
- History
-
Images
- Figure 1: Mrk 975 Observations
- Figure 2: Merged Mrk 975 Observations
- Figure 3: Source Detections on Merged Dataset
- Figure 4: Simple Case: Automatically Generated Regions
- Figure 5: Simple Case: User Supplied Regions
- Figure 6: TWA 32
- Figure 7: TWA 32 Blinking Frames
- Figure 8: Merged TWA 32, broad band
- Figure 9: Default 90%ECF @ 1keV Regions
- Figure 10: Merged broad band counts NGC 1960
- Figure 11: Wavdetect sources in NGC 1960
- Figure 12: Constant Source in NGC 1960
- Figure 13: Variable Source in NGC 1960
- Figure 14: Variable Source in NGC 1960
- Figure 15: Variable Source in NGC 1960, wavdetect regions
Simple Case I: Single source, two observations
This thread will show how to use srcflux in increasingly complicated situations.
Identify Observations
We begin with a simple dataset comprised of two observations of Mrk 975.
unix% find_chandra_obsid "Mrk 975" # obsid sepn inst grat time obsdate piname target 13899 0.0 ACIS-S NONE 10.0 2012-10-28 Mushotzky "Mrk 975" 15575 0.0 ACIS-S NONE 9.1 2012-11-02 Mushotzky "Mrk 975"
We can see that these two observations were taken a few days apart and have approximately the same exposure time.
There is no flag nor specific piece of metadata that indicates that multiple observations were split due to thermal constraints. Generally speaking they will be closely spaced in time, have identical detector configurations, and the mission planners try to match the pointings as best as possible.
Download Data
Download the sample data: 13899 (Mrk 975); 15575 (Mrk 975)
unix% download_chandra_obsid 13899,15575
Before working with multiple observations, it can be useful to check various observation parameters. While it may be mechanically possible to compute fluxes for disparate datasets, users may encounter unexpected results so knowing what is being input into the processing before hand may help.
unix% dmdiff 13899/primary/*evt2.fits.gz 15575/primary/*evt2.fits.gz data- | \ egrep 'SIM_|_NOM|_PNT|DATE-OBS|MJD_OBS|OBS_ID|FP_TEMP' DATE-OBS Values are not equal 2012-10-28T12:07:12 2012-11-02T20:41:44 SIM_Z Values are not equal -190.14006604987 -190.14258036517 -0.00251432 (+0.00132%) RA_PNT Values are not equal 18.460110371879 18.460525677222 +0.000415305 (+0.00225%) DEC_PNT Values are not equal 13.273523446552 13.272951427789 -0.000572019 (-0.00431%) ROLL_PNT Values are not equal 278.15394087308 278.15381775507 -0.000123118 (-4.43e-05%) RA_NOM Values are not equal 18.460110371879 18.460525677222 +0.000415305 (+0.00225%) DEC_NOM Values are not equal 13.273523446552 13.272951427789 -0.000572019 (-0.00431%) ROLL_NOM Values are not equal 278.15394087308 278.15381775507 -0.000123118 (-4.43e-05%) OBS_ID Values are not equal 13899 15575
These differences are all very small so we can proceed with the analysis.
Users cannot combine ACIS with HRC data.
Users cannot combine ACIS TIMED modes (GRADED, FAINT, VFAINT) with CONTINIOUS clocking modes.
Users should be extra cautious if trying to combine 0th order grating data (either together or with non-grating observations).
Reprocessing the data
Users should, unless other wise instructed, always reprocess the data they obtain from the Chandra archive. This will make sure that the energy calibrations (gain) applied to the individual events matches the calibrations used to create the associated response files (ARF and RMF files) which are used to compute the fluxes. This can be especially important when working with data spanning multiple years with different calibrations (CALDBVER) and software versions (ASCDSVER).
unix% chandra_repro 13899,15575 outdir=""
Users are strongly encouraged to use the default output directory name, outdir="" (ie a blank string, quotes added for emphasis). This will create individual repro directories under each OBS_ID; at the same level as the primary and secondary directories.
Various scripts such as srcflux and merge_obs need to locate several ancillary files including the badpixel file, aspect solution, and detector mask files. The file names for these products are stored in the header of the event file. The tools then need to search for these ancillary files in directories relative to the location of the event file. The list of directories searched, relative to the location of the event file, includes ./ (current directory), ../ (parent directory), ./repro, ../repro, ./primary, ./secondary, ../primary, and ../secondary.
The reprocessed data are shown in Figure 1
[Version: full-size]
Figure 1: Mrk 975 Observations
The point-like source is isolated; although for its proximity to the aimpoint (4096.5,4096.5 in physical coordinate for ACIS), the source does appear somewhat larger than the PSF. We may need to account for this later in the analysis.
Check for Offsets
It is in general a good idea to check the astrometric alignment of observations before trying to combine them. Even seemingly small offsets may lead to unexpected (incorrect) results. This can be done using a single source or an entire source catalog.
We start by computing the centroid of the source. We will restrict the energy band to the CSC "broad" band energy range (500 to 7000 eV). Since the source is so near the aimpoint and the source is bright we do not need to worry about the background skewing the centroid location. The centroid will be computed using dmstat in physical pixels and will need to be converted to celestial coordinates using dmcoords to be able to compare the two observations.
OBS_ID 13899 first:
unix% dmstat 13899/repro/acisf13899_repro_evt2.fits'[energy=500:7000,sky=circle(01:13:51.0436,+13:16:17.594,4")][bin sky=1]' \ centroid=yes verb=0 unix% pget dmstat out_cntrd_phys 4077.8910965,4082.5180297 unix% punlearn dmcoords unix% dmcoords 13899/repro/acisf13899_repro_evt2.fits op=sky x=4077.8910965 y=4082.5180297 celfmt=hms v=0 unix% pget dmcoords ra dec 01:13:51.053 +13:16:17.80
and now for obsid 15575
unix% dmstat 15575/repro/acisf15575_repro_evt2.fits'[energy=500:7000,sky=circle(01:13:51.0436,+13:16:17.594,4")][bin sky=1]' \ centroid=yes verb=0 unix% pget dmstat out_cntrd_phys 4080.5849903,4086.5903161 unix% punlearn dmcoords unix% dmcoords 15575/repro/acisf15575_repro_evt2.fits op=sky x=4080.5849903 y=4086.5903161 celfmt=hms v=0 unix% pget dmcoords ra dec 01:13:51.062 +13:16:17.74
We can see that the difference in the centroid location is much, much less than a pixel (0.492 arcsec) so applying a fine astrometric correction is not necessary for this source.
Merge Observations
Next we will create a combined image, exposure map, fluxed image, and PSF map from these two OBS_IDs. Technically, this step is not really even needed with this specific example; however, it can be useful to visualize the merged dataset before extracting the fluxes. As we will see later srcflux uses the individual observation data products.
unix% merge_obs 13899/repro,15575/repro out=merge/ bin=1 band=broad psfecf=0.9 clob+
The output are shown in Figure 2.
[Version: full-size]
Figure 2: Merged Mrk 975 Observations
Run wavdetect to get centroid
In this specific example where the centroid in both individual observations are so well determined we do not really need to do this step. However in the interest of generality we show how to use wavdetect to obtain the centroid of the source position. Users should consult the Running wavdetect thread for details about using the tool.
unix% punlearn wavdetect unix% pset wavdetect \ infile=merge/broad_thresh.img \ expfile=merge/broad_thresh.expmap \ psffile=merge/broad_thresh.psfmap \ outfile=merge/wav.src \ scell=merge/wav.cell defnbkg=merge/wav.nbk imagef=merge/wav.recon \ scale="1.4 2 4" mode=h clob+ unix% wavdetect mode=h
The output source list, merge/wav.src, contains the candidate sources and some preliminary source properties. Two sources were detected in this combined dataset
unix% dmlist merge/wav.src counts 2
and we can display them as in Figure 3.
[Version: full-size]
Figure 3: Source Detections on Merged Dataset
Examining the source list we see that the source we are interested in is listed first. We can use dmlist to obtain the source position and prop_precess to convert to sexagesimal format.
unix% dmlist merge/wav.src"[cols x,y,ra,dec][#row=1]" data,clean # POS(X,Y) RA DEC 4079.2460881935 4084.6097676624 18.4627407642 13.2716124274 unix% prop_precess from j/deg to j/hms p0 eval 18.4627407642 13.2716124274 01 13 51.06 +13 16 17.80
This is consistent with the centroid obtained from the individual observations.
We also get the same result if we just use dmstat on the merged image.
unix% dmstat 'merge/broad_thresh.img[sky=circle(01:13:51.0436,+13:16:17.594,4")]' cen+ v=0 unix% pget dmstat out_cntrd_phys 4079.2495379,4084.5799445 unix% punlearn dmcoords unix% dmcoords merge/broad_thresh.img op=sky x=4079.2495379 y=4084.5799445 celfmt=hms verb=0 unix% pget dmcoords ra dec 01:13:51.057 +13:16:17.79
In the example above we make use of several short cuts by specifying cen+ rather than the full centroid=yes and v=0 and verb=0 instead of the full verbose=0.
Run srcflux I: automatically generate regions
We are now ready to run srcflux. Users will want to review the Calculate source count rates and fluxes thread to review all the tool parameters and modes of operation.
To generate properties for a combined data, users should keep a few key points in mind when running srcflux
- The infile parameter is a stack of event lists. Any valid stack syntax is supported.
- The position parameter, pos, can be a single value, a stack of values, or read in from a file (eg a source list).
- The srcreg and bkgreg parameters are optional. If omitted, the tool will create circular regions which enclose ~90% of the 1.0keV PSF. This is done separately for each observation in the infile stack. If these parameters are specified, then they both must be specified. They are stacks and must contain the same number of regions as positions listed in the pos parameter. The same region is used for all observations. Therefore, unless the input event files have been reprojected to a common tangent plane, users must use regions in celestial coordinates.
With these considerations in mind we create a stack of the per-observation event files.
unix% /bin/ls */repro/*evt2.fits > evt.lis unix% cat evt.lis 13899/repro/acisf13899_repro_evt2.fits 15575/repro/acisf15575_repro_evt2.fits
The merged event file, merge/merged_evt.fits cannot be used. The event files for the individual OBS_IDs created by merge_obs could be used: merge/13899_reproj_evt.fits and merge/13899_reproj_evt.fits; however, users would need to be sure that the ancillary files are located in the same directory.
We then run srcflux with the stack of event files and the position of the source centroid computed above. The source and background regions are left as blank so that the script will automatically generate the 90%ECF @ 1keV circular regions for each OBS_ID.
unix% punlearn srcflux unix% srcflux \ infile=@evt.lis \ out=sf1/out \ srcreg="" bkgreg="" \ pos="01:13:51.048,+13:16:17.84" \ psfmethod=arfcorr bkgresp=yes conf=0.68 \ mode=h clob+
The output looks like this. Note: the order of the processing is random.
srcflux infile = @evt.lis pos = 01:13:51.048,+13:16:17.84 outroot = sf1/out bands = default srcreg = bkgreg = bkgresp = no psfmethod = arfcorr psffile = conf = 0.68 binsize = 1 rmffile = arffile = model = xspowerlaw.pow1 paramvals = pow1.PhoIndex=2.0 absmodel = xsphabs.abs1 absparams = abs1.nH=%GAL% abund = angr fovfile = asolfile = mskfile = bpixfile = dtffile = ecffile = CALDB parallel = yes nproc = INDEF tmpdir = ./ random_seed = -1 clobber = yes verbose = 1 mode = h Processing OBI 001 Extracting counts Making PSF models Getting PSF fraction by running arfcorr 1 Combining PSF fractions together Getting net rate and confidence limits Getting model independent fluxes Getting model fluxes Getting photon fluxes Running tasks in parallel with 4 processors. Running aprates for sf1/out_obi001_0001_broad_rates.par Running eff2evt for sf1/out_obi001_broad_0001_bkg.dat Running eff2evt for sf1/out_obi001_broad_0001_src.dat Making response files for sf1/out_obi001_0001 Running modeflux for region 1 Using GAL=0.0392 for source 1 Adding net rates to output Appending flux results onto output Appending photflux results onto output Computing Net fluxes Adding model fluxes to output Scaling model flux confidence limits Processing OBI 002 Extracting counts Making PSF models Getting PSF fraction by running arfcorr 1 Combining PSF fractions together Getting net rate and confidence limits Getting model independent fluxes Getting model fluxes Getting photon fluxes Running tasks in parallel with 4 processors. Running aprates for sf1/out_obi002_0001_broad_rates.par Running eff2evt for sf1/out_obi002_broad_0001_src.dat Running eff2evt for sf1/out_obi002_broad_0001_bkg.dat Making response files for sf1/out_obi002_0001 Running modeflux for region 1 Using GAL=0.0392 for source 1 Adding net rates to output Appending flux results onto output Appending photflux results onto output Computing Net fluxes Adding model fluxes to output Scaling model flux confidence limits Combining count rates Combining spectra and running model flux for each source Running modeflux for region 1 Using GAL=0.0392 for source 1 Summary of source fluxes in OBI 001 Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|1 13 51.04 +13 16 17.8 Rate 0.123 c/s (0.119,0.127) Flux 2.32E-12 erg/cm2/s (2.25E-12,2.4E-12) Mod.Flux 8.92E-13 erg/cm2/s (8.64E-13,9.19E-13) Unabs Mod.Flux 9.51E-13 erg/cm2/s (9.22E-13,9.8E-13) Summary of source fluxes in OBI 002 Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|1 13 51.04 +13 16 17.8 Rate 0.104 c/s (0.1,0.108) Flux 1.87E-12 erg/cm2/s (1.81E-12,1.94E-12) Mod.Flux 7.55E-13 erg/cm2/s (7.28E-13,7.81E-13) Unabs Mod.Flux 8.05E-13 erg/cm2/s (7.77E-13,8.33E-13) Summary of merged source fluxes Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|1 13 51.04 +13 16 17.8 Rate 0.114 c/s (0.111,0.117) NumObi=2 Mod.Flux 8.26E-13 erg/cm2/s (8.07E-13,8.45E-13) Unabs Mod.Flux 8.81E-13 erg/cm2/s (8.61E-13,9.02E-13)
At the end, the normal per OBS_ID information about each source is shown along with a new section with the Summary of merged source fluxes.
Currently, we do not compute an estimate of the model-independent, eff2evt flux. Also since in general a source may only be imaged in some of the observations (due to differences in pointing or even spacecraft roll), the number of observations, NumObi, contributing to the merged fluxes is also reported.
Description of columns in the merged .flux file
When working with multiple observations srcflux appends obiNNN to the output root file name, where NNN is simply a number from 1 to N matching the order of the infile event lists.
The final merged output flux file is then simply ${root}_${band}.flux The columns in the merged .flux file are different from the individual obi files. The columns are described below.
Merged Flux Output Columns:
- RAPOS, DECPOS, COMPONENT
-
Same as in the per-obi files.
- TOTAL_COUNTS, TOTAL_BG_COUNTS
-
Simply the sum of the per-obi COUNTS and BG_COUNTS.
- TOTAL_COUNTS, TOTAL_BG_COUNTS
-
Simply the sum of the per-obi COUNTS and BG_COUNTS.
- NUM_OBI
-
Number of observations where the RAPOS,DECPOS is inside the that observation's field of view.
- MERGED_NET_RATE_APER, MERGED_NET_RATE_APER_LO, MERGED_NET_RATE_APER_HI
-
These are the combined net rates and the associated confidence limits based on the NUM_OBI observations where the position is inside the field-of-view.
srcflux uses the same approach taken in Version 1 of the Chandra source catalog, specifically the Basic Formalism discussed in the memo Revised Specifications fo Computing Aperture Photometry Quantities. . The hard part is mapping the f,g, and r parameters to the aprates parameters. Using the equations from Evans et al section 3.7.2, we get
\[ \begin{array}{c} F = \sum_i \alpha_i T_{s,i} \\ G = \sum_i \beta_i T_{b,i} \\ R' = \frac{\sum_i r_i b_i}{\sum_i b_i} \end{array} \]Using these we can derive the aprates input parameter values
aprates.n = \(C = \sum_i C_i\)
aprates.m = \(B = \sum_i B_i\)
aprates.T_s = \(T_s = \sum_i T_{s,i}\)
aprates.T_b = \(T_b = \sum_i T_{b,i}\)
aprates.alpha = \(\alpha = \sum_i \alpha_i E_{s,i} / \sum_i E_{s,i}\)
aprates.beta = \(\beta = \sum_i \beta_a E_{b,i} / \sum_i E_{b,i}\)
aprates.E_s = \(E_s = \sum_i E_{s,i}\)
aprates.E_b = \(E_b = \sum_i E_{b,i}\)
aprates.A_s = 1.0
aprates.A_b = \(R' (E_s/E_b)\)
were C,B are the counts in the source and background region, T is the exposure time, E is the effective area, and alpha, beta are the fraction of the PSF in the source and background regions.
Since aprates only ever uses the ratio of \(A_s/A_b\), we choose to simplify the inputs by setting \(A_s=1.0\). To compute count rates, the effective areas, E, is set to 1.0. To compute photon fluxes, the actual effective area is used.
- MERGED_RATE_AREASCAL, MERGED_PHOTFLUX_AREASCAL
-
These are the R' terms when computing count rates and photon fluxes.
- PSF_WEIGHTED_TOTAL_EXPOSURE_TIME
-
This is the F term when computing count rates.
- MERGED_NET_APRATES_PHOTFLUX_APER, MERGED_NET_APRATES_PHOTFLUX_APER_LO, MERGED_NET_APRATES_PHOTFLUX_APER_HI
-
Same as MERGED_NET_RATE_APER (above), but using the actual effective area (averaged over the region) for the E terms.
This is different from the per-obi NET_PHOTFLUX_APER which uses the
- PSF_WEIGHTED_TOTAL_SRC_EXPOSURE, PSF_WEIGHTED_TOTAL_BG_EXPOSURE
-
These are the F and G when computing photon fluxes.
- MERGED_NET_PHOTFLUX_APER, MERGED_NET_PHOTFLUX_APER_LO, MERGED_NET_PHOTFLUX_APER_HI
-
These are simply the exposure weighted average NET_PHOTFLUX_APER from the individual OBS_IDs. The confidence intervals are computed by scaling the MERGE_NET_RATE_APER limits.
- MFLUX_CNV, UMFLUX_CNV
-
srcflux combines the per OBS_ID response files (ARF and RMF), and uses them to compute the absorbed model flux MFLUX, and the unabsorbed model flux, UMFLUX.
These are the modelflux conversion factors to convert from count rates to fluxes.
- MERGED_NET_MFLUX_APER, MERGED_NET_MFLUX_APER_LO, MERGED_NET_MFLUX_APER_HI
-
The (absorbed) model fluxes computed by combining the ARFs and RMF from all the valid OBS_IDs (where the position is inside the field-of-view). The MERGED_NET_RATE is scaled by MFLUX_CNV. The confidence limits are scaled by the same way.
- MERGED_NET_UMFLUX_APER, MERGED_NET_UMFLUX_APER_LO, MERGED_NET_UMFLUX_APER_HI
-
Same as the MERGED_NET_MFLUX_APER, but for the unabsorbed model fluxes.
- TOTAL_FLUX_APER, TOTAL_BG_FLUX_APER
-
The sum of the eff2evt fluxes in the source and background regions.
We are not currently computing a net flux using these values.
Run srcflux II: user supplied regions
As discussed in the previous section, the per OBS_ID data products are included in the output directory, using the name obiNNN where NNN is a 3 digit number matching the order of the infile event files.
Earlier we discussed that the sources may look large compared to the on-axis PSF. We can display the default 90%ECF @ 1keV regions created by srcflux on the event files to check that the regions are an appropriate size match. These are shown in Figure 4.
[Version: full-size]
Figure 4: Simple Case: Automatically Generated Regions
In this case the regions do look a little too small compared to the data. This may not necessarily be surprising given that observer "propose[d] to observe AGN in mergers with multiple nuclei". Given that, it may be that what is being imaged is multiple AGN that are not fully resolved.
We can use our own source and background regions with srcflux. We must specify both source and background, and we must specify the regions in celestial coordinates.
All FITS region files are interpreted as being in physical coordinates; not celestial coordinates. This includes the wavdetect (and other detect tools) source list, the skyfov field-of-view file, the source and background region extensions in the roi outputs. Even if the file contains a WCS on the position column, CIAO tools will only use the physical coordinates.
Physical coordinates are determined based on the tangent point. The tangent point is, by default out of the archive, the same as the mean pointing of the telescope. Most observations, even of the same field, and even those which are separated by only a few days do not have the pointing sufficient close to make the physical coordinates in separate observation be the same. If the coordinates are off even by just 1 pixel, 0.492arcsec, then the regions may not enclose the correct source.
However, since the pixel size (plate scale) is constant (fixed by detector hardware), users can use either physical pixel or degrees for the radii.
With this information in hand we can then generate source and background regions for this source. Given that there are no nearby sources, we will simply select a circle with a larger radius=5 pixels (~2.5arcsec) for the source region and an annulus with inner radius=6 and outer radius=12 pixels. The center of these shapes is the same as the position. These regions will be used for both OBS_IDs.
unix% punlearn srcflux unix% srcflux \ infile=@evt.lis \ out=sf2/out \ pos="01:13:51.048,+13:16:17.84" \ srcreg="circle(01:13:51.048,+13:16:17.84,5)" \ bkgreg="annulus(01:13:51.048,+13:16:17.84,6,12)" \ psfmethod=arfcorr bkgresp=yes conf=0.68 \ mode=h clob+
The screen output is similar to the first run.
srcflux infile = @evt.lis pos = 01:13:51.048,+13:16:17.84 outroot = sf2/out bands = default srcreg = circle(01:13:51.048,+13:16:17.84,5) bkgreg = annulus(01:13:51.048,+13:16:17.84,6,12) bkgresp = no psfmethod = arfcorr psffile = conf = 0.68 binsize = 1 rmffile = arffile = model = xspowerlaw.pow1 paramvals = pow1.PhoIndex=2.0 absmodel = xsphabs.abs1 absparams = abs1.nH=%GAL% abund = angr fovfile = asolfile = mskfile = bpixfile = dtffile = ecffile = CALDB parallel = yes nproc = INDEF tmpdir = ./ random_seed = -1 clobber = yes verbose = 1 mode = h Processing OBI 001 Extracting counts Making PSF models Getting PSF fraction by running arfcorr 1 Combining PSF fractions together Getting net rate and confidence limits Getting model independent fluxes Getting model fluxes Getting photon fluxes Running tasks in parallel with 4 processors. Running aprates for sf2/out_obi001_0001_broad_rates.par Running eff2evt for sf2/out_obi001_broad_0001_src.dat Running eff2evt for sf2/out_obi001_broad_0001_bkg.dat Making response files for sf2/out_obi001_0001 Running modeflux for region 1 Using GAL=0.0392 for source 1 Adding net rates to output Appending flux results onto output Appending photflux results onto output Computing Net fluxes Adding model fluxes to output Scaling model flux confidence limits Processing OBI 002 Extracting counts Making PSF models Getting PSF fraction by running arfcorr 1 Combining PSF fractions together Getting net rate and confidence limits Getting model independent fluxes Getting model fluxes Getting photon fluxes Running tasks in parallel with 4 processors. Running aprates for sf2/out_obi002_0001_broad_rates.par Running eff2evt for sf2/out_obi002_broad_0001_src.dat Running eff2evt for sf2/out_obi002_broad_0001_bkg.dat Making response files for sf2/out_obi002_0001 Running modeflux for region 1 Using GAL=0.0392 for source 1 Adding net rates to output Appending flux results onto output Appending photflux results onto output Computing Net fluxes Adding model fluxes to output Scaling model flux confidence limits Combining count rates Combining spectra and running model flux for each source Running modeflux for region 1 Using GAL=0.0392 for source 1 Summary of source fluxes in OBI 001 Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|1 13 51.04 +13 16 17.8 Rate 0.124 c/s (0.121,0.128) Flux 2.38E-12 erg/cm2/s (2.31E-12,2.45E-12) Mod.Flux 9.01E-13 erg/cm2/s (8.74E-13,9.27E-13) Unabs Mod.Flux 9.61E-13 erg/cm2/s (9.33E-13,9.89E-13) Summary of source fluxes in OBI 002 Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|1 13 51.04 +13 16 17.8 Rate 0.111 c/s (0.107,0.114) Flux 1.98E-12 erg/cm2/s (1.91E-12,2.04E-12) Mod.Flux 8.02E-13 erg/cm2/s (7.76E-13,8.28E-13) Unabs Mod.Flux 8.56E-13 erg/cm2/s (8.28E-13,8.84E-13) Summary of merged source fluxes Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|1 13 51.04 +13 16 17.8 Rate 0.118 c/s (0.115,0.12) NumObi=2 Mod.Flux 8.54E-13 erg/cm2/s (8.35E-13,8.72E-13) Unabs Mod.Flux 9.11E-13 erg/cm2/s (8.91E-13,9.31E-13)
As before, we can now display as in Figure 5 the per OBS_ID regions on their event files to double check our choices.
[Version: full-size]
Figure 5: Simple Case: User Supplied Regions
We can then compare the count rates and fluxes between the two srcflux runs using dmdiff
unix% dmdiff sf1/out_broad.flux sf2/out_broad.flux Infile 1: sf1/out_broad.flux Infile 2: sf2/out_broad.flux ---------------------------------------------------------------------- Compare Headers ---------------------------------------------------------------------- Compare Key Lists: Compare Keyword Details: # dmdiff (CIAO 4.14): WARNING: keyword 'CHECKSUM' comments differ. # dmdiff (CIAO 4.14): comment1="HDU checksum updated 2022-02-23T13:00:31" # dmdiff (CIAO 4.14): comment2="HDU checksum updated 2022-02-23T14:16:37" # dmdiff (CIAO 4.14): WARNING: keyword 'DATASUM' comments differ. # dmdiff (CIAO 4.14): comment1="data unit checksum updated 2022-02-23T13:00:31" # dmdiff (CIAO 4.14): comment2="data unit checksum updated 2022-02-23T14:16:37" Compare Keyword Values: Keyword: Message: Value(s): Diff: -------- -------------------------------------- ---------------------------------- ------------------------ CHECKSUM Values are not equal UY8fVV6fUV6fUV6f i6eji4Zii4bii4Zi DATASUM Values are not equal 3224502551 1041823904 DATE Values are not equal 2022-02-23T13:00:30 2022-02-23T14:16:37 ---------------------------------------------------------------------- Compare Subspaces ---------------------------------------------------------------------- Compare Subspace Structure: Compare Column Details: Compare Subspace Ranges: component 1 Compare Subspace Regions: component 1 ---------------------------------------------------------------------- Compare Tables ---------------------------------------------------------------------- Compare Table Structure: Block name: HISTOGRAM Compare Column Details: Compare Virtual Column Details: Compare Column Data: Column: Row: Message: Value(s): Diff: ----------------------------------- -------------- -------------------------------------- ---------------------------------- ------------------------ TOTAL_COUNTS 1 Values are not equal 1887 2134 +247 (+13.1%) TOTAL_BG_COUNTS 1 Values are not equal 279 43 -236 (-84.6%) MERGED_NET_RATE_APER 1 Values are not equal 0.114038 0.117881 +0.003843 (+3.37%) MERGED_NET_RATE_APER_LO 1 Values are not equal 0.111423 0.115342 +0.003919 (+3.52%) MERGED_NET_RATE_APER_HI 1 Values are not equal 0.11668 0.120446 +0.003766 (+3.23%) MERGED_RATE_AREASCAL 1 Values are not equal 24.3199433847478 4.31433084438745 -20.0056 (-82.3%) PSF_WEIGHTED_TOTAL_EXPOSURE_TIME 1 Values are not equal 16524.4939517712 18095.0599382505 +1570.57 ( +9.5%) MERGED_NET_APRATES_PHOTFLUX_APER 1 Values are not equal 0.00031868 0.000329207 +1.0527e-05 ( +3.3%) MERGED_NET_APRATES_PHOTFLUX_APER_LO 1 Values are not equal 0.000311371 0.000322115 +1.0744e-05 (+3.45%) MERGED_NET_APRATES_PHOTFLUX_APER_HI 1 Values are not equal 0.000326061 0.000336371 +1.031e-05 (+3.16%) MERGED_PHOTFLUX_AREASCAL 1 Values are not equal 24.3606683571605 4.3195989093047 -20.0411 (-82.3%) PSF_WEIGHTED_TOTAL_SRC_EXPOSURE 1 Values are not equal 5913273.06357038 6479412.70664406 +566140 (+9.57%) PSF_WEIGHTED_TOTAL_BG_EXPOSURE 1 Values are not equal 679722.114984218 118428.705929368 -561293 (-82.6%) MERGED_NET_PHOTFLUX_APER 1 Values are not equal 0.000309440956401413 0.000329604596557333 +2.01636e-05 (+6.52%) MERGED_NET_PHOTFLUX_APER_LO 1 Values are not equal 0.00030234518042332 0.000322505351804921 +2.01602e-05 (+6.67%) MERGED_NET_PHOTFLUX_APER_HI 1 Values are not equal 0.000316609996605665 0.0003367765393655 +2.01665e-05 (+6.37%) MFLUX_CNV 1 Values are not equal 7.2435e-12 7.2434e-12 -1e-16 (-0.00138%) UMFLUX_CNV 1 Values are not equal 7.2435e-12 7.2434e-12 -1e-16 (-0.00138%) MERGED_NET_MFLUX_APER 1 Values are not equal 8.26034253e-13 8.538592354e-13 +2.7825e-14 (+3.37%) MERGED_NET_MFLUX_APER_LO 1 Values are not equal 8.070925005e-13 8.354682428e-13 +2.83757e-14 (+3.52%) MERGED_NET_MFLUX_APER_HI 1 Values are not equal 8.4517158e-13 8.724385564e-13 +2.7267e-14 (+3.23%) MERGED_NET_UMFLUX_APER 1 Values are not equal 8.811830298e-13 9.10866487e-13 +2.96835e-14 (+3.37%) MERGED_NET_UMFLUX_APER_LO 1 Values are not equal 8.609766633e-13 8.91247634e-13 +3.0271e-14 (+3.52%) MERGED_NET_UMFLUX_APER_HI 1 Values are not equal 9.01598028e-13 9.30686242e-13 +2.90882e-14 (+3.23%) TOTAL_FLUX_APER 1 Values are not equal 1.82060559548256e-12 2.06747565088482e-12 +2.4687e-13 (+13.6%) TOTAL_BG_FLUX_APER 1 Values are not equal 2.77901053799044e-13 4.86962191916089e-14 -2.29205e-13 (-82.5%)
We can see that in this example that there is about a 3% change in the net rates and fluxes; which given the number of counts is statistically significant (values are outside the 68% confidence limits).
Summary
So far this thread has demonstrated how to run srcflux on a stack of input event files to obtain the combined count rates and fluxes for a point-like (or possibly slightly extended) source. We have shown how to specify user supplied regions and how to check for the need to perform fine astrometric offset corrections. In the next section we show how to perform the astrometric corrections and check region sizes before running srcflux.
Simple Case II: Applying Astrometric Offsets
In this section we are going to build on the earlier techniques and apply them to a more common situation where users need to apply an astrometirc correction to their data before extracting merged properties.
Data preparation
We start this part of the thread with a similar setup: an on-axis point-like source observed in two observations.
unix% find_chandra_obsid "TWA 32" # obsid sepn inst grat time obsdate piname target 18898 0.1 ACIS-S NONE 35.4 2017-04-09 Kastner "TWA 32" 20056 0.1 ACIS-S NONE 24.2 2017-04-14 Kastner "TWA 32"
As before the observations were taken just a couple of days apart and have similar exposure times. We then download the data
Download the sample data: 18898 (TWA 32); 20056 (TWA 32)
unix% download_chandra_obsid 18898,20056
and reprocess it to apply the latest algorithms and calibrations.
unix% chandra_repro 18898,20056 out= verb=0
The data are shown in Figure 6.
[Version: full-size]
Figure 6: TWA 32
Users will notice that there is a slight offset between the source location in the two observations. This is more obvious if we blink the frames in ds9 as shown in Figure 7.
Figure 7: TWA 32 Blinking Frames
Check for astrometric offsets
Since we can see what appears to be an astrometric shift between the two observations, we can compute the centroid for the source and determine the offset.
First we compute the centroid for the source in OBS_ID 18898
unix% dmstat "18898/repro/acisf18898_repro_evt2.fits[energy=500:7000,sky=circle(12:26:51,-33:16:13,10)][bin sky=0.5]" cen+ v=0 unix% pget dmstat out_cntrd_phys 4078.2387641,4097.9778384 unix% punlearn dmcoords unix% dmcoords 18898/repro/acisf18898_repro_evt2.fits op=sky x=4078.2387641 y=4097.9778384 celfmt=hms v=0 unix% pget dmcoords ra dec 12:26:51.267 -33:16:12.86
and now we compute the centroid in OBS_ID 20056
unix% dmstat "20056/repro/acisf20056_repro_evt2.fits[energy=500:7000,sky=circle(12:26:51,-33:16:13,10)][bin sky=0.5]" cen+ v=0 unix% pget dmstat out_cntrd_phys 4074.0906969,4096.6382979 unix% punlearn dmcoords unix% dmcoords 20056/repro/acisf20056_repro_evt2.fits op=sky x=4074.0906969 y=4096.6382979 celfmt=hms v=0 unix% pget dmcoords ra dec 12:26:51.288 -33:16:13.19
The offset is ~0.5arcsec in dec (which is about 1 pixel). This is large enough to need to worry about it; especially for a source close to the aimpoint.
Correct for astrometric offsets
We will now apply an astrometric correction to one of the observation to shift the data to match the other. In this example we will shift the data for OBS_ID 18898 to match OBS_ID 20056. The choice of which observation to apply an astrometric correction to is arbitrary. Users interested in absolute position may which to cross-match the source with say a 3rd catalog and apply astrometric corrections to both datasets.
Users can review the Correcting Absolute Astrometry thread for a full discussion of the steps shown here.
The idea is to use wcs_match to compute the astrometric correction needed to align OBSID 18898 to OBSID 20056, and then use wcs_update to apply the correction. The input to wcs_match is two source lists with the RA and Dec of the sources to match. Since wcs_match can use the datamodel's ASCII kernel, we can easily create a simple ASCII file with the positions we obtain from dmcoords. The only trick is that the columns need to be in decimal degrees, so we change celfmt=deg in the examples below.
unix% mkdir fine_astro unix% echo "#ra dec" > fine_astro/18898.dat unix% punlearn dmcoords unix% dmcoords 18898/repro/acisf18898_repro_evt2.fits op=sky x=4078.2387641 y=4097.9778384 celfmt=deg v=0 unix% pget dmcoords ra dec | paste - - >> fine_astro/18898.dat
paste is a UNIX command that should be available on most systems. With the two dashes, "-", after it, paste will paste the input text into two columns on output. The output looke like:
unix% cat fine_astro/18898.dat #ra dec 186.713616315192 -33.27024113433137
which the DM can read as a simple ASCII table with 2 columns (RA and Dec) and 1 row.
We now repeat for the 2nd observation
unix% echo "#ra dec" > fine_astro/20056.dat unix% punlearn dmcoords unix% dmcoords 20056/repro/acisf20056_repro_evt2.fits op=sky x=4074.0906969 y=4096.6382979 celfmt=deg v=0 unix% pget dmcoords ra dec | paste - - >> fine_astro/20056.dat
We can now run wcs_match to compute the astrometric offset needed to align the two observations on the coordinates of this source. With only 1 source position we can only use the translation-only solution, method=trans. In general unless there are many sources evenly distributed across the field, users should always use method=trans.
unix% punlearn wcs_match unix% wcs_match \ infile=fine_astro/18898.dat \ ref=fine_astro/20056.dat \ wcs=18898/repro/acisf18898_repro_evt2.fits \ method=trans\ out=fine_astro/wav.xform \ radius=4 \ clob+ verbose=2 mode=h
The verbose output has some useful diagnostic information, especially when matching multiple sources.
input (dup) src file : fine_astro/18898.dat input ref src file : fine_astro/20056.dat input wcsfile : 18898/repro/acisf18898_repro_evt2.fits debug level : 2 Opening wcsfile: 18898/repro/acisf18898_repro_evt2.fits asp values from 18898/repro/acisf18898_repro_evt2.fits are: 186.711 -33.270 0.000 ref WCS values are: wcrpix 4096.500 4096.500 wcrval 186.711 -33.270 wcdlt -0.00013667 0.00013667 xfmTableFilename is: fine_astro/wav.xform radius in arcsec, radius in sky pixels are: 4.000 8.130 residlim in arcsec, residlim in sky pixels are: 2.000 4.065 Opened dup srcs file: fine_astro/18898.dat Opened ref srcs file: fine_astro/20056.dat 1 common sources found between: fine_astro/20056.dat fine_astro/18898.dat After deleting poor matches, 1 sources remain Transform elements are: delta_x(sky pix): -0.525661 delta_y(sky pix): -0.667922 rotation(deg.): 0.000000 scale factor: 1.000000 Source Residuals ---------------- Match Ref# Dup# Ref RA Ref Dec. Prior Resid Transfm Resid Resid Incl Index (deg.) (deg.) RSS (x,y) RSS (x,y) Ratio (arcsec) (arcsec) 0 0 0 186.71370 -33.27033 0.42 ( 0.26, 0.33) 0.00 (-0.00,-0.00) 0.00 Y Source Residuals, before/after transform (arcsec), and percentage improvement: Average Residuals: 0.418183 0.000000 100.00% Maximum Residuals: 0.418183 0.000000 100.00% RMS Residuals: 0.295700 0.000000 100.00% Source Residual Ratios, before/after transform, and percentage improvement: Average Residual Ratios: 0.424982 0.000000 100.00% Maximum Residual Ratios: 0.424982 0.000000 100.00% RMS Ratios: 0.300508 0.000000 100.00% # wcs_match (CIAO 4.14): WARNING: Dup src x_err or ra_err cols not found. Assuming x_err = 1. # wcs_match (CIAO 4.14): WARNING: Dup src y_err or dec_err cols not found. Assuming y_err = 1. # wcs_match (CIAO 4.14): WARNING: Ref src x_err or ra_err cols not found. Assuming x_err = 1. # wcs_match (CIAO 4.14): WARNING: Ref src y_err or dec_err cols not found. Assuming y_err = 1.
Looking at the output file, the offsets, in sky pixels (0.492arcsec/pixel), are
unix% dmlist fine_astro/wav.xform"[cols t1,t2]" data,clean # t1 t2 -0.52566100938611 -0.66792243254622
Now we apply the offsets to the event file and the aspect solution
unix% mkdir 18898/fine_astro/ unix% dmcopy 18898/repro/acisf18898_repro_evt2.fits 18898/fine_astro/acisf18898_repro_fac_evt2.fits unix% wcs_update infile=18898/fine_astro/acisf18898_repro_fac_evt2.fits \ outfile="" \ transform=fine_astro/wav.xform \ wcs=")infile" clob+ unix% wcs_update infile= 18898/repro/pcadf18898_000N001_asol1.fits \ outfile=18898/fine_astro/pcadf18898_000N001_fac_asol1.fits \ transform=fine_astro/wav.xform \ wcs=18898/fine_astro/acisf18898_repro_fac_evt2.fits clob+ unix% dmhedit 18898/fine_astro/acisf18898_repro_fac_evt2.fits \ file= op=add key=ASOLFILE value=pcadf18898_000N001_fac_asol1.fits
Do not skip updating the ASOLFILE name in the header of the event file. Failing to do this will result incorrect exposure maps and ARF files.
Finally we can recompute the centroid in the corrected dataset and recompute the offset to be sure that everything worked
unix% dmstat "18898/fine_astro/acisf18898_repro_fac_evt2.fits[energy=500:7000,sky=circle(12:26:51,-33:16:13,10)][bin sky=0.5]" cen+ v=0 unix% pget dmstat out_cntrd_phys 4078.293919,4097.9948752 unix% punlearn dmcoords unix% dmcoords 18898/fine_astro/acisf18898_repro_fac_evt2.fits op=sky x=4078.3049873 y=4098.015509 celfmt=hms v=0 unix% pget dmcoords ra dec 12:26:51.286 -33:16:13.18 unix% echo "#ra dec" > fine_astro/18898_check.dat unix% punlearn dmcoords unix% dmcoords 18898/fine_astro/acisf18898_repro_fac_evt2.fits op=sky x=4078.3049873 y=4098.015509 celfmt=deg v=0 unix% pget dmcoords ra dec | paste - - >> fine_astro/18898_check.dat
Now repeat wcsmatch
unix% punlearn wcs_match unix% wcs_match \ infile=fine_astro/18898_check.dat \ ref=fine_astro/20056.dat \ wcs=18898/fine_astro/acisf18898_repro_fac_evt2.fits \ method=trans\ out=fine_astro/wav_check.xform \ radius=4 \ clob+ verbose=0 mode=h unix% dmlist fine_astro/wav_check.xform"[cols t1,t2]" data,clean # t1 t2 -0.05515368200395 -0.01702177559764
The offsets are now much, much less than a pixel. We can proceed with merging the data.
If we did the correction, correctly, then they why aren't the offsets exactly 0.0?
Remember that the event coordinates are stored as real (floating) point values, not integers. So, a small shift in the WCS, means there will be a small shift in the pixel grid. When we bin this into an image, some events will be located in adjacent pixels. This leads to a slight change in the morphology of the source; and thus a slight change in the centroid.
Merge datasets
We want to be sure that merge_obs uses the event file with the astrometric corrections so we need to specify it explicitly by name:
unix% /bin/ls 18898/fine_astro/*evt2.fits > fac_evt2.lis unix% /bin/ls 20056/repro/*evt2.fits >> fac_evt2.lis unix% cat fac_evt2.lis 18898/fine_astro/acisf18898_repro_fac_evt2.fits 20056/repro/acisf20056_repro_evt2.fits
Since the 18898/fine_astro directory is at the same directory level as the 18898/repro directory, merge_obs and later srcflux will be able to locate the ancillary files.
We can now run merge_obs
unix% merge_obs "@fac_evt2.lis" out=merge_fac/ bin=1 band=broad psfecf=0.9 clob+
wcs_update is used to apply offsets (usually small) to the world coordinates to modify the RA,Dec of the source. As used above, the physical pixel locations (x,y) do not change.
merge_obs (via reproject_events) is used to reproject the events to a new tangent plane projection. In this case, the physical coordinates (x,y) change, but the celestial coordinates remain the same.
In this example we are applying both corrections. We are aligning the data to match WCS and we are then reprojecting the data to a common tangent plane.
The combined dataset is shown in Figure 8.
[Version: full-size]
Figure 8: Merged TWA 32, broad band
Compute centroid for merged data
We now want to compute the centroid for the source in the merged dataset. This is important in this case because we have applied fine astrometric shift to the event positions and have reprojected the events to different tangent planes. The centroid is affected by how the events are binned and these corrections can introduce pixel-to-pixel variations when binning the real-valued event locations into images.
Since we are working with a single source, the dmstat method is usually quicker and as accurate as the wavdetect results.
unix% dmstat "merge_fac/broad_thresh.img[sky=circle(12:26:51,-33:16:13,10)]" cen+ v=0 unix% pget dmstat out_cntrd_phys 4076.225058,4097.3433875 unix% punlearn dmcoords unix% dmcoords merge_fac/broad_thresh.img op=sky x=4076.225058 y=4097.3433875 celfmt=hms v=0 unix% pget dmcoords ra dec 12:26:51.286 -33:16:13.17
Generate user supplied regions
In the previous example we saw that the default 90% ECF source regions were a little too small compared to the data. We can actually check this before running srcflux by using the psfsize_src tool (this is the same script srcflux uses). The idea is to generate the regions before running srcflux to check if maybe user supplied regions would be a better choice.
We start with generating the region for OBS_ID 18898
unix% psfsize_srcs merge_fac/18898_broad_thresh.img pos="12:26:51.287,-33:16:13.16" out=merge_fac/18898.src \ energy=1.0 ecf=0.9 clob+
The script is run with the same parameters srcflux uses: energy=1.0 ecf=0.9. The output table is a FITS region file with additional coordinate information (such as off-axis angles, and mean chip coordinates). We are interested in the source radius
unix% dmlist merge_fac/18898.src"[cols x,y,r]" data,clean # X Y R 4076.2039350898 4097.3826648022 1.6945846652
Only a 1.7 pixel radius (0.836 arcsec). This is almost the same size as the astrometric offset between the observations; this is why making that correction can be especially important when working with sources near the aimpoint.
And now we repeat the process for OBS_ID 20056
unix% psfsize_srcs merge_fac/20056_broad_thresh.img pos="12:26:51.287,-33:16:13.16" out=merge_fac/20056.src \ energy=1.0 ecf=0.9 clob+
Since these are region files we can display them on the reprojected images as shown in Figure 9.
[Version: full-size]
Figure 9: Default 90%ECF @ 1keV Regions
Again, in this example the default regions look to be a little too small compared to the data. Seeing this we will use user-supplied regions when running srcflux.
Run srcflux
We can now run srcflux. We want to be sure that we use the event file with the astrometric corrections applied, so we can use the same list file we created for the merge_obs step. We also are going to use custom source and background regions since we know that the default regions will be a little too small.
unix% punlearn srcflux unix% srcflux \ infile=@fac_evt2.lis \ pos="12:26:51.287,-33:16:13.16" \ srcreg="circle(12:26:51.287,-33:16:13.16,5)" \ bkgreg="annulus(12:26:51.287,-33:16:13.16,6,12)" \ out=sf/out \ bkgresp=yes psfmethod=arfcorr conf=0.68 clob+
For brevity the full output is not shown here, but we can check the final merged rates and fluxes in the out_summary.txt file.
unix% cat sf/out_summary.txt Summary of merged source fluxes Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|12 26 51.28 -33 16 13.1 Rate 0.00757 c/s (0.00721,0.00794) NumObi=2 Mod.Flux 7.52E-14 erg/cm2/s (7.16E-14,7.89E-14) Unabs Mod.Flux 8.25E-14 erg/cm2/s (7.85E-14,8.65E-14)
Summary
In this section we saw how to include astrometric corrections into the processing steps needed to compute the combine source flux for a single source. In the next section we see how to work with multiple sources.
Using region files
As an alternative to using the region strings for the source and background regions
srcreg="circle(12:26:51.287,-33:16:13.16,5)" \ bkgreg="annulus(12:26:51.287,-33:16:13.16,6,12)" \
We can automatically create ds9 format region files using the regphystocel tool. We can use the centroid we obtained from the merged data set, 4076.225058,4097.3433875 to create ds9 format region files for the source region
unix% regphystocel in="circle(4076.225058,4097.3433875,5)" out=src.reg wcsfile=merge_fac/broad_thresh.img unix% cat src.reg % cat src.reg # Region file format: DS9 version 4.1 global color=green dashlist=8 3 width=1 font="helvetica 10 normal roman" select=1 highlite=1 dash=0 fixed=0 edit=1 move=1 delete=1 include=1 source=1 fk5 circle(12:26:51.2861,-33:16:13.1793,2.46") #
and background
unix% regphystocel in="annulus(4076.225058,4097.3433875,6,12)" out=bkg.reg wcsfile=merge_fac/broad_thresh.img unix% cat bkg.reg # Region file format: DS9 version 4.1 global color=green dashlist=8 3 width=1 font="helvetica 10 normal roman" select=1 highlite=1 dash=0 fixed=0 edit=1 move=1 delete=1 include=1 source=1 fk5 annulus(12:26:51.2861,-33:16:13.1793,2.952",5.904") #
We can then use these files for the srcflux srcreg and bkgreg parameters.
srcreg="src.reg" \ bkgreg="bkg.reg" \
The output is the the same as before.
Multiple Sources in Multiple Observations
So far this thread has shown a very simple case of a single source in just two observations. In this section we show the steps involved in processing multiple sources in multiple observations.
Data Preparation: NGC 1960
The data preparation steps are the same as before: find, download, reprocesss. For this part of the thread we are going to use data for NGC 1960.
unix% find_chandra_obsid "NGC1960" # obsid sepn inst grat time obsdate piname target 21168 0.1 ACIS-I NONE 17.8 2018-12-26 Getman "NGC 1960" 22031 0.1 ACIS-I NONE 21.8 2018-12-27 Getman "NGC 1960" 22032 0.1 ACIS-I NONE 14.9 2019-01-01 Getman "NGC 1960" 22033 0.1 ACIS-I NONE 11.9 2019-01-06 Getman "NGC 1960"
As before, these observations are all close together although the exposure times vary by a factor of 2.
Download the sample data: 21168 (NGC 1960); 22031 (NGC 1960); 22032 (NGC 1960); 22033 (NGC 1960)
unix% download_chandra_obsid 21168,22031,22032,22033
and reprocess:
unix% chandra_repro 21168,22031,22032,22033 out= clob+
Merge the observations
In this example we will skip ahead and go straight to the merge step. Our plan is to run wavdetect to detect sources and then use the wavdetect regions as inputs to srcflux Since those regions are generally large compared to the size of typical astrometric offsets and in the interest of shortening this thread we are skipping that step here. In general users should check for the need to apply astrometric offsets before combining data.
We now run merge_obs as before
unix% merge_obs 21168,22031,22032,22033 out=merge/ bin=1 psfecf=0.9 clob+
The merged broad and counts image is shown in Figure 10.
[Version: full-size]
Figure 10: Merged broad band counts NGC 1960
Run wavdetect
We can now run wavdetect on the merged dataset
unix% mkdir detect unix% punlearn wavdetect unix% pset wavdetect \ infile=merge/broad_thresh.img \ expfile=merge/broad_thresh.expmap \ psffile=merge/broad_thresh.psfmap \ outfile=detect/wav.src \ scales="1.4 2 4 8 12" \ scell=detect/wav.cell defn=detect/wav.bkg imagef=detect/wav.recon \ interdir=`pwd`/detect/ unix% wavdetect mode=h clobber=yes
and display the regions as in Figure 11.
[Version: full-size]
Figure 11: Wavdetect sources in NGC 1960
There are 225 sources detected in merged data. For simplicity we will filter out the a few of the brightest sources to make this thread go more quickly.
unix% dmcopy detect/wav.src"[src_significance>20]" detect/bright.src clob+ unix% dmlist detect/bright.src counts 10
Users are reminded to always scrutinize the output from any source detection tool and make adjustments if necessary. This may be false sources along the edge or readout streak, sources with radii=0, detecting sub-structure in the off-angle PSF as multiple sources, etc.
Users are also reminded that the properties output from wavdetect are preliminary and have not been corrected for things like PSF fractions.
Run srcflux using standard regions
We will start by simply running srcflux using the default regions. First we generate our stack list of input event files:
unix% /bin/ls {21168,22031,22032,22033}/repro/*evt2.fits > evt2.lis unix% cat evt2.lis 21168/repro/acisf21168_repro_evt2.fits 22031/repro/acisf22031_repro_evt2.fits 22032/repro/acisf22032_repro_evt2.fits 22033/repro/acisf22033_repro_evt2.fits
and then we run srcflux.
unix% punlearn srcflux unix% srcflux \ infile=@evt2.lis \ pos=detect/bright.src \ srcreg="" bkgreg="" \ outroot=sf1/out \ bkgresp=yes clobber=yes conf=0.68 psfmethod=arfcorr \ mode=h clob+
The verbose output looks similar to above but with more sources and more observations.
punlearn srcflux srcflux \ infile=@evt2.lis \ pos=detect_many/bright.src \ srcreg="" bkgreg="" \ outroot=sf_many/out \ bkgresp=no clobber=yes conf=0.68 psfmethod=arfcorr \ mode=h clob+ srcflux infile = @evt2.lis pos = detect_many/bright.src outroot = sf_many/out bands = default srcreg = bkgreg = bkgresp = no psfmethod = arfcorr psffile = conf = 0.68 binsize = 1 rmffile = arffile = model = xspowerlaw.pow1 paramvals = pow1.PhoIndex=2.0 absmodel = xsphabs.abs1 absparams = abs1.nH=%GAL% abund = angr fovfile = asolfile = mskfile = bpixfile = dtffile = ecffile = CALDB parallel = yes nproc = INDEF tmpdir = ./ random_seed = -1 clobber = yes verbose = 1 mode = h Processing OBI 001 Extracting counts Making PSF models Getting PSF fraction by running arfcorr 1 Getting PSF fraction by running arfcorr 3 Getting PSF fraction by running arfcorr 2 Getting PSF fraction by running arfcorr 4 Getting PSF fraction by running arfcorr 5 Getting PSF fraction by running arfcorr 6 Getting PSF fraction by running arfcorr 7 Getting PSF fraction by running arfcorr 8 Getting PSF fraction by running arfcorr 9 Getting PSF fraction by running arfcorr 10 Combining PSF fractions together Getting net rate and confidence limits Getting model independent fluxes Getting model fluxes Getting photon fluxes Running tasks in parallel with 4 processors. Running aprates for sf_many/out_obi001_0001_broad_rates.par Running aprates for sf_many/out_obi001_0003_broad_rates.par Running aprates for sf_many/out_obi001_0002_broad_rates.par Running aprates for sf_many/out_obi001_0004_broad_rates.par Running aprates for sf_many/out_obi001_0005_broad_rates.par Running aprates for sf_many/out_obi001_0006_broad_rates.par Running aprates for sf_many/out_obi001_0007_broad_rates.par Running aprates for sf_many/out_obi001_0008_broad_rates.par Running aprates for sf_many/out_obi001_0009_broad_rates.par Running aprates for sf_many/out_obi001_0010_broad_rates.par Running eff2evt for sf_many/out_obi001_broad_0001_src.dat Running eff2evt for sf_many/out_obi001_broad_0002_src.dat Running eff2evt for sf_many/out_obi001_broad_0003_src.dat Running eff2evt for sf_many/out_obi001_broad_0004_src.dat Running eff2evt for sf_many/out_obi001_broad_0005_src.dat Running eff2evt for sf_many/out_obi001_broad_0006_src.dat Running eff2evt for sf_many/out_obi001_broad_0007_src.dat Running eff2evt for sf_many/out_obi001_broad_0008_src.dat Running eff2evt for sf_many/out_obi001_broad_0009_src.dat Running eff2evt for sf_many/out_obi001_broad_0010_src.dat Running eff2evt for sf_many/out_obi001_broad_0001_bkg.dat Running eff2evt for sf_many/out_obi001_broad_0002_bkg.dat Running eff2evt for sf_many/out_obi001_broad_0003_bkg.dat Running eff2evt for sf_many/out_obi001_broad_0004_bkg.dat Running eff2evt for sf_many/out_obi001_broad_0005_bkg.dat Running eff2evt for sf_many/out_obi001_broad_0006_bkg.dat Running eff2evt for sf_many/out_obi001_broad_0007_bkg.dat Running eff2evt for sf_many/out_obi001_broad_0008_bkg.dat Running eff2evt for sf_many/out_obi001_broad_0009_bkg.dat Running eff2evt for sf_many/out_obi001_broad_0010_bkg.dat Making response files for sf_many/out_obi001_0001 Making response files for sf_many/out_obi001_0002 Making response files for sf_many/out_obi001_0003 Making response files for sf_many/out_obi001_0004 Running modeflux for region 1 Using GAL=0.5765 for source 1 Running modeflux for region 3 Using GAL=0.5777 for source 3 Running modeflux for region 2 Using GAL=0.5748 for source 2 Running modeflux for region 4 Using GAL=0.5746 for source 4 Making response files for sf_many/out_obi001_0005 Making response files for sf_many/out_obi001_0006 Making response files for sf_many/out_obi001_0007 Making response files for sf_many/out_obi001_0008 Running modeflux for region 8 Using GAL=0.575 for source 8 Running modeflux for region 7 Using GAL=0.5746 for source 7 Running modeflux for region 5 Using GAL=0.5727 for source 5 Running modeflux for region 6 Using GAL=0.5742 for source 6 Making response files for sf_many/out_obi001_0009 Making response files for sf_many/out_obi001_0010 Running modeflux for region 9 Running modeflux for region 10 Using GAL=0.5739 for source 9 Using GAL=0.578 for source 10 Adding net rates to output Appending flux results onto output Appending photflux results onto output Computing Net fluxes Adding model fluxes to output Scaling model flux confidence limits Processing OBI 002 Extracting counts Making PSF models Getting PSF fraction by running arfcorr 2 Getting PSF fraction by running arfcorr 1 Getting PSF fraction by running arfcorr 3 Getting PSF fraction by running arfcorr 4 Getting PSF fraction by running arfcorr 5 Getting PSF fraction by running arfcorr 6 Getting PSF fraction by running arfcorr 7 Getting PSF fraction by running arfcorr 8 Getting PSF fraction by running arfcorr 9 Getting PSF fraction by running arfcorr 10 Combining PSF fractions together Getting net rate and confidence limits Getting model independent fluxes Getting model fluxes Getting photon fluxes Running tasks in parallel with 4 processors. Running aprates for sf_many/out_obi002_0001_broad_rates.par Running aprates for sf_many/out_obi002_0002_broad_rates.par Running aprates for sf_many/out_obi002_0003_broad_rates.par Running aprates for sf_many/out_obi002_0004_broad_rates.par Running aprates for sf_many/out_obi002_0005_broad_rates.par Running aprates for sf_many/out_obi002_0006_broad_rates.par Running aprates for sf_many/out_obi002_0007_broad_rates.par Running aprates for sf_many/out_obi002_0008_broad_rates.par Running aprates for sf_many/out_obi002_0009_broad_rates.par Running aprates for sf_many/out_obi002_0010_broad_rates.par Running eff2evt for sf_many/out_obi002_broad_0001_src.dat Running eff2evt for sf_many/out_obi002_broad_0002_src.dat Running eff2evt for sf_many/out_obi002_broad_0003_src.dat Running eff2evt for sf_many/out_obi002_broad_0004_src.dat Running eff2evt for sf_many/out_obi002_broad_0005_src.dat Running eff2evt for sf_many/out_obi002_broad_0006_src.dat Running eff2evt for sf_many/out_obi002_broad_0007_src.dat Running eff2evt for sf_many/out_obi002_broad_0008_src.dat Running eff2evt for sf_many/out_obi002_broad_0009_src.dat Running eff2evt for sf_many/out_obi002_broad_0010_src.dat Running eff2evt for sf_many/out_obi002_broad_0001_bkg.dat Running eff2evt for sf_many/out_obi002_broad_0002_bkg.dat Running eff2evt for sf_many/out_obi002_broad_0003_bkg.dat Running eff2evt for sf_many/out_obi002_broad_0004_bkg.dat Running eff2evt for sf_many/out_obi002_broad_0005_bkg.dat Running eff2evt for sf_many/out_obi002_broad_0006_bkg.dat Running eff2evt for sf_many/out_obi002_broad_0007_bkg.dat Running eff2evt for sf_many/out_obi002_broad_0008_bkg.dat Running eff2evt for sf_many/out_obi002_broad_0009_bkg.dat Running eff2evt for sf_many/out_obi002_broad_0010_bkg.dat Making response files for sf_many/out_obi002_0001 Making response files for sf_many/out_obi002_0002 Making response files for sf_many/out_obi002_0003 Making response files for sf_many/out_obi002_0004 Running modeflux for region 3 Using GAL=0.5777 for source 3 Running modeflux for region 1 Using GAL=0.5765 for source 1 Running modeflux for region 2 Using GAL=0.5748 for source 2 Making response files for sf_many/out_obi002_0005 Making response files for sf_many/out_obi002_0006 Running modeflux for region 4 Using GAL=0.5746 for source 4 Making response files for sf_many/out_obi002_0007 Making response files for sf_many/out_obi002_0008 Running modeflux for region 5 Using GAL=0.5727 for source 5 Running modeflux for region 7 Using GAL=0.5746 for source 7 Running modeflux for region 6 Using GAL=0.5742 for source 6 Running modeflux for region 8 Using GAL=0.575 for source 8 Making response files for sf_many/out_obi002_0009 Making response files for sf_many/out_obi002_0010 Running modeflux for region 10 Using GAL=0.578 for source 10 Running modeflux for region 9 Using GAL=0.5739 for source 9 Adding net rates to output Appending flux results onto output Appending photflux results onto output Computing Net fluxes Adding model fluxes to output Scaling model flux confidence limits Processing OBI 003 Extracting counts Making PSF models Getting PSF fraction by running arfcorr 1 Getting PSF fraction by running arfcorr 3 Getting PSF fraction by running arfcorr 2 Getting PSF fraction by running arfcorr 4 Getting PSF fraction by running arfcorr 5 Getting PSF fraction by running arfcorr 6 Getting PSF fraction by running arfcorr 7 Getting PSF fraction by running arfcorr 8 Getting PSF fraction by running arfcorr 9 Getting PSF fraction by running arfcorr 10 Combining PSF fractions together Getting net rate and confidence limits Getting model independent fluxes Getting model fluxes Getting photon fluxes Running tasks in parallel with 4 processors. Running aprates for sf_many/out_obi003_0001_broad_rates.par Running aprates for sf_many/out_obi003_0002_broad_rates.par Running aprates for sf_many/out_obi003_0003_broad_rates.par Running aprates for sf_many/out_obi003_0004_broad_rates.par Running aprates for sf_many/out_obi003_0005_broad_rates.par Running aprates for sf_many/out_obi003_0006_broad_rates.par Running aprates for sf_many/out_obi003_0007_broad_rates.par Running aprates for sf_many/out_obi003_0008_broad_rates.par Running aprates for sf_many/out_obi003_0009_broad_rates.par Running aprates for sf_many/out_obi003_0010_broad_rates.par Running eff2evt for sf_many/out_obi003_broad_0001_src.dat Running eff2evt for sf_many/out_obi003_broad_0002_src.dat Running eff2evt for sf_many/out_obi003_broad_0003_src.dat Running eff2evt for sf_many/out_obi003_broad_0004_src.dat Running eff2evt for sf_many/out_obi003_broad_0005_src.dat Running eff2evt for sf_many/out_obi003_broad_0006_src.dat Running eff2evt for sf_many/out_obi003_broad_0007_src.dat Running eff2evt for sf_many/out_obi003_broad_0008_src.dat Running eff2evt for sf_many/out_obi003_broad_0009_src.dat Running eff2evt for sf_many/out_obi003_broad_0010_src.dat Running eff2evt for sf_many/out_obi003_broad_0001_bkg.dat Running eff2evt for sf_many/out_obi003_broad_0002_bkg.dat Running eff2evt for sf_many/out_obi003_broad_0003_bkg.dat Running eff2evt for sf_many/out_obi003_broad_0004_bkg.dat Running eff2evt for sf_many/out_obi003_broad_0005_bkg.dat Running eff2evt for sf_many/out_obi003_broad_0006_bkg.dat Running eff2evt for sf_many/out_obi003_broad_0007_bkg.dat Running eff2evt for sf_many/out_obi003_broad_0008_bkg.dat Running eff2evt for sf_many/out_obi003_broad_0009_bkg.dat Running eff2evt for sf_many/out_obi003_broad_0010_bkg.dat Making response files for sf_many/out_obi003_0001 Making response files for sf_many/out_obi003_0002 Making response files for sf_many/out_obi003_0003 Making response files for sf_many/out_obi003_0004 Running modeflux for region 3 Using GAL=0.5777 for source 3 Running modeflux for region 1 Using GAL=0.5765 for source 1 Making response files for sf_many/out_obi003_0005 Running modeflux for region 2 Using GAL=0.5748 for source 2 Making response files for sf_many/out_obi003_0006 Running modeflux for region 4 Using GAL=0.5746 for source 4 Making response files for sf_many/out_obi003_0007 Making response files for sf_many/out_obi003_0008 Running modeflux for region 5 Using GAL=0.5727 for source 5 Running modeflux for region 6 Using GAL=0.5742 for source 6 Running modeflux for region 7 Using GAL=0.5746 for source 7 Running modeflux for region 8 Using GAL=0.575 for source 8 Making response files for sf_many/out_obi003_0009 Making response files for sf_many/out_obi003_0010 Running modeflux for region 9 Using GAL=0.5739 for source 9 Running modeflux for region 10 Using GAL=0.578 for source 10 Adding net rates to output Appending flux results onto output Appending photflux results onto output Computing Net fluxes Adding model fluxes to output Scaling model flux confidence limits Processing OBI 004 Extracting counts Making PSF models Getting PSF fraction by running arfcorr 2 Getting PSF fraction by running arfcorr 1 Getting PSF fraction by running arfcorr 3 Getting PSF fraction by running arfcorr 4 Getting PSF fraction by running arfcorr 5 Getting PSF fraction by running arfcorr 6 Getting PSF fraction by running arfcorr 7 Getting PSF fraction by running arfcorr 8 Getting PSF fraction by running arfcorr 9 Getting PSF fraction by running arfcorr 10 Combining PSF fractions together Getting net rate and confidence limits Getting model independent fluxes Getting model fluxes Getting photon fluxes Running tasks in parallel with 4 processors. Running aprates for sf_many/out_obi004_0001_broad_rates.par Running aprates for sf_many/out_obi004_0003_broad_rates.par Running aprates for sf_many/out_obi004_0002_broad_rates.par Running aprates for sf_many/out_obi004_0004_broad_rates.par Running aprates for sf_many/out_obi004_0005_broad_rates.par Running aprates for sf_many/out_obi004_0006_broad_rates.par Running aprates for sf_many/out_obi004_0007_broad_rates.par Running aprates for sf_many/out_obi004_0008_broad_rates.par Running aprates for sf_many/out_obi004_0009_broad_rates.par Running aprates for sf_many/out_obi004_0010_broad_rates.par Running eff2evt for sf_many/out_obi004_broad_0001_src.dat Running eff2evt for sf_many/out_obi004_broad_0002_src.dat Running eff2evt for sf_many/out_obi004_broad_0003_src.dat Running eff2evt for sf_many/out_obi004_broad_0004_src.dat Running eff2evt for sf_many/out_obi004_broad_0005_src.dat Running eff2evt for sf_many/out_obi004_broad_0006_src.dat Running eff2evt for sf_many/out_obi004_broad_0007_src.dat Running eff2evt for sf_many/out_obi004_broad_0008_src.dat Running eff2evt for sf_many/out_obi004_broad_0009_src.dat Running eff2evt for sf_many/out_obi004_broad_0010_src.dat Running eff2evt for sf_many/out_obi004_broad_0001_bkg.dat Running eff2evt for sf_many/out_obi004_broad_0002_bkg.dat Running eff2evt for sf_many/out_obi004_broad_0003_bkg.dat Running eff2evt for sf_many/out_obi004_broad_0004_bkg.dat Running eff2evt for sf_many/out_obi004_broad_0005_bkg.dat Running eff2evt for sf_many/out_obi004_broad_0006_bkg.dat Running eff2evt for sf_many/out_obi004_broad_0007_bkg.dat Running eff2evt for sf_many/out_obi004_broad_0008_bkg.dat Running eff2evt for sf_many/out_obi004_broad_0009_bkg.dat Running eff2evt for sf_many/out_obi004_broad_0010_bkg.dat Making response files for sf_many/out_obi004_0001 Making response files for sf_many/out_obi004_0002 Making response files for sf_many/out_obi004_0003 Making response files for sf_many/out_obi004_0004 Running modeflux for region 3 Running modeflux for region 1 Using GAL=0.5777 for source 3 Using GAL=0.5765 for source 1 Running modeflux for region 2 Using GAL=0.5748 for source 2 Making response files for sf_many/out_obi004_0005 Making response files for sf_many/out_obi004_0006 Running modeflux for region 4 Using GAL=0.5746 for source 4 Making response files for sf_many/out_obi004_0007 Making response files for sf_many/out_obi004_0008 Running modeflux for region 7 Using GAL=0.5746 for source 7 Running modeflux for region 6 Running modeflux for region 5 Using GAL=0.5742 for source 6 Using GAL=0.5727 for source 5 Running modeflux for region 8 Using GAL=0.575 for source 8 Making response files for sf_many/out_obi004_0009 Making response files for sf_many/out_obi004_0010 Running modeflux for region 10 Using GAL=0.578 for source 10 Running modeflux for region 9 Using GAL=0.5739 for source 9 Adding net rates to output Appending flux results onto output Appending photflux results onto output Computing Net fluxes Adding model fluxes to output Scaling model flux confidence limits Combining count rates Combining spectra and running model flux for each source Running modeflux for region 1 Using GAL=0.5765 for source 1 Running modeflux for region 2 Using GAL=0.5748 for source 2 Running modeflux for region 3 Using GAL=0.5777 for source 3 Running modeflux for region 4 Using GAL=0.5746 for source 4 Running modeflux for region 5 Using GAL=0.5727 for source 5 Running modeflux for region 6 Using GAL=0.5742 for source 6 Running modeflux for region 7 Using GAL=0.5746 for source 7 Running modeflux for region 8 Using GAL=0.575 for source 8 Running modeflux for region 9 Using GAL=0.5739 for source 9 Running modeflux for region 10 Using GAL=0.578 for source 10 Summary of source fluxes in OBI 001 Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|5 36 2.24 +34 4 41.0 Rate 0.00183 c/s (0.0015,0.0022) Flux 1.82E-14 erg/cm2/s (1.5E-14,2.2E-14) Mod.Flux 2.77E-14 erg/cm2/s (2.27E-14,3.34E-14) Unabs Mod.Flux 4.59E-14 erg/cm2/s (3.77E-14,5.53E-14) #0002|5 36 13.97 +34 4 54.7 Rate 0.000294 c/s (0.000168,0.000464) Flux 9.62E-15 erg/cm2/s (5.5E-15,1.52E-14) Mod.Flux 4.95E-15 erg/cm2/s (2.83E-15,7.81E-15) Unabs Mod.Flux 8.21E-15 erg/cm2/s (4.69E-15,1.29E-14) #0003|5 35 57.71 +34 5 0.2 Rate 0.00224 c/s (0.00187,0.00265) Flux 4.05E-14 erg/cm2/s (3.39E-14,4.79E-14) Mod.Flux 3.35E-14 erg/cm2/s (2.8E-14,3.96E-14) Unabs Mod.Flux 5.56E-14 erg/cm2/s (4.65E-14,6.57E-14) #0004|5 36 17.98 +34 5 38.7 Rate 0.000995 c/s (0.000766,0.00126) Flux 1.09E-14 erg/cm2/s (8.42E-15,1.38E-14) Mod.Flux 1.54E-14 erg/cm2/s (1.18E-14,1.95E-14) Unabs Mod.Flux 2.54E-14 erg/cm2/s (1.96E-14,3.23E-14) #0005|5 36 33.39 +34 6 5.1 Rate 0.000573 c/s (0.000398,0.000794) Flux 5.69E-15 erg/cm2/s (3.95E-15,7.88E-15) Mod.Flux 2.61E-14 erg/cm2/s (1.81E-14,3.61E-14) Unabs Mod.Flux 4.32E-14 erg/cm2/s (3E-14,5.98E-14) #0006|5 36 22.80 +34 6 7.3 Rate 5.78E-05 c/s (1.05E-05,0.000154) Flux 6.73E-16 erg/cm2/s (1.22E-16,1.79E-15) Mod.Flux 8.37E-16 erg/cm2/s (1.52E-16,2.23E-15) Unabs Mod.Flux 1.39E-15 erg/cm2/s (2.52E-16,3.69E-15) #0007|5 36 20.05 +34 6 11.6 Rate 0.000563 c/s (0.000396,0.000773) Flux 5.62E-15 erg/cm2/s (3.96E-15,7.72E-15) Mod.Flux 8.35E-15 erg/cm2/s (5.88E-15,1.15E-14) Unabs Mod.Flux 1.38E-14 erg/cm2/s (9.73E-15,1.9E-14) #0008|5 36 17.87 +34 6 31.8 Rate 0.00115 c/s (0.000899,0.00144) Flux 1.12E-14 erg/cm2/s (8.76E-15,1.4E-14) Mod.Flux 1.75E-14 erg/cm2/s (1.37E-14,2.19E-14) Unabs Mod.Flux 2.89E-14 erg/cm2/s (2.27E-14,3.63E-14) #0009|5 36 40.84 +34 10 14.1 Rate 0.00323 c/s (0.00276,0.00369) Flux 6.73E-15 erg/cm2/s (5.77E-15,7.71E-15) Mod.Flux 5.05E-14 erg/cm2/s (4.32E-14,5.78E-14) Unabs Mod.Flux 8.35E-14 erg/cm2/s (7.15E-14,9.56E-14) #0010|5 36 11.47 +34 10 37.4 Rate 0.00133 c/s (0.00106,0.00164) Flux 1.84E-14 erg/cm2/s (1.47E-14,2.27E-14) Mod.Flux 2.03E-14 erg/cm2/s (1.62E-14,2.5E-14) Unabs Mod.Flux 3.37E-14 erg/cm2/s (2.69E-14,4.15E-14) Summary of source fluxes in OBI 002 Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|5 36 2.24 +34 4 41.0 Rate 0.00205 c/s (0.00173,0.0024) Flux 3.58E-14 erg/cm2/s (3.03E-14,4.19E-14) Mod.Flux 3.1E-14 erg/cm2/s (2.62E-14,3.63E-14) Unabs Mod.Flux 5.14E-14 erg/cm2/s (4.34E-14,6.02E-14) #0002|5 36 13.97 +34 4 54.7 Rate 0.00272 c/s (0.00235,0.00311) Flux 4.18E-14 erg/cm2/s (3.6E-14,4.77E-14) Mod.Flux 4.57E-14 erg/cm2/s (3.94E-14,5.21E-14) Unabs Mod.Flux 7.58E-14 erg/cm2/s (6.53E-14,8.63E-14) #0003|5 35 57.71 +34 5 0.2 Rate 0.00215 c/s (0.00182,0.00251) Flux 4.86E-14 erg/cm2/s (4.12E-14,5.67E-14) Mod.Flux 3.21E-14 erg/cm2/s (2.72E-14,3.75E-14) Unabs Mod.Flux 5.33E-14 erg/cm2/s (4.52E-14,6.22E-14) #0004|5 36 17.98 +34 5 38.7 Rate 0.0037 c/s (0.00326,0.00414) Flux 5E-14 erg/cm2/s (4.4E-14,5.59E-14) Mod.Flux 5.73E-14 erg/cm2/s (5.05E-14,6.41E-14) Unabs Mod.Flux 9.48E-14 erg/cm2/s (8.36E-14,1.06E-13) #0005|5 36 33.39 +34 6 5.1 Rate 0.00137 c/s (0.00111,0.00166) Flux 1.81E-14 erg/cm2/s (1.47E-14,2.2E-14) Mod.Flux 6.46E-14 erg/cm2/s (5.25E-14,7.83E-14) Unabs Mod.Flux 1.07E-13 erg/cm2/s (8.68E-14,1.3E-13) #0006|5 36 22.80 +34 6 7.3 Rate 9.47E-05 c/s (3.36E-05,0.000194) Flux 1.51E-15 erg/cm2/s (5.37E-16,3.1E-15) Mod.Flux 1.38E-15 erg/cm2/s (4.89E-16,2.82E-15) Unabs Mod.Flux 2.28E-15 erg/cm2/s (8.1E-16,4.68E-15) #0007|5 36 20.05 +34 6 11.6 Rate 0.000575 c/s (0.000413,0.000771) Flux 9.13E-15 erg/cm2/s (6.56E-15,1.22E-14) Mod.Flux 8.66E-15 erg/cm2/s (6.22E-15,1.16E-14) Unabs Mod.Flux 1.43E-14 erg/cm2/s (1.03E-14,1.92E-14) #0008|5 36 17.87 +34 6 31.8 Rate 0.00371 c/s (0.00327,0.00416) Flux 4.97E-14 erg/cm2/s (4.37E-14,5.56E-14) Mod.Flux 5.67E-14 erg/cm2/s (4.99E-14,6.35E-14) Unabs Mod.Flux 9.39E-14 erg/cm2/s (8.27E-14,1.05E-13) #0009|5 36 40.84 +34 10 14.1 Rate 0.00364 c/s (0.00319,0.00409) Flux 5.16E-14 erg/cm2/s (4.53E-14,5.8E-14) Mod.Flux 5.69E-14 erg/cm2/s (4.99E-14,6.39E-14) Unabs Mod.Flux 9.42E-14 erg/cm2/s (8.27E-14,1.06E-13) #0010|5 36 11.47 +34 10 37.4 Rate 0.000891 c/s (0.000691,0.00113) Flux 8.73E-15 erg/cm2/s (6.76E-15,1.1E-14) Mod.Flux 1.36E-14 erg/cm2/s (1.05E-14,1.72E-14) Unabs Mod.Flux 2.26E-14 erg/cm2/s (1.75E-14,2.85E-14) Summary of source fluxes in OBI 003 Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|5 36 2.24 +34 4 41.0 Rate 0.00291 c/s (0.00245,0.00342) Flux 3.22E-14 erg/cm2/s (2.71E-14,3.79E-14) Mod.Flux 4.46E-14 erg/cm2/s (3.76E-14,5.24E-14) Unabs Mod.Flux 7.4E-14 erg/cm2/s (6.23E-14,8.69E-14) #0002|5 36 13.97 +34 4 54.7 Rate 0.000836 c/s (0.0006,0.00113) Flux 9.5E-15 erg/cm2/s (6.82E-15,1.28E-14) Mod.Flux 1.45E-14 erg/cm2/s (1.04E-14,1.96E-14) Unabs Mod.Flux 2.4E-14 erg/cm2/s (1.73E-14,3.24E-14) #0003|5 35 57.71 +34 5 0.2 Rate 0.00283 c/s (0.00238,0.00333) Flux 3.67E-14 erg/cm2/s (3.08E-14,4.31E-14) Mod.Flux 4.28E-14 erg/cm2/s (3.59E-14,5.03E-14) Unabs Mod.Flux 7.09E-14 erg/cm2/s (5.96E-14,8.34E-14) #0004|5 36 17.98 +34 5 38.7 Rate 0.000772 c/s (0.000545,0.00105) Flux 2.7E-15 erg/cm2/s (1.91E-15,3.68E-15) Mod.Flux 1.19E-14 erg/cm2/s (8.39E-15,1.62E-14) Unabs Mod.Flux 1.97E-14 erg/cm2/s (1.39E-14,2.68E-14) #0005|5 36 33.39 +34 6 5.1 Rate 0.00122 c/s (0.000933,0.00156) Flux 1.39E-14 erg/cm2/s (1.06E-14,1.77E-14) Mod.Flux 5.88E-14 erg/cm2/s (4.49E-14,7.53E-14) Unabs Mod.Flux 9.73E-14 erg/cm2/s (7.43E-14,1.25E-13) #0006|5 36 22.80 +34 6 7.3 Rate 0.000227 c/s (0.000114,0.000392) Flux 1.92E-15 erg/cm2/s (9.65E-16,3.31E-15) Mod.Flux 3.29E-15 erg/cm2/s (1.65E-15,5.68E-15) Unabs Mod.Flux 5.45E-15 erg/cm2/s (2.74E-15,9.41E-15) #0007|5 36 20.05 +34 6 11.6 Rate 0.00866 c/s (0.00783,0.00949) Flux 1.21E-13 erg/cm2/s (1.09E-13,1.32E-13) Mod.Flux 1.27E-13 erg/cm2/s (1.15E-13,1.39E-13) Unabs Mod.Flux 2.1E-13 erg/cm2/s (1.9E-13,2.3E-13) #0008|5 36 17.87 +34 6 31.8 Rate 0.00075 c/s (0.000537,0.00101) Flux 1.29E-14 erg/cm2/s (9.26E-15,1.74E-14) Mod.Flux 1.14E-14 erg/cm2/s (8.16E-15,1.54E-14) Unabs Mod.Flux 1.89E-14 erg/cm2/s (1.35E-14,2.55E-14) #0009|5 36 40.84 +34 10 14.1 Rate 0.00373 c/s (0.00318,0.00429) Flux 4.73E-14 erg/cm2/s (4.04E-14,5.44E-14) Mod.Flux 5.84E-14 erg/cm2/s (4.98E-14,6.7E-14) Unabs Mod.Flux 9.66E-14 erg/cm2/s (8.24E-14,1.11E-13) #0010|5 36 11.47 +34 10 37.4 Rate 0.00107 c/s (0.00081,0.00138) Flux 1.25E-14 erg/cm2/s (9.44E-15,1.61E-14) Mod.Flux 1.63E-14 erg/cm2/s (1.24E-14,2.11E-14) Unabs Mod.Flux 2.71E-14 erg/cm2/s (2.05E-14,3.49E-14) Summary of source fluxes in OBI 004 Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|5 36 2.24 +34 4 41.0 Rate 0.00102 c/s (0.000725,0.00138) Flux NAN erg/cm2/s (NAN,NAN) Mod.Flux 1.62E-14 erg/cm2/s (1.15E-14,2.19E-14) Unabs Mod.Flux 2.68E-14 erg/cm2/s (1.91E-14,3.63E-14) #0002|5 36 13.97 +34 4 54.7 Rate 0.000182 c/s (6.98E-05,0.000363) Flux 1.92E-15 erg/cm2/s (7.4E-16,3.85E-15) Mod.Flux 3.08E-15 erg/cm2/s (1.19E-15,6.16E-15) Unabs Mod.Flux 5.1E-15 erg/cm2/s (1.96E-15,1.02E-14) #0003|5 35 57.71 +34 5 0.2 Rate 0.00302 c/s (0.00251,0.0036) Flux 5.83E-14 erg/cm2/s (4.85E-14,6.95E-14) Mod.Flux 4.52E-14 erg/cm2/s (3.75E-14,5.38E-14) Unabs Mod.Flux 7.5E-14 erg/cm2/s (6.23E-14,8.93E-14) #0004|5 36 17.98 +34 5 38.7 Rate 0.000372 c/s (0.000204,0.000605) Flux 7.43E-15 erg/cm2/s (4.07E-15,1.21E-14) Mod.Flux 5.72E-15 erg/cm2/s (3.13E-15,9.3E-15) Unabs Mod.Flux 9.47E-15 erg/cm2/s (5.18E-15,1.54E-14) #0005|5 36 33.39 +34 6 5.1 Rate 0.00143 c/s (0.00109,0.00183) Flux 3.32E-15 erg/cm2/s (2.53E-15,4.27E-15) Mod.Flux 5.67E-14 erg/cm2/s (4.32E-14,7.28E-14) Unabs Mod.Flux 9.38E-14 erg/cm2/s (7.15E-14,1.21E-13) #0006|5 36 22.80 +34 6 7.3 Rate 0.00819 c/s (0.0073,0.0091) Flux 1.23E-13 erg/cm2/s (1.1E-13,1.37E-13) Mod.Flux 1.19E-13 erg/cm2/s (1.06E-13,1.32E-13) Unabs Mod.Flux 1.97E-13 erg/cm2/s (1.75E-13,2.19E-13) #0007|5 36 20.05 +34 6 11.6 Rate 0.000255 c/s (0.000132,0.000442) Flux 7.49E-15 erg/cm2/s (3.87E-15,1.3E-14) Mod.Flux 4.15E-15 erg/cm2/s (2.14E-15,7.18E-15) Unabs Mod.Flux 6.87E-15 erg/cm2/s (3.55E-15,1.19E-14) #0008|5 36 17.87 +34 6 31.8 Rate 0.00109 c/s (0.000803,0.00143) Flux 1.33E-14 erg/cm2/s (9.84E-15,1.75E-14) Mod.Flux 1.65E-14 erg/cm2/s (1.22E-14,2.17E-14) Unabs Mod.Flux 2.73E-14 erg/cm2/s (2.02E-14,3.59E-14) #0009|5 36 40.84 +34 10 14.1 Rate 0.00424 c/s (0.0036,0.0049) Flux 5.96E-14 erg/cm2/s (5.05E-14,6.87E-14) Mod.Flux 6.64E-14 erg/cm2/s (5.63E-14,7.66E-14) Unabs Mod.Flux 1.1E-13 erg/cm2/s (9.33E-14,1.27E-13) #0010|5 36 11.47 +34 10 37.4 Rate 0.00115 c/s (0.000844,0.00152) Flux 1.05E-14 erg/cm2/s (7.69E-15,1.38E-14) Mod.Flux 1.77E-14 erg/cm2/s (1.3E-14,2.34E-14) Unabs Mod.Flux 2.94E-14 erg/cm2/s (2.16E-14,3.88E-14) Summary of merged source fluxes Position 0.5 - 7.0 keV Value 68% Conf Interval #0001|5 36 2.24 +34 4 41.0 Rate 0.002 c/s (0.00181,0.00219) NumObi=4 Mod.Flux 3.06E-14 erg/cm2/s (2.78E-14,3.35E-14) Unabs Mod.Flux 5.08E-14 erg/cm2/s (4.6E-14,5.56E-14) #0002|5 36 13.97 +34 4 54.7 Rate 0.0012 c/s (0.00106,0.00135) NumObi=4 Mod.Flux 2.04E-14 erg/cm2/s (1.79E-14,2.29E-14) Unabs Mod.Flux 3.37E-14 erg/cm2/s (2.97E-14,3.79E-14) #0003|5 35 57.71 +34 5 0.2 Rate 0.00249 c/s (0.00228,0.0027) NumObi=4 Mod.Flux 3.73E-14 erg/cm2/s (3.42E-14,4.04E-14) Unabs Mod.Flux 6.18E-14 erg/cm2/s (5.66E-14,6.71E-14) #0004|5 36 17.98 +34 5 38.7 Rate 0.00174 c/s (0.00157,0.00191) NumObi=4 Mod.Flux 2.68E-14 erg/cm2/s (2.41E-14,2.95E-14) Unabs Mod.Flux 4.44E-14 erg/cm2/s (4E-14,4.89E-14) #0005|5 36 33.39 +34 6 5.1 Rate 0.00114 c/s (0.000998,0.00128) NumObi=4 Mod.Flux 5.17E-14 erg/cm2/s (4.53E-14,5.82E-14) Unabs Mod.Flux 8.55E-14 erg/cm2/s (7.49E-14,9.63E-14) #0006|5 36 22.80 +34 6 7.3 Rate 0.00156 c/s (0.0014,0.00173) NumObi=4 Mod.Flux 2.27E-14 erg/cm2/s (2.03E-14,2.51E-14) Unabs Mod.Flux 3.75E-14 erg/cm2/s (3.36E-14,4.15E-14) #0007|5 36 20.05 +34 6 11.6 Rate 0.00231 c/s (0.00211,0.00251) NumObi=4 Mod.Flux 3.48E-14 erg/cm2/s (3.18E-14,3.79E-14) Unabs Mod.Flux 5.77E-14 erg/cm2/s (5.27E-14,6.27E-14) #0008|5 36 17.87 +34 6 31.8 Rate 0.00192 c/s (0.00174,0.0021) NumObi=4 Mod.Flux 2.92E-14 erg/cm2/s (2.64E-14,3.2E-14) Unabs Mod.Flux 4.84E-14 erg/cm2/s (4.38E-14,5.3E-14) #0009|5 36 40.84 +34 10 14.1 Rate 0.00366 c/s (0.0034,0.00392) NumObi=4 Mod.Flux 5.72E-14 erg/cm2/s (5.32E-14,6.13E-14) Unabs Mod.Flux 9.47E-14 erg/cm2/s (8.81E-14,1.01E-13) #0010|5 36 11.47 +34 10 37.4 Rate 0.00112 c/s (0.000976,0.00126) NumObi=4 Mod.Flux 1.71E-14 erg/cm2/s (1.49E-14,1.92E-14) Unabs Mod.Flux 2.83E-14 erg/cm2/s (2.48E-14,3.19E-14)
Plot Fluxes
It can be hard to interpret the verbose output; and even viewing the individual output .flux files can be overwhelming. We have provided a little helper script in this thread to plot, for each source individually, the Model Flux in each of the individual OBS_IDs to compare with the merged model flux.
Users can download the script here: Download plotit.py
unix% python plotit.py
The results for two sources are shown in Figure 12 and Figure 13.
[Version: full-size]
Figure 12: Constant Source in NGC 1960
[Version: full-size]
Figure 13: Variable Source in NGC 1960
The source shown in Figure 13 looks to be variable. The model flux increases significantly during OBS_ID 22033. We can take a look at the source in each of the OBS_IDs to see if this results makes sense. The images are shown in Figure 14.
[Version: full-size]
Figure 14: Variable Source in NGC 1960
Use wavdetect regions in srcflux
We can also see in Figure 14 that the default 90%ECF regions are not a great choice for this source. So far we have seen how to input a single source region into srcflux but manually creating source and background regions for each source would be tedious. Instead we can follow technique shown in the Calculate source count rates and fluxes thread. This involves running the roi tool to automatically create source and background regions from the wavdetect source list.
unix% mkdir roi unix% punlearn roi unix% roi \ infile=detect/bright.src \ outsrc=roi/bright_%02d.fits \ group=indi target=target \ compute_conf- clob+ mode=h
This creates a separate source region for each group=individual source with the background region located around just the target=target source. The output files have the source number in the file name, taken from the COMPONENT value in the input file. Since we filtered the source list, the output file names look like:
unix% /bin/ls roi bright_03.fits bright_05.fits bright_17.fits bright_19.fits bright_68.fits bright_04.fits bright_12.fits bright_18.fits bright_25.fits bright_74.fits
Luckily, COMPONENT values in the source list are in ascending order, so the srcflux region 0010 is bright_74.fits and region 0006 is bright_18.fits.
We need the regions in celestial coordinates; but FITS regions like those created by roi are in physical coordinates. The new script regphystocel is used to do the conversion.
The roi output file has 2 extensions: source and background. Both need to be converted to celestial coordinates. The easiest way to loop over the files is with the UNIX xargs command, something like this:
unix% /bin/ls roi/*fits | xargs -I@ regphystocel @ @.srcreg clob+ verb=0 unix% /bin/ls roi/*fits | xargs -I@ regphystocel @"[bkgreg]" @.bkgreg clob+ verb=0
However, for users unfamiliar with that utility, they can also use the sh|bash|zsh specific for command or the tcsh specific foreach command to loop over the files.
bash$ for r in roi/*.fits do regphystocel $r ${r}.srcreg clob+ verb=0 regphystocel "${r}[bkgreg]"" ${r}.bkgreg clob+ verb=0 done -or- tcsh% foreach r ( roi/*.fits ) regphystocel $r ${r}.srcreg clob+ verb=0 regphystocel "${r}[bkgreg]"" ${r}.bkgreg clob+ verb=0 end
The source and background region file names are then stored in separate list files.
unix% /bin/ls roi/*srcreg > srcreg.lis unix% /bin/ls roi/*bkgreg > bkgreg.lis
We then re-run srcflux using these stacks of region file names
unix% punlearn srcflux unix% srcflux \ infile=@evt2.lis \ pos=detect/bright.src \ outroot=sf2/out \ srcreg=@srcreg.lis \ bkgreg=@bkgreg.lis \ bkgresp=yes clobber=yes conf=0.68 psfmethod=arfcorr \ mode=h clob+
Each source will use the same source and background regions with each observation. The new regions for source #0006 are shown in Figure 15.
[Version: full-size]
Figure 15: Variable Source in NGC 1960, wavdetect regions
Summary
In this final example we saw how to use srcflux to compute rates and fluxes for multiple source positions together with multiple source and background regions with multiple observations. We saw how important it is to review the results since things like source variability between observations may lead to aberrant results.
Final Summary
This thread has shown how to use srcflux to compute rates and fluxes for sources which have been observed in multiple observations. We saw how to handle the simple case of a single source in two nearly identically pointed observations. We saw how to deal with situations which require applying astrometric corrections before computing fluxes. The thread wrapped up with a large example of processing a catalog of source positions in multiple observations. We demonstrated several diagnostic techniques to improve the flux and rate estimates, and showed how to use user-supplied regions throughout.
We also discussed the limitation of this tool, for example, in the presence of variable sources.
History
16 Dec 2020 | New. |
05 Dec 2022 | Review for CIAO 4.15. Updated to set bkgresp=yes to work around a bug introduced in CIAO 4.15. |
17 Sep 2024 | Updated example to use updated aspect solution file names created by chandra_repro. |