|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | ENUM CONSTANTS | FIELD | METHOD | DETAIL: ENUM CONSTANTS | FIELD | METHOD | |||||||||
ObjectEnum<ComparisonMode>
ComparisonMode
public enum ComparisonMode
Specifies the degree of strictness when comparing two LenientComparable objects
for equality. This enumeration is ordered from stricter to more lenient
degrees: STRICT, BY_CONTRACT, IGNORE_METADATA, APPROXIMATIVE.
if two objects are equal at some degree of strictness E, then they should also
be equal at all degrees listed below E in this page. For example if two objects
are equal at the degree BY_CONTRACT, then they should also be equal at the degree
IGNORE_METADATA but not necessarily at the degree STRICT.
LenientComparable.equals(Object, ComparisonMode),
Utilities.deepEquals(Object, Object, ComparisonMode)
| utility/geotk-utility (download) | View source code for this class |
| Enum Constant Summary | |
|---|---|
APPROXIMATIVE
Only the attributes relevant to the object functionality are compared, with some tolerance threshold on numerical values. |
|
BY_CONTRACT
Only the attributes published in some contract (typically a GeoAPI interface) need to be compared. |
|
DEBUG
Same as APPROXIMATIVE, except that an AssertionError is thrown if the two
objects are not equal and assertions are enabled. |
|
IGNORE_METADATA
Only the attributes relevant to the object functionality are compared. |
|
STRICT
All attributes of the compared objects shall be strictly equal. |
|
| Method Summary | |
|---|---|
static ComparisonMode |
equalityLevel(Object o1,
Object o2)
If the two given objects are equals according one of the mode enumerated in this class, then returns that mode. |
static ComparisonMode |
valueOf(String name)
Returns the enum constant of this type with the specified name. |
static ComparisonMode[] |
values()
Returns an array containing the constants of this enum type, in the order they are declared. |
| Methods inherited from class Enum |
|---|
clone, compareTo, equals, finalize, getDeclaringClass, hashCode, name, ordinal, toString, valueOf |
| Methods inherited from class Object |
|---|
getClass, notify, notifyAll, wait, wait, wait |
| Enum Constant Detail |
|---|
public static final ComparisonMode STRICT
Object.equals(Object) method, and must be compliant with
the contract documented in that method. In particular, this comparison mode shall be
consistent with Object.hashCode() and be symmetric (A.equals(B) implies
B.equals(A)).
Implementation note
In the Geotk implementation, this comparison mode usually have the following
characteristics (not always, this is only typical):
Object.equals(Object)public static final ComparisonMode BY_CONTRACT
Note that this comparison mode does not guaranteed Object.hashCode()
consistency, neither comparison symmetry (i.e. A.equals(B) and B.equals(A) may
return different results if the equals methods are implemented differently).
Implementation note
In the Geotk implementation, this comparison mode usually have the following
characteristics (not always, this is only typical):
public static final ComparisonMode IGNORE_METADATA
BY_CONTRACT.
Examples
If the objects being compared are
CoordinateReferenceSystem instances, then only the
properties relevant to the coordinate localization shall be compared. Metadata like the
identifiers
or the domain of validity, which have no impact on the coordinates being calculated, shall be ignored.
If the objects being compared are MathTransform
instances, then two transforms defined in a different way may be considered equivalent.
For example it is possible to define a
Mercator projection
in two different ways, as a "Mercator (1SP)" or a "Mercator (2SP)" projection,
each having their own set of parameters. The STRICT or BY_CONTRACT modes
shall consider two projections as equal only if their
parameter values are strictly identical, while the IGNORE_METADATA mode can consider
those objects as equivalent despite difference in the set of parameters, as long as coordinate
transformations still produce the same results.
Example: A"Mercator (2SP)"projection with a standard parallel value of 60° produces the same results than a"Mercator (1SP)"projection with a scale factor value of 0.5.
CRS.equalsIgnoreMetadata(Object, Object)public static final ComparisonMode APPROXIMATIVE
Application to coordinate transforms
If two MathTransform objects are considered equal
according this mode, then for any given identical source position, the two compared transforms
shall compute at least approximatively the same target position. A small difference is
tolerated between the target coordinates calculated by the two math transforms. How small
is "small" is implementation dependent - the threshold can not be specified in the current
implementation, because of the non-linear nature of map projections.
@Debug public static final ComparisonMode DEBUG
APPROXIMATIVE, except that an AssertionError is thrown if the two
objects are not equal and assertions are enabled. The exception message and stack trace help
to locate which attributes are not equal. This mode is typically used in assertions like below:
Note that a comparison inassert Utilities.deepEquals(object1, object2, ComparisonMode.DEBUG);
DEBUG mode may still return false without
throwing an exception, since not all corner cases are tested. The exception is only
intended to provide more details for some common cases.
| Method Detail |
|---|
public static ComparisonMode[] values()
for (ComparisonMode c : ComparisonMode.values()) System.out.println(c);
public static ComparisonMode valueOf(String name)
name - the name of the enum constant to be returned.
IllegalArgumentException - if this enum type has no constant
with the specified name
NullPointerException - if the argument is null
public static ComparisonMode equalityLevel(Object o1,
Object o2)
null. This method is used mostly for
diagnostic purpose.
o1 - The first object to compare, or null.o2 - The second object to compare, or null.
null if the two given objects
are not equal for any mode in this enumeration.
|
||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | ENUM CONSTANTS | FIELD | METHOD | DETAIL: ENUM CONSTANTS | FIELD | METHOD | |||||||||