setsymdiff: Symmetric Difference of Two Sets

Description Usage Arguments Details Value See Also Examples

View source: R/operation_setsymdiff.R

Description

Returns the symmetric difference of two objects inheriting from class Set.

Usage

1
2
3
setsymdiff(x, y, simplify = TRUE)

x %-% y

Arguments

x, y

Set

simplify

logical, if TRUE (default) returns the result in its simplest form, usually a Set or UnionSet, otherwise a ComplementSet.

Details

The symmetric difference, aka disjunctive union, of two sets, X, Y, is defined as the set of elements that exist in set X or in Y but not both,

{z : (z ε X or z ε Y) and !(z ε X and z ε Y)}

The symmetric difference can also be expressed as the union of two sets minus the intersection. Therefore setsymdiff is written as a thin wrapper over these operations, so for two sets, A,B:
A %-% B = (A | B) - (A & B).

The symmetric difference of fuzzy and crisp sets first coerces fuzzy sets to crisp sets by finding their support.

Value

An object inheriting from Set containing the symmetric difference of elements in both x and y.

See Also

Other operators: powerset(), setcomplement(), setintersect(), setpower(), setproduct(), setunion()

Examples

1
2
3
4
5
6
7
# symmetrical difference compared to union and intersection
Set$new(1, 2, 3) %-% Set$new(3, 4)
(Set$new(1, 2, 3) | Set$new(3, 4)) - (Set$new(1, 2, 3) & Set$new(3, 4))

# ConditionalSets demonstrate the internal logic
ConditionalSet$new(function(x) x > 0) %-%
  ConditionalSet$new(function(y) y == 0)

set6 documentation built on Oct. 18, 2021, 5:06 p.m.