44MAYAFLUX_API
void download_host_visible(
const std::shared_ptr<VKBuffer>& source,
const std::shared_ptr<VKBuffer>& target);
58MAYAFLUX_API
void download_device_local(
const std::shared_ptr<VKBuffer>& source,
const std::shared_ptr<VKBuffer>& target,
const std::shared_ptr<VKBuffer>& staging_buffer);
75 const std::shared_ptr<VKBuffer>& target,
76 const std::shared_ptr<VKBuffer>& staging =
nullptr);
87 std::span<const T> data,
88 const std::shared_ptr<VKBuffer>& target,
89 const std::shared_ptr<VKBuffer>& staging =
nullptr)
91 upload_to_gpu(data.data(), data.size_bytes(), target, staging);
103 const std::vector<T>& data,
104 const std::shared_ptr<VKBuffer>& target,
105 const std::shared_ptr<VKBuffer>& staging =
nullptr)
123 const std::shared_ptr<VKBuffer>& source,
126 const std::shared_ptr<VKBuffer>& staging =
nullptr);
137 const std::shared_ptr<VKBuffer>& source,
139 const std::shared_ptr<VKBuffer>& staging =
nullptr)
153 const std::shared_ptr<VKBuffer>& source,
154 std::vector<T>& data,
155 const std::shared_ptr<VKBuffer>& staging =
nullptr)
157 size_t element_count = source->get_size_bytes() /
sizeof(T);
158 data.resize(element_count);
174MAYAFLUX_API
bool is_device_local(
const std::shared_ptr<VKBuffer>& buffer);
189 const std::shared_ptr<VKBuffer>& target,
190 const std::shared_ptr<VKBuffer>& staging =
nullptr)
192 auto view = accessor.
view<T>();
194 const void* data_ptr = view.data();
195 size_t data_bytes = view.size() *
sizeof(T);
197 if constexpr (std::is_same_v<T, double>) {
198 if (target->get_format() != vk::Format::eR64Sfloat) {
200 "Uploading double precision to buffer with format {}. Consider using R64Sfloat for audio.",
201 vk::to_string(target->get_format()));
222 const std::shared_ptr<VKBuffer>& target,
223 const std::shared_ptr<VKBuffer>& staging =
nullptr)
226 error<std::invalid_argument>(
229 std::source_location::current(),
230 "Cannot upload structured view from non-structured data");
233 auto structured_view = accessor.
view<T>();
234 upload_to_gpu(structured_view.data(), structured_view.size_bytes(), target, staging);
242 const std::shared_ptr<VKBuffer>& source,
244 const std::vector<Kakshya::DataDimension>& dimensions,
246 const std::shared_ptr<VKBuffer>& staging =
nullptr)
248 size_t element_count = source->get_size_bytes() /
sizeof(T);
250 std::vector<T> temp_buffer(element_count);
253 target_variant = std::move(temp_buffer);
270 const std::shared_ptr<AudioBuffer>& audio_buffer,
271 const std::shared_ptr<VKBuffer>& gpu_buffer,
272 const std::shared_ptr<VKBuffer>& staging =
nullptr);
285 const std::shared_ptr<VKBuffer>& gpu_buffer,
286 const std::shared_ptr<AudioBuffer>& audio_buffer,
287 const std::shared_ptr<VKBuffer>& staging =
nullptr);
#define MF_WARN(comp, ctx,...)
auto view() const
Get explicit typed view of data.
bool is_structured() const
Type-erased accessor for NDData with semantic view construction.
void upload_host_visible(const std::shared_ptr< VKBuffer > &target, const Kakshya::DataVariant &data)
Upload data to a host-visible buffer.
void upload_audio_to_gpu(const std::shared_ptr< AudioBuffer > &audio_buffer, const std::shared_ptr< VKBuffer > &gpu_buffer, const std::shared_ptr< VKBuffer > &staging)
Upload AudioBuffer to GPU (always double precision)
void upload_structured_view(const Kakshya::DataAccess &accessor, const std::shared_ptr< VKBuffer > &target, const std::shared_ptr< VKBuffer > &staging=nullptr)
Upload structured data with GLM double-precision types.
void upload_device_local(const std::shared_ptr< VKBuffer > &target, const std::shared_ptr< VKBuffer > &staging_buffer, const Kakshya::DataVariant &data)
Upload data to a device-local buffer using a staging buffer.
std::shared_ptr< VKBuffer > create_staging_buffer(size_t size)
Create staging buffer for transfers.
bool is_device_local(const std::shared_ptr< VKBuffer > &buffer)
Check if buffer is device-local (staging needed)
void download_audio_from_gpu(const std::shared_ptr< VKBuffer > &gpu_buffer, const std::shared_ptr< AudioBuffer > &audio_buffer, const std::shared_ptr< VKBuffer > &staging)
Download GPU buffer to AudioBuffer (expects double precision)
void upload_from_view(const Kakshya::DataAccess &accessor, const std::shared_ptr< VKBuffer > &target, const std::shared_ptr< VKBuffer > &staging=nullptr)
Upload data from DataAccess view to GPU buffer (precision-preserving)
void download_from_gpu(const std::shared_ptr< VKBuffer > &source, void *data, size_t size, const std::shared_ptr< VKBuffer > &staging)
Download from GPU buffer to raw data (auto-detects host-visible vs device-local)
void download_host_visible(const std::shared_ptr< VKBuffer > &source, const std::shared_ptr< VKBuffer > &target)
Download data from a host-visible buffer.
void download_device_local(const std::shared_ptr< VKBuffer > &source, const std::shared_ptr< VKBuffer > &target, const std::shared_ptr< VKBuffer > &staging_buffer)
Download data from a device-local buffer using a staging buffer.
Kakshya::DataAccess download_to_view(const std::shared_ptr< VKBuffer > &source, Kakshya::DataVariant &target_variant, const std::vector< Kakshya::DataDimension > &dimensions, Kakshya::DataModality modality, const std::shared_ptr< VKBuffer > &staging=nullptr)
Download GPU buffer to DataAccess-compatible format (precision-preserving)
void upload_to_gpu(const void *data, size_t size, const std::shared_ptr< VKBuffer > &target, const std::shared_ptr< VKBuffer > &staging)
Upload raw data to GPU buffer (auto-detects host-visible vs device-local)
@ BufferProcessing
Buffer processing (Buffers::BufferManager, processing chains)
@ Buffers
Buffers, Managers, processors and processing chains.
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.
DataModality
Data modality types for cross-modal analysis.