Experimental:Topology POP
Summary
The Topology POP gives finer control on how to combine existing points and topology (vertices and primitives), as well as their memory allocation.
Any unsigned int attribute from the input POP or another POP, interpreted as a list of point indices, can be used to describe the topology of the POP, alongside a manual description of the number of primitives (Topology Info), either using the parameters when the number of primitives of each type are known on the CPU, or using values coming from attributes, when the number of primitives of each type are only known on the GPU. This allows to combine multiple buffers created with GLSL and GLSL Advanced POP to describe geometry for example.
Alternatively the Topology and Topology info can be provided from another POP. Primitives and Vertices attributes can also be merged in from other POPs.
Last but not least, for POPs whose numbers of points and primitives are known on the GPU, the maximum numbers can be updated here, if the user knows them to be smaller, to reduce the memory allocation of downstream POPs. Alternatively if the exact counts are known they can also be entered manually and the POP updated to know that its point count info and topology info are now known on the CPU, without incurring the cost and stall of a download. (Refer to Learning about POPs, Information known on CPU/GPU)
Parameters - Topology Page
render
-
maxpointsmode
- ⊞ -
- From Input
input
-
- Custom
custom
-
maxpoints
-
primsourcemode
- ⊞ -
- Input
input
-
- Specify POP
specpop
-
primmode
- ⊞ -
- Source Topology and Topology Info
topo
-
- Source Attribute and Manual Topology Info
attr
-
primspop
-
pointindexattrclass
- ⊞ -
- Point
point
-
- Vertex
vertex
-
- Primitive
primitive
-
pointindexattrname
-
vertattrmode
- ⊞ -
- None
none
-
- Primitive Source
primsource
-
- Specify POP
specpop
-
vertattrpop
-
vertattrclass
- ⊞ -
- Point
point
-
- Vertex
vertex
-
- Primitive
primitive
-
primattrmode
- ⊞ -
- None
none
-
- Primitive Source
primsource
-
- Specify POP
specpop
-
primattrpop
-
primattrclass
- ⊞ -
- Point
point
-
- Vertex
vertex
-
- Primitive
primitive
-
topology
- ⊞ -
- Source Topology Reference
ref
-
- Source Topology Copy
copy
-
maxtrianglesmode
- ⊞ -
- Primitive Source
primsource
-
- Custom
custom
-
maxtriangles
-
maxquadsmode
- ⊞ -
- Primitive Source
primsource
-
- Custom
custom
-
maxquads
-
maxlinestripsmode
- ⊞ -
- Primitive Source
primsource
-
- Custom
custom
-
maxlinestrips
-
maxlsvertsmode
- ⊞ -
- Primitive Source
primsource
-
- Custom
custom
-
maxlsverts
-
maxlinesmode
- ⊞ -
- Primitive Source
primsource
-
- Custom
custom
-
maxlines
-
maxpointprimsmode
- ⊞ -
- Primitive Source
primsource
-
- Custom
custom
-
maxpointprims
-
lsinfofromprimsource
-
lsinfoupdate
- ⊞ -
- Auto
auto
-
- Manual
manual
-
lsinfopop
-
lsinfoclass
- ⊞ -
- Point
point
-
- Vertex
vertex
-
- Primitive
primitive
-
lsinfoattr
-
lsindexpop
-
lsindexclass
- ⊞ -
- Point
point
-
- Vertex
vertex
-
- Primitive
primitive
-
lsindexattr
-
lsmaxvertsoverride
-
lsmaxverts
-
pointcounttopoinfo
- ⊞ -
- From Input
input
-
- From Primitive Source
primsource
-
- From Parameters
fromparams
-
- From Attributes
fromattrs
-
pointcountmode
- ⊞ -
- From Input
input
-
- Set
set
-
pointcountpop
-
pointcountclass
- ⊞ -
- Point
point
-
- Vertex
vertex
-
- Primitive
primitive
-
pointcountattr
-
topoinfopop
-
topoinfoclass
- ⊞ -
- Point
point
-
- Vertex
vertex
-
- Primitive
primitive
-
trianglecountmode
- ⊞ -
- Primitive Source
primsource
-
- Zero
zero
-
- Set
set
-
trianglecountattr
-
quadcountmode
- ⊞ -
- Primitive Source
primsource
-
- Zero
zero
-
- Set
set
-
quadcountattr
-
linestripcountmode
- ⊞ -
- Primitive Source
primsource
-
- Zero
zero
-
- Set
set
-
linestripcountattr
-
lsvertcountmode
- ⊞ -
- Primitive Source
primsource
-
- Zero
zero
-
- Set
set
-
lsvertcountattr
-
linecountmode
- ⊞ -
- Primitive Source
primsource
-
- Zero
zero
-
- Set
set
-
linecountattr
-
pointprimcountmode
- ⊞ -
- Primitive Source
primsource
-
- Zero
zero
-
- Set
set
-
pointprimcountattr
-
Parameters - Common Page
bypass
-
delinputattrs
-
Operator Inputs
- Input 0: -
Info CHOP Channels
Extra Information for the Topology POP can be accessed via an Info CHOP.
Common POP Info Channels
Common Operator Info Channels
- total_cooks - Number of times the operator has cooked since the process started.
- cook_time - Duration of the last cook in milliseconds.
- cook_frame - Frame number when this operator was last cooked relative to the component timeline.
- cook_abs_frame - Frame number when this operator was last cooked relative to the absolute time.
- cook_start_time - Time in milliseconds at which the operator started cooking in the frame it was cooked.
- cook_end_time - Time in milliseconds at which the operator finished cooking in the frame it was cooked.
- cooked_this_frame - 1 if operator was cooked this frame.
- warnings - Number of warnings in this operator if any.
- errors - Number of errors in this operator if any.
TouchDesigner Build: