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

◆ process_batch()

void MayaFlux::Nodes::Network::WaveguideNetwork::process_batch ( unsigned int  num_samples)
overridevirtual

Process the network for the given number of samples.

Parameters
num_samplesNumber of samples/frames to process

Subclasses implement their specific processing logic:

  1. Update internal state (physics, relationships, etc.)
  2. Process individual nodes
  3. Apply inter-node interactions
  4. Aggregate outputs if needed

Called by NodeGraphManager during token processing.

Implements MayaFlux::Nodes::Network::NodeNetwork.

Definition at line 122 of file WaveguideNetwork.cpp.

123{
125 m_last_audio_buffer.clear();
126
127 if (!is_enabled() || m_segments.empty()) {
128 m_last_audio_buffer.assign(num_samples, 0.0);
129 m_last_output = 0.0;
130 return;
131 }
132
134 m_last_audio_buffer.reserve(num_samples);
135
136 auto& seg = m_segments[0];
137
139 process_unidirectional(seg, num_samples);
140 } else {
141 process_bidirectional(seg, num_samples);
142 }
143
146}
void apply_output_scale()
Apply m_output_scale to m_last_audio_buffer.
bool is_enabled() const
Check if network is enabled.
void ensure_initialized()
Ensure initialize() is called exactly once.
std::vector< double > m_last_audio_buffer
void process_bidirectional(WaveguideSegment &seg, unsigned int num_samples)
void process_unidirectional(WaveguideSegment &seg, unsigned int num_samples)
std::vector< WaveguideSegment > m_segments

References MayaFlux::Nodes::Network::NodeNetwork::apply_output_scale(), MayaFlux::Nodes::Network::NodeNetwork::ensure_initialized(), MayaFlux::Nodes::Network::NodeNetwork::is_enabled(), MayaFlux::Nodes::Network::NodeNetwork::m_last_audio_buffer, m_last_output, m_segments, process_bidirectional(), process_unidirectional(), MayaFlux::Nodes::Network::WaveguideNetwork::WaveguideSegment::UNIDIRECTIONAL, and update_mapped_parameters().

+ Here is the call graph for this function: