MayaFlux 0.2.0
Digital-First Multimedia Processing Framework
Loading...
Searching...
No Matches

◆ process_bidirectional()

void MayaFlux::Nodes::Network::WaveguideNetwork::process_bidirectional ( WaveguideSegment seg,
unsigned int  num_samples 
)
private

Definition at line 167 of file WaveguideNetwork.cpp.

169{
170 for (unsigned int i = 0; i < num_samples; ++i) {
171 const double exciter = generate_exciter_sample();
172
173 const double plus_end = read_with_interpolation(
175
176 const double minus_end = read_with_interpolation(
178
179 auto* filt_open = seg.loop_filter_open ? seg.loop_filter_open.get()
180 : seg.loop_filter.get();
181 auto* filt_closed = seg.loop_filter_closed ? seg.loop_filter_closed.get()
182 : seg.loop_filter.get();
183
184 const double filtered_plus = filt_open ? filt_open->process_sample(plus_end)
185 : plus_end;
186 const double filtered_minus = filt_closed ? filt_closed->process_sample(minus_end)
187 : minus_end;
188
189 seg.p_minus.push(filtered_plus * seg.loss_factor * seg.reflection_open);
190 seg.p_plus.push(exciter + filtered_minus * seg.loss_factor * seg.reflection_closed);
191
192 m_last_audio_buffer.push_back(observe_sample(seg));
193 }
194}
std::vector< double > m_last_audio_buffer
double observe_sample(const WaveguideSegment &seg) const
double read_with_interpolation(const Memory::HistoryBuffer< double > &delay, size_t integer_part, double fraction) const
Read from delay line with linear fractional interpolation.

References generate_exciter_sample(), MayaFlux::Nodes::Network::WaveguideNetwork::WaveguideSegment::loop_filter, MayaFlux::Nodes::Network::WaveguideNetwork::WaveguideSegment::loop_filter_closed, MayaFlux::Nodes::Network::WaveguideNetwork::WaveguideSegment::loop_filter_open, MayaFlux::Nodes::Network::WaveguideNetwork::WaveguideSegment::loss_factor, m_delay_length_fraction, m_delay_length_integer, MayaFlux::Nodes::Network::NodeNetwork::m_last_audio_buffer, observe_sample(), MayaFlux::Nodes::Network::WaveguideNetwork::WaveguideSegment::p_minus, MayaFlux::Nodes::Network::WaveguideNetwork::WaveguideSegment::p_plus, MayaFlux::Memory::HistoryBuffer< T >::push(), read_with_interpolation(), MayaFlux::Nodes::Network::WaveguideNetwork::WaveguideSegment::reflection_closed, and MayaFlux::Nodes::Network::WaveguideNetwork::WaveguideSegment::reflection_open.

Referenced by process_batch().

+ Here is the call graph for this function:
+ Here is the caller graph for this function: