aboutsummaryrefslogtreecommitdiff
path: root/sys/vops/lz/amed4i.x
diff options
context:
space:
mode:
authorJoseph Hunkeler <jhunkeler@gmail.com>2015-07-08 20:46:52 -0400
committerJoseph Hunkeler <jhunkeler@gmail.com>2015-07-08 20:46:52 -0400
commitfa080de7afc95aa1c19a6e6fc0e0708ced2eadc4 (patch)
treebdda434976bc09c864f2e4fa6f16ba1952b1e555 /sys/vops/lz/amed4i.x
downloadiraf-linux-fa080de7afc95aa1c19a6e6fc0e0708ced2eadc4.tar.gz
Initial commit
Diffstat (limited to 'sys/vops/lz/amed4i.x')
-rw-r--r--sys/vops/lz/amed4i.x41
1 files changed, 41 insertions, 0 deletions
diff --git a/sys/vops/lz/amed4i.x b/sys/vops/lz/amed4i.x
new file mode 100644
index 00000000..f39d01b6
--- /dev/null
+++ b/sys/vops/lz/amed4i.x
@@ -0,0 +1,41 @@
+# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.
+
+# AMED4 -- Median of four vectors. Each output point M[i] is the median of the
+# four input points A[i],B[i],C[i],D[i]. The vector min and max are also
+# computed and returned in the A and D vectors. The input vectors are modifed
+# in place.
+
+procedure amed4i (a, b, c, d, m, npix)
+
+int a[ARB], b[ARB] # input vectors
+int c[ARB], d[ARB] # input vectors
+int m[ARB] # output vector (median)
+int npix
+
+int i
+int temp
+define swap {temp=$1;$1=$2;$2=temp}
+
+begin
+ do i = 1, npix {
+ # Move the minimum value to A[i].
+ if (b[i] < a[i])
+ swap (b[i], a[i])
+ if (c[i] < a[i])
+ swap (c[i], a[i])
+ if (d[i] < a[i])
+ swap (d[i], a[i])
+
+ # Move the maximum value to D[i].
+ if (b[i] > d[i])
+ swap (b[i], d[i])
+ if (c[i] > d[i])
+ swap (c[i], d[i])
+
+ # Return the median value.
+ if (b[i] < c[i])
+ m[i] = b[i]
+ else
+ m[i] = c[i]
+ }
+end