2120acb2942b3a1ee40c8f521703df244abb1056
[fw/altos] / doc / micropeak.xsl
1 <?xml version="1.0" encoding="utf-8" ?>
2 <!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3   "/usr/share/xml/docbook/schema/dtd/4.5/docbookx.dtd">
4 <book>
5   <title>MicroPeak Owner's Manual</title>
6   <subtitle>A recording altimeter for hobby rocketry</subtitle>
7   <bookinfo>
8     <author>
9       <firstname>Keith</firstname>
10       <surname>Packard</surname>
11     </author>
12     <copyright>
13       <year>2012</year>
14       <holder>Bdale Garbee and Keith Packard</holder>
15     </copyright>
16     <legalnotice>
17       <para>
18         This document is released under the terms of the
19         <ulink url="http://creativecommons.org/licenses/by-sa/3.0/">
20           Creative Commons ShareAlike 3.0
21         </ulink>
22         license.
23       </para>
24     </legalnotice>
25     <revhistory>
26       <revision>
27         <revnumber>0.1</revnumber>
28         <date>29 October 2012</date>
29         <revremark>
30           Initial release with preliminary hardware.
31         </revremark>
32       </revision>
33       <revision>
34         <revnumber>1.0</revnumber>
35         <date>18 November 2012</date>
36         <revremark>
37           Updates for version 1.0 release.
38         </revremark>
39       </revision>
40       <revision>
41         <revnumber>1.1</revnumber>
42         <date>12 December 2012</date>
43         <revremark>
44           Add comments about EEPROM storage format and programming jig.
45         </revremark>
46       </revision>
47       <revision>
48         <revnumber>1.2</revnumber>
49         <date>20 January 2013</date>
50         <revremark>
51           Add documentation for the MicroPeak USB adapter board. Note
52           the switch to a Kalman filter for peak altitude
53           determination.
54         </revremark>
55       </revision>
56     </revhistory>
57   </bookinfo>
58   <acknowledgements>
59     <para>
60       Thanks to John Lyngdal for suggesting that we build something like this.
61     </para>
62     <para>
63       Have fun using these products, and we hope to meet all of you
64       out on the rocket flight line somewhere.
65       <literallayout>
66 Bdale Garbee, KB0G
67 NAR #87103, TRA #12201
68
69 Keith Packard, KD7SQG
70 NAR #88757, TRA #12200
71       </literallayout>
72     </para>
73   </acknowledgements>
74   <chapter>
75     <title>Quick Start Guide</title>
76     <para>
77       MicroPeak is designed to be easy to use. Requiring no external
78       components, flying takes just a few steps
79     </para>
80     <itemizedlist>
81       <listitem>
82         <para>
83           Install the battery. Fit a CR1025 battery into the plastic
84           carrier. The positive (+) terminal should be towards the more
85           open side of the carrier. Slip the carrier into the battery
86           holder with the positive (+) terminal facing away from the
87           circuit board.
88         </para>
89       </listitem>
90       <listitem>
91         <para>
92           Install MicroPeak in your rocket. This can be as simple as
93           preparing a soft cushion of wadding inside a vented model payload
94           bay. Wherever you mount it, make sure you protect the
95           barometric sensor from corrosive ejection gasses as those
96           will damage the sensor, and shield it from light as that can
97           cause incorrect sensor readings.
98         </para>
99       </listitem>
100       <listitem>
101         <para>
102           Turn MicroPeak on. Slide the switch so that the actuator
103           covers the '1' printed on the board. MicroPeak will report
104           the maximum height of the last flight in decimeters using a
105           sequence of flashes on the LED. A sequence of short flashes
106           indicates one digit. A single long flash indicates zero. The
107           height is reported in decimeters, so the last digit will be
108           tenths of a meter. For example, if MicroPeak reports 5 4 4
109           3, then the maximum height of the last flight was 544.3m, or
110           1786 feet.
111         </para>
112       </listitem>
113       <listitem>
114         <para>
115           Finish preparing the rocket for flight. After the
116           previous flight data have been reported, MicroPeak waits for
117           30 seconds before starting to check for launch. This gives
118           you time to finish assembling the rocket. As those
119           activities might cause pressure changes inside the airframe,
120           MicroPeak might accidentally detect boost. If you need to do
121           anything to the airframe after the 30 second window passes,
122           make sure to be careful not to disturb the altimeter. The
123           LED will remain dark during the 30 second delay, but after
124           that, it will start blinking once every 3 seconds.
125         </para>
126       </listitem>
127       <listitem>
128         <para>
129           Fly the rocket. Once the rocket passes about 10m in height
130           (32 feet), the micro-controller will record the ground
131           pressure and track the pressure seen during the flight. In
132           this mode, the LED flickers rapidly. When the rocket lands,
133           and the pressure stabilizes, the micro-controller will record
134           the minimum pressure pressure experienced during the flight,
135           compute the height represented by the difference in air
136           pressure and blink that value out on the LED. After that,
137           MicroPeak powers down to conserve battery power.
138         </para>
139       </listitem>
140       <listitem>
141         <para>
142           Recover the data. Turn MicroPeak off and then back on. MicroPeak
143           will blink out the maximum height for the last flight. Turn
144           MicroPeak back off to conserve battery power.
145         </para>
146       </listitem>
147     </itemizedlist>
148   </chapter>
149   <chapter>
150     <title>Handling Precautions</title>
151     <para>
152       All Altus Metrum products are sophisticated electronic devices.  
153       When handled gently and properly installed in an air-frame, they
154       will deliver impressive results.  However, as with all electronic 
155       devices, there are some precautions you must take.
156     </para>
157     <para>
158       The CR1025 Lithium batteries have an
159       extraordinary power density.  This is great because we can fly with
160       much less battery mass... but if they are punctured
161       or their contacts are allowed to short, they can and will release their
162       energy very rapidly!
163       Thus we recommend that you take some care when handling MicroPeak
164       to keep conductive material from coming in contact with the exposed metal elements.
165     </para>
166     <para>
167       The barometric sensor used in MicroPeak is sensitive to
168       sunlight. Please consider this when designing an
169       installation. Many model rockets with payload bays use clear
170       plastic for the payload bay. Replacing these with an opaque
171       cardboard tube, painting them, or wrapping them with a layer of
172       masking tape are all reasonable approaches to keep the sensor
173       out of direct sunlight.
174     </para>
175     <para>
176       The barometric sensor sampling ports must be able to "breathe",
177       both by not being covered by foam or tape or other materials that might
178       directly block the hole on the top of the sensor, and also by having a
179       suitable static vent to outside air.
180     </para>
181     <para>
182       As with all other rocketry electronics, Altus Metrum altimeters must 
183       be protected from exposure to corrosive motor exhaust and ejection 
184       charge gasses.
185     </para>
186   </chapter>
187   <chapter>
188     <title>The MicroPeak USB adapter</title>
189     <para>
190       MicroPeak stores barometric pressure information for the first
191       48 seconds of the flight in on-board non-volatile memory. The
192       contents of this memory can be downloaded to a computer using
193       the MicroPeak USB adapter.
194     </para>
195     <section>
196       <title>Installing the MicroPeak software</title>
197       <para>
198         The MicroPeak application runs on Linux, Mac OS X and
199         Windows. You can download the latest version from
200         <ulink url="http://altusmetrum.org/AltOS"/>.
201       </para>
202       <para>
203         On Mac OS X and Windows, the FTDI USB device driver needs to
204         be installed. A compatible version of this driver is included
205         with the MicroPeak application, but you may want to download a
206         newer version from <ulink
207         url="http://www.ftdichip.com/FTDrivers.htm"/>.
208       </para>
209     </section>
210     <section>
211       <title>Downloading Micro Peak data</title>
212       <itemizedlist>
213         <listitem>
214           <para>
215             Connect the MicroPeak USB adapter to a USB cable and plug it
216             in to your computer.
217           </para>
218         </listitem>
219         <listitem>
220           <para>
221             Start the MicroPeak application, locate the File menu and
222             select the Download entry.
223           </para>
224         </listitem>
225         <listitem>
226           <para>
227             The MicroPeak USB adapter has a small phototransistor on the 
228             end of the board furthest from the USB connector. Locate
229             this and place the LED on the MicroPeak right over
230             it. Turn on the MicroPeak board and adjust the position
231             until the blue LED on the MicroPeak USB adapter blinks in
232             time with the orange LED on the MicroPeak board.
233           </para>
234         </listitem>
235         <listitem>
236           <para>
237             After the maximum flight height is reported, MicroPeak will
238             pause for a few seconds, blink the LED four times rapidly
239             and then send the data in one long blur on the LED. The
240             MicroPeak application should receive the data. When it does,
241             it will present the data in a graph and offer to save the
242             data to a file. If not, you can power cycle the MicroPeak
243             board and try again.
244           </para>
245         </listitem>
246       </itemizedlist>
247     </section>
248     <section>
249       <title>Analyzing MicroPeak Data</title>
250       <para>
251         The MicroPeak application can present flight data in the form
252         of a graph, a collection of computed statistics or in tabular
253         form.
254       </para>
255       <para>
256         MicroPeak collects raw barometric pressure data which is
257         then used to compute the remaining data. Altitude is computed
258         through a standard atmospheric model. Absolute error in this
259         data will be affected by local atmospheric
260         conditions. Fortunately, these errors tend to mostly cancel
261         out, so the error in the height computation is much smaller
262         than the error in altitude would be.
263       </para>
264       <para>
265         Speed and acceleration are computed by first smoothing the
266         height data with a Gaussian window averaging filter. For speed
267         data, this average uses seven samples. For acceleration data,
268         eleven samples are used. These were chosen to provide
269         reasonably smooth speed and acceleration data, which would
270         otherwise be swamped with noise.
271       </para>
272       <para>
273         Under the Graph tab, the height, speed and acceleration values
274         are displayed together. You can zoom in on the graph by
275         clicking and dragging to sweep out an area of
276         interest. Right-click on the plot to bring up a menu that will
277         let you save, copy or print the graph.
278       </para>
279       <para>
280         The Statistics tab presents overall data from the flight. Note
281         that the Maximum height value is taken from the minumum
282         pressure captured in flight, and may be different from the
283         apparant apogee value as the on-board data are sampled twice
284         as fast as the recorded values, or because the true apogee
285         occurred after the on-board memory was full. Each value is
286         presented in several units as appropriate.
287       </para>
288       <para>
289         A table consisting of the both the raw barometric pressure
290         data and values computed from that for each recorded time.
291       </para>
292       <para>
293         The File menu has operations to open existing flight logs,
294         Download new data from MicroPeak, Save a copy of the flight
295         log to a new file, Export the tabular data (as seen in the Raw
296         Data tab) to a file, change the application Preferences, Close
297         the current window or close all windows and Exit the
298         application.
299       </para>
300     </section>
301     <section>
302       <title>Configuring the MicroPeak application</title>
303       <para>
304         The MicroPeak application has a few user settings which are
305         configured through the Preferences dialog, which can be
306         accessed from the File menu.
307       <itemizedlist>
308         <listitem>
309           <para>
310             The Log Directory is where flight data will be saved to
311             and loaded from by default. Of course, you can always
312             navigate to other directories in the file chooser windows,
313             this setting is just the starting point.
314           </para>
315         </listitem>
316         <listitem>
317           <para>
318             If you prefer to see your graph data in feet and
319             miles per hour instead of meters and meters per second,
320             you can select Imperial Units.
321           </para>
322         </listitem>
323         <listitem>
324           <para>
325             To see what data is actually arriving over the serial
326             port, start the MicroPeak application from a command
327             prompt and select the Serial Debug option. This can be
328             useful in debugging serial communication problems, but
329             most people need never choose this.
330           </para>
331         </listitem>
332         <listitem>
333           <para>
334             You can adjust the size of the text in the Statistics tab
335             by changing the Font size preference. There are three
336             settings, with luck one will both fit on your screen and
337             provide readable values.
338           </para>
339         </listitem>
340         <listitem>
341           <para>
342             The Look &amp; feel menu shows a list of available
343             application appearance choices. By default, the MicroPeak
344             application tries to blend in with other applications, but
345             you may choose some other appearance if you like.
346           </para>
347         </listitem>
348       </itemizedlist>
349       </para>
350       <para>
351         Note that MicroPeak shares a subset of the AltosUI
352         preferences, so if you use both of these applications, change
353         in one application will affect the other.
354       </para>
355     </section>
356   </chapter>
357   <chapter>
358     <title>Technical Information</title>
359     <section>
360       <title>Barometric Sensor</title>
361       <para>
362         MicroPeak uses the Measurement Specialties MS5607 sensor. This
363         has a range of 120kPa to 1kPa with an absolute accuracy of
364         150Pa and a resolution of 2.4Pa.
365       </para>
366       <para>
367         The pressure range corresponds roughly to an altitude range of
368         -1500m (-4900 feet) to 31000m (102000 feet), while the
369         resolution is approximately 20cm (8 inches) near sea level and
370         60cm (24in) at 10000m (33000 feet).
371       </para>
372       <para>
373         Ground pressure is computed from an average of 16 samples,
374         taken while the altimeter is at rest. Flight pressure is
375         computed from a Kalman filter designed to smooth out any minor
376         noise in the sensor values. 
377       </para>
378     </section>
379     <section>
380       <title>Micro-controller</title>
381       <para>
382         MicroPeak uses an Atmel ATtiny85 micro-controller. This tiny
383         CPU contains 8kB of flash for the application, 512B of RAM for
384         temporary data storage and 512B of EEPROM for non-volatile
385         storage of previous flight data.
386       </para>
387       <para>
388         The ATtiny85 has a low-power mode which turns off all of the
389         clocks and powers down most of the internal components. In
390         this mode, the chip consumes only .1μA of power. MicroPeak
391         uses this mode once the flight has ended to preserve battery
392         power.
393       </para>
394     </section>
395     <section>
396       <title>Lithium Battery</title>
397       <para>
398         The CR1025 battery used by MicroPeak holes 30mAh of power,
399         which is sufficient to run for over 40 hours. Because
400         MicroPeak powers down on landing, run time includes only time
401         sitting on the launch pad or during flight.
402       </para>
403       <para>
404         The large positive terminal (+) is usually marked, while the
405         smaller negative terminal is not. Make sure you install the
406         battery with the positive terminal facing away from the
407         circuit board where it will be in contact with the metal
408         battery holder. A small pad on the circuit board makes contact
409         with the negative battery terminal.
410       </para>
411       <para>
412         Shipping restrictions may prevent us from including a CR1025
413         battery with MicroPeak. If so, many stores carry CR1025
414         batteries as they are commonly used in small electronic
415         devices such as flash lights.
416       </para>
417     </section>
418     <section>
419       <title>Atmospheric Model</title>
420       <para>
421         MicroPeak contains a fixed atmospheric model which is used to
422         convert barometric pressure into altitude. The model was
423         converted into a 469-element piece wise linear approximation
424         which is then used to compute the altitude of the ground and
425         apogee. The difference between these represents the maximum
426         height of the flight.
427       </para>
428       <para>
429         The model assumes a particular set of atmospheric conditions,
430         which while a reasonable average cannot represent the changing
431         nature of the real atmosphere. Fortunately, for flights
432         reasonably close to the ground, the effect of this global
433         inaccuracy are largely canceled out when the computed ground
434         altitude is subtracted from the computed apogee altitude, so
435         the resulting height is more accurate than either the ground
436         or apogee altitudes.
437       </para>
438     </section>
439     <section>
440       <title>Mechanical Considerations</title>
441       <para>
442         MicroPeak is designed to be rugged enough for typical rocketry
443         applications. It contains two moving parts, the battery holder
444         and the power switch, which were selected for their
445         ruggedness.
446       </para>
447       <para>
448         The MicroPeak battery holder is designed to withstand impact
449         up to 150g without breaking contact (or, worse yet, causing
450         the battery to fall out). That means it should stand up to
451         almost any launch you care to try, and should withstand fairly
452         rough landings.
453       </para>
454       <para>
455         The power switch is designed to withstand up to 50g forces in
456         any direction. Because it is a sliding switch, orienting the
457         switch perpendicular to the direction of rocket travel will
458         serve to further protect the switch from launch forces.
459       </para>
460     </section>
461     <section>
462       <title>On-board data storage</title>
463       <para>
464         The ATtiny85 has 512 bytes of non-volatile storage, separate
465         from the code storage memory. The MicroPeak firmware uses this
466         to store information about the last completed
467         flight. Barometric measurements from the ground before launch
468         and at apogee are stored, and used at power-on to compute the
469         height of the last flight.
470       </para>
471       <para>
472         In addition to the data used to present the height of the last
473         flight, MicroPeak also stores barometric information sampled
474         at regular intervals during the flight. This information can
475         be extracted from MicroPeak through any AVR programming
476         tool.
477       </para>
478       <table frame='all'>
479         <title>MicroPeak EEPROM Data Storage</title>
480         <tgroup cols='3' align='center' colsep='1' rowsep='1'>
481           <colspec align='center' colwidth='2*' colname='Address'/>
482           <colspec align='center' colwidth='*' colname='Size (bytes)'/>
483           <colspec align='left' colwidth='7*' colname='Description'/>
484           <thead>
485             <row>
486               <entry align='center'>Address</entry>
487               <entry align='center'>Size (bytes)</entry>
488               <entry align='center'>Description</entry>
489             </row>
490           </thead>
491           <tbody>
492             <row>
493               <entry>0x000</entry>
494               <entry>4</entry>
495               <entry>Average ground pressure (Pa)</entry>
496             </row>
497             <row>
498               <entry>0x004</entry>
499               <entry>4</entry>
500               <entry>Minimum flight pressure (Pa)</entry>
501             </row>
502             <row>
503               <entry>0x008</entry>
504               <entry>2</entry>
505               <entry>Number of in-flight samples</entry>
506             </row>
507             <row>
508               <entry>0x00a … 0x1fe</entry>
509               <entry>2</entry>
510               <entry>Instantaneous flight pressure (Pa) low 16 bits</entry>
511             </row>
512           </tbody>
513         </tgroup>
514       </table>
515       <para>
516         All EEPROM data are stored least-significant byte first. The
517         instantaneous flight pressure data are stored without the
518         upper 16 bits of data. The upper bits can be reconstructed
519         from the previous sample, assuming that pressure doesn't
520         change by more more than 32kPa in a single sample
521         interval. Note that this pressure data is <emphasis>not</emphasis>
522         filtered in any way, while both the recorded ground and apogee
523         pressure values are, so you shouldn't expect the minimum
524         instantaneous pressure value to match the recorded minimum
525         pressure value exactly.
526       </para>
527       <para>
528         MicroPeak samples pressure every 96ms, but stores only every
529         other sample in the EEPROM. This provides for 251 pressure
530         samples at 192ms intervals, or 48.192s of storage. The clock
531         used for these samples is a factory calibrated RC circuit
532         built into the ATtiny85 and is accurate only to within ±10% at
533         25°C. So, you can count on the pressure data being accurate,
534         but speed or acceleration data computed from this will be
535         limited by the accuracy of this clock.
536       </para>
537     </section>
538     <section>
539       <title>MicroPeak Programming Interface</title>
540       <para>
541         MicroPeak exposes a standard 6-pin AVR programming interface,
542         but not using the usual 2x3 array of pins on 0.1"
543         centers. Instead, there is a single row of tiny 0.60mm ×
544         0.85mm pads on 1.20mm centers exposed near the edge of the
545         circuit board. We couldn't find any connector that was
546         small enough to include on the circuit board.
547       </para>
548       <para>
549         In lieu of an actual connector, the easiest way to connect to
550         the bare pads is through a set of Pogo pins. These
551         spring-loaded contacts are designed to connect in precisely
552         this way. We've designed a programming jig, the MicroPeak
553         Pogo Pin board which provides a standard AVR interface on one
554         end and a recessed slot for MicroPeak to align the board with
555         the Pogo Pins.
556       </para>
557       <para>
558         The MicroPeak Pogo Pin board is not a complete AVR programmer,
559         it is an interface board that provides a 3.3V regulated power
560         supply to run the MicroPeak via USB and a standard 6-pin AVR
561         programming interface with the usual 2x3 grid of pins on 0.1"
562         centers. This can be connected to any AVR programming
563         dongle.
564       </para>
565       <para>
566         The AVR programming interface cannot run faster than ¼ of the
567         AVR CPU clock frequency. Because MicroPeak runs at 250kHz to
568         save power, you must configure your AVR programming system to
569         clock the AVR programming interface at no faster than
570         62.5kHz, or a clock period of 32µS.
571       </para>
572     </section>
573   </chapter>
574 </book>
575 <!--  LocalWords:  Altusmetrum MicroPeak
576 -->