mirror of https://github.com/apache/lucene.git
Separate point filtering from edge filtering.
This commit is contained in:
parent
129f6d4767
commit
65dc8ed2ae
|
@ -90,7 +90,7 @@ public class GeoPolygonFactory {
|
||||||
// First, exercise a sanity filter on the provided pointList, and remove identical points, linear points, and backtracks
|
// First, exercise a sanity filter on the provided pointList, and remove identical points, linear points, and backtracks
|
||||||
//System.err.println(" filtering "+pointList.size()+" points...");
|
//System.err.println(" filtering "+pointList.size()+" points...");
|
||||||
//final long startTime = System.currentTimeMillis();
|
//final long startTime = System.currentTimeMillis();
|
||||||
final List<GeoPoint> filteredPointList = filterPoints(pointList, leniencyValue);
|
final List<GeoPoint> filteredPointList = filterEdges(filterPoints(pointList), leniencyValue);
|
||||||
//System.err.println(" ...done in "+(System.currentTimeMillis()-startTime)+"ms ("+((filteredPointList==null)?"degenerate":(filteredPointList.size()+" points"))+")");
|
//System.err.println(" ...done in "+(System.currentTimeMillis()-startTime)+"ms ("+((filteredPointList==null)?"degenerate":(filteredPointList.size()+" points"))+")");
|
||||||
if (filteredPointList == null) {
|
if (filteredPointList == null) {
|
||||||
return null;
|
return null;
|
||||||
|
@ -167,12 +167,11 @@ public class GeoPolygonFactory {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Filter duplicate points and coplanar points.
|
/** Filter duplicate points.
|
||||||
* @param input with input list of points
|
* @param input with input list of points
|
||||||
* @param leniencyValue is the allowed distance of a point from the plane for cleanup of overly detailed polygons
|
|
||||||
* @return the filtered list, or null if we can't get a legit polygon from the input.
|
* @return the filtered list, or null if we can't get a legit polygon from the input.
|
||||||
*/
|
*/
|
||||||
static List<GeoPoint> filterPoints(final List<GeoPoint> input, final double leniencyValue) {
|
static List<GeoPoint> filterPoints(final List<GeoPoint> input) {
|
||||||
|
|
||||||
final List<GeoPoint> noIdenticalPoints = new ArrayList<>(input.size());
|
final List<GeoPoint> noIdenticalPoints = new ArrayList<>(input.size());
|
||||||
|
|
||||||
|
@ -214,6 +213,16 @@ public class GeoPolygonFactory {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return noIdenticalPoints;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Filter coplanar points.
|
||||||
|
* @param noIdenticalPoints with input list of points
|
||||||
|
* @param leniencyValue is the allowed distance of a point from the plane for cleanup of overly detailed polygons
|
||||||
|
* @return the filtered list, or null if we can't get a legit polygon from the input.
|
||||||
|
*/
|
||||||
|
static List<GeoPoint> filterEdges(final List<GeoPoint> noIdenticalPoints, final double leniencyValue) {
|
||||||
|
|
||||||
// Now, do the depth-first search needed to find a path that has no coplanarities in it.
|
// Now, do the depth-first search needed to find a path that has no coplanarities in it.
|
||||||
// This is, unfortunately, not easy, because coplanarity is not transitive as you walk around the polygon.
|
// This is, unfortunately, not easy, because coplanarity is not transitive as you walk around the polygon.
|
||||||
// If point C is not coplanar with edge A-B, there is no guarantee that A is not coplanar with B-C.
|
// If point C is not coplanar with edge A-B, there is no guarantee that A is not coplanar with B-C.
|
||||||
|
|
|
@ -44,7 +44,7 @@ public class GeoPolygonTest {
|
||||||
originalPoints.add(point2);
|
originalPoints.add(point2);
|
||||||
originalPoints.add(point2);
|
originalPoints.add(point2);
|
||||||
originalPoints.add(point3);
|
originalPoints.add(point3);
|
||||||
final List<GeoPoint> filteredPoints =GeoPolygonFactory.filterPoints(originalPoints, 0.0);
|
final List<GeoPoint> filteredPoints = GeoPolygonFactory.filterEdges(GeoPolygonFactory.filterPoints(originalPoints), 0.0);
|
||||||
assertEquals(3, filteredPoints.size());
|
assertEquals(3, filteredPoints.size());
|
||||||
assertEquals(point1, filteredPoints.get(0));
|
assertEquals(point1, filteredPoints.get(0));
|
||||||
assertEquals(point2, filteredPoints.get(1));
|
assertEquals(point2, filteredPoints.get(1));
|
||||||
|
@ -57,7 +57,7 @@ public class GeoPolygonTest {
|
||||||
originalPoints.add(point1);
|
originalPoints.add(point1);
|
||||||
originalPoints.add(point3);
|
originalPoints.add(point3);
|
||||||
originalPoints.add(point2);
|
originalPoints.add(point2);
|
||||||
final List<GeoPoint> filteredPoints =GeoPolygonFactory.filterPoints(originalPoints, 0.0);
|
final List<GeoPoint> filteredPoints = GeoPolygonFactory.filterEdges(GeoPolygonFactory.filterPoints(originalPoints), 0.0);
|
||||||
assertEquals(3, filteredPoints.size());
|
assertEquals(3, filteredPoints.size());
|
||||||
assertEquals(point2, filteredPoints.get(0));
|
assertEquals(point2, filteredPoints.get(0));
|
||||||
assertEquals(point1, filteredPoints.get(1));
|
assertEquals(point1, filteredPoints.get(1));
|
||||||
|
@ -71,7 +71,7 @@ public class GeoPolygonTest {
|
||||||
originalPoints.add(point3);
|
originalPoints.add(point3);
|
||||||
originalPoints.add(point4);
|
originalPoints.add(point4);
|
||||||
originalPoints.add(point5);
|
originalPoints.add(point5);
|
||||||
final List<GeoPoint> filteredPoints =GeoPolygonFactory.filterPoints(originalPoints, 0.0);
|
final List<GeoPoint> filteredPoints = GeoPolygonFactory.filterEdges(GeoPolygonFactory.filterPoints(originalPoints), 0.0);
|
||||||
assertEquals(3, filteredPoints.size());
|
assertEquals(3, filteredPoints.size());
|
||||||
assertEquals(point1, filteredPoints.get(0));
|
assertEquals(point1, filteredPoints.get(0));
|
||||||
assertEquals(point3, filteredPoints.get(1));
|
assertEquals(point3, filteredPoints.get(1));
|
||||||
|
@ -85,7 +85,7 @@ public class GeoPolygonTest {
|
||||||
originalPoints.add(point3);
|
originalPoints.add(point3);
|
||||||
originalPoints.add(point4);
|
originalPoints.add(point4);
|
||||||
System.err.println("Before: "+originalPoints);
|
System.err.println("Before: "+originalPoints);
|
||||||
final List<GeoPoint> filteredPoints =GeoPolygonFactory.filterPoints(originalPoints, 0.0);
|
final List<GeoPoint> filteredPoints = GeoPolygonFactory.filterEdges(GeoPolygonFactory.filterPoints(originalPoints), 0.0);
|
||||||
System.err.println("After: "+filteredPoints);
|
System.err.println("After: "+filteredPoints);
|
||||||
assertEquals(3, filteredPoints.size());
|
assertEquals(3, filteredPoints.size());
|
||||||
assertEquals(point5, filteredPoints.get(0));
|
assertEquals(point5, filteredPoints.get(0));
|
||||||
|
|
Loading…
Reference in New Issue