1.2. How to run SPEX

SPEX is a spectral fitting program used to fit high-resolution X-ray spectra. The code contains several simple and detailed models that are able to deal with the radiative processes observed in the X-ray band. Because SPEX has a command-line interface, a first-time user should get familiar with the syntax of the commands to be able to work with it. This chapter provides some basic commands and threads to fit X-ray spectra.

1.2.1. The SPEX data format

The data files containing the spectrum of the source and the response need to be in the correct format. In the SPEX installation, we provide a program called Trafo to convert OGIP standard fits files into SPEX format (see How to convert spectra to SPEX format for an explanation of how to use trafo). In this chapter, we assume that you already have spectra in SPEX format. If not, you can find example files in the SPEX Exercises section. Each exercise contains a .spo and .res file that can be downloaded.

SPEX needs two files per spectrum:

  • <filename>.spo – This file contains the countrate per energy bin for the source (D_i), as well as the background countrate and the errors (\sigma_i).

  • <filename>.res – This file contains the instrumental response: the energy redistribution and effective area (R_{ij}~ A_j).

In order to calculate the observed model spectrum, SPEX uses this integral equation to account for the imperfections caused by the instrument:

(1)D(c) =  \int R(c,E) A(E) S(E) dE

D_i =  \sum_{j=1}^n R_{ij} A_j S_j

The .res and .spo files are so-called FITS files. This is a data format widely used in Astronomy. FITS files can contain images as well as data tables. The software package FTOOLS provided by NASA contains a large number of tools to manipulate FITS files. If you are interested, then you can launch flaunch to see which tools are available. For more information about the SPEX spectrum and response format see Optimal definition of respons matrices.

1.2.2. Loading spectra into SPEX

The SPEX program is started by entering spex in a linux terminal window. In the following sections we describe one run of the program. To start SPEX do this:

user@linux:~> spex
 Welcome user to SPEX version 3.00.00

SPEX>

First, we have to load the data files. This is done using the data command (Data: read response file and spectrum). It is a general thing in SPEX that filename extensions are not typed explicitly when issuing a command. If you have a file called filename.spo and filename.res then you type:

SPEX> data filename filename

The responsefile (.res) is entered first and then the file containing the spectrum (.spo). You can avoid confusion by giving the same filename to both .res and .spo files. Remember that the order of the words in the commands is very important!

To save you from typing a lot, many commands can be abbreviated by typing just the first few characters. For example, da is equivalent to dat and data.

1.2.3. Plotting the data

If the data command was successful, we can now have a look at the spectra. SPEX offers a lot of different plot commands (see Plot: Plotting data and models). Using default settings, the easiest way of plotting a spectrum is as follows:

SPEX> plot dev xs
SPEX> plot type data
SPEX> plot

The sequence above opens a PGPLOT window (plot dev xs) and tells SPEX that we want to plot the spectral data (plot type data). This will create a linear-linear plot in keV units.

The plot can be tailored to your wishes. Below is an example to change the plot to a linear-linear plot in Å and add a title to the plot:

SPEX> plot x lin
SPEX> plot y lin
SPEX> plot ux a
SPEX> plot uy a
SPEX> plot rx 8.:35.
SPEX> plot ry 0.:0.05
SPEX> plot set 1
SPEX> plot cap ut text "This is my plot"
SPEX> plot cap lt disp false
SPEX> plot cap id disp false
SPEX> plot

To make sure the axes are linear, we give the commands (plot x lin and plot y lin) and change the axes to unit Å (plot ux a and plot uy a). The commands plot rx 8.:35. and plot ry 0.:0.05 change the ranges on the x and y axes, respectively. Then the color of the data, background spectrum and model are set. The last commands beginning with plot cap remove some standard titles and other text around the plot. After you define the plot like in the example above, you can plot it with a single plot command.

The y-axis in this plot is in \mathrm{counts} \mathrm{s}^{-1} \mathrm{Å}^{-1}. Ångstrom is not the only unit used in high-energy astrophysics. Usually, the energy of the photons is expressed in keV. In SPEX you can use keV by writing k instead of a in all commands. For example, plot ux k to use keV for the x-axis. An overview of possible units is provided in Plot axis units and scales.

1.2.4. Ignoring and rebinning

High-resolution X-ray spectra from Chandra and XMM-Newton are usually oversampled (e.g. the energy bins are much smaller than the spectral resolution) and contain a lot more channels then is useful. Therefore, it is necessary to remove wavelength intervals which contain bad data and rebin your spectrum. The SPEX command to ignore parts of the spectrum is called ignore (Ignore: ignoring part of the spectrum) and the command to rebin is called bin (Bin: rebin the spectrum). In the next example we bin the spectrum over the 8–35 Å range with a factor of 5 and ignore the rest of the spectrum:

ign 0:8 unit a
ign 35:100 unit a
bin 8:35 5 unit a

The words unit a tells SPEX that the ranges (for example 8.0:35.0) are given in Å. If you work with more than one spectrum (from more than one instrument), you can add an extra instrument statement:

ign ins 1:2 0:8 unit a
ign ins 1:2 35:100 unit a
bin ins 1:2 8:35 5 unit a

Here, instrument 1 to 2 are binned with a factor of 5 over the 8–35 Å range.

1.2.5. Defining a model

Now we have a clean and rebinned spectrum that is ready to fit. Before we can start fitting, we first need to define a model. It’s equivalent to S(E) in Eq. (1). The model can contain one or more of these components:

  • absm Model for interstellar absorption.

  • reds Redshift.

  • po Powerlaw.

  • ga Gaussian.

And there are more (see Overview of spectral components)! The following command sequence defines a simple powerlaw model at a certain redshift and absorbed by the interstellar medium. The individual components of the model are loaded one-by-one with the com command (Comp: create, delete and relate spectral components):

SPEX> com reds
SPEX> com absm
SPEX> com po
SPEX> com rel 3 1,2

The last command (com rel 3 1,2) tells SPEX that component 3, the powerlaw, is first redshifted by component 1 and then absorbed by component 2. The order of the 1 and the 2 is important! Always think what happens in which order on the way from the source to the telescope.

For most sources the distance is more or less known. To get a right luminosity estimate for the source, the expected distance has to be provided to SPEX. This is done with the distance command (Distance: set the source distance):

SPEX> dist 0.1 z
Distances assuming H0 =  50.0 km/s/Mpc and q0 = 0.500
Sector    m      A.U.        ly        pc       kpc       Mpc  redshift        cz
---------------------------------------------------------------------------------
1 1.894E+25 1.266E+14 2.002E+09 6.139E+08 6.139E+05  613.8689    0.1000   29979.2
---------------------------------------------------------------------------------

With this command, the distance to the source is set to a redshift of 0.1. The derived distances for this cosmology are in the output of the dist command.

Now we have to estimate the initial parameters. With the command par show we can see which parameters there are:

SPEX> par show
----------------------------------------------------------------------------------
sect comp mod  acro parameter with unit     value      status    minimum   maximum

   1    1 reds z    Redshift              0.000000     frozen   -1.0      1.00E+10

   1    2 absm nh   Column (1E28/m**2)   9.9999997E-05 thawn     0.0      1.00E+20
   1    2 absm f    Covering fraction     1.000000     frozen    0.0       1.0

   1    3 pow  norm Norm (1E44 ph/s/keV)  1.000000     thawn     0.0      1.00E+20
   1    3 pow  gamm Photon index          2.000000     thawn    -10.       10.
   1    3 pow  dgam Photon index break    0.000000     frozen   -10.       10.
   1    3 pow  e0   Break energy (keV)   1.0000000E+10 frozen    0.0      1.00E+20
   1    3 pow  b    Break strength        0.000000     frozen    0.0       10.
   1    3 pow  type Type of norm          0.000000     frozen    0.0       1.0
   1    3 pow  elow Low flux limit (keV)  2.000000     frozen   1.00E-20  1.00E+10
   1    3 pow  eupp Upp flux limit (keV)  10.00000     frozen   1.00E-20  1.00E+10
   1    3 pow  lum  Luminosity (1E30 W)   1.000000     frozen    0.0      1.00E+20

--------------------------------------------------------------------------------
Fluxes and restframe luminosities between   2.0000     and    10.000     keV

 sect comp mod   photon flux   energy flux nr of photons    luminosity
            (phot/m**2/s)      (W/m**2)   (photons/s)           (W)
    1    3 pow    0.00000       0.00000       0.00000       0.00000

We can set the parameters using the par command (Par: Input and output of model parameters). The first “1” in column “sect” can usually be ignored. The commands then look like this:

SPEX> par 1 z val 0.1
SPEX> par 2 nh val 2.E-3
SPEX> par 3 norm val 1.E+10
SPEX> par gamm val 1.5

The last component number used is saved, so in the last line we can skip typing the number 3 after par. Then, we run par show again to see what happened:

SPEX> par show
----------------------------------------------------------------------------------
sect comp mod  acro parameter with unit     value      status    minimum   maximum

   1    1 reds z    Redshift              0.100000     frozen   -1.0      1.00E+10

   1    2 absm nh   Column (1E28/m**2)   2.0000001E-03 thawn     0.0      1.00E+20
   1    2 absm f    Covering fraction     1.000000     frozen    0.0       1.0

   1    3 pow  norm Norm (1E44 ph/s/keV)  1.000000E+10 thawn     0.0      1.00E+20
   1    3 pow  gamm Photon index          1.500000     thawn    -10.       10.
   1    3 pow  dgam Photon index break    0.000000     frozen   -10.       10.
   1    3 pow  e0   Break energy (keV)   1.0000000E+10 frozen    0.0      1.00E+20
   1    3 pow  b    Break strength        0.000000     frozen    0.0       10.
   1    3 pow  type Type of norm          0.000000     frozen    0.0       1.0
   1    3 pow  elow Low flux limit (keV)  2.000000     frozen   1.00E-20  1.00E+10
   1    3 pow  eupp Upp flux limit (keV)  10.00000     frozen   1.00E-20  1.00E+10
   1    3 pow  lum  Luminosity (1E30 W)  5.6014867E+08 frozen    0.0      1.00E+20

--------------------------------------------------------------------------------
Fluxes and restframe luminosities between   2.0000     and    10.000     keV

 sect comp mod   photon flux   energy flux nr of photons    luminosity
            (phot/m**2/s)      (W/m**2)   (photons/s)           (W)
    1    3 pow    0.00000       0.00000       0.00000       0.00000

Finding the right initial values for the parameters is a game of trial and error. To see whether you are going in the right direction, you can calculate the model with the command calc and plot again (Calculate: evaluate the spectrum). If you see the model appear in your screen, then the model is close enough to be fitted. Especially the normalization of the powerlaw (3 norm) can vary a lot depending on the count rate of the source.

1.2.6. Fitting the data

We are ready to fit the data! SPEX has a nice feature to look at the progress of the fit. To activate this feature you have to give the command fit print 1 (see Fit: spectral fitting). If your initial parameters were acceptable, you can see the model converge to the data in the plot window after you entered the fit command. When the fit is done, then the parameters and C-stat are printed on screen. If the C-stat value is close to the expected C-stat value, then your fit is acceptable. Sometimes more runs of the command fit are necessary after changing some initial parameters. This is especially true when using complex models. Again this is a game of trial and error.

You also might want to fix or free certain parameters to see if they can be constrained. In SPEX fixing is f (frozen) and freeing is t (thawn). You can free the redshift and fix the N_{\mathrm{H}} by the following commands:

SPEX> par 1 z stat t
SPEX> par 2 nh stat f

1.2.7. Calculating errors

When the fit is acceptable, you might want to know the uncertainties on your fitted parameters. Errors are determined one-by-one by fixing the parameter to some value and calculate the \Delta C-stat with respect to the best fit. If you want to know the 1\sigma error on the parameter, you need to know its values at \Delta C-stat = 1. This is done by the error command (Error: Calculate the errors of the fitted parameters). You can calculate the error for each parameter. For example redshift:

SPEX> error 1 z

If you need another \Delta C-stat limit (not recommended), then you can set the desired \Delta C-stat in SPEX using the command: error dchi 1.

1.2.8. Making life easier

In this short manual you have seen a lot of commands, but to avoid typing too much you want to use some identical series of commands every time you fit a certain spectrum. For example, you don’t want to type all plot commands again when making a plot. Therefore, the program has a command to solve this problem called log (see Log: Making and using command files). With the command log exe filename you can execute a number of commands at the same time. The numbers are read from a normal text file with (in this case) the name filename.com. Again the extension .com should not be typed explicitly. Below is an example to setup a plot for an EPIC spectrum (range 0.2–10.0 keV) with a small frame that shows residuals. Note that you can put any command in such a command file and you can make comment lines by putting a # sign in front of the line.

# This is a command file that creates a plot with residuals.
plot dev xs
plot type data
plot x log
plot y log
plot rx 0.2:10.
plot ry 0.0001:10.
plot back disp t
plot set 1
plot data col 1
plot model col 2
plot back col 1
plot set all
plot frame new
plot frame 2
plot type chi
plot uy rel
plot x log
plot rx 0.2:10.
plot ry -0.5:0.5
plot view def f
plot view x 0.08:0.92
plot view y 0.1:0.3
plot cap y text "Rel. Error"
plot cap ut disp f
plot cap lt disp f
plot cap id disp f
plot frame 1
plot view def f
plot view x 0.08:0.92
plot view y 0.3:0.9
plot cap x disp f
plot cap id disp f
plot cap ut disp f
plot box numlab bot f

1.2.9. Saving your work

There are several ways in SPEX you can save your work. Below you find a few examples to save your commands, output or plots.

1.2.9.1. Saving a plot

These commands open a PostScript plot device with filename filename.ps, then they plot your figure in the PS file and closes the device:

SPEX> plot dev cps filename.ps
SPEX> plot
SPEX> plot close 2

1.2.9.2. Saving commands

If you want to save all commands that you execute to an ASCII file (filename.com), then type log save filename (see also Log: Making and using command files). Do not forget to close the file at the end of the session by typing log close save. The saved commands in the textfile can be executed again by the log exe filename command.

1.2.9.3. Saving output

In the same way as in the previous example, you can also save the output on your screen by typing log out filename (the file will be an ASCII file called filename.out). You can close the file with log close out. This command is very useful to save your parameters and errors.

1.2.10. Quitting the program

Just type quit (see Quit: finish the program).

1.2.11. Tips & Tricks

  • If you make a typo in a command or you want to do the same command again, then push the arrow-up button on your keyboard. There is an entire history of your commands there.

  • The Tab key is able to automatically complete the command you are typing. In case there are more possibilities, it shows them all.