Mapping-Diagramm für DirectX / OpenGL (Vulkan) -Konzepte

32

Häufig wird eine ähnliche Hardwarefunktion über DirectX und OpenGL mit unterschiedlichen Begriffen bereitgestellt.

Zum Beispiel:
Konstanter Puffer / Einheitliches
Pufferobjekt RWBuffer / SSBO

Ich suche nach einer vollständigen Tabelle, die beschreibt, welche DirectX-Terminologie verwendet wird, um auf welches OpenGL-Konzept zu verweisen, und umgekehrt.
Wo finde ich eine solche Ressource?

wischen
quelle
Kommentare sind nicht für längere Diskussionen gedacht. Diese Unterhaltung wurde in den Chat verschoben .
Trichoplax

Antworten:

55

Ich konnte eine solche Karte nicht im Web finden, also habe ich hier eine gemacht. (Jeder kann Fehler hinzufügen, ausarbeiten oder korrigieren. Einige davon sind nur die besten Vermutungen, die auf einem teilweisen Verständnis der API und der Hardware-Interna beruhen.)

API-Grundlagen

D3D11                          OpenGL 4.x
-----                          ----------
device                         context
immediate context              (implicit; no specific name)
deferred context               (no cross-vendor equivalent, but see
                                GL_NV_command_list)
swap chain                     (implicit; no specific name)
(no cross-vendor equivalent)   extensions
debug layer; info queue        GL_KHR_debug extension

Shader

D3D11              OpenGL 4.x
-----              ----------
pixel shader       fragment shader
hull shader        tessellation control shader
domain shader      tessellation evaluation shader
(vertex shader, geometry shader, and compute shader
 are called the same in both)

registers          binding points
semantics          interface layouts
SV_Foo semantics   gl_Foo builtin variables

class linkage      subroutines

(no equivalent)    program objects; program linking

(D3D11's normal
 behavior; no      separate shader objects
 specific name)

Geometrie und Zeichnung

D3D11              OpenGL 4.x
-----              ----------
vertex buffer      vertex attribute array buffer; vertex buffer object
index buffer       element array buffer
input layout       vertex array object (sort of)

Draw               glDrawArrays
DrawIndexed        glDrawElements
(instancing and indirect draw are called similarly in both)
(no equivalent)    multi-draw, e.g. glMultiDrawElements​

stream-out         transform feedback
DrawAuto           glDrawTransformFeedback​

predication        conditional rendering
(no equivalent)    sync objects

Puffer und Texturen

D3D11                    OpenGL 4.x
-----                    ----------
constant buffer          uniform buffer object
typed buffer             texture buffer
structured buffer        (no specific name; subset of SSBO features)
UAV buffer; RWBuffer     SSBO (shader storage buffer object)
UAV texture; RWTexture   image load/store

shader resource view     texture view
sampler state            sampler object

interlocked operations   atomic operations
append/consume buffer    SSBO + atomic counter

discard buffer/texture   invalidate buffer/texture
(no equivalent)          persistent mapping
(D3D11's normal
 behavior; no            immutable storage
 specific name)
(implicitly inserted     glMemoryBarrier; glTextureBarrier
 by the API)

Rendern von Zielen

D3D11                     OpenGL 4.x
-----                     ----------
(no equivalent)           framebuffer object
render target view        framebuffer color attachment
depth-stencil view        framebuffer depth-stencil attachment
multisample resolve       blit multisampled buffer to non-multisampled one

multiple render targets   multiple color attachments
render target array       layered image

(no equivalent)           renderbuffer

Abfragen

D3D11                       OpenGL 4.x
-----                       ----------
timestamp query             timer query
timestamp-disjoint query    (no equivalent)
(no equivalent)             time-elapsed query
occlusion query             samples-passed query
occlusion predicate query   any-samples-passed query
pipeline statistics query   (no equivalent in core, but see
                             GL_ARB_pipeline_statistics_query)
SO statistics query         primitives-generated/-written queries 
(no equivalent)             query buffer object

Shader berechnen

D3D11                     OpenGL 4.x
-----                     ----------
thread                    invocation
thread group              work group
thread group size         local size
threadgroup variable      shared variable

group sync                "plain" barrier
group memory barrier      shared memory barrier
device memory barrier     atomic+buffer+image memory barriers
all memory barrier        group memory barrier

Andere Ressourcen

Nathan Reed
quelle
3
Wow. Sie stellen wahrscheinlich die härtesten Köpfe der Welt ein, um die verschiedensten Namen für dieselben Dinge zu erfinden.
Narthex
Das Diagramm ist großartig, danke, dass Sie sich die Zeit genommen haben, es aufzuschreiben!
Wip
3
" texture array - layered image " OpenGL nennt sie auch Array Textures; Der Begriff "geschichtetes Bild" wird hauptsächlich um ihre Anhänge in FBOs verwendet. Außerdem sollten Sie wahrscheinlich OpenGL-Sampler-Objekte und ihren D3D-äquivalenten Sampler-Status erwähnen.
Nicol Bolas
2
@ CpCd0y Ja, sie werden umgangssprachlich so genannt, aber ich wollte hier sagen, wie diese Dinge heißen / wie sie in API-ese dargestellt werden.
Nathan Reed
1
@ NathanReed: MRT wird in der OpenGL-Spezifikation nicht verwendet, aber "Okklusionsabfrage" ist sehr viel. Der Ausdruck "Proben bestanden" ist lediglich eine Art von Okklusionsabfrage; Es gibt auch "alle Proben bestanden" und "konservativ alle Proben bestanden".
Nicol Bolas
28

Hier ist eine nicht vollständige Liste von Vulkan und DirectX 12. Diese sind nach ähnlichen Kriterien wie Nathans zusammengestellt.

Insgesamt sind beide APIs überraschend ähnlich. Dinge wie Shader-Stufen bleiben gegenüber DX11 und OpenGL unverändert. Und natürlich verwendet DirectX Ansichten, um Dinge für Shader sichtbar zu machen. Vulkan verwendet auch Ansichten, aber sie sind weniger häufig.

Das Verhalten der Shader-Sichtbarkeit unterscheidet sich etwas zwischen den beiden. Vulkan verwendet eine Maske, um festzustellen, ob ein Deskriptor für die verschiedenen Shader-Stufen sichtbar ist. DX12 geht damit etwas anders um, die Sichtbarkeit der Ressourcen erfolgt entweder einstufig oder über alle Stufen.

Ich habe das Deskriptor-Set / Root-Parameter-Zeug nach besten Kräften heruntergebrochen. Die Behandlung von Deskriptoren ist einer der Bereiche, die zwischen den beiden APIs sehr unterschiedlich sind. Das Endergebnis ist jedoch ziemlich ähnlich.

API-Grundlagen

Vulkan                              DirectX 12
---------------                     ---------------
n/a                                 IDXGIFactory4
VkInstance                          n/a
VkPhysicalDevice                    IDXGIAdapter1
VkDevice                            ID3D12Device
VkQueue                             ID3D12CommandQueue
VkSwapchain                         IDXGISwapChain3
VkFormat                            DXGI_FORMAT
SPIR-V                              D3D12_SHADER_BYTECODE
VkFence                             fences
VkSemaphore                         n/a
VkEvent                             n/a

Vulkans WSI-Schicht liefert Bilder für die Swap-Kette. Für DX12 sind Erstellungsressourcen erforderlich, um das Image darzustellen.

Das allgemeine Warteschlangenverhalten ist zwischen beiden ziemlich ähnlich. Es ist etwas eigenwillig, wenn Sie von mehreren Threads aus übermitteln.

Ich werde versuchen zu aktualisieren, wenn ich mich an mehr Dinge erinnere ...

Befehlspuffer und Pool

Vulkan                              DirectX 12
---------------                     ---------------
VkCommandPool                       ID3D12CommandAllocator
VkCommandBuffer                     ID3D12CommandList/ID3D12GraphicsCommandList

Die in Vulkan / DX12-Dokumenten enthaltenen Informationen zu Befehlspool / Allokator beschreiben das Verhalten in sehr unterschiedlichen Worten - das tatsächliche Verhalten ist jedoch ziemlich ähnlich. Den Benutzern steht es frei, viele Befehlspuffer / -listen aus dem Pool zuzuweisen. Es kann jedoch nur ein Befehlspuffer / eine Befehlsliste aus dem Pool aufgezeichnet werden. Pools können nicht zwischen Threads geteilt werden. Daher erfordern mehrere Threads mehrere Pools. Sie können die Aufzeichnung auch sofort nach dem Senden des Befehlspuffers / der Befehlsliste auf beiden starten.

DX12-Befehlslisten werden in geöffnetem Zustand erstellt. Ich finde das etwas nervig, da ich an Vulkan gewöhnt bin. DX12 erfordert auch ein explizites Zurücksetzen des Befehlszuordners und der Befehlsliste. Dies ist ein optionales Verhalten in Vulkan.

Deskriptoren

Vulkan                              DirectX 12
---------------                     ---------------
VkDescriptorPool                    n/a
VkDescriptorSet                     n/a
VkDescriptorSetLayout               n/a
VkDescriptorSetLayoutBinding        RootParameter**
n/a                                 ID3D12DescriptorHeap

** RootParameter - kein genaues Äquivalent zu VkDescriptorSetLayoutBinding, aber im Großen und Ganzen ähnliches Denken.

VkDescriptorPool und ID3D12DescriptorHeaps sind ähnlich (danke Nicolas), da sie beide die Zuordnung der Deskriptoren selbst verwalten.

Es ist zu beachten, dass DX12 maximal zwei Deskriptor-Heaps unterstützt, die zu einem bestimmten Zeitpunkt an eine Befehlsliste gebunden sind. Ein CBVSRVUAV und ein Sampler. Sie können so viele Deskriptortabellen haben, wie Sie möchten, um auf diese Heaps zu verweisen.

Auf der vulkanischen Seite gibt es eine feste Grenze für die maximale Anzahl von Deskriptorsätzen, die Sie dem Deskriptorpool mitteilen. In beiden Fällen müssen Sie die Anzahl der Deskriptoren pro Typ, die der Pool / Heap haben kann, manuell abrechnen. Vulkan ist auch expliziter mit der Art der Deskriptoren. Während auf DX12 Deskriptoren entweder CBVSRVUAV oder Sampler sind.

DX12 verfügt auch über eine Funktion, mit der Sie eine CBV mithilfe von SetGraphicsRootConstantBufferView direkt binden können. Die SRV-Version von SetGraphicsRootShaderResourceView funktioniert jedoch nicht für Texturen. Es steht in der Dokumentation - aber es kann auch ein paar Stunden dauern, bis Sie dies herausgefunden haben, wenn Sie kein sorgfältiger Leser sind.

Pipeline

Vulkan                              DirectX 12
---------------                     ---------------
VkPipelineLayout                    RootSignature***
VkPipeline                          ID3D12PipelineState
VkVertexInputAttributeDescription   D3D12_INPUT_ELEMENT_DESC
VkVertexInputBindingDescription     "

* ** RootSignature - entspricht nicht exakt VkPipelineLayout .

DX12 kombiniert das Vertex-Attribut und die Bindung in einer einzigen Beschreibung.

Bilder und Puffer

Vulkan                              DirectX 12
---------------                     ---------------
VkImage                             ID3D12Resource
VkBuffer                            ID3D12Resource
uniform buffer                      constant buffer
index buffer                        index buffer
vertex buffer                       vertex buffer
VkSampler                           sampler
barriers/transitions                barriers/transitions

Die Barrieren auf beiden APIs sind etwas unterschiedlich, haben jedoch ein ähnliches Nettoergebnis.

RenderPasses / RenderTargets

Vulkan                              DirectX 12
---------------                     ---------------
VkRenderPass                        render pass
VkFramebuffer                       collection of ID3D12Resource
subpass                             n/a
n/a                                 render target

Vulkan-Renderpässe haben eine nette Funktion zur automatischen Auflösung. DX12 hat diesen AFIAK nicht. Beide APIs bieten Funktionen für die manuelle Lösung.

Es gibt keine direkte Entsprechung zwischen VkFramebuffer und Objekten in DX12. Eine Sammlung von ID3D12Resource, die RTVs zugeordnet sind, weist eine lose Ähnlichkeit auf.

VkFramebuffer verhält sich mehr oder weniger wie ein Anhangspool, auf den VkRenderPass mithilfe eines Index verweist. Subpässe in einem VkRenderPass können auf alle Anhänge in einem VkFramebuffer verweisen, vorausgesetzt, auf denselben Anhang wird nicht mehr als einmal pro Subpass verwiesen. Die maximale Anzahl der gleichzeitig verwendeten Farbanhänge ist auf VkPhysicalDeviceLimits.maxColorAttachments beschränkt.

Die Renderziele von DX12 sind nur RTVs, die von einem ID3D12Resource-Objekt unterstützt werden. Die maximale Anzahl der gleichzeitig verwendeten Farbanhänge ist auf D3D12_SIMULTANEOUS_RENDER_TARGET_COUNT (8) begrenzt.

Bei beiden APIs müssen Sie die Renderziele / -durchläufe bei der Erstellung der Pipelineobjekte angeben. In Vulkan können Sie jedoch kompatible Renderpässe verwenden, sodass Sie nicht an die gebunden sind, die Sie bei der Erstellung der Pipeline angegeben haben. Ich habe es nicht auf DX12 getestet, aber ich würde raten, da es nur ein RTV ist, gilt dies auch für DX12.

Codingforlove
quelle
Schön, das ist großartige Arbeit!
Wip
Ich denke , es wäre fair zu sagen , dass VkDescriptorPoolund ID3D12DescriptorHeapist ähnlich in der Funktion (in , dass sie , wie Sie Deskriptoren zuzuteilen), aber ganz anders in der Form, aufgrund der Unterschiede in den Gesamt Weise Deskriptoren zwischen dem APIs behandelt. Außerdem stelle ich mir vor, dass das D3D12-Äquivalent zu VkBufferViewPuffern getippt ist, genau wie für D3D11.
Nicol Bolas
Du bist direkt auf dem Deskriptorhaufen. Aktualisiert. In Bezug auf die Pufferansichten haben beide APIs ein Ansichtskonzept. Ich konnte nicht sagen, ob DX12 von der DX1-Konvention für getippte Puffer abweicht oder nicht, da ich nicht viel Erfahrung mit DX11 habe.
Codingforlove
Könnten Sie sagen, dass D3D12-Renderziele VkFramebuffer entsprechen?
Jorge Rodriguez
2
Inspiriert von diesem Thema habe ich Implementierungen für einzelne Header von Vulkan- und DX12-Renderern geschrieben: renderers: github.com/chaoticbob/tinyrenderers
codingforlove