aboutsummaryrefslogtreecommitdiff
path: root/sys/vops/lz/amaps.x
blob: fd3b8fe0d76c8a733c02c9b38059a10fd2605602 (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
# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.

# AMAP -- Vector linear transformation.  Map the range of pixel values
# a1,a2 from a into the range b1,b2 in b.  It is assumed that a1 < a2
# and b1 < b2.

procedure amaps (a, b, npix, a1, a2, b1, b2)

short	a[ARB], b[ARB]
short	a1, a2, b1, b2

long	minout, maxout, aoff, boff, pixval

real	scalar

int	npix, i

begin
	    scalar = (real (b2) - real (b1)) / (real (a2) - real (a1))

	minout = min (b1, b2)
	maxout = max (b1, b2)
	aoff = a1
	boff = b1

	do i = 1, npix {
	    pixval = (a[i] - aoff) * scalar
	    b[i] = max(minout, min(maxout, pixval + boff))
	}
end