/elec/quadcopter

To get this branch, use:
bzr branch http://bzr.ed.am/elec/quadcopter

« back to all changes in this revision

Viewing changes to test/receiver/pulse-width/main.ino

  • Committer: Tim Marston
  • Date: 2013-10-30 22:41:50 UTC
  • Revision ID: tim@ed.am-20131030224150-t6xs1l783m2yg6rd
updated comments in receiver test programs

Show diffs side-by-side

added added

removed removed

Lines of Context:
8
8
// microseconds.  It takes several measurements and prints it the average over
9
9
// serial.
10
10
//
11
 
 
12
 
 
13
 
// number of signal pulses to average (for damping)
14
 
#define DAMPING_SAMPLES 1
 
11
// NOTES: Due to the way our receiver works (by varying the position of the
 
12
// rising edge of the pulse and keeping the falling edge fixed), it is
 
13
// sufficient for us to measure the pule width to determine the channel value
 
14
// (e.g., throttle position).  But it should be noted that this relies on a
 
15
// quirk of our receiver/transmitter and it is not truly measuring PPM.  Our
 
16
// next experiment is measuring PPM (../ppm-read).
 
17
 
 
18
// number of signal pulses to average
 
19
#define AVERAGE_SAMPLES 1
 
20
 
 
21
// should average be result, or damping?
 
22
#define AVERAGE_DAMP 1
 
23
 
 
24
// graphic display
 
25
#define GRAPH 1
 
26
#define GRAPH_MIN 1000
 
27
#define GRAPH_MAX 2000
 
28
#define GRAPH_SIZE 30
15
29
 
16
30
 
17
31
// set to the time that the last signal pulse was at
39
53
        Serial.begin( 9600 );
40
54
}
41
55
 
 
56
 
42
57
void loop()
43
58
{
44
59
        unsigned long last_pulse_off = 0;
45
 
        unsigned long intervals[ DAMPING_SAMPLES ] = {0};
 
60
        unsigned long intervals[ AVERAGE_SAMPLES ];     
46
61
        int interval_idx = 0;
47
62
 
 
63
        // reset intervals
 
64
        for( int a = 0; a < AVERAGE_SAMPLES; a++ )
 
65
                intervals[ a ] = 0;
 
66
 
 
67
#ifdef GRAPH
 
68
        // init graph
 
69
        char graph[ GRAPH_SIZE + 3 ];
 
70
        for( int a = 1; a < GRAPH_SIZE + 1; a++ )
 
71
                graph[ a ] = '-';
 
72
        graph[ 0 ] = '[';
 
73
        graph[ GRAPH_SIZE + 1 ] = ']';
 
74
        graph[ GRAPH_SIZE + 2 ] = 0;
 
75
#endif // GRAPH
 
76
 
48
77
        while( true )
49
78
        {
50
79
                // detect pulse falling-edge
59
88
                        {
60
89
                                // update interval buffer
61
90
                                intervals[ interval_idx ] = pulse_off - pulse_on;
62
 
                                if( ++interval_idx >= DAMPING_SAMPLES )
 
91
                                if( ++interval_idx >= AVERAGE_SAMPLES )
63
92
                                        interval_idx = 0;
64
93
 
65
94
                                got_pulse = true;
69
98
                }
70
99
 
71
100
                // display average?
72
 
                if( got_pulse )
 
101
                if( got_pulse &&
 
102
                        ( AVERAGE_DAMP || interval_idx == 0 ) )
73
103
                {
74
104
                        // calculate average
75
105
                        unsigned long ave = 0;
76
 
                        for( int a = 0; a < DAMPING_SAMPLES; a++ )
 
106
                        for( int a = 0; a < AVERAGE_SAMPLES; a++ )
77
107
                                ave += intervals[ a ];
78
 
                        ave /= DAMPING_SAMPLES;
 
108
                        ave /= AVERAGE_SAMPLES;
 
109
 
 
110
#ifdef GRAPH
 
111
 
 
112
                        // draw graph
 
113
                        int pos = ( GRAPH_SIZE ) *
 
114
                                ( ave - GRAPH_MIN ) / ( GRAPH_MAX - GRAPH_MIN );
 
115
                        graph[ pos + 1 ] = '|';
 
116
                        Serial.println( graph );
 
117
                        graph[ pos + 1 ] = '-';
 
118
 
 
119
#else // GRAPH
79
120
 
80
121
                        // tell it like it is
81
 
                        Serial.print( ave );
82
 
                        Serial.print( "\r\n" );
 
122
                        Serial.println( ave );
 
123
 
 
124
#endif // GRAPH
83
125
                }               
84
126
        }
85
127
}