AviSynth Syntax - Numeric functions

Numeric functions provide common mathematical operations on numeric variables.

Returns the maximum value of a set of numbers.
If all the values are of type Int, the result is an Int. If any of the values are of type Float, the result is a Float.
This may cause an unexpected result when an Int value greater than 16777216 is mixed with Float values.
Examples:
Max (1, 2) = 2
Max (5, 3.0, 2) = 5.0
Returns the minimum value of a set of numbers.
Examples:
Max (1, 2) = 1
Max (5, 3.0, 2) = 2.0
Multiplies two ints (m, n) and divides the product by a third (d) in a single operation, with 64 bit intermediate result. The actual equation used is (m * n + d / 2) / d .
Examples:
MulDiv (1, 1, 2) = 1
MulDiv (2, 3, 2) = 3
Converts from float to int (round down on any fractional amount).
Examples:
Floor(1.2) = 1
Floor(1.6) = 1
Floor(-1.2) = -2
Floor(-1.6) = -2
Converts from float to int (round up on any fractional amount).
Examples:
Ceil(1.2) = 2.0
Ceil(1.6) = 2.0
Ceil(-1.2) = -1
Ceil(-1.6) = -1
Converts from float to int (round off to nearest integer).
Examples:
Round(1.2) = 1
Round(1.6) = 2
Round(-1.2) = -1
Round(-1.6) = -2
Returns the sine of the argument (assumes it is radians).
Examples:
Sin(Pi()/4) = 0.707
Sin(Pi()/2) = 1.0
Returns the cosine of the argument (assumes it is radians).
Examples:
Cos(Pi()/4) = 0.707
Cos(Pi()/2) = 0.0
Returns the tangent of the argument (assumes it is radians).
Examples:
Tan(Pi()/4) = 1.0
Tan(Pi()/2) = not defined
32 bit ieee floats do not have sufficient resolution to exactly represent
Π/2 so AviSynth returns a large positive number for the value slightly less
than Π/2 and a large negative value for the next possible value which is
slightly greater than Π/2.
Returns the inverse of the sine of the argument (output is radians).
Examples:
Asin(0.707) = 0.7852471634 (~ Pi/4)
Asin(1.0) = 1.570796327 (~ Pi/2)
Returns the inverse of the cosine of the argument (output is in radians).
Examples:
Acos(0.707) = 0.7852471634 (~ Pi/4)
Acos(0.0) = 1.570796327 (~ Pi/2)
Returns the inverse of the tangent of the argument (output is in radians).
Examples:
Atan(0.707) = 0.6154085176
Atan(1.0) = 0.7853981634 (~ Pi/4)
Returns the angle between the positive x-axis of a plane and the point given by the coordinates (x, y) on it (output is in radians). See wikipedia for more information.
y is the first argument and x is the second argument.
Examples:
Atan2(1.0, 0) = 1.570796327 (~ Pi/2)
Atan2(1.0, 1.0) = 0.7852471634 (~ Pi/4)
Atan2(-1.0, -1.0) = -2.356194490 (~ -3Pi/4)
Returns the hyperbolic sine of the argument. See wikipedia for more information.
Examples:
Sinh(2.0) = 3.626860408
Returns the hyperbolic cosine of the argument.
Examples:
Cosh(2.0) = 3.762195691
Returns the hyperbolic tangent of the argument.
Examples:
Tanh(2.0) = 0.9640275801
Returns the modulo of the argument. Output is float.
Examples:
Fmod(3.5, 0.5) = 0 (since 3.5 - 7*0.5 = 0)
Fmod(3.5, 1.0) = 0.5 (since 3.5 - 3*1.0 = 0.5)
Returns the value of the "pi" constant (the ratio of a circle's circumference to its diameter).
Examples:
d = Pi()    # d == 3.141593
Returns the value of the "tau" constant (the ratio of a circle's circumference to its radius). See Tau_(2Π) for more information.
Examples:
d = Tau()   # d == 6.283186
Returns the natural (base-e) exponent of the argument.
Examples:
Exp(1) = 2.718282
Exp(0) = 1.0
Returns the natural (base-e) logarithm of the argument.
Examples:
Log(1) = 0.0
Log(10) = 2.30259
Log(Exp(1)) = 1.0
Returns the common logarithm of the argument.
Examples:
Log10(1.0) = 0
Log10(10.0) = 1.0
Log10(2.0) = 0.3010299957
Returns "base" raised to the power indicated by the second argument.
Examples:
Pow(2, 3) = 8
Pow(3, 2) = 9
Pow(3.45, 1.75) = 8.7334
Returns the square root of the argument.
Examples:
Sqrt(1) = 1.0
Sqrt(2) = 1.4142
Returns the absolute value of its argument (returns float for float, integer for integer).
Examples:
Abs(-3.8) = 3.8
Abs(-4) = 4
Returns the sign of the value passed as argument (1, 0 or -1).
Examples:
Sign(-3.5) = -1
Sign(3.5) = 1
Sign(0) = 0
Converts from single-precision, floating-point value to int (round towards zero).
Examples:
Int(1.2) = 1
Int(1.6) = 1
Int(-1.2) = -1
Int(-1.6) = -1
Returns the fractional portion of the value provided.
Examples:
Frac(3.7) = 0.7
Frac(-1.8) = -0.8
Converts int to single-precision, floating-point value. Integer values that require more than 24-bits to be represented will have their lower 8-bits truncated yielding unexpected values.
Examples:
Float(4) = 4.0
Float(4) / 3 = 1.333 (while 4 / 3 = 1 , due to integer division)
Returns a random integer value. All parameters are optional.
Typically, this function would be used with the Select function for random clips.
Examples:
Select(Rand(5), clip1, clip2, clip3, clip4, clip5)
Interpolates the Y value at point X using the control points x1/y1, ... There have to be at least 2 x/y-pairs. The interpolation can be cubic (the result is a spline) or linear (the result is a polygon). Default is cubic.
Examples:
Spline(5, 0, 0, 10, 10, 20, 0, false) = 5
Spline(5, 0, 0, 10, 10, 20, 0, true) = 7
The rational pair (ContinuedNumerator,ContinuedDenominator) returned has the smallest possible denominator such that the absolute error is less than 1/limit. More information can be found on wikipedia.
If limit is not specified in the Float case the rational pair returned is to the limit of the single precision floating point value. Thus (float)((double)Num/(double)Den) == V.
In the Int pair case if limit is not specified then the normalised original values will be returned, i.e. reduced by the GCD.
Examples:
ContinuedNumerator(PI(), limit=5000]) = 355
ContinuedDenominator(PI(), limit=5000) = 113

ContinuedNumerator(PI(), limit=50]) = 22
ContinuedDenominator(PI(), limit=50) = 7

ContinuedNumerator(355, 113, limit=50]) = 22
ContinuedDenominator(355, 113, limit=50) = 7 
The functions: BitAnd, BitNot, BitOr, BitXor, etc, are bitwise operators. This means that their arguments (being integers) are converted to binary numbers, the operation is performed on their bits, and the resulting binary number is converted back again.
BitAnd returns the bitwise AND (sets bit to 1 if both bits are 1 and sets bit to 0 otherwise).
Examples:
BitAnd(5, 6) = 4 # since 5 = 101, 6 = 110, and 101&110 = 100
Returns the bit-inversion (sets bit to 1 if bit is 0 and vice-versa).
Examples:
BitNOT(5) = -6 # since 5 = 101, and ~101 = 11111111111111111111111111111010
Note: 1111 1111 1111 1111 1111 1111 1111 1010 = (2^32-1)-2^0-2^2 = 2^32-(1+2^0+2^2) = (signed) -(1+2^0+2^2) = -6.
Returns the bitwise inclusive OR (sets bit to 1 if one of the bits (or both) is 1 and sets bit to 0 otherwise).
Examples:
BitOr(5, 6) = 7 # since 5 = 101, 6 = 110, and 101|110 = 111
BitOr(4, 2) = 6 # since 4 = 100, 2 = 010, and 100|010 = 110
Returns the bitwise exclusive OR (sets bit to 1 if exactly one of the bits is 1 and sets bit to 0 otherwise).
Examples:
BitXor(5, 6) = 3 # since 5 = 101, 6 = 110, and 101^110 = 011
BitXor(4, 2) = 6 # since 4 = 100, 2 = 010, and 100^010 = 110
Shift the bits of a number to the left.
Examples:
Shifts the bits of the number 5 two bits to the left:
BitLShift(5, 2) = 20 (since 101 << 2 = 10100)
Shift the bits of an unsigned integer to the right. (Logical, zero fill, Right Shift)
Examples:
Shifts the bits of the number -42 one bit to the right, treating it as unsigned:
BitRShiftL(-42, 1) = 2147483627 (since 11111111111111111111111111010110 >>> 1 = 01111111111111111111111111101011)
Note: -42 = -(1+2^0+2^3+2^5) = (unsigned) 2^32-(1+2^0+2^3+2^5) = (2^32-1)-2^0-2^3-2^5 = 11111111111111111111111111010110.
Shift the bits of an integer to the right. (Arithmetic, Sign bit fill, Right Shift)
Examples:
Shifts the bits of the number -42 one bit to the right, treating it as signed:
BitRShiftA(-42, 1) = -21 (since 11111111111111111111111111010110 >> 1 = 11111111111111111111111111101011)
Rotates the bits of an unsigned integer to the left.
Examples:
Rotates the bits of the number -2147483642 one bit to the right:
BitLRotate(-2147483642, 1) = 13 (since 10000000000000000000000000000110 ROL 1 = 00000000000000000000000000001101)
Rotate the bits of an integer to the right.
Examples:
Rotates the bits of the number 13 one bit to the right:
BitRRotate(13, 1) = -2147483642 (since 00000000000000000000000000001101 ROR 1 = 10000000000000000000000000000110)
Invert the state of the n'th bit of an integer. The 1 bit is bit 0. The sign bit is bit 31.
Examples:
Change the state of the fourth bit:
BitChange(3, 4) = 19
BitChange(19, 4) = 3

Change the state of the sign bit:
BitChange(-1, 31) = 2147483647
Clear the state of the n'th bit of an integer.
Examples:
Clear the state of the fourth bit:
BitClear(3, 4) = 3
BitClear(19, 4) = 3

Clear the state of the sign bit:
BitClear(-1, 31) = 2147483647
Set the state of the n'th bit of an integer.
Examples:
Set the state of the fourth bit:
BitSet(3, 4) = 19
BitSet(19, 4) = 19

Set the state of the sign bit:
BitSet(-1, 31) = -1
BitSet(2147483647, 31) = -1
Test the state of the n'th bit of an integer. Result is a bool.
Examples:
Check the state of the fourth bit:
BitTest(3, 4) = False
BitTest(19, 4) = True

Check the state of the sign bit:
BitTest(-1, 31) = True
BitTest(2147483647, 31) = False

Back to Internal functions.

$Date: 2013/01/06 13:38:34 $