2. IRAF (DEPRECATED)#
Important
You will need the tutorial data for HR30 to proceed with this example. You can download it from here:
This short lecture note is used as material for the “legacy session,” which uses IRAF. For basic concepts and ideas (e.g., the reason for flat division, etc.), please refer to the other lecture note sections.
This time, you will learn the very basic tasks of IRAF. This includes
Print information about images (
IMSTAT
,CCDLIST
,IMHEADER
,HSELECT
)Arithmetics on images: copying an image and adding, subtracting, multiplying, and dividing an image with others (
IMCOPY
,IMARITH
)Combining: make master bias, dark, and flat (
IMCOMBINE
)Preprocessing
Then
Primitive photometry (
IMEXAM
,DAOEDIT
)Aperture photometry (
PHOT
)Spectroscopic data reduction (
APALL
,IDENTIFY
,REIDENTIFY
,FITCOORDS
,SENSFUNC
,FLUXCALIB
)
I will explain the usage of IRAF/PyRAF in a conda environment, so it may slightly differ from normal IRAF, but is basically the same.
[TOC]
Data files
There are two sets of data: for photometry (P/2006 HR30 data from SMOKA) and spectroscopy (Vega data from SNU AO2 class of 2016). The contents are
HR30 (Used until section 9):
KCD095628.fits KCD095629.fits KCD095630.fits KCD095631.fits bias: KCD095601.fits KCD095603.fits KCD095605.fits KCD095607.fits KCD095609.fits KCD095626.fits KCD095602.fits KCD095604.fits KCD095606.fits KCD095608.fits KCD095610.fits KCD095627.fits flat: KCD095734.fits KCD095736.fits KCD095738.fits KCD095740.fits KCD095742.fits KCD095735.fits KCD095737.fits KCD095739.fits KCD095741.fits KCD095743.fitsVega (Used from section 10):
vega_7s.fits bias: bias-1.fits bias-2.fits bias-3.fits dark: dark-001_7.fits dark-002_7.fits flat: flat_30-001.fits flat_30-002.fits flat_30-003.fits ref: ne_30.fits ne_60.fitsBecause of the size of the images, I did not include them in this GitHub repo. If you want, please contact me at (ysbach93@gmail.com)! The HR30 data are actually publicly available via SMOKA and the Vega data are obtained in the class.
2.1. 1. Run PyRAF#
You can start the IRAF environment (not IRAF itself!) by typing
$ source activate iraf
on the terminal. iraf
is the name of the conda environment you set when creating the environment, and you may have used iraf27
, etc. Then you are now in the IRAF environment running on Python 2.7. In a suitable directory, type
$ mkiraf
and answer the question with xgterm
. Typing ls
will show you login.cl
and uparms
directory. login.cl
is the file that saves basic properties; it’s a settings file, in short. It will be used only when you run IRAF in this directory. You have to run the IRAF in the directory where you have login.cl
. uparms
is a directory that will save the changes you make to the default settings of IRAF.
Now, you can run IRAF by typing $ cl
or run PyRAF by typing
$ pyraf
I used PyRAF since AstroConda does not fully guarantee the stability of IRAF CL. The IMEXAM
, for example, does not correctly work if you use cl
. You will see the following on the terminal with the prompt “-->
”:
NOTE:
Change all the names to “.fits”, NOT “.fit”
All the images should have the header keys
BZERO
andBSCALE
. If they don’t, type the following on the CL terminal:--> noao --> imred --> ccdred --> ccdhedit *.fits BZERO 32768 --> ccdhedit *.fits BSCALE 1
This might be necessary for images obtained from some personal CCDs. The real pixel value should be
real_value = pixel * BSCALE + BZERO
. People sacrificed the 15th bit of a 16-bit system and used it as a “sign” bit. Usually,BZERO = 2**15 = 32768
, andBSCALE=1.0
. If you do not add these header keywords to the image header, you will result in many negative values from bias/dark/flat raw images, which eventually lead to the wrong result. For more information, please see the astropy documentation.
2.2. 2. Display Image#
PyRAF supports a few Linux commands, such as ls
or cd
without an exclamation mark (!
). But to display an image, you must use !ds9
or !ginga
. You should also use (!
) when deleting files using rm
.
Since IRAF is extremely comfortable when used with SAO DS9
, I will use ds9
throughout this note.
2.2.1. SAO DS9#
Display the image:
TIP: It’s better to append the ampersand (
&
) at the end ofds9
. Try it without it and see what happens.TIP: Always try to use
tab
key on your keyboard to “autocomplete”!
In the HR30/
directory, you have four images and bias/
and flat/
directories. The four images are the real images. I first will make master bias and flat.
2.2.2. IRAF IMPLOT
#
There are many plotting packages in IRAF too, e.g., IMPLOT
, for image display, and SPLOT
, for spectrum display:
--> implot vega_7s.fits
Click on the Graphics
window and hit :
key; then you will see a small box at the bottom of the window. The left image is obtained by typing :a 30
and then :l 700
(average over 30 pixels around line (row) 700), and the right image is obtained by typing :a 30
and then :c 500
. On the images, there will be a small T-shaped tick on the right y-axis (red arrows). This indicates which line/column you are looking at.
2.3. 3. Bias Combine#
First, make a list of bias files. Go to the bias directory by typing “--> cd bias
” and typing
--> ls *.fits > bias.list
This will make a file bias.list
containing the list of all files that are bias.
QUESTION: Try what happens when you do
ls bias* > bias.list
(delete.fits
). Open thebias.list
file, and you will find something happened. Why?
Then
--> epar imcombine
epar
means “edit parameters. The task IMCOMBINE
will do task of combining images using many options.
We will combine all 12 images in the bias/
directory and make one output named bias.fits
using the so-called median combine, while all other options are left as default:
In IRAF commands, @filename
means “open the file named filename
, and put the contents here”. Since bias.list
contains the list of file names for bias images,
@bias.list == KCD095601.fits, KCD095602.fits, ....... , KCD095627.fits
See how efficient it is?
By clicking Execute
, you will see that a new file has appeared. Check it out by
--> !ds9 -zscale bias.fits &
In this tutorial, we will neglect the dark because it is extremely small compared to that of bias and almost constant over the image in modern CCDs. So regard this master bias as “bias+dark”. If you have dark frames and want to make a master dark frame, you can just do the same procedure for the dark frame images with identical exposure times (e.g., make dark10s.list
, dark100s.list
, etc.).
2.4. 4. Flat Combine#
To make the master flat, you have to subtract the master bias from the combined flat image. All the processes are identical to those of bias, but subtract master bias from the final combined flat.
--> cd ../flat/
--> ls *.fits > flat.list
--> epar imcombine
I want to make the combined image as flat0.fits
first. Then save the result of subtracting bias, i.e., “flat0 - bias
”, as flat.fits
. Do the median combine first:
Now copy the master bias to here and subtract it from the combined flat:
--> cp ../bias/bias.fits .
--> imarith flat0.fits - bias.fits flat.fits
--> !ds9 -zscale flat.fits &
It’s very intuitive: “IMARITH image1 operator image2 output
” means do the operation (operator
can be +, -, *, /
) on images (image1
, image2
) and save the result as “output
”. IMARITH
of course, means image arithmetics. You can open the full options’ window as you did for IMCOMBINE
by typing
--> epar imarith
2.5. 5. Preprocessing#
2.5.1. IMUTIL
Package#
Preprocessing is simply “(raw image - master bias)/(master flat)”.
--> cd ..
--> cp bias/bias.fits .
--> cp flat/flat.fits .
--> ls
bias bias.fits flat flat.fits KCD095628.fits KCD095629.fits KCD095630.fits KCD095631.fits
Conceptually, what we have to do is first
--> imarith object_image - bias.fits output1
and then do
--> imarith output1 / flat.fits output2
Because we have 4 images, which is few, you can do this for each image. However, there is a cleverer way to do it.
--> ls KCD*.fits > obj.list
--> cp obj.list output1.list
--> cp obj.list output2.list
--> !perl -pi -e "s/KCD/b_KCD/g" output1.list
--> !perl -pi -e "s/KCD/bf_KCD/g" output2.list
--> imarith @obj.list - bias.fits @output1.list
--> imarith @output1.list / flat.fits @output2.list
--> ls
bf_KCD095628.fits bias b_KCD095630.fits KCD095628.fits obj.list
bf_KCD095629.fits bias.fits b_KCD095631.fits KCD095629.fits output1.list
bf_KCD095630.fits b_KCD095628.fits flat KCD095630.fits output2.list
bf_KCD095631.fits b_KCD095629.fits flat.fits KCD095631.fits
Here, perl -pi -e
command is used for changing all the strings “KCD
” to “b_KCD
” or “bf_KCD
”:
perl -pi -e "s/string1/string2/g" filename
^ ^ ^ ^
First s
means we will change the strings from “string1
” to “string2
”, within the file filename
. I used b
for bias corrected and bf
for bias and flat corrected. You can display all the images:
--> !ds9 -zscale bf_*.fits -single &
TIP: Hit the
tab
key, and the next image will be displayed.TIP: When I did the flat fielding, I did not normalize (normalization: scaling the image so that its average value = 1). See the next section’s Question.
Question: Hit the
tab
key several times. Can you find something? What do you think it is?
2.5.2. CCDRED
package#
There are some tasks that are made especially for bias, dark, and flat combine processes. They are called ZEROCOMBINE
, DARKCOMBINE
, and FLATCOMBINE
, which are subtasks of CCDRED
. They are all small variants of COMBINE
(different from IMCOIMBINE
), and run through CCDPROC
task.
I usually avoid teaching these because they obscure what’s happening in IRAF and are thus not very good for educational purposes. But I am showing you how to use these tasks since they may be necessary for your future work. Manuals are kindly available from STScI: Just google with keywords such as “iraf zerocombine” and you will find the STScI website manuals like this.
ZEROCOMBINE
#
For bias (zero) combine, use the following settings:
Many students fail to do it because they put something in
ccdtype
. Let it be blank unless the header information is correctly set!Don’t bother too much with
rdnoise
andgain
, since they are used only forreject==ccdclip
orreject==crreject
. See the Zerocombine Manual.
DARKCOMBINE
#
For dark combinations, use the following settings:
Please leave
ccdtype
blank as before.Don’t bother too much with
rdnoise
andgain
, since they are used only forreject==ccdclip
orreject==crreject
. See the Darkcombine Manual.process
means it will do the bias subtraction (zerocor
orCCDPROC
task).scale
means it will scale the dark images to the exposure time and combine all darks appropriately.The zero-corrected dark may have negative values, and the mean is around 0.
If you do
DARKCOMBINE
, the input dark files may be changed (automatically zero subtracted). If you type--> ccdlist
, you can see [Z] to each dark file, which means the zero correction has already been done. This can be avoided by usingCCDPROC
:--> epar ccdprocset:
input=@dark.list, (output)=dark.fits, (zerocor)=yes, (zero)=bias.fits.
See below:Or
COMBINE
orIMCOMBINE
to get the median-combined dark, and then subtractbias.fits
by IMARITH
:–> combine dark*.fits tmp.fits combine=median –> imarith tmp.fits – Zero.fits Dark.fits
Of course,
(IM)COMBINE
andIMARITH
all can be controlled by usingepar
(epar combine
, etc) as before. If you have better ways to do this, please let the TA know T__T
FLATCOMBINE
#
For flat combine, use the following settings:
Please leave
ccdtype
blank as before.Don’t bother too much with
rdnoise
andgain
, since they are used only forreject==ccdclip
orreject==crreject
. See the Flatcombine Manual.Now we have to think about
subset
option. Since flats should be differentiated by filters, slits (spectroscopy), etc., IRAF scans the headers and automatically subdivides the flats into several groups. Sometimes it does not work properly.scale
means it will normalize the flat image by its mode, average, etc.
If you use
CCDPROC
,input=@flat.list, (output)=flat.fits, (zerocor)=yes, (darkcor)=yes (zero)=bias.fits (dark)=dark.fits
is required.
2.6. 6. File Information#
You may want to see the brief information, such as statistics or the so-called “header information”, of images. You can do this in many ways.
2.6.1. Statistics from IRAF#
There is a task named IMSTATISTICS
which gives some statistics for each image:
--> imstatistics *.fits
# IMAGE NPIX MEAN STDDEV MIN MAX
KCD095628.fits 4194304 5590. 2655. 4098. 65354.
KCD095629.fits 4194304 5599. 2662. 4111. 65349.
KCD095630.fits 4194304 5582. 2643. 4116. 65361.
KCD095631.fits 4194304 5574. 2666. 4116. 65358.
b_KCD095628.fits 4194304 1395. 2307. -59. 61141.
b_KCD095629.fits 4194304 1403. 2315. -46. 61143.
b_KCD095630.fits 4194304 1386. 2293. -44.5 61145.
b_KCD095631.fits 4194304 1378. 2319. -43. 61141.
bf_KCD095628.fits 4194304 0.07362 0.1266 -3.118 3.335
bf_KCD095629.fits 4194304 0.07374 0.1271 -2.826 3.402
bf_KCD095630.fits 4194304 0.07279 0.1263 -3.6 3.402
bf_KCD095631.fits 4194304 0.0726 0.1273 -3.118 3.4
bias.fits 4194304 4196. 1345. 4141. 65275.
flat.fits 4194304 18973. 1960. 8.5 40058.
Question: Why do you think the results
bf_*.fits
have such low min/max values? Do you have a better idea of how to cope with this issue? This becomes bothersome for IRAF sometimes; seeDAOEDIT
section below.Question: From File Explorer, you can see the sizes of each image. The original
KCD*.fits
images are about 8.4 MB while the newly generated images are about twice as large. Why do you think this is so?TIP: If you do the flat fielding, etc., by using some tasks several times, you may see the file size increase. If this happens, you are now not even able to do basic arithmetics for the images (the error message will contain something like
FXF~~~
). This is because IRAF automatically makes a new “extension” on top of the original file, not overwriting it. You must delete the original file and do the reduction again.
2.6.2. Header from ds9#
On ds9
, you can click on file -> header
to see all the header contents.
2.6.3. Header from IRAF#
You can use IMHEADER
:
--> imheader *.fits
KCD095628.fits[2048,2048][ushort]: P/2006HR30
KCD095629.fits[2048,2048][ushort]: P/2006HR30
KCD095630.fits[2048,2048][ushort]: P/2006HR30
KCD095631.fits[2048,2048][ushort]: P/2006HR30
b_KCD095628.fits[2048,2048][real]: P/2006HR30
b_KCD095629.fits[2048,2048][real]: P/2006HR30
b_KCD095630.fits[2048,2048][real]: P/2006HR30
b_KCD095631.fits[2048,2048][real]: P/2006HR30
bf_KCD095628.fits[2048,2048][real]: P/2006HR30
bf_KCD095629.fits[2048,2048][real]: P/2006HR30
bf_KCD095630.fits[2048,2048][real]: P/2006HR30
bf_KCD095631.fits[2048,2048][real]: P/2006HR30
bias.fits[2048,2048][real]: bias
flat.fits[2048,2048][real]: flat
The result is slightly different from IRAF because of Python’s nature. If you want to see the full header, you can do the following:
--> imheader KCD095628.fits lo+
which means “long+”. If you want to see only the exposure time, for example, which is EXPTIME
in the header keyword, you can use “| grep
”:
–> imheader *.fits lo+ | grep ‘EXPTIME’
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 120.0 / [sec] Total integration time
EXPTIME = 0.0 / [sec] Total integration time
EXPTIME = 10.0 / [sec] Total integration time
More flexibility comes with HSELECT
which means header select:
--> hselect *.fits "$I, EXPTIME, UT" yes
KCD095628.fits 120.0 11:04:53
KCD095629.fits 120.0 11:09:00
KCD095630.fits 120.0 11:13:15
KCD095631.fits 120.0 11:17:22
b_KCD095628.fits 120.0 11:04:53
b_KCD095629.fits 120.0 11:09:00
b_KCD095630.fits 120.0 11:13:15
b_KCD095631.fits 120.0 11:17:22
bf_KCD095628.fits 120.0 11:04:53
bf_KCD095629.fits 120.0 11:09:00
bf_KCD095630.fits 120.0 11:13:15
bf_KCD095631.fits 120.0 11:17:22
bias.fits 0.0 09:30:25
flat.fits 10.0 19:27:15
You may understand what this task gets and gives. I
is for “inputs”, and it prints the filenames.
2.6.4. CCDLIST
#
There is another useful tool similar to IMHEADER
if you have used ZEROCOMBINE
, DARKCOMBINE
, and FLATCOMBINE
. It will show you which preprocessing has been done for each image. But since we used IMARITH
only, this result will be almost identical to that of IMHEADER
and no more information will be there. To use CCDLIST
, you have to activate some packages:
–> imred
imred/:
argus/ ctioslit/ hydra/ kpnocoude/ vtel/
bias/ dtoi/ iids/ kpnoslit/
ccdred/ echelle/ irred/ quadred/
crutil/ generic/ irs/ specred/
–> ccdred
ccdred/:
badpiximage ccdlist combine mkillumcor setinstrument
ccdgroups ccdmask darkcombine mkillumflat zerocombine
ccdhedit ccdproc flatcombine mkskycor
ccdinstrument ccdtest mkfringecor mkskyflat
–> ccdlist *.fits
KCD095628.fits[2048,2048][ushort][none][]:P/2006HR30
KCD095629.fits[2048,2048][ushort][none][]:P/2006HR30
KCD095630.fits[2048,2048][ushort][none][]:P/2006HR30
KCD095631.fits[2048,2048][ushort][none][]:P/2006HR30
b_KCD095628.fits[2048,2048][real][none][]:P/2006HR30
b_KCD095629.fits[2048,2048][real][none][]:P/2006HR30
b_KCD095630.fits[2048,2048][real][none][]:P/2006HR30
b_KCD095631.fits[2048,2048][real][none][]:P/2006HR30
bf_KCD095628.fits[2048,2048][real][none][]:P/2006HR30
bf_KCD095629.fits[2048,2048][real][none][]:P/2006HR30
bf_KCD095630.fits[2048,2048][real][none][]:P/2006HR30
bf_KCD095631.fits[2048,2048][real][none][]:P/2006HR30
bias.fits[2048,2048][real][none][]:bias
flat.fits[2048,2048][real][none][]:flat
2.7. 7. Primitive Photometry#
2.7.1. IMEXAMINE
#
For photometry, let’s use IMEXAM
first. IRAF becomes extremely powerful when you use the interactive mode with the aid of SAO ds9
.
--> !ds9 bf_KCD095628.fits &
--> imexam
If you type imexam
, your mouse cursor will blink. Put your cursor on a star you are interested in and hit the a
key. On the terminal, you will see the following information:
# COL LINE COORDINATES
# R MAG FLUX SKY PEAK E PA BETA ENCLOSED MOFFAT DIRECT
1034.81 1036.09 1034.81 1036.09
8.36 23.77 3.093 0.06386 0.3435 0.21 -80 4.83 2.34 2.94 2.79
The meaning of the result is explained here. The lines starting with #
are comment lines, and they correspond to the next lines composed of numbers, which indicate the corresponding parameter. In the above example, the sky is estimated to be 0.05386 and the star flux is 3.093, with a Moffat-fitted FWHM of 2.94.
Hitting r
will show you the radial profile of the star from the photo center. s
shows the surface plot. These may be useful if you do PSF photometry in the future using IRAF.
In interactive mode, you can exit by hitting q
key. Hit ?
key to see the manual or help on the terminal. You can scroll down with enter
key and escape by hitting the q
key. The manual here is a short version of the website version.
2.7.2. DAOEDIT
#
In DIGIPHOT.DAOPHOT
, there are many tasks. Quite a few people do use the stand-alone version (see here). Since we will not use IRAF intensively throughout this semester, I will just briefly mention the tasks. First, type “daophot
” and you will see:
--> daophot
daophot/:
addstar daotest nstar pexamine psf
allstar datapars@ pcalc pfmerge psort
centerpars@ findpars@ pconcat phot pstselect
daoedit fitskypars@ pconvert photpars@ seepsf
daofind group pdump prenumber setimpars
daopars@ grpselect peak pselect substar
As an example, I measured a few of the stars in the image by hitting a
key on the image:
--> !ds9 bf_KCD095628.fits &
--> daoedit bf_KCD095628.fits
Warning: Graphics overlay not available for display device.
# XCENTER YCENTER SKY SKYSIGMA FWHM COUNTS MAG
1034.76 1036.13 0.1 0.00 2.99 2.9 -1.138
1007.33 990.14 0.1 0.00 3.01 0.8 0.199
1016.51 1004.80 0.1 0.00 2.90 0.2 1.752
1048.00 942.55 0.1 0.00 3.04 2.0 -0.767
1074.63 939.88 0.1 0.00 3.02 1.2 -0.221
1136.91 947.06 0.1 0.00 2.97 4.6 -1.652
Hit r
to check whether the star is saturated. Hit ?
to see help, as usual.
In the previous Question, I asked you what would happen if the min/max values of the image were too small. Now you see the problem: Due to the default decimal point print of DAOEDIT
, SKY
and SKYSIGMA
(representative sky value and its error) are unrealistic. In reality, this should be something like 0.064 and 0.0011, i.e., roughly about 2% of the fluctuation level. So I will assume that we’ve obtained the following results:
# XCENTER YCENTER SKY SKYSIGMA FWHM COUNTS MAG
1034.76 1036.13 0.064 0.0011 2.99 2.9 -1.138
1007.33 990.14 0.064 0.0011 3.01 0.8 0.199
1016.51 1004.80 0.064 0.0011 2.90 0.2 1.752
1048.00 942.55 0.064 0.0011 3.04 2.0 -0.767
1074.63 939.88 0.064 0.0011 3.02 1.2 -0.221
1136.91 947.06 0.064 0.0011 2.97 4.6 -1.652
Question: When doing photometry (which we’ll do in the next section), people prefer
DAOEDIT
overIMEXAM
. Why do you think so? Can you see what the major difference is between the outputs of these two?
2.8. 8. More on Photometry#
What you have obtained from IMEXAM
and DAOEDIT
are very primitive results. In theory, the seeing effect should be nearly identical for all the point sources in the image, so we should have the same FWHM for each star. What we do is accept the average of the FWHMs of the stars I gave above. You may have now realized that we had to choose stars that are quite isolated! If there is another star near it, then its profile may have been polluted, and thus the FWHM is unreliable.
Let me show you how to get photometry results using FWHM=3
(pixels).
2.8.1. Using IRAF PHOT
#
--> epar phot
Then set the parameters as shown in the figure below.
(You can open up the parameter editor of DATAPARS, etc., by clicking on the PSET datapars
OR typing --> epar datapars
.)
You can hit Save & Quit
after setting all the values. They are explained below:
Parameters in PHOT
will be used for the aperture photometry:
image
: The input image nameinteractive
,radplot
: You will see what we can do if you chooseinteractive
mode. It is recommended to check “yes” to both of these.verify
: You can easily see what will be shown or hidden if you checkyes/no
. Ifyes
, it re-asks about the parameters.verbose
: The word verbose means “display the results so that I can see what you are doing!” in the computer world.
Parameters in DATAPARS
will be used for the flux calculation:
fwhmpsf
: The FWHM we obtained from above (3.0)sigma
: The uncertainty in sky estimation (0.0011). This will not be used depending onsalgorithm
ofFITSKYPARS
. See below.ccdread
,gain
,exptime
: Put the header keywords, not the actual values.In our case, the image does not contain the header for readout noise, so you may encounter a warning from PyRAF when you run the task, but it does not halt the process.
If you do not have the value in the header but still want to put, say,
ccdgain=5.0
, then you can use the parameterreadnoise
. Same goes true for gain, exposure time, etc.
Parameters in FITSKYPARS
will be used for the sky estimation:
salgorithm
: Quite many IRAF users are unaware of the sky estimation algorithm. You will learn it while using Python, but you can refer to the manual website linked above.annulus
,dannulus
: To estimate the sky value, IRAF can only use a method called “annulus”. It means you are going to calculate the sky value and its uncertainty using the ring shaped region around the target (annulus with an inner radius ofannulus
and an outer radius ofannulus + dannulus
).Rule of Thumb:
annulus = 4*FWHM
,dannulus = 2*FWHM
generally works well.More on sky estimation: IRAF uses the sigma clipping method to reject unrealistic sky values from the annulus defined by
annulus
anddannulus
, centered at the target. To tune this rejection, you can change other parameters such assloclip
,khist
,binsize
, etc. You will learn what these do in the near future and make your own code to do the same thing.skyvalue
: This will be used only whensalgorithm=const
.
Parameters in PHOTPARS
will be used for the photometric magnitude calculation with DATAPARS
:
apertures
: You have to sum the photon number within the aperture to get the stellar flux and thus magnitude. To do so, you have to set the aperture.Rule of Thumb:
apertures = 1.5 * FWHM
works well.zmag
: The zero-point magnitude. You can set it to any value in theory, but 25 is used in general practice.
After saving these, you MUST display the image yourself.
--> !ds9 bf_KCD095628.fits &
--> phot
The input image(s) ('bf_KCD095628.fits'):
Warning: Graphics overlay not available for display device.
Warning: Image bf_KCD095628.fits Keyword RONOISE not found.
Hit ?
to see the help. Usually you will use f
(or space bar
if you want to save the result immediately). Some other things, such as c
or t
may be used.
TIP: You MUST open the image on
ds9
which is the same as theinputs
in thePHOT
. It is a known bug and may not be fixed in the future.
If you hit f
on a certain star, some kind of radial plot will appear with three vertical lines:
The image shows the plot of pixel values (Intensity
) with respect to the radial distance from the calculated photo center of the star near the cursor. In the lower axis, radial distance is shown in pixel units, and the upper axis shows scale units.
Question: Why do you think I used aperture
~1.5 FWHM
?Question: Why do you think I used such an annulus? Why can’t we use the annulus from 4.50 to 12.00, for example, in our case?
TIP: You may want to see the x-axis in arcsecond unit. Then, if you knew 1 pixel corresponds to 0.5 arcsec, for example, you could have set
scale = 0.5
inDATAPARS
.
The vertical lines show the aperture and inner/outer edge of the annulus to measure the sky. From the messages shown at the top of the image, you can read the centroid result and the sky (depending on salgorithm
you selected) statistics:
xc, yc
: The result from marginalized centroidingxerr, yerr
: The error ofxc, yc
after marginalized centroiding. I just guess these are calculated from Gaussian fitting to the marginalized fluxes (projection onto the x and y axes)value
: The representatice sky value, such as mode, median, mean, etc., depending onsalgorithm
.sigma
: The sky’s uncertainty (centered second moment)skew
: The centered third moment (so-called skewness)nsky
: The number of sky pixels used to getvalue, sigma, skew
after sigma clippingnrej
: The number of sky pixels rejected after the sigma-clipping
2.8.2. Looking at the Results of PHOT
#
Now you must have a file named filename+.mag.1
, and mine is like this:
#N IMAGE XINIT YINIT ID COORDS LID \
#U imagename pixels pixels ## filename ## \
#F %-23s %-10.3f %-10.3f %-6d %-23s %-6d
#
#N XCENTER YCENTER XSHIFT YSHIFT XERR YERR CIER CERROR \
#U pixels pixels pixels pixels pixels pixels ## cerrors \
#F %-14.3f %-11.3f %-8.3f %-8.3f %-8.3f %-15.3f %-5d %-9s
#
#N MSKY STDEV SSKEW NSKY NSREJ SIER SERROR \
#U counts counts counts npix npix ## serrors \
#F %-18.7g %-15.7g %-15.7g %-7d %-9d %-5d %-9s
#
#N ITIME XAIRMASS IFILTER OTIME \
#U timeunit number name timeunit \
#F %-18.7g %-15.7g %-23s %-23s
#
#N RAPERT SUM AREA FLUX MAG MERR PIER PERROR \
#U scale counts pixels counts mag mag ## perrors \
#F %-12.2f %-14.7g %-11.7g %-14.7g %-7.3f %-6.3f %-5d %-9s
#
bf_KCD095628.fits 1067.000 998.000 1 nullfile 0 \
1070.161 998.227 3.161 0.227 0.114 0.116 107 BigShift \
0.06422786 0.001279112 7.303506E-4 2118 255 0 NoError \
120. INDEF INDEF INDEF \
4.50 58.87154 63.82666 54.77209 25.852 0.080 0 NoError
Because it is too long, I extracted only the last part. The commented lines explain the names of the parameters (N
), unit (U
), and format (F
). What you will use most frequently are XCENTER
, YCENTER
, RAPERT
(aperture radius), MAG
(instrumental magnitude), and MERR
(uncertainty in instrumental magnitude).
I have obtained \( m_{\rm inst} = 25.852 \pm 0.080\)!
TIP: Although I have said that the small min/max of the preprocessed image caused problems for
DAOEDIT
, you can see that they are saved internally and have proper values in the.mag.1
file.
2.8.3. Saving IRAF Files to Normal Text: TXDUMP
#
Now, it is difficult for a human to read. So IRAF supports a task called TXDUMP
, which dumps texts. For example, let me print XCENTER
and YCENTER
:
--> txdump bf_KCD095628.fits.mag.2 'xcenter, ycenter' yes
1070.161 998.227
You don’t have to use capital letters, as you can see. yes
is actually the answer to the verbose option. You can open up the parameter setting by epar txdump
. You can save the output as a file, as you did in LINUX:
--> txdump bf_KCD095628.fits.mag.2 'xcenter, ycenter, mag, merr' yes > output.txt
and output.txt
contains only the following numbers:
1070.161 998.227 25.852 0.080
TIP: You may worry that this kind of IRAF-specific format of output file cannot be read properly from Python. But
astropy
has a built-in function calledascii
, which properly reads these output files even faster, more readable, useful, and fancier thanTXDUMP
.
2.9. 9. For Your Future… DAOFIND
#
Although I will not teach more on IRAF than this, you may need to learn to use IRAF for photometry (even PSF photometry) in the future because many older generations prefer IRAF due to the legacy. I want to put one more item of information on PHOT
task for your future reference, and then the DAOFIND
.
In PHOT
, you may not want to do all the things interactively, since you have 100 images with 2 stars of interest in each image (so that you need 100x2 = 200 interactions for the same XY coordinates). Then what you can do is saving the XY coordinates of the two stars in a file called stars.coo.1
and fill coords
of “epar PHOT
” with this filename. The file may look like this:
1312.3 332.2
132.6 423.6
The first and second columns are the X, Y coordinates of the stars found from DAOEDIT
or PHOT
.
What this will do is similar to a mouse-keyboard macro program: load the image, put the cursor at the given position, and hit certain keys to measure and save magnitudes.
Now, what if you have 100 images with 100 stars in each image!? Doing DAOEDIT
to 100 stars itself is exhausting. Then you can do DAOFIND
or IRAF’s own starfinder algorithm, which is not widely used. FYI: The same algorithms are also implemented in Astropy/Photutils, too.
--> epar daofind
(Settings is a simplified version of PHOT, so you can easily understand it.)
--> daofind
Task daofind is running...
FWHM of features in scale units (3.) (CR or value):
New FWHM of features: 3. scale units 3. pixels
Standard deviation of background in counts (0.0011) (CR or value):
New standard deviation of background: 0.0011 counts
Detection threshold in sigma (4.) (CR or value):
New detection threshold: 4. sigma 0.0044 counts
Minimum good data value (INDEF) (CR or value):
New minimum good data value: INDEF counts
Maximum good data value (INDEF) (CR or value):
New maximum good data value: INDEF counts
Warning: Image bf_KCD095628.fits Keyword RONOISE not found.
HHere, the detection threshold is the most important one. If the peak intensity of the fitted star (NOT the peak pixel value, but the peak value of the fitted function!) is below the |threshold * skysigma|
, they are neglected and not considered stars.
After a while, a file with filename.coo.1
will be generated with the following contents:
#N XCENTER YCENTER MAG SHARPNESS SROUND GROUND ID \
#U pixels pixels # # # # # \
#F %-13.3f %-10.3f %-9.3f %-12.3f %-12.3f %-12.3f %-6d \
#
428.683 1.885 -0.704 0.507 -0.730 0.313 1
1336.253 2.638 -1.416 0.728 0.581 0.771 2
1399.732 1.493 -2.154 0.472 -0.726 0.345 3
......
About 20,000 stars are detected in my case.
Here, sharpness
, sround
, and ground
are the parameters used to determine whether the source is a star-like one or not. They are defined in the Stetson 1987 paper for the first time. sharpness
is a measure of “how sharp the target is”, and is kind of a “peak value” or “sky value”, roughly speaking. sround
and ground
are roundness parameters: sround
is to measure the roundness based on the symmetric property of the source, and ground
is based on the marginalized Gaussian fit to the object.
2.10. 10. Spectroscopic Preprocessing#
The preprocessing procedures are identical to photometry. One thing to be careful of is flats: flats should have an identical filter, slit, grating, etc., with the object of interest.
We may then need one more step, i.e., trimming (cropping the image). Go display the flat.fits
file by implot
--> implot flat.fits
Left image: typing
:a 30
and then:l 700
(average over 30 pixels around line (row) 700)Right image: typing
:a 30
and then:c 500
(average over 30 pixels around column 500).
We may say that x
(column): 500~2100 and y
(line): 550~850 are reliable, and other pixels are useless. For smaller x values, there seems to be a signal, but it is due to the higher order dispersion and/or the order sorting filter.
We can trim all the images (including the object) using the trimcor
option in CCDPROC
. The trim region can be specified at (trim) by [x1:x2,y1:y2]
, i.e., [500:2100,550:850]
, in our case. You can do it by
--> imcopy image[500:2100,550:850] image
to overwrite the original image with the trimmed image.
You can do preprocessing identical to the above sections. If you want to use
CCDPROC
:Now we turn on
zerocor
,darkcor
, andflatcor
withbias.fits
,dark.fits
, andflat.fits
as follows:--> epar ccdprocClick on Execute. You may see some results like this (exact values may differ):
--> imstat List of input images ('*.fits'): # IMAGE NPIX MEAN STDDEV MIN MAX dark.fits 481901 -0.7664 8.627 -33.5 2321. flat.fits 481901 1804. 823.4 73.57 24817. bias.fits 481901 113.3 5.251 90. 829. pvega.fits 481901 168.3 2541. -2224. 133972. vega_7s.fits 481901 220.9 1254. 83. 35427. --> ccdlist CCD images to listed ('*.fits'): dark.fits[1601,301][real][unknown][][TZ]:dark flat.fits[1601,301][real][unknown][][TZD]: bias.fits[1601,301][real][unknown][][T]: pvega.fits[1601,301][real][unknown][][TZDF]: vega_7s.fits[2184,1472][ushort][unknown][]:The
TZDF
means it is trimmed, zero-corrected, dark-corrected, and flat-corrected, respectively.
2.11. 11. APALL
and IDENTIFY
#
There are two cases for spectroscopic data:
The object is faint, so the sky lines are clearly visible (due to the long exposure).
The object is bright, so the sky lines are not visible (due to the short exposure).
For the first case, we can do the wavelength identification by sky line, and the second case requires some reference (calibration) lamp images.
For convenience,
--> !mkdir after_prep
--> cd after_prep/
--> !mv ../pvega.fits .
The dispersion axis should be saved in the header for the IRAF to work properly. We can manually correct this information. First, check whether the header contains the information:
--> imhead pvega.fits long+ | grep DISPAXIS
You can edit headers:
--> hedit pvega.fits DISPAXIS 1 add+
add vega.fits,DISPAXIS = 1
update vega.fits ? (yes):
vega.fits updated
--> imhead pvega.fits long+ | grep DISPAXIS
DISPAXIS= 1
Now, the image has the DISPAXIS
header keyword.
2.11.1. Aperture Extraction#
We use APALL
task:
--> noao
--> onedspec
--> twodspec
twodspec/:
apextract/ longslit/
--> apextract
apextract/:
apall apedit apflatten apnormalize apscatter
apdefault@ apfind apmask aprecenter apsum
apdemos/ apfit apnoise apresize aptrace
--> epar apall
Set parameters as in the figure. If you want the IRAF to automatically find the aperture (you can modify it later by yourself, but you can get an idea of how it finds the aperture), you can just set everything as default by turning the background subtraction on.
--> epar apextract
(Set dispaxis = 1)
--> apall
List of input images ('vega.fits'):
Edit apertures for vega? ('yes'):
If you hit ?
, the command will show you the help page. Hit q
, and you may be able to get out of the help page. The following images show four basic steps you have to do first:
Your screens can be very different from this!
Top left: You will see the plot as “original”. Hit
w
for zoom ande
for the lower left and upper right corners to zoom in. Hitw
a
to get to the default zoom.QUESTION
e
for lower left and then upper right. How would you then obtain the x-inverted zoomed image?
Top right: Hit
m
orn
after you put the cursor near the peak, and IRAF will automatically find the aperture for the profile. Hitd
to delete some misplaced ones. Hity
key so that you can define the aperture size as the width of the cursor. Hitl
andu
to set the aperture’s lower and upper limits manually.Bottom left: Hit
b
to get into the background mode. We will now fit the background. This is needed to subtract the background from the source. Hitw
a
to go to the original zoom. Then dow
e
e
to zoom. It is better to zoom in on the small y range to see the background fluctuation, as indicated in the figure (red marks).Bottom right: The dashed line is the fitted sky (background). Sometimes the sky fit is very unrealistic, and you need to change the sky sampling region. Delete the original one by hitting
z
near the ticks (the I-beam-shaped ones). Hits
at the lower/upper for both sides (usually more than a total of 4 hits). Hitf
to fit the sky. Type:func cheb
, and:ord 3
, and thenf
again to see the 3rd order Chebyshev fit.Hit
q
to get out of the background mode. Hit q again. On the terminal, you will see some questions. Type “yes” to the GRAPHICS, NOT THE TERMINAL!
You may have to answer a few times, depending on the APALL
epar setting. Type return again and again until you see the following left figure:
This is the aperture trace. The fitting does not look good, but if you look closely, the error is only a few pixels off. But you may still want a better fit.
Type :order n
to fit the nth order fitting line to the +
signs. :order 2
to 5
will be enough for most of the cases. Hit f
to see the newly fitted dashed line. You can delete some points with d
and redo them with u
.
Moving along columns, the center of the aperture should move due to the imperfection of instruments. This “shift” is called the trace. The above image shows this “trace” value along the columns (x-axis).
On the right, the extracted Vega spectrum is shown.
What is remaining? We have to change the x value to wavelength.
2.11.2. Wavelength Identification (Bright Object)#
You may have the trimmed reference (calibration) lamp image.
--> epar identify
Set
coordlist
to the appropriate line profile text files. If you are not provided any files such asne.dat
, leave it as default.section
is usually set asmiddle column
ormiddle line
. It will show you the middle column or line cut (1-D plot).nsum
is to sum a certain number of pixels (lines or columns) to eliminate unwanted features (cosmic ray, etc.). Just use ~ 10.fwidth
is the initial guess of the full width of the lines. If it is very different from the real line width, the interactive line finder may not work properly.function
is to fit the pixel-wavelength relation. Usually, it is safe to use the Chebyshev polynomial.
The “desired” line spectrum of the lamp should be provided by the observatory. Since our observations do not, let me draw one figure from a public website:
(If the image is low resolution, you may find “low resolution lamp spectrum” more similar to your image, such as that in this link)
Now we have to let IRAF know the wavelengths of some peaks in the graphics. IRAF then automatically uses the “peaks” data file to find all other peaks. Let’s see how it works:
Left: Use
w
e
e
andw
a
to zoom the spectrum. Put the cursor near one of the peaks (e.g., the largest peak at 5852.49 Angstrom). Then typem
(for mark). At the bottom of the graphics, type the rough wavelength value (e.g., “5852”). Hit return. At the bottom, there will be the found wavelength value. It is found in the Ne.dat file, using your input value.Do the same thing a few more times. We will let IRAF’s AID (Auto Identification) algorithm find all other peaks based on the pre-defined database.
In some cases, when you are not provided with line profiles (
.dat
file) and it contains lines from uncatalogued data, you cannot use AID.Hit
l
if you have provided line profiles. IRAF will automatically read an appropriate .dat file (containing all possible line centers) and find all peak values.
Right: After hitting
l
, you may see a lot of identified lines, as in the figure. The lines, however, are not always the real ones, since very small emission peaks may be in the line data file, too. So this process is not always accurate, so you have to edit them.Delete some marks by
d
where no peak is visible.If you feel satisfied, hit
f
to see the residual plot. If there is any point with a significant residual, hitd
near it to delete it (an X mark will appear). Hitf
again, and you will fit again. Hitq
twice to quit identifying.
Some shortcuts are summarized below (from Documentation):
d (D)elete the feature nearest the cursor.
n Move the cursor or zoom window to the (n)ext feature (same as +).
p (P)an to the original window after (z)ooming on a feature.
z (Z)oom on the feature nearest the cursor. The width of the zoom window is determined by the parameter zwidth .
The ne_30.fits now include information about our calibration. We now have to implement the object image file so that the image fits file has the same reference spectrum data as this neon fits file! To do so:
--> hedit pvega.ms REFSPEC1 "ne_30.fits" add+
add pvega.ms,REFSPEC1 = ne_30.fits
update pvega.ms ? (yes):
pvega.ms updated
For check:
--> imhead pvega.ms long+ | grep REFSPEC1
REFSPEC1= 'ne_30.fits'
So the IRAF now be able to change the x-pixels into wavelengths based on this Ne lamp fit data. This can be done by dispersion correction:
--> dispcor pvega.ms vega_final
Then plot:
--> splot vega_final
Left: Hit the
space
. You will seex
,y
,z
values.y
is the cursor’s y-value, andz
is the actual y value (flux) of the plot.Right: See below.
To study a line (absorption, in our case), zoom into a certain region using w
e
e
. We will fit the continuum and the absorption line. At the left- and right-most positions you want to fit the continuum, hit d
at each edge.
At the bottom of the graphics, you will be asked about “Lines”. This means with which profile you want to fit the absorption. I will select Gaussian. Put the cursor near the absorption line and hit g
. There will appear a small vertical tick, which indicates the center you selected.
After you have selected all the lines you want to calculate within the zoomed window, hit q
. Another question is about fit positions: just type a
. The next is the Fit Gaussian width question; just type a
. Fit background? Oh, yes: type y
. Then you will see a green continuum fitting line and a red fitting line (absorption fitting line).
You can see the center, flux, equivalent width, and Gaussian FWHM value at the bottom of the graphics. +/- will show you the results at the next/previous peaks. r will show you the RMS of the background after fitting.
Hit q
to exit. The same question will be asked if you have other things to fit. Just hit q
to quit completely. You will see the “Deblending Done” message. The process we’ve done is called deblending, since we “deblended” lines from the continuum.
2.12. 12. Flux Calibration#
We need a standard star spectrum to do the flux calibration. The standard star data is saved somewhere like ${ANACONDA3}/envs/iraf/iraf/noao/lib/onedstds/
. I haven’t yet made a lecture note for this, but you can easily find a simple example in the FOCAS Cookbook. See Section 5.7 of the cookbook.
2.13. A. IRAF Trouble Shooting#
2.13.1. Errors: Messages That You Cannot Change uparm
something#
Check that you ran pyraf
at the directory where you have login.cl
”!
Many of the students ran pyraf
where you didn’t do mkiraf
. In such a case, you can “run” pyraf
, but nothing will work correctly. Even ls
will not work. If you had to put !
in front of ls
, that means you made some mistake.
2.13.2. Errors: “FXF” or “Not an Image or a Number”#
The following error messages may pop up if the image reduction has some problems:
FXF: must specify which FITS extenstion
(filename) is not an image or a number
For a check, do imstat *.fits
and see whether the results are printed normally.
Possible reasons for wrong image processing:
I found many students wrongly did
ls *.fits > ~~~~.list
. Please open the~~~~.list
file and check whether it contains only the desired fits files. These should not containbias.fits
orflat.fits
, etc.In other cases, students didn’t remove the pre-existing bias or flat files. You must remove the pre-existing files via
!rm bias.fits
, etc, before median combining. If not, IRAF automatically adds one more extension on top of the original file, which then doubles, triples, … the size of the image.