RestrictedDatatype<?> merge = it.next(); while (it.hasNext()) merge = merge.union(it.next());
RestrictedDatatype<?> merge = it.next(); while (it.hasNext()) merge = merge.union(it.next());
/** * Same test as {@link #integerEnumeration2a()}, but with range constructed using union, not intersection * * @throws InvalidConstrainingFacetException */ @Test public void integerEnumeration2b() throws InvalidConstrainingFacetException { RestrictedDatatype<Number> dr = new RestrictedRealDatatype(dt, IntegerInterval.allIntegers(), null, null); dr = dr.applyConstrainingFacet(MIN_INCLUSIVE.getName(), -250); dr = dr.applyConstrainingFacet(MAX_EXCLUSIVE.getName(), -5); RestrictedDatatype<Number> b = new RestrictedRealDatatype(dt, IntegerInterval.allIntegers(), null, null); b = b.applyConstrainingFacet(MIN_EXCLUSIVE.getName(), -2); b = b.applyConstrainingFacet(MAX_INCLUSIVE.getName(), 350); dr = dr.union(b); final Iterator<Number> it = dr.valueIterator(); for (int i = -250; i <= 350; i++) { if ((i >= -5) && (i <= -2)) continue; assertEquals(0, OWLRealUtils.compare(i, it.next())); } }
dr2 = dr2.applyConstrainingFacet(MAX_INCLUSIVE.getName(), 13); final RestrictedDatatype<Number> dr = dr1.union(dr2);