source: git/doc/TODO.htm @ b1b86eb

stereo-2025
Last change on this file since b1b86eb was c7c0f93, checked in by Olly Betts <olly@…>, 7 months ago

Support ISO dates and date types

Fixes #96, reported by Milosch

  • Property mode set to 100644
File size: 8.8 KB
Line 
1<HTML><HEAD>
2<TITLE>Survex To-Do List</TITLE>
3<STYLE type="text/css"><!--
4BODY, TD, CENTER, UL, OL {font-family: sans-serif;}
5-->
6</STYLE>
7</HEAD><BODY BGCOLOR=white TEXT=black>
8<H1>Survex To-Do List</H1>
9
10<H2>3d format</H2>
11
12<ul>
13
14<li>sort out XSECT - I'm sure I meant there to be 1 and 2 byte forms, not 2
15and 4 - 4 byte is only useful if a passage dimension is &gt; 327.67m!
16
17<li>store equated stations in some way
18
19<li>store legs by end stations rather than repeating coordinates over and
20over?
21
22</ul>
23
24<H2>Aven</H2>
25
26<ul>
27
28<li>loading a .3d file with no survey data (or which has a valid header but is broken later) with a survey already loaded doesn't work well.
29
30<li>After keyboard controlled movement, the measuring line/circle doesn't
31reappear until the mouse is moved (e.g. plan/elevation transition with P/L).
32
33<li>Fix depth clipping on grid
34
35<li>Does anyone use Controls-&gt;"Reverse Sense"?  It made some sense with
36caverot but now seeing the mouse pointer makes people expect the default
37motions (for right button drag particularly).
38
39<li>Clean up export.cc and allow line width, etc to be specified
40
41<li>Better handling of missing LRUD values
42
43<li>Smooth wrinkles in presentation code (stop pres on Open or
44New, changing focus on listctrl as presentation plays doesn't really work
45properly)
46
47<li>Draw the measuring line directly onto the front buffer, so we can remove it
48with a copy from the back buffer and redraw it in the new position without a
49re-render.
50
51<li>Process all pending input before rerendering to improve responsiveness.
52
53<li>Check timing code - we need to glFinish to ensure it's all drawn, and that
54may be needed to get meaningful timing info.
55
56<li>Allow control of colours in "colour by survey"; allow controlling what level
57colours are applied at e.g. colour by cave (and more generally by sub-prefix)
58
59<li>Implement "Skip blank pages" in aven printing
60
61<li>different keyboard layouts mean that some key choices don't make much sense...
62
63<li>File-&gt;Extended Elevation - provide a way to specify a spec file?  Or
64better a UI to control the extending.
65
66<li>Optional lazy label redraw during drags?  Or turn on at some redraw time
67threshold...
68
69<li>Some way to view older/newer version of survey
70
71<li>Label lengths aren't considered when working out image size when
72printing so a long label can spill off the edge of the printout
73
74<li>print to an image file?
75
76<li>grid on printouts
77<ul>
78<li>grid crosses option (only draw cross at intersections, not a full grid).
79<li>[(x,y) of a point to go through (easting, northing)
80<li>x spacing, y spacing (default to x spacing)
81<li>orientation (bearing of y-axis?) (defaults to 0)]
82</ul>
83
84<li>Profile aven further (for both speed and memory usage)
85
86<li>by default put crosses on those points with no legs attached (unused
87fixed points)?
88
89<li>label junctions/dead ends?
90
91<li>section colouring/selective labelling
92
93<li>clipping - want to select a clip sphere (or maybe cube) centred on
94centre on rotation I think.
95
96<li>Some way to display all the names of an equated station (e.g. in pop-up
97window or the info panel).
98
99<li>check on monochrome, 16, and 256 colour displays - especially that depth
100colouring looks OK
101
102<li>Feed back redraw time to key based movement as in caverot?  Or perhaps best
103not to?  It depends on whether we expect people to hold down keys or not...
104Perhaps something smart where the first press is a fixed size, then after that
105it depends on the redraw?
106
107<li>improve .plt export to include less crude survey structure.
108
109<li>If multiple methods for drawing crosses and/or blobs pass the
110visual fidelity check, check which is fastest.
111
112<li>Lots of aven things need documenting.
113
114</ul>
115
116<H2>Documentation</H2>
117
118<ul>
119
120<li>Platform specific versions of docs?
121
122<li>Put more terms in terminology in docs ? trip, instrument, ...
123
124<li>Finish off manual loose ends.
125
126<li>Look at rewording extend.sgml (AndyA comments)
127
128</ul>
129
130<H2>Internationalisation and Localisation</H2>
131
132<ul>
133
134<li>Update translations.
135
136<li>length units in .err file?
137
138</ul>
139
140<H2>Test Suite</H2>
141
142<ul>
143
144<li>test diving data with compass omitted (plumbed)
145
146<li>more tests for direction
147
148<li>improve 3d torture test and try to automate its use if possible.
149
150</ul>
151
152<H2>Miscellaneous</H2>
153
154<ul>
155
156<li>resolve FIXMEs in code
157
158<li>diffpos: compare connectivity (i.e legs as well as stations) - e.g.
159
160<pre>
161foo.1 moved by (0.02, 0.10, -0.06)
162leg between foo.1 and bar.2 removed
163...
164bar.2 moved by (-0.02, -0.05, 0.03)
165</pre>
166
167</ul>
168
169<H2>Cavern</H2>
170
171<ul>
172
173<li>This gives "*** Singular!!!" warning with DEBUG_INVALID on:
174<pre>
1751 2 50000 0 -
1761 2 5 0 -30
177</pre>
178
179<li>Default variance for topofil counter? (currently same as that of tape)
180
181<li>Rather than forming a linked list of components, solve each as it is
182identified?  Beware of issues like those that revcomplist test checks.
183
184<li>Don't split other traverses at articulating traverses when reporting error
185stats.
186
187<li>sort out title which goes in .3d file for this (if no *includes in ...
188it gets the title of the leafname of this .svx file, otherwise it's the
189leafnames of the *include-d files, comma-separated):
190
191<pre>
192*begin mycave
193*title "My Cave"
194...
195*end mycave
196</pre>
197
198<li>look at solution by QR factorisation in matrix.c more
199
200<li>consider disabling the more expensive asserts - turning them all off
201speeds up cavern by about 10%.
202
203<li>
204Warn bearings not 3 digits, gradient not &lt;sign&gt;&lt;digit&gt;&lt;digit&gt;
205
206<li>Sort out gross error detection code
207
208<li>For warnings such as "Negative adjusted tape reading" report the
209value of the adjusted tape reading (currently we just highlight the
210reading as it appears in the Survex file).
211
212<li>legs: implied flags: inloop/plumb
213
214<li>legs: "dubious" for "tapeless" legs - bearing along continuation...
215
216<li>station flags: "important" - e.g. top camp "fixed" point /
217junction,deadend (implied by order) /
218articulation pt (know for nodes I think a station is if at least one
219of its nodes is)
220
221<li>Maybe station lists should know how long they are?
222
223<li>Articulation point code: ideally the articulation point code should allow
224further network reductions to happen after splitting at articulation
225points?
226
227</ul>
228
229<H2>Survex file format</H2>
230
231<ul>
232
233<li>*data chamber ...
234
235<li>*data nsew ... for pitches (bearings rather than having to be NSEW)
236
237<li>Allow angles as deg/min/sec (for theodolite data) (060&deg;10'15" as 060 10
23815, or 060.1005 (crap notation))
239
240<li>should % after a clino reading work?
241
242<li>Fixing a point by triangulation?
243
244<li>multiple readings:
245<p>
246average bearings specially - they don't average like normal numbers
247<p>
248%age gradients should probably average the same as angle gradients
249<p>
250Document - works like so:
251<pre>
252*set open {
253*set close }
254*calibrate compass {000.5 001.0 001.25}
2551 2 10.23 {000 001} -02
2562 3 {10.16 10.17} 127 {+06 +05}
2573 4 11.98 007 {+03 +03}
258</pre>
259Implement as extension to number format so any suitable numeric value to be
260repeated?
261<li>Theodolite + level:
262<ul>
263  <li>delta(bearing (relative to 0 at start)
264  <li>delta(horizontal)
265  <li>delta(vertical) / maybe "clino" instead
266</ul>
267
268<li>Theodolite only:
269<ul>
270  <li>delta(bearing (relative to 0 at start)
271  <li>delta(horizontal)
272  <li>infinite sd for z
273</ul>
274
275<li>Infinite sds so we can fix in x and y only (or z only)?
276
277<li>legs: hydrology - fossil/active/not recorded/static water/underwater
278(sump) [diving underwater by default? except style can mean altimeter
279too...]
280
281<li>legs: floor type - mud/sand/breakdown/flowstone/etc and can then used
282LRUD to draw crude survey...
283
284<li>Allow valid range for an instrument to be specified.  Tie in with
285*instrument.  *units date - ranges for dates - e.g. "1990-" or
286"jun-aug"...
287
288<li>cope with any combination of readings which gives enough info ???
289
290<li>leg and station "comments":
291
292<pre>*data passage station left right up down comment
293
2941 1.0 - 50+ 0.5 "large cairn"
295
2962 ...
297
298*data normal station l r u d comment newline tape compass clino
299
3001 1.0 - 50+ 0.5 "large cairn"
301
302  10.78 123 -03
303
3042 ...
305</pre>
306
307comment can be omitted "-" or not present if at end of line...?
308commentall?
309
310<li>Allow covariances to be specified in cartesian style?
311
312<li>flag legs as "skeletal" or something? (i.e. not in the cave passage) -
313e.g. a radiolocation leg from one passage to another isn't surface,
314but it isn't in the cave itself either (it's through rock).  You could
315just call it surface but maybe later we want to use the surface
316flag to produce points for a surface triangulation...
317
318<li>?outlaw prefixes on stations in data legs (as Todd has lobbied for)
319and then the prefix of a leg == prefix of each end...?
320
321<li>Find a solution to Thilo's "." problem.
322
323<li>Units in *fix (currently metres)
324
325</ul>
326
327<H2>img library</H2>
328
329<ul>
330
331<li>make img more modular (convert to C++?)
332
333<li>add support for .KST?  Gary says documentation is out of date, and recent
334releases of winkarst have broken .KST export/import...
335
336<li>resolve documentation/examples mismatch for station based XYZ files and
337implement reading of legs from them.
338
339</ul>
340
341</BODY></HTML>
Note: See TracBrowser for help on using the repository browser.