aboutsummaryrefslogtreecommitdiff
path: root/noao/digiphot/apphot/center/apctr1d.x
blob: 10ee109e229354aa4e2fe043045eb8c656a720b4 (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
106
107
108
109
110
111
112
113
include <mach.h>
include "../lib/center.h"

# AP_CTR1D -- Procedure to compute the center from the 1D marginal
# distributions.

int procedure ap_ctr1d (ctrpix, nx, ny, norm, xc, yc, xerr, yerr)

real	ctrpix[nx, ny]		# object to be centered
int	nx, ny			# dimensions of subarray
real	norm			# the normalization factor
real	xc, yc			# computed centers
real	xerr, yerr		# estimate of centering error

pointer	sp, xm, ym

begin
	call smark (sp)
	call salloc (xm, nx, TY_REAL)
	call salloc (ym, ny, TY_REAL)

	# Compute the marginal distributions.
	call ap_mkmarg (ctrpix, Memr[xm], Memr[ym], nx, ny)
	call adivkr (Memr[xm], real (ny), Memr[xm], nx)
	call adivkr (Memr[ym], real (nx), Memr[ym], ny)

	# Get the centers and errors.
	call ap_cmarg (Memr[xm], nx, norm, xc, xerr)
	call ap_cmarg (Memr[ym], ny, norm, yc, yerr)

	call sfree (sp)
	return (AP_OK)
end


# AP_CMARG -- Compute the center and estimate its error given the
# marginal distribution and the number of points.

procedure ap_cmarg (a, npts, norm, xc, err)

real	a[npts]		# array
int	npts		# number of points
real	norm		# the normalization factor
real	xc		# center value
real	err		# error

int	i, npos
real	val, sumi, sumix, sumix2

begin
	# Initialize.
	npos = 0
	sumi = 0.0
	sumix = 0.0
	sumix2 = 0.0

	# Accumulate the sums.
	do i = 1, npts {
	    val = a[i]
	    if (val > 0.0)
	        npos = npos + 1
	    sumi = sumi + val
	    sumix = sumix + val * i
	    sumix2 = sumix2 + val * i ** 2
	}

	# Compute the position and the error.
	if (npos <= 0) {
	    xc =  (1.0 + npts) / 2.0
	    err = INDEFR
	} else {
	    xc = sumix / sumi
	    err = (sumix2 / sumi - xc * xc)
	    if (err <= 0.0) {
		err = 0.0
	    } else {
	        err = sqrt (err / (sumi * norm))
		if (err > real (npts))
		    err = INDEFR
	    }
	}
end


# AP_MKMARG -- Accumulate the marginal distributions.

procedure ap_mkmarg (ctrpix, xm, ym, nx, ny)

real	ctrpix[nx, ny]		# pixels
real	xm[nx]			# x marginal distribution
real	ym[ny]			# y marginal distribution
int	nx, ny			# dimensions of array

int	i, j
real	sum

begin
	# Compute the x marginal.
	do i = 1, nx {
	    sum = 0.0
	    do j = 1, ny
		sum = sum + ctrpix[i,j]
	    xm[i] = sum
	}

	# Compute the y marginal.
	do j = 1, ny {
	    sum = 0.0
	    do i = 1, nx
		sum = sum + ctrpix[i,j]
	    ym[j] = sum
	}
end