aboutsummaryrefslogtreecommitdiff
path: root/noao/onedspec/identify/idlog.x
blob: d893f6714aa56f39ba86faf6d2c31dc6dcfbbc2c (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
include	<time.h>
include	"identify.h"

# ID_LOG -- Write log

procedure id_log (id, file)

pointer	id			# ID pointer
char	file[ARB]		# Log file

char	str[SZ_TIME]
int	i, fd, nrms
double	resid, rms

int	open()
long	clktime()
errchk	open()

begin
	if (ID_NFEATURES(id) == 0)
	    return

	fd = open (file, APPEND, TEXT_FILE)

	call cnvtime (clktime (0), str, SZ_TIME)
	call fprintf (fd, "\n%s\n")
	    call pargstr (str)
	call fprintf (fd, "Features identified in image %s.\n")
	    call pargstr (ID_IMAGE(id))

	call fprintf (fd, "   %8s %10s %10s %10s %6s %2s %s\n")
	    call pargstr ("Pixel")
	    call pargstr ("Fit")
	    call pargstr ("User")
	    call pargstr ("Residual")
	    call pargstr ("Fwidth")
	    call pargstr ("Wt")
	    call pargstr ("Label")

	rms = 0.
	nrms = 0
	do i = 1, ID_NFEATURES(id) {
	    call fprintf (fd, "%2d %8.2f %10.8g %10.8g %10.8g %6.2f %2d %s\n")
		call pargi (i)
		call pargd (PIX(id,i))
		call pargd (FIT(id,i))
		call pargd (USER(id,i))
		if (IS_INDEFD (USER(id,i)))
		    call pargd (USER(id,i))
		else {
		    resid = FIT(id,i) - USER(id,i)
		    call pargd (resid)
		    if (WTS(id,i) > 0.) {
		        rms = rms + resid ** 2
		        nrms = nrms + 1
		    }
		}
		call pargr (FWIDTH(id,i))
		call pargd (WTS(id,i))
		if (Memi[ID_LABEL(id)+i-1] != NULL)
		    call pargstr (Memc[Memi[ID_LABEL(id)+i-1]])
		else
		    call pargstr ("")
	}

	if (nrms > 1) {
	    call fprintf (fd, "RMS = %0.8g\n")
		call pargd (sqrt (rms / nrms))
	}

	call close (fd)
end