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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
include <error.h>
include <math/gsurfit.h>
include <pkg/dttext.h>
include <units.h>
# FC_DBWRITE -- Write an fitcoords database entry.
procedure fc_dbwrite (database, fitname, axis, un, sf)
char database[ARB] # Database
char fitname[ARB] # Database fit name
int axis # Axis for surface
pointer un # Units pointer
pointer sf # Surface pointer
int i, nsave
pointer dt, coeffs, sp, dbfile
int xgsgeti()
pointer dtmap1()
begin
if (sf == NULL)
return
call smark (sp)
call salloc (dbfile, SZ_FNAME, TY_CHAR)
call strcpy ("fc", Memc[dbfile], SZ_FNAME)
call imgcluster (fitname, Memc[dbfile+2], SZ_FNAME-2)
dt = dtmap1 (database, Memc[dbfile], APPEND)
call dtptime (dt)
call dtput (dt, "begin\t%s\n")
call pargstr (fitname)
call dtput (dt, "\ttask\tfitcoords\n")
call dtput (dt, "\taxis\t%d\n")
call pargi (axis)
if (un != NULL) {
call dtput (dt, "\tunits\t%s\n")
call pargstr (UN_UNITS(un))
}
nsave = xgsgeti (sf, GSNSAVE)
call salloc (coeffs, nsave, TY_DOUBLE)
call xgssave (sf, Memd[coeffs])
call dtput (dt, "\tsurface\t%d\n")
call pargi (nsave)
do i = 1, nsave {
call dtput (dt, "\t\t%g\n")
call pargd (Memd[coeffs+i-1])
}
call sfree (sp)
call dtunmap (dt)
end
# LM_DBREAD -- Read an lsmap database entry.
procedure lm_dbread (database, fitname, axis, un, sf)
char database[ARB] # Database
char fitname[ARB] # Fit name
int axis # Axis for surface
pointer un # Units pointer
pointer sf # Surface pointer
int rec, ncoeffs
pointer dt, coeffs, sp, dbfile, units
int dtlocate(), dtgeti()
pointer dtmap1(), un_open()
errchk dtlocate(), dtgeti(), dtgad(), un_open()
begin
un = NULL
sf = NULL
coeffs = NULL
call smark (sp)
call salloc (dbfile, SZ_FNAME, TY_CHAR)
call salloc (units, SZ_FNAME, TY_CHAR)
call strcpy ("fc", Memc[dbfile], SZ_FNAME)
call imgcluster (fitname, Memc[dbfile+2], SZ_FNAME-2)
dt = dtmap1 (database, Memc[dbfile], READ_ONLY)
rec = dtlocate (dt, fitname)
axis = dtgeti (dt, rec, "axis")
ifnoerr (call dtgstr (dt, rec, "units", Memc[units], SZ_FNAME))
un = un_open (Memc[units])
ncoeffs = dtgeti (dt, rec, "surface")
call salloc (coeffs, ncoeffs, TY_DOUBLE)
call dtgad (dt, rec, "surface", Memd[coeffs], ncoeffs, ncoeffs)
call xgsrestore (sf, Memd[coeffs])
call sfree (sp)
call dtunmap (dt)
end
|