aboutsummaryrefslogtreecommitdiff
path: root/noao/onedspec/hireswcal.cl
blob: f4d4198679504968b2f8dcc490b4bd38c084bb55 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
# HIRESWCAL -- Apply HIRES wavelengths to flux data to produce an IRAF file.
#
# This script requires the onedspec, proto, and artdata packages be loaded.

procedure hireswcal (input, waves, output)

file	input		{prompt="Input hires data file"}
file	waves		{prompt="Input matching hires wavelength file"}
file	output		{prompt="Output IRAF file"}

struct	*fd		# Required to loop through a list.

begin
	file	in, win, out
	file	im, wim, out1, tmp
	int	ap

	# Set query parameters.
	in = input
	win = waves
	out = output

	# Check if output is already present.
	if (imaccess(out))
	    error (1, "Output already exists ("//out//")")

	# Define a temporary file rootname.
	tmp = mktemp ("tmp")

	# Expand input into a list of spectra.
	slist (in, apertures="", long-, > tmp)

	# For each spectrum in the list create an IRAF 1D spectrum.
	fd = tmp
	while (fscan (fd, im, ap) != EOF) {

	    # Form names for each spectrum.
	    printf ("%s[*,%d]\n", in, ap) | scan (im)
	    printf ("%s[*,%d]\n", win, ap) | scan (wim)
	    printf ("%s_%d\n", tmp, ap) | scan (out1)

	    # Dump the wavelengths and flux and put together into
	    # a file for rspectext.

	    listpix (wim, v-, > tmp//"waves")
	    listpix (im, v-, > tmp//"flux")
	    joinlines (tmp//"waves", tmp//"flux") |
	        fields ("STDIN", "2,4", > tmp//"join")

	    # Create the IRAF spectrum.
	    rspectext (tmp//"join", out1, title="", flux-, dtype="interp")

	    # Delete working files.
	    delete (tmp//"[wfj]*", v-)
	    print (out1, >> tmp//".list")
	}
	fd = ""; delete (tmp, v-)

	# Put the 1D spectrum into a multispec file.
	scopy ("@"//tmp//".list", out, format="multispec", renumber+)

	# Add the input header for what its worth.
	mkhead (out, in, append+, verbose-)

	# Finish up.
	imdelete ("@"//tmp//".list", v-)
	delete (tmp//"*", v-)
end