Looking to move from deferred to a vis-buffer approach w/ compute and indirect-draw/dispatch, I have a multi-user many views on one machine situation (7-8 before surplus shadowmaps) that looks like it'd benefit from multiview culling like Engel (http://diaryofagraphicsprogrammer.blogspot.com/2018/03/triangle-visibility-buffer.html) and other general GPU culling. I'm not quite grokking coping with IDs in a more general pipeline vs the trivial one in Engel which is pre-transformed soup, what I've got is basically an X-COM tile map of mesh instances whose tiles (or whole spans of tiles) are frequently swapped out.
If it's just straight drawing these generated index buffers, that's no big deal. If programmable pulling on SV_VertexID then cluster is implicit from the pulled indices if max-triangles-per-cluster aligned so there's no need to pass that then. I've seen other approaches that record the triangle index relative to the cluster and then use 24-bits for cluster, which is again ... everything is there and pretransformed into world-space in those.
I'm thinking I have to suck it up and swallow an R32G32 target for the visibility buffer to hold the instance and triangle-index then pull transform/material/base-offset info by instance ID.
If I had to I could do massive a buffer for the world geom of pre-transformed geometry and add some bitfields like in DOOM:Eternal to discard triangles to make the destruction work (be a headache, but I can make that work) or just deallocate the old clusters and pump some new ones in wherever there's a big enough span, then a bit in the framebuffer to denote “nah, dude, that's in the animated meshes output buffers, it's something else sourced elsewhere”, but - is a great big giant pretransformed set of clusters actually a win? Do instances just become a CPU side thing taking responsibility for their allocated clusters and dispatch to do whatever they need to in order to change GPU data to reflect state?
---
I guess what I'm really asking, is vaguely, what do these pipelines look like in real world usage? I'm not asking how to compact some draw-args or build a fragment list for material dispatch. I'm asking how you get a "hey, meshlet cluster here, you're 700 degrees Celsius right now, do your glowing shader thingy" instance param through the pipe and used by the right triangle/fragment at shade and not bungle everybody else using the same geometry?