comparison projects/basic_analog_input/render.cpp @ 108:3068421c0737 ultra-staging

Merged default into ultra-staging
author Giulio Moro <giuliomoro@yahoo.it>
date Tue, 18 Aug 2015 00:35:15 +0100
parents 72726dd4f66c
children ac8eb07afcf5
comparison
equal deleted inserted replaced
54:d3f869b98147 108:3068421c0737
1 /*
2 * render.cpp
3 *
4 * Created on: Oct 24, 2014
5 * Author: parallels
6 */
7
8
9 #include <BeagleRT.h>
10 #include <Utilities.h>
11 #include <rtdk.h>
12 #include <cmath>
13
14 float gPhase;
15 float gInverseSampleRate;
16 int gAudioFramesPerAnalogFrame;
17
18 // These settings are carried over from main.cpp
19 // Setting global variables is an alternative approach
20 // to passing a structure to userData in setup()
21
22 extern int gSensorInputFrequency;
23 extern int gSensorInputAmplitude;
24
25 // setup() is called once before the audio rendering starts.
26 // Use it to perform any initialisation and allocation which is dependent
27 // on the period size or sample rate.
28 //
29 // userData holds an opaque pointer to a data structure that was passed
30 // in from the call to initAudio().
31 //
32 // Return true on success; returning false halts the program.
33
34 bool setup(BeagleRTContext *context, void *userData)
35 {
36 if(context->analogFrames == 0 || context->analogFrames > context->audioFrames) {
37 rt_printf("Error: this example needs analog enabled, with 4 or 8 channels\n");
38 return false;
39 }
40
41 gAudioFramesPerAnalogFrame = context->audioFrames / context->analogFrames;
42 gInverseSampleRate = 1.0 / context->audioSampleRate;
43 gPhase = 0.0;
44
45 return true;
46 }
47
48 // render() is called regularly at the highest priority by the audio engine.
49 // Input and output are given from the audio hardware and the other
50 // ADCs and DACs (if available). If only audio is available, numMatrixFrames
51 // will be 0.
52
53 void render(BeagleRTContext *context, void *userData)
54 {
55 float frequency = 440.0;
56 float amplitude = 0.8;
57
58 // There are twice as many audio frames as matrix frames since audio sample rate
59 // is twice as high
60
61 for(unsigned int n = 0; n < context->audioFrames; n++) {
62 if(!(n % gAudioFramesPerAnalogFrame)) {
63 // Even audio samples: update frequency and amplitude from the matrix
64 frequency = map(analogReadFrame(context, n/gAudioFramesPerAnalogFrame, gSensorInputFrequency), 0, 1, 100, 1000);
65 amplitude = analogReadFrame(context, n/gAudioFramesPerAnalogFrame, gSensorInputAmplitude);
66 }
67
68 float out = amplitude * sinf(gPhase);
69
70 for(unsigned int channel = 0; channel < context->audioChannels; channel++)
71 context->audioOut[n * context->audioChannels + channel] = out;
72
73 gPhase += 2.0 * M_PI * frequency * gInverseSampleRate;
74 if(gPhase > 2.0 * M_PI)
75 gPhase -= 2.0 * M_PI;
76 }
77 }
78
79 // cleanup() is called once at the end, after the audio has stopped.
80 // Release any resources that were allocated in setup().
81
82 void cleanup(BeagleRTContext *context, void *userData)
83 {
84
85 }