MayaFlux 0.4.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,
std::vector< double > &  out 
)
private

Definition at line 176 of file WaveguideNetwork.cpp.

178{
179 for (unsigned int i = 0; i < num_samples; ++i) {
180 const double exciter = generate_exciter_sample();
181
182 const double plus_end = read_with_interpolation(
184
185 const double minus_end = read_with_interpolation(
187
188 auto* filt_open = seg.loop_filter_open ? seg.loop_filter_open.get()
189 : seg.loop_filter.get();
190 auto* filt_closed = seg.loop_filter_closed ? seg.loop_filter_closed.get()
191 : seg.loop_filter.get();
192
193 const double filtered_plus = filt_open ? filt_open->process_sample(plus_end)
194 : plus_end;
195 const double filtered_minus = filt_closed ? filt_closed->process_sample(minus_end)
196 : minus_end;
197
198 seg.p_minus.push(filtered_plus * seg.loss_factor * seg.reflection_open);
199 seg.p_plus.push(exciter + filtered_minus * seg.loss_factor * seg.reflection_closed);
200 out[i] = observe_sample(seg);
201 }
202}
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, 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: