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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
/******************************************/
/*
call_saw.c
by Gary P. Scavone, 2001
Play sawtooth waveforms of distinct frequency.
Takes number of channels and sample rate as
input arguments. Use callback functionality.
*/
/******************************************/
#include "RtAudio.h"
#include <iostream.h>
/*
typedef signed long MY_TYPE;
#define FORMAT RtAudio::RTAUDIO_SINT24
#define SCALE 2147483647.0
typedef char MY_TYPE;
#define FORMAT RtAudio::RTAUDIO_SINT8
#define SCALE 127.0
typedef signed short MY_TYPE;
#define FORMAT RtAudio::RTAUDIO_SINT16
#define SCALE 32767.0
typedef signed long MY_TYPE;
#define FORMAT RtAudio::RTAUDIO_SINT32
#define SCALE 2147483647.0
*/
typedef float MY_TYPE;
#define FORMAT RtAudio::RTAUDIO_FLOAT32
#define SCALE 1.0
/*
typedef double MY_TYPE;
#define FORMAT RtAudio::RTAUDIO_FLOAT64
#define SCALE 1.0
*/
#define BASE_RATE 0.005
#define TIME 1.0
void usage(void) {
/* Error function in case of incorrect command-line
argument specifications
*/
cout << "\nuseage: call_saw N fs <device>\n";
cout << " where N = number of channels,\n";
cout << " fs = the sample rate,\n";
cout << " and device = the device to use (default = 0).\n\n";
exit(0);
}
int chans;
int saw(char *buffer, int buffer_size, void *data)
{
int i, j;
extern int chans;
MY_TYPE *my_buffer = (MY_TYPE *) buffer;
double *my_data = (double *) data;
for (i=0; i<buffer_size; i++) {
for (j=0; j<chans; j++) {
*my_buffer++ = (MY_TYPE) (my_data[j] * SCALE);
my_data[j] += BASE_RATE * (j+1+(j*0.1));
if (my_data[j] >= 1.0) my_data[j] -= 2.0;
}
}
return 0;
}
int main(int argc, char *argv[])
{
int stream, buffer_size, fs, device = 0;
RtAudio *audio;
double *data;
char input;
// minimal command-line checking
if (argc != 3 && argc != 4 ) usage();
chans = (int) atoi(argv[1]);
fs = (int) atoi(argv[2]);
if ( argc == 4 )
device = (int) atoi(argv[3]);
// Open the realtime output device
buffer_size = 1024;
try {
audio = new RtAudio(&stream, device, chans, 0, 0,
FORMAT, fs, &buffer_size, 4);
}
catch (RtError &) {
exit(EXIT_FAILURE);
}
data = (double *) calloc(chans, sizeof(double));
try {
audio->setStreamCallback(stream, &saw, (void *)data);
audio->startStream(stream);
}
catch (RtError &) {
goto cleanup;
}
cout << "\nPlaying ... press <enter> to quit (buffer size = " << buffer_size << ").\n";
cin.get(input);
// Stop the stream.
try {
audio->stopStream(stream);
}
catch (RtError &) {
}
cleanup:
audio->closeStream(stream);
delete audio;
if (data) free(data);
return 0;
}
|