VTK  9.5.20250807
vtkWebGPUConfiguration.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-License-Identifier: BSD-3-Clause
18#ifndef vtkWebGPUConfiguration_h
19#define vtkWebGPUConfiguration_h
20
21#include "vtkObject.h"
22
23#include "vtkCommand.h" // for vtkCommand
24#include "vtkLogger.h" // for vtkLogger::Verbosity enum
25#include "vtkRenderingWebGPUModule.h" // for export macro
26#include "vtkWrappingHints.h" // For VTK_MARSHALAUTO
27#include "vtk_wgpu.h" // for wgpu
28
29#include <memory> // for unique_ptr
30
31VTK_ABI_NAMESPACE_BEGIN
32
36
37class VTKRENDERINGWEBGPU_EXPORT VTK_MARSHALAUTO vtkWebGPUConfiguration : public vtkObject
38{
39public:
42 void PrintSelf(ostream& os, vtkIndent indent) override;
43
49 {
50 Undefined,
51 LowPower,
52 HighPerformance
53 };
54
55 enum class BackendType
56 {
57 Undefined,
58 Null,
59 WebGPU,
60 D3D11,
61 D3D12,
62 Metal,
63 Vulkan,
64 OpenGL,
65 OpenGLES
66 };
67
69
80
82
99
101
109 vtkSetMacro(Timeout, double);
110 vtkGetMacro(Timeout, double);
112
116 static void SetDefaultTimeout(double);
117
125
130
132
135 wgpu::Adapter GetAdapter();
136 wgpu::Device GetDevice();
137 wgpu::Instance GetInstance();
139
157
163 void Finalize();
164
173
180 static std::size_t Align(std::size_t value, std::size_t alignment);
181
182 enum
183 {
184 AdapterRequestCompletedEvent = vtkCommand::UserEvent,
186 };
187
191 std::string ReportCapabilities();
192 static std::string DeviceNotReadyMessage();
193
200 std::uint32_t GetAdapterVendorID();
201 std::uint32_t GetAdapterDeviceID();
202
204
222
224
229 wgpu::Buffer CreateBuffer(unsigned long sizeBytes, wgpu::BufferUsage usage,
230 bool mappedAtCreation = false, const char* label = nullptr);
231 wgpu::Buffer CreateBuffer(const wgpu::BufferDescriptor& bufferDescriptor);
233
238 void WriteBuffer(const wgpu::Buffer& buffer, unsigned long offset, const void* data,
239 unsigned long sizeBytes, const char* description = nullptr);
240
242
245 wgpu::Texture CreateTexture(wgpu::Extent3D extents, wgpu::TextureDimension dimension,
246 wgpu::TextureFormat format, wgpu::TextureUsage usage, int mipLevelCount = 1,
247 const char* label = nullptr);
248 wgpu::Texture CreateTexture(const wgpu::TextureDescriptor& textureDescriptor);
250
254 wgpu::TextureView CreateView(wgpu::Texture texture, wgpu::TextureViewDimension dimension,
255 wgpu::TextureAspect aspect, wgpu::TextureFormat format, int baseMipLevel, int mipLevelCount,
256 const char* label = nullptr);
257 wgpu::TextureView CreateView(
258 wgpu::Texture texture, const wgpu::TextureViewDescriptor& viewDescriptor);
259
264 void WriteTexture(wgpu::Texture texture, uint32_t bytesPerRow, uint32_t byteSize,
265 const void* data, const char* description = nullptr);
266
268
282
290
291protected:
294
295 PowerPreferenceType PowerPreference = PowerPreferenceType::HighPerformance;
296 // Initialized in constructor at runtime based on the operating system.
298 // In milliseconds
299 double Timeout;
300
302
303private:
305 void operator=(const vtkWebGPUConfiguration&) = delete;
306
308 std::unique_ptr<vtkWebGPUConfigurationInternals> Internals;
309};
310
311VTK_ABI_NAMESPACE_END
312
313#endif
a simple class to control print indentation
Definition vtkIndent.h:108
@ VERBOSITY_INVALID
Definition vtkLogger.h:214
abstract base class for most VTK objects
Definition vtkObject.h:162
A compute pipeline is the orchestrator of a collection of compute passes.
Create a webgpu device for use in rendering and compute pipelines.
vtkGetEnumMacro(PowerPreference, PowerPreferenceType)
Set/Get the power preference of the graphics adapter.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
bool IsMicrosoftGPUInUse()
Checks whether a particular vendor's GPU is in use.
wgpu::TextureView CreateView(wgpu::Texture texture, const wgpu::TextureViewDescriptor &viewDescriptor)
wgpu::Device GetDevice()
Get handles of the WGPU adapter/device/instance.
vtkLogger::Verbosity GetGPUMemoryLogVerbosity()
Set/Get the log verbosity of messages that are emitted when data is uploaded to GPU memory.
bool IsBroadcomGPUInUse()
Checks whether a particular vendor's GPU is in use.
wgpu::Texture CreateTexture(wgpu::Extent3D extents, wgpu::TextureDimension dimension, wgpu::TextureFormat format, wgpu::TextureUsage usage, int mipLevelCount=1, const char *label=nullptr)
Creates a WebGPU texture with the given device and returns it.
PowerPreferenceType
These enums have a one-one correspondence with the webgpu enums.
BackendType GetBackendInUse()
Get the backend in use.
vtkGetEnumMacro(Backend, BackendType)
Set/Get the graphics backend to use from the graphics adapter.
std::uint32_t GetAdapterDeviceID()
static std::size_t Align(std::size_t value, std::size_t alignment)
Adjusts a given value to the nearest multiple of the specified alignment.
~vtkWebGPUConfiguration() override
wgpu::Buffer CreateBuffer(const wgpu::BufferDescriptor &bufferDescriptor)
Convenient methods used to create webgpu buffers.
wgpu::Buffer CreateBuffer(unsigned long sizeBytes, wgpu::BufferUsage usage, bool mappedAtCreation=false, const char *label=nullptr)
Convenient methods used to create webgpu buffers.
static vtkWebGPUConfiguration * New()
void WriteBuffer(const wgpu::Buffer &buffer, unsigned long offset, const void *data, unsigned long sizeBytes, const char *description=nullptr)
Convenient method used to write data into an existing buffer.
void SetGPUMemoryLogVerbosity(vtkLogger::Verbosity verbosity)
Set/Get the log verbosity of messages that are emitted when data is uploaded to GPU memory.
static void SetDefaultTimeout(double)
Use this method to customize the default value for Timeout.
bool IsAppleGPUInUse()
Checks whether a particular vendor's GPU is in use.
void WriteTexture(wgpu::Texture texture, uint32_t bytesPerRow, uint32_t byteSize, const void *data, const char *description=nullptr)
Upload byteSize of data from the data pointer to the given texture, assuming bytesPerRow bytes of dat...
vtkSetEnumMacro(Backend, BackendType)
Set/Get the graphics backend to use from the graphics adapter.
std::string ReportCapabilities()
Print information of webgpu adapter and device to the output string.
wgpu::TextureView CreateView(wgpu::Texture texture, wgpu::TextureViewDimension dimension, wgpu::TextureAspect aspect, wgpu::TextureFormat format, int baseMipLevel, int mipLevelCount, const char *label=nullptr)
Creates a texture view of a texture.
wgpu::Texture CreateTexture(const wgpu::TextureDescriptor &textureDescriptor)
Creates a WebGPU texture with the given device and returns it.
bool IsAMDGPUInUse()
Checks whether a particular vendor's GPU is in use.
void DumpMemoryStatistics()
This method prints the information corresponding to all active wgpu::Buffer and wgpu::Texture objects...
void Finalize()
Finalizes the class.
bool IsNVIDIAGPUInUse()
Checks whether a particular vendor's GPU is in use.
vtkSetEnumMacro(PowerPreference, PowerPreferenceType)
Set/Get the power preference of the graphics adapter.
void ProcessEvents()
Process events on the WGPUInstance.
bool IsIntelGPUInUse()
Checks whether a particular vendor's GPU is in use.
bool IsARMGPUInUse()
Checks whether a particular vendor's GPU is in use.
std::uint32_t GetAdapterVendorID()
Get the PCI vendor ID of the adapter and the system PCI ID of the device.
bool IsMesaGPUInUse()
Checks whether a particular vendor's GPU is in use.
bool IsSamsungGPUInUse()
Checks whether a particular vendor's GPU is in use.
static std::string DeviceNotReadyMessage()
std::string GetBackendInUseAsString()
Convenient function returns a string representation of the currently used backend.
wgpu::Instance GetInstance()
Get handles of the WGPU adapter/device/instance.
bool Initialize()
Initializes the class.
wgpu::Adapter GetAdapter()
Get handles of the WGPU adapter/device/instance.
WebGPU rendering window.
#define VTK_MARSHALAUTO