OSSIA
Open Scenario System for Interactive Application
Loading...
Searching...
No Matches
raw_stretcher.hpp
1#pragma once
2#include <ossia/dataflow/audio_port.hpp>
3#include <ossia/dataflow/graph_node.hpp>
4#include <ossia/dataflow/nodes/media.hpp>
5#include <ossia/dataflow/token_request.hpp>
6
7namespace ossia
8{
9
10struct raw_stretcher
11{
12 int64_t next_sample_to_read{};
13 raw_stretcher() noexcept = default;
14 raw_stretcher(const raw_stretcher&) noexcept = default;
15 raw_stretcher(raw_stretcher&&) noexcept = default;
16 raw_stretcher& operator=(const raw_stretcher&) noexcept = default;
17 raw_stretcher& operator=(raw_stretcher&&) noexcept = default;
18 raw_stretcher(int64_t pos) noexcept
19 : next_sample_to_read{pos}
20 {
21 }
22
23 [[nodiscard]] static constexpr int64_t start_delay() noexcept { return 0; }
24
25 void transport(int64_t date) { next_sample_to_read = date; }
26
27 template <typename T>
28 void
29 run(T& audio_fetcher, const ossia::token_request& t, const ossia::exec_state_facade e,
30 double tempo_ratio, const std::size_t chan, const int64_t len,
31 const int64_t samples_to_read, const int64_t samples_to_write,
32 const int64_t samples_offset, const ossia::mutable_audio_span<double>& ap) noexcept
33 {
34 if(t.forward())
35 {
36 double** output = (double**)alloca(sizeof(double*) * chan);
37 for(std::size_t i = 0; i < chan; i++)
38 output[i] = ap[i].data() + samples_offset;
39
40 audio_fetcher.fetch_audio(next_sample_to_read, samples_to_write, output);
41 next_sample_to_read += samples_to_write;
42 }
43 else
44 {
45 // Backward playback
46 double** output = (double**)alloca(sizeof(double*) * chan);
47 for(std::size_t i = 0; i < chan; i++)
48 output[i] = ap[i].data() + samples_offset;
49
50 audio_fetcher.fetch_audio_backward(next_sample_to_read, samples_to_write, output);
51 next_sample_to_read -= samples_to_write;
52 }
53 }
54};
55
56}
Definition git_info.h:7