2#include <ossia/dataflow/graph_node.hpp>
3#include <ossia/dataflow/nodes/sound.hpp>
4#include <ossia/dataflow/nodes/sound_utils.hpp>
11 void set_start(std::size_t v) { start = v; }
13 void set_upmix(std::size_t v) { upmix = v; }
15 [[nodiscard]] std::size_t channels()
const {
return m_data.size(); }
17 [[nodiscard]] std::size_t duration()
const
19 return m_data.empty() ? 0 : m_data[0].size();
22 void transport(time_value date)
24 info->m_resampler.transport(to_sample(date, m_dataSampleRate));
27 void transport(time_value date,
const ossia::tick_transport_info& tinfo)
29 info->m_resampler.transport(info->file_sample_for_model_time(
30 date, tinfo.current_tempo, m_dataSampleRate));
34 void set_sound(audio_array data)
36 m_handle = std::make_shared<audio_data>();
37 m_handle->data = std::move(data);
40 m_dataSampleRate = 44100;
41 m_data.assign(m_handle->data.begin(), m_handle->data.end());
42 info->m_resampler.reset(
43 0, audio_stretch_mode::None, m_handle->data.size(), m_dataSampleRate);
47 void set_sound(
const audio_handle& hdl,
int channels,
int sampleRate)
53 m_dataSampleRate = sampleRate;
54 m_data.assign(m_handle->data.begin(), m_handle->data.end());
60 const int64_t start,
const int64_t samples_to_write,
61 T**
const audio_array)
const noexcept
63 read_audio_from_buffer(
64 m_data, start, samples_to_write, info->m_start_offset_samples,
65 info->m_loop_duration_samples, info->m_loops, audio_array);
69 void fetch_audio_backward(
70 const int64_t start,
const int64_t samples_to_write,
71 T**
const audio_array)
const noexcept
73 read_audio_from_buffer_backward(
74 m_data, start, samples_to_write, info->m_start_offset_samples,
75 info->m_loop_duration_samples, info->m_loops, audio_array);
78 void run(
const ossia::token_request& t, ossia::exec_state_facade e)
noexcept
83 const std::size_t chan = m_data.size();
84 const std::size_t len = m_data[0].size();
85 ossia::audio_port& ap = *audio_out;
86 ap.set_channels(std::max(this->upmix, chan));
88 const auto [samples_to_read, samples_to_write]
89 = snd::sample_info(e.bufferSize(), e.modelToSamples(), t);
90 if(samples_to_read == 0)
92 if(samples_to_write <= 0)
95 assert(samples_to_write > 0);
97 const auto samples_offset = t.physical_start(e.modelToSamples());
101 if(t.prev_date < info->m_prev_date)
106 info->m_prev_date = t.prev_date;
108 transport(t.prev_date);
113 if(t.prev_date > info->m_prev_date)
116 info->m_prev_date = t.prev_date;
118 transport(t.prev_date);
122 for(std::size_t i = 0; i < chan; ++i)
124 ap.channel(i).resize(e.bufferSize());
127 const double stretch_ratio = info->update_stretch(t, e);
128 const double abs_stretch_ratio = std::abs(stretch_ratio);
130 info->m_resampler.run(
131 *
this, t, e, stretch_ratio, chan, len, samples_to_read, samples_to_write,
134 const bool start_discontinuous = t.start_discontinuous || (m_last_stretch > 70.);
135 const bool end_discontinuous = t.end_discontinuous || (abs_stretch_ratio > 70.);
136 if(abs_stretch_ratio > 70. && m_last_stretch > 70.)
139 for(std::size_t i = 0; i < chan; i++)
141 ossia::snd::do_zero(ap.channel(i), samples_offset, samples_to_write);
147 for(std::size_t i = 0; i < chan; i++)
150 start_discontinuous, end_discontinuous, ap.channel(i), samples_offset,
155 ossia::snd::perform_upmix(this->upmix, chan, ap);
156 ossia::snd::perform_start_offset(this->start, ap);
158 info->m_prev_date = t.date;
159 m_last_stretch = abs_stretch_ratio;
162 sound_processing_info* info{};
163 ossia::audio_port* audio_out{};
165 audio_span<float> m_data{};
170 std::size_t m_dataSampleRate{};
171 audio_handle m_handle{};
172 double m_last_stretch{1.0};
The time_value class.
Definition ossia/editor/scenario/time_value.hpp:30