aboutsummaryrefslogtreecommitdiff
path: root/noao/onedspec/sensfunc/sfadd.x
blob: c77694d70c3540ecba9fd0767de0301d74802161 (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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
include	<gset.h>
include	"sensfunc.h"

# SF_ADD -- Add a point to the added point observation structure.
# The added star is the next to last of the standard stars.

procedure sf_add (gp, stds, nstds, cv, wx, wy, wc)

pointer	gp			# Graphics structure
pointer	stds[nstds]		# Standard star structures
int	nstds			# Number of standard stars
pointer	cv			# Sensitivity function curve
real	wx			# Cursor X value
real	wy			# Cursor Y value
int	wc			# Cursor WCS

int	nwaves
real	wave, sen, fit, cveval()
pointer	std, waves, sens, fits, wts, iwts, x, y
errchk	malloc, realloc

begin
	# Convert from particular WCS to wavelength and sensitivity.  In
	# order to add a point the graph must be either sensitivity or
	# residual verses wavelength.  If not then return without adding
	# a point.

	switch (GP_GRAPHS(gp,wc)) {
	case 's':
	    wave = wx
	    fit = cveval (cv, wx)
	    sen = wy
	case 'r':
	    wave = wx
	    fit = cveval (cv, wx)
	    sen = wy + fit
	default:
	    return
	}

	# Add the point to the next to last standard star.  Allocate
	# or reallocate memory as needed.  Turn the added star on by
	# setting INCLUDE flag.

	std = stds[nstds-1]
	nwaves = STD_NWAVES(std) + 1
	waves = STD_WAVES(std)
	if (waves == NULL) {
	    call malloc (waves, nwaves, TY_REAL)
	    call malloc (sens, nwaves, TY_REAL)
	    call malloc (fits, nwaves, TY_REAL)
	    call malloc (wts, nwaves, TY_REAL)
	    call malloc (iwts, nwaves, TY_REAL)
	    call malloc (x, nwaves, TY_REAL)
	    call malloc (y, nwaves, TY_REAL)
	} else {
	    sens = STD_SENS(std)
	    fits = STD_FIT(std)
	    wts = STD_WTS(std)
	    iwts = STD_IWTS(std)
	    x = STD_X(std)
	    y = STD_Y(std)
	    call realloc (waves, nwaves, TY_REAL)
	    call realloc (sens, nwaves, TY_REAL)
	    call realloc (fits, nwaves, TY_REAL)
	    call realloc (wts, nwaves, TY_REAL)
	    call realloc (iwts, nwaves, TY_REAL)
	    call realloc (x, nwaves, TY_REAL)
	    call realloc (y, nwaves, TY_REAL)
	}
	STD_FLAG(std) = SF_INCLUDE
	STD_NWAVES(std) = nwaves
	STD_WAVES(std) = waves
	STD_SENS(std) = sens
	STD_FIT(std) = fits
	STD_WTS(std) = wts
	STD_IWTS(std) = iwts
	STD_X(std) = x
	STD_Y(std) = y

	Memr[waves+nwaves-1] = wave
	Memr[sens+nwaves-1] = sen
	Memr[fits+nwaves-1] = fit
	Memr[wts+nwaves-1] = 1
	Memr[iwts+nwaves-1] = 1

	# Mark the added point on all graphs.
	for (wc = 1; GP_GRAPHS(gp,wc) != EOS; wc=wc+1) {
	    call gseti (GP_GIO(gp), G_WCS, wc)
	    call gseti (GP_GIO(gp), G_PLCOLOR, GP_CADD(gp))
	    switch (GP_GRAPHS(gp,wc)) {
	    case 's':
 		call gmark (GP_GIO(gp), wave, sen, GP_MADD(gp), GP_SZMARK(gp),
		    GP_SZMARK(gp))
	    case 'r':
		wy = sen - cveval (cv, wave)
 		call gmark (GP_GIO(gp), wave, wy, GP_MADD(gp), GP_SZMARK(gp),
		    GP_SZMARK(gp))
	    case 'a':
		wy = sen - cveval (cv, wave)
 		call gmark (GP_GIO(gp), STD_AIRMASS(std), wy, GP_MADD(gp),
		    GP_SZMARK(gp), GP_SZMARK(gp))
	    }
	}
end