aboutsummaryrefslogtreecommitdiff
path: root/noao/onedspec/identify/autoid/aidlog.x
diff options
context:
space:
mode:
authorJoe Hunkeler <jhunkeler@gmail.com>2015-08-11 16:51:37 -0400
committerJoe Hunkeler <jhunkeler@gmail.com>2015-08-11 16:51:37 -0400
commit40e5a5811c6ffce9b0974e93cdd927cbcf60c157 (patch)
tree4464880c571602d54f6ae114729bf62a89518057 /noao/onedspec/identify/autoid/aidlog.x
downloadiraf-osx-40e5a5811c6ffce9b0974e93cdd927cbcf60c157.tar.gz
Repatch (from linux) of OSX IRAF
Diffstat (limited to 'noao/onedspec/identify/autoid/aidlog.x')
-rw-r--r--noao/onedspec/identify/autoid/aidlog.x57
1 files changed, 57 insertions, 0 deletions
diff --git a/noao/onedspec/identify/autoid/aidlog.x b/noao/onedspec/identify/autoid/aidlog.x
new file mode 100644
index 00000000..b0247d00
--- /dev/null
+++ b/noao/onedspec/identify/autoid/aidlog.x
@@ -0,0 +1,57 @@
+include "../identify.h"
+
+
+# AID_LOG -- Log final solution.
+
+procedure aid_log (id, fd, hdr)
+
+pointer id #I ID object
+int fd #I Log file descriptor
+int hdr #U Print header?
+
+double wc, dw, id_fitpt(), id_rms()
+pointer str
+bool fp_equald()
+
+begin
+ if (fd == NULL)
+ return
+
+ if (fd == STDOUT && ID_GP(id) != NULL)
+ call gdeactivate (ID_GP(id), 0)
+
+ if (hdr == YES) {
+ call malloc (str, SZ_LINE, TY_CHAR)
+ call sysid (Memc[str], SZ_LINE)
+ call fprintf (fd, "\nAUTOIDENTIFY: %s\n")
+ call pargstr (Memc[str])
+ call mfree (str, TY_CHAR)
+
+ call fprintf (fd, " %-20s %10s %10s %10s %10s\n")
+ call pargstr ("Spectrum")
+ call pargstr ("# Found")
+ call pargstr ("Midpoint")
+ call pargstr ("Dispersion")
+ call pargstr ("RMS")
+
+ hdr = NO
+ }
+
+ call fprintf (fd, " %s%s%24t ")
+ call pargstr (ID_IMAGE(id))
+ call pargstr (ID_SECTION(id))
+ if (ID_CV(id) == NULL)
+ call fprintf (fd, " No solution found\n")
+ else {
+ wc = id_fitpt (id, (ID_NPTS(id) + 1D0) / 2D0)
+ dw = wc - id_fitpt (id, (ID_NPTS(id) - 1D0) / 2D0)
+ if (!fp_equald (dw, 0D0)) {
+ call fprintf (fd, "%10d %10.*g %10.3g %10.3g\n")
+ call pargi (ID_NFEATURES(id))
+ call pargi (int (log10 (abs (wc / dw)) + 3))
+ call pargd (wc)
+ call pargd (dw)
+ call pargd (id_rms(id))
+ }
+ }
+end