aboutsummaryrefslogtreecommitdiff
path: root/sys/vops/lz/amed3l.x
diff options
context:
space:
mode:
Diffstat (limited to 'sys/vops/lz/amed3l.x')
-rw-r--r--sys/vops/lz/amed3l.x30
1 files changed, 30 insertions, 0 deletions
diff --git a/sys/vops/lz/amed3l.x b/sys/vops/lz/amed3l.x
new file mode 100644
index 00000000..480d3b05
--- /dev/null
+++ b/sys/vops/lz/amed3l.x
@@ -0,0 +1,30 @@
+# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.
+
+# AMED3 -- Median of three vectors. Each output point M[i] is the median value
+# of the three input points A[i],B[i],C[i].
+
+procedure amed3l (a, b, c, m, npix)
+
+long a[ARB], b[ARB], c[ARB] # input vectors
+long m[ARB] # output vector (median)
+int npix
+int i
+
+begin
+ do i = 1, npix
+ if (a[i] < b[i]) {
+ if (b[i] < c[i]) # abc
+ m[i] = b[i]
+ else if (a[i] < c[i]) # acb
+ m[i] = c[i]
+ else # cab
+ m[i] = a[i]
+ } else {
+ if (b[i] > c[i]) # cba
+ m[i] = b[i]
+ else if (a[i] > c[i]) # bca
+ m[i] = c[i]
+ else # bac
+ m[i] = a[i]
+ }
+end