This node contains a VOP network (double-click the node in the network editor to go inside it), which can use CHOP context VOPs to manipulate channel data.
Note
To define a CHOP using a (textual) VEX program instead of a VOP network, use the
Channel Wrangle instead.
Note
If you create a Transform VOP node using the Tab menu, it creates a Channel VOP and sets it to work with transform channels and constraints.
This node is useful for creating "one-off" programs to manipulate channel data in a single network.
Parameters
Compiler
Channel Names
Space separated names of the channels to create when the first input isn’t connected. Supports the same patterns as the Scope parameter.
Channel Count
Repeats the Channel Names multiple times when the first input isn’t connected.
Iterate
How to iterate over channels and samples.
Over Channels and Samples
Iterates over all the samples of a channel one channel at a time.
Use the V
global variable to read and write the current channel value.
Over Samples and Channels
Iterates over channels one sample at a time.
Use the V
global variable to read and write the current channel value.
Over Samples and Every Nth Channels
Iterates over channels one sample at a time, but you can evaluate a group of channels together.
Use the Iterate Step to define the size a channel group.
Use the Iterate Names with a @
prefix to read and write the current values.
Over Samples and Every Translate/Rotate/Scale
Iterates over transform channels one sample at a time.
Access the translation vector using @t
, the rotation using @r
and the scale using @s
.
A struct chopConstraintContext
is also bound to the c
variable.
Use c->fetchInput(1)
to return the second input transform as a struct chopTRS
.
Use c->fetchInputMatrix(1)
to return the second input transform as a matrix.
Over Clip
Runs the snippet a single time with C
and I
variables set to zero.
Use this to if you want to analyze all the channels using a snippet.
You can’t write to the global variable V
or to any channel data.
You can read and write clip attributes using chattr
and chsetattr
.
Over Channels
Runs the snippet one time per channel with the I
variable set to zero.
Use this to if you want to analyze channels individually using a snippet.
You can’t write to the global variable V
or to any channel data.
You can read and write channel attributes using chattr
and chsetattr
.
Over Sample
Runs the snippet one time per sample with the C
variable always set to zero.
Use this to if you want to analyze the all channel values for a single sample using a snippet.
You can’t write to the global variable V
or to any channel data.
You can read and write sample attributes using chattr
and chsetattr
.
Iterate Step
Sets the number of channels to regroup together when Iterate is set to Every Nth Channels.
Iterate Names
A space separated string representing the bind names when Iterate is set to Every Nth Channels.
Use an iterate name prefixed by @
to read and write to a channel.
Compiler
The command line Houdini uses to compile the VOP network inside this node.
Force Compile
Recompiles the VOP network inside this node.
Evaluation Node Path
VEX functions like ch()
usually evaluate with respect to this node.
Enter a node path here to override where the path search starts from.
This is useful for embedding in a digital asset, where you want searches
to start from the asset root.
Channel
Align
The alignment option to use.
Extend to Min/Max
Find the earliest start and latest end, and extend all inputs to that range using the extend conditions.
Stretch to Min/Max
Find the earliest start and latest end, and stretch every channel’s start and end to that range.
Shift to Minimum
Find the earliest start and shift all channels so they all start at that index. All channels are extended to the length of the longest one.
Shift to Maximum
Find the latest end and shift all channels so they all end at that index. Extend all channels to the length of the longest one.
Shift to First Interval
Shift all channels to the start of the first channel and sample all inputs using the first input’s range.
Trim to First Interval
Trim all channels to first channel’s range.
Stretch to First Interval
Stretch all channels to the first channel’s range.
Trim to Smallest Interval
Trim all channels to the smallest start/end interval. The start and end values may not come from the same channel.
Stretch to Smallest Interval
Stretch all channels to the smallest start/end interval. The start and end values may not come from the same channel.
Range
Specifies the range of data to generate.
Use Full Animation Range
All of the animated range.
Use Current Frame
Only the sample at the current frame.
Use Start/End
The range is specified from the Start and End parameters.
Use Value Animation
The range is taken from range of keys available in the evaluated Value parameters.
Start
The start time of the channel range.
End
The end time of the channel range.
Sample Rate
The sample rate of the CHOP.
Number of Threads
The number of separate threads to use to evaluate the channel samples. The default is no threading.
Since Houdini evaluates the VEX program for each sample in the input geometry, it can benefit greatly from threading on a multi-processor or multi-core machine when the CHOP nodes have many samples.
Common
Some of these parameters may not be available on all CHOP nodes.
Scope
To determine which channels get affected, some CHOPs have a scope string. Patterns can be used in the scope, for example *
(match all), and ?
(match single character).
The following are examples of possible channel name matching options:
chan2
Matches a single channel name.
chan3 tx ty tz
Matches four channel names, separated by spaces.
chan*
Matches each channel that starts with chan
.
*foot*
Matches each channel that has foot
in it.
t?
The ?
matches a single character. t?
matches two-character channels starting with t.
r[xyz]
Matches channels rx
, ry
and rz
.
blend[3-7:2]
Matches number ranges giving blend3
, blend5
, and blend7
.
blend[2-3,5,13]
Matches channels blend2
, blend3
, blend5
, blend13
.
t[xyz]
[xyz]
matches three characters, giving channels tx
, ty
and tz
.
Sample Rate Match
The Sample Rate Match Options handle cases where multiple input CHOPs’ sample rates are different.
Resample At First Input’s Rate
Use rate of first input to resample others.
Resample At Maximum Rate
Resample to highest sample rate.
Resample At Minimum Rate
Resample to the lowest sample rate.
Error if Rates Differ
Does not accept conflicting sample rates.
Units
The units for which time parameters are specified.
For example, you can specify the amount of time a lag should last for in seconds (default), frames (at the Houdini FPS), or samples (in the CHOP’s sample rate).
Note
When you change the Units parameter, it does not convert the existing parameters to the new units.
Time Slice
Time Slicing is a feature which boosts cooking performance and reduces memory usage. Traditionally, CHOPs calculate the channel over its entire frame range. If the channel does need to be evaluated every frame, then cooking the entire range of the channel is unnecessary. It is more efficient to calculate only the fraction of the channel that is needed. This fraction is known as a Time Slice.
Unload
Causes the memory consumed by a CHOP to be released after it is cooked and the data passed to the next CHOP.
Export Prefix
The Export prefix is prepended to CHOP channel names to determine where to export to.
For example, if the CHOP channel was named geo1:tx
, and the prefix was /obj
, the channel would be exported to /obj/geo1/tx
.
Note
You can leave the Export Prefix blank, but then your CHOP track names need to be absolute paths, such as obj:geo1:tx
.
Graph Color
Every CHOP has this option. Each CHOP gets a default color assigned for display in the Graph port, but you can override the color in the Common page under Graph Color. There are 36 RGB color combinations in the Palette.
Graph Color Step
When the graph displays the animation curves and a CHOP has two or more channels, this defines the difference in color from one channel to the next, giving a rainbow spectrum of colors.
See also |