commit
a37dcb93be
|
@ -870,11 +870,15 @@ public class PolygonsSet extends AbstractRegion<Euclidean2D, Euclidean1D> {
|
||||||
// we need at least 2 segments in order for one of the contained vertices
|
// we need at least 2 segments in order for one of the contained vertices
|
||||||
// to be unnecessary
|
// to be unnecessary
|
||||||
if (loop.size() > 1) {
|
if (loop.size() > 1) {
|
||||||
|
// Go through the list and compare each segment with the next
|
||||||
|
// one in line. We can remove the shared vertex if the segments
|
||||||
|
// are not infinite and they lie on the same line.
|
||||||
for (int i = 0; i < loop.size(); ++i) {
|
for (int i = 0; i < loop.size(); ++i) {
|
||||||
final Segment previous = loop.get(i);
|
final Segment previous = loop.get(i);
|
||||||
int j = (i + 1) % loop.size();
|
int j = (i + 1) % loop.size();
|
||||||
final Segment next = loop.get(j);
|
final Segment next = loop.get(j);
|
||||||
if (next != null &&
|
if (next != null &&
|
||||||
|
previous.getStart() != null && next.getEnd() != null &&
|
||||||
Precision.equals(previous.getLine().getAngle(), next.getLine().getAngle(), Precision.EPSILON)) {
|
Precision.equals(previous.getLine().getAngle(), next.getLine().getAngle(), Precision.EPSILON)) {
|
||||||
// the vertex between the two edges is a spurious one
|
// the vertex between the two edges is a spurious one
|
||||||
// replace the two segments by a single one
|
// replace the two segments by a single one
|
||||||
|
|
|
@ -22,6 +22,7 @@ import java.util.List;
|
||||||
import org.apache.commons.math4.exception.MathIllegalArgumentException;
|
import org.apache.commons.math4.exception.MathIllegalArgumentException;
|
||||||
import org.apache.commons.math4.geometry.euclidean.oned.Interval;
|
import org.apache.commons.math4.geometry.euclidean.oned.Interval;
|
||||||
import org.apache.commons.math4.geometry.euclidean.oned.IntervalsSet;
|
import org.apache.commons.math4.geometry.euclidean.oned.IntervalsSet;
|
||||||
|
import org.apache.commons.math4.geometry.GeometryTestUtils;
|
||||||
import org.apache.commons.math4.geometry.euclidean.oned.Cartesian1D;
|
import org.apache.commons.math4.geometry.euclidean.oned.Cartesian1D;
|
||||||
import org.apache.commons.math4.geometry.euclidean.twod.Euclidean2D;
|
import org.apache.commons.math4.geometry.euclidean.twod.Euclidean2D;
|
||||||
import org.apache.commons.math4.geometry.euclidean.twod.Line;
|
import org.apache.commons.math4.geometry.euclidean.twod.Line;
|
||||||
|
@ -37,11 +38,53 @@ import org.apache.commons.math4.geometry.partitioning.RegionFactory;
|
||||||
import org.apache.commons.math4.geometry.partitioning.SubHyperplane;
|
import org.apache.commons.math4.geometry.partitioning.SubHyperplane;
|
||||||
import org.apache.commons.math4.geometry.partitioning.Region.Location;
|
import org.apache.commons.math4.geometry.partitioning.Region.Location;
|
||||||
import org.apache.commons.math4.util.FastMath;
|
import org.apache.commons.math4.util.FastMath;
|
||||||
|
import org.apache.commons.numbers.core.Precision;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
public class PolygonsSetTest {
|
public class PolygonsSetTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testInfiniteLines_twoIntersecting() {
|
||||||
|
// arrange
|
||||||
|
Line line1 = new Line(new Cartesian2D(0, 0), new Cartesian2D(1, 1), 1e-10);
|
||||||
|
Line line2 = new Line(new Cartesian2D(1, -1), new Cartesian2D(0, 0), 1e-10);
|
||||||
|
|
||||||
|
List<SubHyperplane<Euclidean2D>> boundaries = new ArrayList<SubHyperplane<Euclidean2D>>();
|
||||||
|
boundaries.add(line1.wholeHyperplane());
|
||||||
|
boundaries.add(line2.wholeHyperplane());
|
||||||
|
|
||||||
|
// act
|
||||||
|
PolygonsSet poly = new PolygonsSet(boundaries, 1e-10);
|
||||||
|
|
||||||
|
// assert
|
||||||
|
Assert.assertEquals(1e-10, poly.getTolerance(), Precision.EPSILON);
|
||||||
|
Assert.assertEquals(Double.POSITIVE_INFINITY, poly.getSize(), 1e-10);
|
||||||
|
Assert.assertEquals(Double.POSITIVE_INFINITY, poly.getBoundarySize(), 1e-10);
|
||||||
|
Assert.assertEquals(false, poly.isEmpty());
|
||||||
|
Assert.assertEquals(false, poly.isFull());
|
||||||
|
GeometryTestUtils.assertVectorEquals(Cartesian2D.NaN, (Cartesian2D) poly.getBarycenter(), 1e-10);
|
||||||
|
|
||||||
|
Cartesian2D[][] vertices = poly.getVertices();
|
||||||
|
Assert.assertEquals(1, vertices.length);
|
||||||
|
|
||||||
|
Cartesian2D[] loop = vertices[0];
|
||||||
|
Assert.assertEquals(3, loop.length);
|
||||||
|
Assert.assertEquals(null, loop[0]);
|
||||||
|
GeometryTestUtils.assertVectorEquals(line2.toSpace(new Cartesian1D(-Float.MAX_VALUE)), loop[1], 1e-10);
|
||||||
|
GeometryTestUtils.assertVectorEquals(line2.toSpace(new Cartesian1D(Float.MAX_VALUE)), loop[2], 1e-10);
|
||||||
|
|
||||||
|
checkPoints(Region.Location.INSIDE, poly, new Cartesian2D[] {
|
||||||
|
new Cartesian2D(-1, 0),
|
||||||
|
new Cartesian2D(-Float.MAX_VALUE, Float.MAX_VALUE / 2.0)
|
||||||
|
});
|
||||||
|
checkPoints(Region.Location.OUTSIDE, poly, new Cartesian2D[] {
|
||||||
|
new Cartesian2D(1, 0),
|
||||||
|
new Cartesian2D(Float.MAX_VALUE, Float.MAX_VALUE / 2.0)
|
||||||
|
});
|
||||||
|
checkPoints(Region.Location.BOUNDARY, poly, new Cartesian2D[] { Cartesian2D.ZERO });
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSimplyConnected() {
|
public void testSimplyConnected() {
|
||||||
Cartesian2D[][] vertices = new Cartesian2D[][] {
|
Cartesian2D[][] vertices = new Cartesian2D[][] {
|
||||||
|
|
Loading…
Reference in New Issue