LUCENE-7270: Perofmance improvements related to tree structure.

This commit is contained in:
Karl Wright 2016-05-03 13:15:37 -04:00
parent 492dcfbdd0
commit 925f2b28c1
1 changed files with 40 additions and 10 deletions

View File

@ -16,7 +16,9 @@
*/ */
package org.apache.lucene.spatial3d.geom; package org.apache.lucene.spatial3d.geom;
import java.util.Arrays;
import java.util.List; import java.util.List;
import java.util.ArrayList;
import java.util.Set; import java.util.Set;
import java.util.HashSet; import java.util.HashSet;
@ -33,9 +35,9 @@ import java.util.HashSet;
*/ */
class GeoComplexPolygon extends GeoBasePolygon { class GeoComplexPolygon extends GeoBasePolygon {
private final Tree xTree = new XTree(); private final Tree xTree;
private final Tree yTree = new YTree(); private final Tree yTree;
private final Tree zTree = new ZTree(); private final Tree zTree;
private final boolean testPointInSet; private final boolean testPointInSet;
private final GeoPoint testPoint; private final GeoPoint testPoint;
@ -82,17 +84,17 @@ class GeoComplexPolygon extends GeoBasePolygon {
this.edgePoints = new GeoPoint[pointsList.size()]; this.edgePoints = new GeoPoint[pointsList.size()];
this.shapeStartEdges = new Edge[pointsList.size()]; this.shapeStartEdges = new Edge[pointsList.size()];
final ArrayList<Edge> allEdges = new ArrayList<>();
int edgePointIndex = 0; int edgePointIndex = 0;
for (final List<GeoPoint> shapePoints : pointsList) { for (final List<GeoPoint> shapePoints : pointsList) {
allEdges.ensureCapacity(allEdges.size() + shapePoints.size());
GeoPoint lastGeoPoint = shapePoints.get(shapePoints.size()-1); GeoPoint lastGeoPoint = shapePoints.get(shapePoints.size()-1);
edgePoints[edgePointIndex] = lastGeoPoint; edgePoints[edgePointIndex] = lastGeoPoint;
Edge lastEdge = null; Edge lastEdge = null;
Edge firstEdge = null; Edge firstEdge = null;
for (final GeoPoint thisGeoPoint : shapePoints) { for (final GeoPoint thisGeoPoint : shapePoints) {
final Edge edge = new Edge(planetModel, lastGeoPoint, thisGeoPoint); final Edge edge = new Edge(planetModel, lastGeoPoint, thisGeoPoint);
xTree.add(edge); allEdges.add(edge);
yTree.add(edge);
zTree.add(edge);
// Now, link // Now, link
if (firstEdge == null) { if (firstEdge == null) {
firstEdge = edge; firstEdge = edge;
@ -109,6 +111,10 @@ class GeoComplexPolygon extends GeoBasePolygon {
shapeStartEdges[edgePointIndex] = firstEdge; shapeStartEdges[edgePointIndex] = firstEdge;
edgePointIndex++; edgePointIndex++;
} }
xTree = new XTree(allEdges);
yTree = new YTree(allEdges);
zTree = new ZTree(allEdges);
} }
@Override @Override
@ -447,10 +453,31 @@ class GeoComplexPolygon extends GeoBasePolygon {
protected static final int GREATER = 5; protected static final int GREATER = 5;
protected static final int EXACT = 6; protected static final int EXACT = 6;
private final static Edge[] NO_EDGES = new Edge[0];
/** Create a tree.
* @param edges is the list of edges.
*/
public Tree(final List<Edge> allEdges) {
final Edge[] edges = allEdges.toArray(NO_EDGES);
// Sort by edge length, and then by minimum value
Arrays.sort(edges, (left, right) -> {
int ret = Double.compare(getMaximum(left) - getMinimum(left), getMaximum(right) - getMinimum(right));
if (ret == 0) {
ret = Double.compare(getMinimum(left), getMinimum(right));
}
return ret;
});
for (final Edge edge : edges) {
add(edge);
}
}
/** Add a new edge to the tree. /** Add a new edge to the tree.
* @param edge is the edge to add. * @param edge is the edge to add.
*/ */
public void add(final Edge edge) { private void add(final Edge edge) {
rootNode = addEdge(rootNode, edge, getMinimum(edge), getMaximum(edge)); rootNode = addEdge(rootNode, edge, getMinimum(edge), getMaximum(edge));
} }
@ -646,7 +673,8 @@ class GeoComplexPolygon extends GeoBasePolygon {
private static class ZTree extends Tree { private static class ZTree extends Tree {
public Node rootNode = null; public Node rootNode = null;
public ZTree() { public ZTree(final List<Edge> allEdges) {
super(allEdges);
} }
/* /*
@ -673,7 +701,8 @@ class GeoComplexPolygon extends GeoBasePolygon {
*/ */
private static class YTree extends Tree { private static class YTree extends Tree {
public YTree() { public YTree(final List<Edge> allEdges) {
super(allEdges);
} }
/* /*
@ -700,7 +729,8 @@ class GeoComplexPolygon extends GeoBasePolygon {
*/ */
private static class XTree extends Tree { private static class XTree extends Tree {
public XTree() { public XTree(final List<Edge> allEdges) {
super(allEdges);
} }
/* /*