Subtraction: -
Syntax
op1 - op2
Input parameters
op1 |
the minuend |
op2 |
the subtrahend |
Examples of valid syntaxes
DS_1 - DS_2
3 - 5
Semantics for scalar operations
The operator subtraction returns the difference of two numbers. For example:
3 - 5
gives -2
Input parameters type
op1, op2
dataset { measure<number> _+ }
| component<number>
| number
Result type
result
dataset { measure<number> _+ }
| component<number>
| number
Additional Constraints
None.
Behaviour
The operator has the behaviour of the “Operators applicable on two Scalar Values or Data Sets or Data Set Components” (see the section “Typical behaviours of the ML Operators”). According to the general rules about data types, the operator can be applied also on sub-types of number, that is the type integer. If the type of both operands is integer then the result has type integer. If one of the operands is of type number, then the other operand is implicitly cast to number and therefore the result has type number.
Examples
Given the operand datasets DS_1 and DS_2:
Input DS_1 (see structure)
Id_1 |
Id_2 |
Me_1 |
Me_2 |
---|---|---|---|
10 |
A |
5 |
5.0 |
10 |
B |
2 |
10.5 |
11 |
A |
3 |
12.2 |
11 |
B |
4 |
20.3 |
Input DS_2 (see structure)
Id_1 |
Id_2 |
Me_1 |
Me_2 |
---|---|---|---|
10 |
A |
10 |
3.0 |
10 |
C |
11 |
6.2 |
11 |
B |
6 |
7.0 |
Example 1
DS_r := DS_1 - DS_2;
results in (see structure):
Id_1 |
Id_2 |
Me_1 |
Me_2 |
---|---|---|---|
10 |
A |
-5 |
2.0 |
11 |
B |
-2 |
13.3 |
Example 2
DS_r := DS_1 - 3;
results in (see structure):
Id_1 |
Id_2 |
Me_1 |
Me_2 |
---|---|---|---|
10 |
A |
2 |
2.0 |
10 |
B |
-1 |
7.5 |
11 |
A |
0 |
9.2 |
11 |
B |
1 |
17.3 |
Example 3
DS_r := DS_1 [ calc Me_3 := Me_1 - 3 ];
results in (see structure):
Id_1 |
Id_2 |
Me_1 |
Me_2 |
Me_3 |
---|---|---|---|---|
10 |
A |
5 |
5.0 |
2 |
10 |
B |
2 |
10.5 |
-1 |
11 |
A |
3 |
12.2 |
0 |
11 |
B |
4 |
20.3 |
1 |