diff options
author | lonkaars <loek@pipeframe.xyz> | 2023-06-03 16:21:05 +0200 |
---|---|---|
committer | lonkaars <loek@pipeframe.xyz> | 2023-06-03 16:21:19 +0200 |
commit | 4ddbd609e537acbf5610651772d969ea59f99a4c (patch) | |
tree | c5add84a52e6eba996896152b2c4d3fabf62779f /os2eindopdracht/main.cpp | |
parent | 31293dd9b427be45175a928cf55f90ea1bccebeb (diff) |
add comments and remove non-working align method
Diffstat (limited to 'os2eindopdracht/main.cpp')
-rw-r--r-- | os2eindopdracht/main.cpp | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/os2eindopdracht/main.cpp b/os2eindopdracht/main.cpp index bc7ce17..b451652 100644 --- a/os2eindopdracht/main.cpp +++ b/os2eindopdracht/main.cpp @@ -14,37 +14,48 @@ using std::vector; using std::counting_semaphore; using std::thread; +using std::ref; #define SAMPLE_BLOCK_SIZE 1024 int main(int argc, char** argv) { + // parse arguments Arguments args(argc, argv); + // read input file to std::string std::fstream file_input(args.file_input, std::ios::in | std::ios::binary); std::stringstream file_input_content; file_input_content << file_input.rdbuf(); file_input.close(); + // convert std::string to vector<int16_t> SampleStream input(file_input_content.str()); + // split into 1024-sample blocks vector<SampleBlock> input_blocks = input.split(SAMPLE_BLOCK_SIZE); + // do the same for output stream (input stream is later used as reference but not mutated) SampleStream output(file_input_content.str()); vector<SampleBlock> output_blocks = output.split(SAMPLE_BLOCK_SIZE); + // c++20 semaphore for limiting active thread count counting_semaphore semaphore(args.max_threads); + // thread array vector<thread> threads; for (size_t i = 0; i < input_blocks.size(); i++) { - semaphore.acquire(); + semaphore.acquire(); // wait until less than args.max_threads threads are running + // create thread threads.push_back(thread([&args, &semaphore](SampleBlock& input, SampleBlock& output) { + // apply filter to output FilterWorker(input, output).filter(args.bass, args.treble); + // allow new thread to be created semaphore.release(); - }, std::ref(input_blocks[i]), std::ref(output_blocks[i]))); + }, ref(input_blocks[i]), ref(output_blocks[i]))); } + // make sure all threads are done for (thread& t : threads) t.join(); - output.align(SAMPLE_BLOCK_SIZE); - + // write pcm stream to output file std::fstream file_output(args.file_output, std::ios::out | std::ios::binary); std::string edited_stream = output.save(); file_output.write(edited_stream.c_str(), edited_stream.size()); |