eqPercent
Syntax
eqPercent(X, Y, [toleranceLevel=0.0001])
Arguments
- X / Y are two numbers to compare. They must be scalars, vectors, pairs, or matrices of the same shape. Supported data types include BOOL, CHAR, SHORT, INT, LONG, FLOAT, DOUBLE, DECIMAL. Note: X and Y must be of the same form, and elements in X and Y can be of different data types.
- toleranceLevel (optional) is a number in (0, 100), representing the tolerable percentage error. The default value is 0.0001. This means the absolute difference between the two elements must not exceed the toleranceLevel percentage of the absolute value of Y. For example, if Y is 1000 and toleranceLevel is 0.0001, the allowable error is 1000 * 0.0001% = 0.001. Thus, an X value between [999.999, 1000.001] will be considered equal to Y.
Details
Check element-wise equality of two inputs X and Y are equal within the specified toleranceLevel.
Return Value: A Boolean scalar
Note:
-
If the type of the input X or Y is not supported, the function returns the result of
eqObj(X, Y).
-
Null values are not equal to other values.
-
Null values of different types are considered equal.
Examples
eqPercent((1.9999 2.9999), (2 3))
// Output: true
eqPercent((1.9 2.9), (2 3), 2)
// Output: false
Elements in X and Y can be of different data types:
eqPercent((1.99f 2.99), (2 3h), 2)
// Output: true
When comparing null values:
// Null values are not equal to other values
eqPercent((1.9999 NULL), (2 3))
// Output: false
// Null values of DOUBLE and VOID types are considered equal
a=double(NULL)
eqPercent(a,NULL)
// Output: true
When an unsupported type is passed, the function returns the result of eqObj(X,
Y)
:
eqPercent(2012.06M, 2)
// Output: false