aboutsummaryrefslogtreecommitdiff
path: root/sys/vops/asqr.gx
diff options
context:
space:
mode:
Diffstat (limited to 'sys/vops/asqr.gx')
-rw-r--r--sys/vops/asqr.gx31
1 files changed, 31 insertions, 0 deletions
diff --git a/sys/vops/asqr.gx b/sys/vops/asqr.gx
new file mode 100644
index 00000000..1a584853
--- /dev/null
+++ b/sys/vops/asqr.gx
@@ -0,0 +1,31 @@
+# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.
+
+# ASQR -- Compute the square root of a vector (generic). If the square root
+# is undefined (x < 0) a user supplied function is called to compute the value.
+
+procedure asqr$t (a, b, npix, errfcn)
+
+PIXEL a[ARB], b[ARB]
+int npix, i
+extern errfcn()
+PIXEL errfcn()
+errchk errfcn
+
+begin
+ do i = 1, npix {
+ $if (datatype != x)
+ if (a[i] < 0)
+ b[i] = errfcn (a[i])
+ else
+ $endif
+ {
+ $if (datatype == rdx)
+ b[i] = sqrt (a[i])
+ $else $if (datatype == l)
+ b[i] = sqrt (double (a[i]))
+ $else
+ b[i] = sqrt (real (a[i]))
+ $endif $endif
+ }
+ }
+end