Experimental:Force POP
Summary
The Force POP is used in a Particle POP loop and outputs a float3 attribute named PartForce
that sums a set of forces defined in the Force POP.
The forces include, first on the Global page, a single global force, plus a Wind Speed converted to a wind force.
These forces are by default uniform for all particles, but because it can be affected by attributes on the Map page, each particle (point) can have a different global force or wind speed applied to it.
Currently the conversion of wind speed to wind force is hard-wired in the Force POP, but more detailed control will be provided in a future build.
On the Force (Local) page, you can choose between Radial, Axial, Vortex and Spiral local fore types, with position (Translate), Direction, rolloff (Radius) and Strength controls. The global and local forces are added together.
In one Force POP, the local force is added to the global and wind forces to generate the PartForce
attribute. If the input of the Force POP already exists, then the Force POP's sum of forces is added to the input's PartForce
.
Thus you can string a bunch of Force POPs together and mask each one with a Field POP.
Assuming PartForce
is in the (usually Null) POP at the end of the Particle POP's feedback loop, PartForce
feeds back to the Particle POP where it is used to calculate all particles' velocity and position on the next frame of the simulation.
However you can define multiple local forces in one Force POP: To enable many forces to be included in one Force POP, the parameter called Spec POP is a pointer to, usually, a Point POP, where each point of the Point POP defines a separate local force, where the attribute names are matched to the the parameter names (for example, attribute strength
represents the Strength parameter). In the Point POP you need to create the appropriate matching attributes.
Then the sum of the local forces are added to the global and wind forces to generate the PartForce
attribute.
Note that you can create the PartForce
attribute any way you want - using Noise, Math Mix, Pattern, Lookup, GLSL POPs etc. You don't need the Force POP - it is just a convenience.
See also Particle POP, Field POP.
Parameters - Force Page
specpop
-
globforce
- ⊞ -
- Global Force
globforcex
-
- Global Force
globforcey
-
- Global Force
globforcez
-
globforcemult
-
windforce
- ⊞ -
- Wind Force
windforcex
-
- Wind Force
windforcey
-
- Wind Force
windforcez
-
windforcemult
-
forcetype
- ⊞ -
- Radial
radial
-
- Axial
axial
-
- Vortex
vortex
-
- Spiral
spiral
-
t
- ⊞ -
- Translate
tx
-
- Translate
ty
-
- Translate
tz
-
rad
-
amount
-
direction
- ⊞ -
- Direction
directionx
-
- Direction
directiony
-
- Direction
directionz
-
Parameters - Map Page
map
-
map0op
-
map0element
-
map0parm
- ⊞ -
- globforce (Global Force)
globforce
-
- globforcex
globforcex
-
- globforcey
globforcey
-
- globforcez
globforcez
-
- globforcemult (Global Force Multiplier)
globforcemult
-
- windforce (Wind Force)
windforce
-
- windforcex
windforcex
-
- windforcey
windforcey
-
- windforcez
windforcez
-
- windforcemult (Wind Force Multiplier)
windforcemult
-
map0combineop
- ⊞ -
- Set
set
-
- Multiply
mult
-
- Add
add
-
Parameters - Common Page
bypass
-
delinputattrs
-
Operator Inputs
- Input 0: -
Info CHOP Channels
Extra Information for the Force 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: