Point File In POP
Summary[edit]
The Point File In POP loads 3D point data into POPs from either a single file or a sequence of files. The Point File In POP will load all available point data after you select field names and give them attribute names. Fields include standard ones like XYZ position, normal vectors, texture coordinates and RGBA color. More specialized fields are read in via any number of sequential blocks that map fields to attributes.
By default, field x, y and z are placed into the P attribute, and r g b a into the Color attribute, but that can be all re-assigned. The sequential blocks can create float, float2, float3 and float4 attributes, as well as arrays of values (no matrices or double at the moment).
The Thin page lets you skip points in the file, either randomly or in patterns. The ReRange page lets you scale/offset attribute values without having to create a temporary version of an attribute.
The Point File In POP will read point data from various mesh and floating point data files including: .obj, .ply, .fits (astronomy format), and .exr. It can also load ASCII point files (.xyz, .pts, .csv, .txt, etc) with one point per line and comma- or space-separated fields. The first line in ASCII point files can either be the number of points, the names of the point fields or the first point in the file.
For a complete list, see File Types. The OpenEXR file format is generally best to use as it is binary, can be read in multi-frame file sequences that uses TouchDesigner's movie file pre-reading and buffering, and can be written from TouchDesigner's Movie File Out TOP with unlimited numbers of channels.
Gaussian Splat files: The Point File In POP can read in all the specialized attributes of Gaussian Splat files. Give there are over 45 components of attributes, there is an example file in POPs Examples / GaussianSplats/ with a full setup, and there is an example in Help -> Browse Samples : PointClouds/
(TBD: Examine the state of a Point File In POP by attaching an Info CHOP. This will show information like the number of points, fields per point and the number of frames. It also shows dynamic information like the file open status, current frame, readahead frames and queue size, dropped frame count, CPU decode time and GPU upload time.)
Headers: If the file contains any additional header data, this can be viewed by attaching an Info DAT. Header data is stored as key-value pairs with the keys in the first column and the corresponding data in the second column, which can easily be interpreted with python.
All of the ASCII point list formats are loaded the same way whether their extension is txt, csv, xyz, etc. The parser looks for the first separating character (comma, space or tab) and then uses that to delimit the rest of the file. It will ignore delimiters that are inside single or double quotes. There are a few special rules depending on the delimiter style e.g. multiple spaces are merged together, but a comma at the end of a line indicates a blank field afterwards. Once a delimiter is established, The first line can be the number of points, but it is ignored. If the next line are strings then it is treated as a row of headers (channel names). Each row after that is considered the attributes of point.
Parameters - Point File In Page
file - The path and name of the point file to load.
reload - ⊞ - Re-import and load the geometry.
- Reload
reload-
- Reload Pulse
reloadpulse- Force reload.
createpointprim - Enable creating point primitives
maxpointsenable - Enable the setting of the max number of points.
maxpoints - Sets the max number of points when the automatic max number of points is overriden.
positionfields - ⊞ - Fields mapped to the position.
- x
x-
- y
y-
- z
z-
- nx
nx-
- ny
ny-
- nz
nz-
- r
r-
- g
g-
- b
b-
- a
a-
normalfields - ⊞ - Fields for the normal attribute.
- x
x-
- y
y-
- z
z-
- nx
nx-
- ny
ny-
- nz
nz-
- r
r-
- g
g-
- b
b-
- a
a-
texturefields - ⊞ - Fields mapped to the texture coordinates.
- x
x-
- y
y-
- z
z-
- nx
nx-
- ny
ny-
- nz
nz-
- r
r-
- g
g-
- b
b-
- a
a-
colorfields - ⊞ - The fields to use for the color attribute.
- x
x-
- y
y-
- z
z-
- nx
nx-
- ny
ny-
- nz
nz-
- r
r-
- g
g-
- b
b-
- a
a-
attr - Start of Sequential Parameter Blocks for attribute conditions.
attr0fields - ⊞ - Determines fields that can be used to create additional attributes.
- x
x-
- y
y-
- z
z-
- nx
nx-
- ny
ny-
- nz
nz-
- r
r-
- g
g-
- b
b-
- a
a-
attr0name - Name of attribute
attr0isarray - Attribute is an array, for example 5 float3 values is an array of size 5.
attr0arraysize - Nunber of elements in the array.
attr0qualifier - ⊞ - Whether the new attribute is generic attribute or not. Qualifiers are taken into account for some operations.
- None
none-
- Color
color-
- Direction
dir-
inputcolorspace - ⊞ - Override / set the color space, or use the color space in the file, or assume default if there is none.
- Automatic
automatic-
- sRGB
srgb-
- sRGB - Linear
srgblinear-
- Rec.601 (NTSC)
rec601ntsc-
- Rec.709
rec709-
- Rec.2020
rec2020-
- Rec.2020 ST2084PQ
rec2020st2084pq-
- Rec.2020 HLG
rec2020hlg-
- DCI-P3
dcip3-
- DCI-P3 (D60)
dcip3d60-
- Display P3 (D65)
displayp3d65-
- Display P3 (D65) - Linear
displayp3d65linear-
- ACES2065-1
aces2065-1-
- ACEScg
acescg-
- ACESproxy
acesproxy-
- Passthrough
passthrough-
inputreferencewhite - ⊞ - Color space to use for the incoming data.
- Default For Color Space
default-
- Standard (SDR)
sdr-
- High (HDR)
hdr-
- UI
ui-
Parameters - Thin Page
thinoutrange - Enable index-based point filtering.
thinrangestart - Determines the starting index for range-based point filtering.
thinrangelength - Determines the number of points being filtered by index range.
thinstep - Filters every Nth point.
thinrandom - Determines the proportion of points randomly filtered.
thinrandomseed - Sets the random seed for points being randomly filtered.
Parameters - ReRange Page
rerange - Start of Sequential Parameter Blocks to re-range created attributes.
rerange0scope - ⊞ - Rerange any attribute from the file.
- P
P-
- P.i01
P.i01-
- Color
Color-
- Color.rgb
Color.rgb-
- N
N-
rerange0parsize - ⊞ - Number of independent configurable parameter values.
- 1
1-
- 2
2-
- 3
3-
- 4
4-
rerange0fromlow - Reranges the attribute value.
rerange0fromhigh - Reranges the attribute value.
rerange0tolow - Reranges the attribute value.
rerange0tohigh - Reranges the attribute value.
Parameters - Common Page
bypass - Pass through the first input to the output unchanged.
freeextragpumem - Free memory that has accumulated when output memory has grown and shrunk.
delinputattrs - Only output which attributes you specify in this POP - helps isolate attributes into a separate branch.
parmcolorspace - ⊞ - Controls how all color parameters on this node are interpreted. The color values as treated as being in the selected color space, and are converted to the Working Color Space before they are used as part of the node's operation. Note that this does not change the color space of the node itself, as that is always in the Working Color Space.
- sRGB
srgb- sRGB color space, with sRGB transfer function. Considered an SDR color space with respect to Reference White.
- sRGB - Linear
srgblinear- sRGB color space, with linear transfer function. Considered an SDR color space with respect to Reference White.
- Rec.601 (NTSC)
rec601ntsc- Rec.601 with NTSC primaries color space, with Rec.601 transfer function. Considered an SDR color space with respect to Reference White.
- Rec.709
rec709- Rec.709 color space, with Rec.709 (same as Rec.2020) transfer function. Considered an SDR color space with respect to Reference White.
- Rec.2020
rec2020- Rec.2020 color space, with Rec.2020 (same as Rec.709) transfer function. Considered an HDR color space with respect to Reference White.
- DCI-P3
dcip3- DCI-P3 color space, with D65 white point and 2.6 gamma transfer function. Considered an HDR color space with respect to Reference White.
- DCI-P3 (D60)
dcip3d60- DCI-P3 "D60 sim" color space, with D60 white point, and 2.6 gamma transfer function. Considered an HDR color space with respect to Reference White.
- Display-P3 (D65)
displayp3d65- Display-P3 color space, with D65 white point, and sRGB gamma transfer function. Considered an HDR color space with respect to Reference White.
- ACES2065-1
aces2065-1- ACES 2065-1 (also known as ACES AP0) color space, with a linear gamma transfer function. Considered an HDR color space with respect to Reference White.
- ACEScg
acescg- ACEScg (also known as ACES AP1) color space, with a linear gamma transfer function. Considered an HDR color space with respect to Reference White.
- Passthrough
passthrough- When selected, the color values will be used as-is in the operation, without any modification or attempt to convert them into the Working Color Space.
parmreferencewhite - ⊞ - When converting a parameter color value to the Working Color Space, this controls how it should be treated with respect to Reference White. If the Working Color Space is the same Reference White, then no adjustment is done. If they are different, then the Reference White level (brightness) of this color will be adjusted to the range expected by the Working Color Space. For example if the project is set to have a SDR Reference White of 120 nits, and the HDR Reference White is 80 nits, then a color of (1, 1, 1), which is 120 nits in the SDR color space, will be converted to be (1.5, 1.5, 1.5), which is 120 nits still in the HDR Working Color Space.
- Default For Color Space
default- Will use either the SDR or the HDR Reference White, based on the color space selected.
- Use Parent Panel
useparent- Will use the Reference White that the parent panel has selected. If the top-level panel also has 'Use Parent' selected, then 'UI Reference White' will be used.
- Standard (SDR)
sdr- Will treat the Parameter Color Space as SDR for it's reference white value.
- High (HDR)
hdr- Will treat the Parameter Color Space as HDR for it's reference white value.
- UI
ui- Will treat the Parameter Color Space as UI for it's reference white value. This uses the 'UI Reference White Nits' value for it's brightness.
Info CHOP Channels
Extra Information for the Point File In 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:
| POPs |
|---|
| • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • • |