Using a Function as a Manipulator

Select Function to specify your own mathematical expressions to be used as a particle manipulator. You can use the channels from the Particle Manipulator and Particle Generator menus in your expressions, as well as arithmetic operations, mathematical conventions, functions, and constants.

(a) Expression field  

The arithmetic operators, conventions, constants, and functions that you can use in your expressions are listed in the following sections. Before writing your own expressions, you should understand the following:

Expression field operators are listed in the following table.

Operator Description
= Equals
+ Addition
- Subtraction
* Multiplication
/ Division
% Percentage
(x,y,z) Vector where x, y, z may also be the results of functions
== Equivalence
!= Not equal to
< Less than
<= Less than or equal to
> Greater than
>= Greater than or equal to

Particle and manipulator variables that you can use in the Expression field are listed in the following table.

Particle Symbol Description
pos Position, a vector (x,y,z).
speed Speed, a vector (x,y,z).
rgba Red, green, blue, and alpha colour channels for each particle, expressed as a 4D vector (r,g,b,a). Each component is a value between 0 and 1.
rgb Red, green, and blue colour channel, expressed as a vector (r,g,b). Each component is a value between 0 and 1.
red Red channel, a value between 0 and 1.
green Green channel, a value between 0 and 1.
blue Blue channel, a value between 0 and 1.
transparency Transparency of each particle (surface or geometry), a value between 0 and 1.
lifetime Lifetime of each particle, in frames.
lifetimeI A value between 1.0 and 0.0 where 1.0 is when a particle is first generated and 0.0 is when it ends.
mass Mass of each particle.
size Size of each particle, in pixels.
tailSize Width of the particle's tail, a value between 0 and 1.

The following variables are read only. You cannot change them in the Expression field, but you can use them in your calculations.

Manipulator Symbol Description
frame Current frame
magnitude Value from the Magnitude field
power Value from the Power field
damping Value from the Damping field
minSpeed Value from the MinSpeed field
maxSpeed Value from the MaxSpeed field

Single argument arithmetic functions are listed in the following table.

One Argument Description
sin(a) Sine of a
cos(a) Cosine of a
tan(a) Tangent of a
asin(a) Arcsine of a
acos(a) Arccosine of a
atan(a) Arctangent of a
exp(x) Exponential function of x
expm1(x) Equivalent to exp(x)-1
log(x) Natural logarithm of x
log10(x) Base 10 logarithm of x
log1p(x) Equivalent to log (1+ x)
sqrt(x) Square root of x
abs(x) Absolute value of x
trunc(x) Integer value of x
floor(x) Smallest integer greater than or equal to x
ceil(x) Largest integer greater than or equal to x
round(x) x rounded to the nearest integer
radians(a) a converted to radians
degrees(r) r converted to degrees
sign(x) Returns +1 or -1 depending on the sign of x
length(p) Euclidean length of point p
noise(v) Noise of vector v, returns a float
fnoise(v) Fractal noise vector v, returns a float
noise3(v) Noise of vector v, returns a vector

Making Particles Transparent

The following example illustrates how to make particles become transparent as they reach the end of their lifetime using the expression transparency = lifetimeI. The settings in the Particle Manipulator menu, Particle Generator menu, and the resulting effect are shown.

Making Particles Spin

The following example illustrates how to spin particles using the expression:

speed = speed + (cos(frame),sin(frame),0)

The settings in the Particle Manipulator menu, Particle Generator menu, and the resulting effect are shown. Notice that the particle Timestep value is increased to improve the accuracy of the particle stream.

Arithmetic functions that have two or more arguments are listed in the following table.

Symbol Description
atan(x,y) Arctangent of y over x
pow(x,y) x to the power of y
mod(x,y) Returns the remainder of dividing x by y
min(x,y) Minimum value of x and y
max(x,y) Maximum value of x and y
step(x,y) Returns 0 if x < y, 1 if x >= y
dot(v1, v2) Dot product of two vectors; returns a scalar
cross(v1, v2) Cross product of two vectors; returns a vector
turbulence(v, o) Turbulence of vector v and octave o; returns a float
turbulence3(v, o) Turbulence of vector v and octave o; returns a vector
smoothstep (min,max, x) Returns 0 if x < min, 1if x >= max; if neither are true, returns a hermite interpolation between 0 and 1
clamp(x, min, max) x clamped to the range [min,max]

The following example illustrates how to create animated turbulence using the expression:

pos = pos + turbulence3(pos, 1) * power