-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathAudioProcessing.cpp
More file actions
96 lines (70 loc) · 2.34 KB
/
AudioProcessing.cpp
File metadata and controls
96 lines (70 loc) · 2.34 KB
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
#include<iostream>
#include <fstream>
#include<cmath>
using namespace std;
//Riff Chunk
const string chunck_id = "RIFF";
const string chunk_size = "----";
const string format = "WAVE";
//FMT sub-chunk
const string subchunk1_id = "fmt ";
const int subchunk1_size = 16; // 4 bytes
const int audio_format = 1; // 2 bytes
const int num_channels = 2; // 2 bytes
const int sample_rate = 44100;
const int byte_rate = sample_rate * num_channels * (subchunk1_size / 8 );
const int block_align = num_channels * (subchunk1_size / 8);
const int bits_per_sample = 16;
// Data sub chunk
const string subchunk2_id = "data";
const string subchunk2_size = "----";
const int duration = 2;
const int max_amplitude = 32760;
const double frequency = 250;
// helps us enforce that ant integer takes up only a particular number of
// bytes
void write_as_bytes(ofstream& file, int value, int byte_size) {
file.write(reinterpret_cast<const char*>(&value),byte_size);
}
int main() {
ofstream wav;
wav.open("test.wav", ios::binary);
if (wav.is_open()) {
wav << chunck_id;
wav << chunk_size;
wav << format;
wav << subchunk1_id;
write_as_bytes(wav, subchunk1_size, 4);
write_as_bytes(wav, audio_format, 2);
write_as_bytes(wav, num_channels, 2);
write_as_bytes(wav, sample_rate, 4);
write_as_bytes(wav, byte_rate, 4);
write_as_bytes(wav, block_align, 2);
write_as_bytes(wav, bits_per_sample, 2);
wav << subchunk2_id;
wav << subchunk2_size;
int start_audio = wav.tellp();
for (size_t i = 0; i < sample_rate * duration; i++)
{
//respect the max amplitude
// operate as a wave
// calculate amplitude for our sin function
double amplitude = (double)i / sample_rate * max_amplitude;
double value = sin(( 2 * 3.14 * i * frequency) / sample_rate);
//supply channel data
double channel_1 = amplitude * value / 2; // left ear
double channel_2 = (max_amplitude - amplitude) * value; // right ear
write_as_bytes(wav, channel_1, 2);
write_as_bytes(wav, channel_2, 2);
}
//update the size of the data
int end_audio = wav.tellp();
wav.seekp(start_audio - 4);
write_as_bytes(wav, end_audio - start_audio, 4);
// update our header file
wav.seekp(4, ios::beg);
write_as_bytes(wav, end_audio - 8, 4);
}
wav.close();
return 0;
}