aboutsummaryrefslogtreecommitdiff
path: root/noao/onedspec/splot/smooth.x
blob: 1418fc4f257c47607c8ee1ef8ac54ba5d8724530 (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
# SMOOTH -- Box smooth the array

procedure smooth (y, n)

real	y[ARB]
int	n

int	i, j, boxsize, halfbox, del
int	nsum
real	sum
pointer	sp, smy

int	clgeti()

begin
	call smark (sp)
	call salloc (smy, n, TY_REAL)

	# Get boxsize
	boxsize = clgeti ("boxsize")
	if (mod (boxsize, 2) == 0) {
	    boxsize = boxsize + 1
	    call eprintf ("WARNING: Using a box size of %d")
		call pargi (boxsize)
	}

	halfbox = boxsize/2

	# This is not efficiently coded, but easy to code
	# A running box mean would be faster
	do i = 1, n {
	    sum = 0.0
	    nsum = 0

	    if (i > halfbox && i < (n-halfbox))
		del = halfbox
	    else
	    if (i <= halfbox)
		del = i/2
	    else
		del = (n - i + 1)/2

	    do j = i-del, i+del {
		nsum = nsum + 1
		sum = sum + y[j]
	    }

	    Memr[smy+i-1] = sum / nsum
	}

	# Replace pixels back
	call amovr (Memr[smy], y, n)
	call sfree (sp)
end