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

◆ process_operation()

void MayaFlux::Kriya::BufferPipeline::process_operation ( BufferOperation op,
uint64_t  cycle 
)
private

Definition at line 483 of file BufferPipeline.cpp.

484{
485 try {
486 switch (op.get_type()) {
488 capture_operation(op, cycle);
489
490 break;
491 }
492
494 Kakshya::DataVariant input_data;
495 if (m_operation_data.find(&op) != m_operation_data.end()) {
496 input_data = m_operation_data[&op];
497 } else {
498 for (auto& it : m_operation_data) {
499 input_data = it.second;
500 break;
501 }
502 }
503
504 if (op.m_transformer) {
505 auto transformed = op.m_transformer(input_data, cycle);
506 m_operation_data[&op] = transformed;
507
508 for (auto& m_operation : std::ranges::reverse_view(m_operations)) {
509 if (&m_operation == &op)
510 continue;
511 if (m_operation.get_type() == BufferOperation::OpType::CAPTURE && m_operation.m_capture.get_buffer()) {
512 write_to_buffer(m_operation.m_capture.get_buffer(), transformed);
513 break;
514 }
515 }
516 }
517 break;
518 }
519
521 Kakshya::DataVariant data_to_route;
522 if (m_operation_data.find(&op) != m_operation_data.end()) {
523 data_to_route = m_operation_data[&op];
524 } else {
525 for (auto& it : m_operation_data) {
526 data_to_route = it.second;
527 break;
528 }
529 }
530
531 if (op.m_target_buffer) {
532 write_to_buffer(op.m_target_buffer, data_to_route);
533 } else if (op.m_target_container) {
534 write_to_container(op.m_target_container, data_to_route);
535 }
536 break;
537 }
538
540 auto loaded_data = read_from_container(op.m_source_container,
541 op.m_start_frame,
542 op.m_load_length);
543
544 if (op.m_target_buffer) {
545 write_to_buffer(op.m_target_buffer, loaded_data);
546 }
547
548 m_operation_data[&op] = loaded_data;
549 break;
550 }
551
553 std::vector<Kakshya::DataVariant> fusion_inputs;
554
555 for (auto& source_buffer : op.m_source_buffers) {
556 bool should_process = op.m_capture.get_processing_control() == BufferCapture::ProcessingControl::ON_CAPTURE;
557 auto buffer_data = extract_buffer_data(source_buffer, should_process);
558 fusion_inputs.push_back(buffer_data);
559 }
560
561 for (auto& source_container : op.m_source_containers) {
562 auto container_data = read_from_container(source_container, 0, 0);
563 fusion_inputs.push_back(container_data);
564 }
565
566 if (op.m_fusion_function && !fusion_inputs.empty()) {
567 auto fused_data = op.m_fusion_function(fusion_inputs, cycle);
568
569 if (op.m_target_buffer) {
570 write_to_buffer(op.m_target_buffer, fused_data);
571 } else if (op.m_target_container) {
572 write_to_container(op.m_target_container, fused_data);
573 }
574
575 m_operation_data[&op] = fused_data;
576 }
577 break;
578 }
579
581 Kakshya::DataVariant data_to_dispatch;
582 if (m_operation_data.find(&op) != m_operation_data.end()) {
583 data_to_dispatch = m_operation_data[&op];
584 } else {
585 for (auto& it : m_operation_data) {
586 data_to_dispatch = it.second;
587 break;
588 }
589 }
590
591 if (op.m_dispatch_handler) {
592 op.m_dispatch_handler(data_to_dispatch, cycle);
593 }
594 break;
595 }
596
598 if (!m_buffer_manager) {
599 error<std::invalid_argument>(Journal::Component::Kriya,
601 std::source_location::current(),
602 "BufferPipeline has no BufferManager for MODIFY operation");
603 }
604
605 if (!op.m_attached_processor) {
606 op.m_attached_processor = m_buffer_manager->attach_quick_process(
607 op.m_buffer_modifier,
608 op.m_target_buffer, Buffers::ProcessingToken::AUDIO_BACKEND);
609 if (m_max_cycles != 0 && op.is_streaming()) {
610 op.m_modify_cycle_count = m_max_cycles - cycle;
611 }
612 }
613
614 if (op.m_modify_cycle_count > 0 && cycle >= op.m_modify_cycle_count - 1) {
615 if (op.m_attached_processor) {
616 m_buffer_manager->remove_processor(
617 op.m_attached_processor,
618 op.m_target_buffer);
619 op.m_attached_processor = nullptr;
620 }
621 }
622
623 break;
624 }
625
627 break;
628
629 default:
632 "Unknown operation type in pipeline : {} : {}",
633 Utils::enum_to_string(op.get_type()), std::to_string(static_cast<int>(op.get_type())));
634 break;
635 }
636 } catch (const std::exception& e) {
639 std::source_location::current(),
640 "Error processing operation in BufferPipeline: {}",
641 e.what());
642 }
643}
#define MF_ERROR(comp, ctx,...)
@ LOAD
Load data from container to buffer with position control.
@ CONDITION
Conditional operation for branching logic.
@ FUSE
Fuse multiple sources using custom fusion functions.
@ ROUTE
Route data to destination (buffer or container)
@ CAPTURE
Capture data from source buffer using BufferCapture strategy.
@ MODIFY
Modify Buffer Data using custom quick process.
@ DISPATCH
Dispatch to external handler for custom processing.
@ TRANSFORM
Apply transformation function to data variants.
std::unordered_map< BufferOperation *, Kakshya::DataVariant > m_operation_data
static void write_to_container(const std::shared_ptr< Kakshya::DynamicSoundStream > &container, const Kakshya::DataVariant &data)
void capture_operation(BufferOperation &op, uint64_t cycle)
std::vector< BufferOperation > m_operations
static Kakshya::DataVariant read_from_container(const std::shared_ptr< Kakshya::DynamicSoundStream > &container, uint64_t start, uint32_t length)
static void write_to_buffer(const std::shared_ptr< Buffers::AudioBuffer > &buffer, const Kakshya::DataVariant &data)
std::shared_ptr< Buffers::BufferManager > m_buffer_manager
static Kakshya::DataVariant extract_buffer_data(const std::shared_ptr< Buffers::AudioBuffer > &buffer, bool should_process=false)
@ AUDIO_BACKEND
Standard audio processing backend configuration.
@ CoroutineScheduling
Coroutine scheduling and temporal coordination (Vruta::TaskScheduler)
void error_rethrow(Component component, Context context, std::source_location location=std::source_location::current(), std::string_view additional_context="")
Catch and log an exception, then rethrow it.
@ Kriya
Automatable tasks and fluent scheduling api for Nodes and Buffers.
std::variant< std::vector< double >, std::vector< float >, std::vector< uint8_t >, std::vector< uint16_t >, std::vector< uint32_t >, std::vector< std::complex< float > >, std::vector< std::complex< double > >, std::vector< glm::vec2 >, std::vector< glm::vec3 >, std::vector< glm::vec4 >, std::vector< glm::mat4 > > DataVariant
Multi-type data storage for different precision needs.
Definition NDData.hpp:73
constexpr std::string_view enum_to_string(EnumType value) noexcept
Universal enum to string converter using magic_enum (original case)
Definition EnumUtils.hpp:51

References MayaFlux::Buffers::AUDIO_BACKEND, MayaFlux::Kriya::BufferOperation::CAPTURE, capture_operation(), MayaFlux::Kriya::BufferOperation::CONDITION, MayaFlux::Journal::CoroutineScheduling, MayaFlux::Kriya::BufferOperation::DISPATCH, MayaFlux::Utils::enum_to_string(), extract_buffer_data(), MayaFlux::Kriya::BufferOperation::FUSE, MayaFlux::Kriya::BufferCapture::get_processing_control(), MayaFlux::Kriya::BufferOperation::get_type(), MayaFlux::Kriya::BufferOperation::is_streaming(), MayaFlux::Journal::Kriya, MayaFlux::Kriya::BufferOperation::LOAD, MayaFlux::Kriya::BufferOperation::m_attached_processor, m_buffer_manager, MayaFlux::Kriya::BufferOperation::m_buffer_modifier, MayaFlux::Kriya::BufferOperation::m_capture, MayaFlux::Kriya::BufferOperation::m_dispatch_handler, MayaFlux::Kriya::BufferOperation::m_fusion_function, MayaFlux::Kriya::BufferOperation::m_load_length, m_max_cycles, MayaFlux::Kriya::BufferOperation::m_modify_cycle_count, m_operation_data, m_operations, MayaFlux::Kriya::BufferOperation::m_source_buffers, MayaFlux::Kriya::BufferOperation::m_source_container, MayaFlux::Kriya::BufferOperation::m_source_containers, MayaFlux::Kriya::BufferOperation::m_start_frame, MayaFlux::Kriya::BufferOperation::m_target_buffer, MayaFlux::Kriya::BufferOperation::m_target_container, MayaFlux::Kriya::BufferOperation::m_transformer, MF_ERROR, MayaFlux::Kriya::BufferOperation::MODIFY, MayaFlux::Kriya::BufferCapture::ON_CAPTURE, read_from_container(), MayaFlux::Kriya::BufferOperation::ROUTE, MayaFlux::Kriya::BufferOperation::TRANSFORM, write_to_buffer(), and write_to_container().

Referenced by execute_phased(), and execute_streaming().

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