Fixed missing last iteration in a loop.

git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@1557514 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Luc Maisonobe 2014-01-12 11:13:05 +00:00
parent 5f0fcfce89
commit 638def643f
2 changed files with 33 additions and 1 deletions

View File

@ -628,7 +628,7 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
double sum = 0; double sum = 0;
Vector3D sumP = Vector3D.ZERO; Vector3D sumP = Vector3D.ZERO;
for (Edge edge = startVertex.getOutgoing(); for (Edge edge = startVertex.getOutgoing();
edge.getEnd() != startVertex; n == 0 || edge.getStart() != startVertex;
edge = edge.getEnd().getOutgoing()) { edge = edge.getEnd().getOutgoing()) {
final Vector3D middle = edge.getPointAt(0.5 * edge.getLength()); final Vector3D middle = edge.getPointAt(0.5 * edge.getLength());
sumP = new Vector3D(1, sumP, edge.getLength(), middle); sumP = new Vector3D(1, sumP, edge.getLength(), middle);

View File

@ -16,9 +16,12 @@
*/ */
package org.apache.commons.math3.geometry.spherical.twod; package org.apache.commons.math3.geometry.spherical.twod;
import java.util.List;
import org.apache.commons.math3.geometry.euclidean.threed.Vector3D; import org.apache.commons.math3.geometry.euclidean.threed.Vector3D;
import org.apache.commons.math3.geometry.partitioning.Region.Location; import org.apache.commons.math3.geometry.partitioning.Region.Location;
import org.apache.commons.math3.geometry.partitioning.RegionFactory; import org.apache.commons.math3.geometry.partitioning.RegionFactory;
import org.apache.commons.math3.geometry.spherical.twod.SphericalPolygonsSet.Vertex;
import org.apache.commons.math3.random.UnitSphereRandomVectorGenerator; import org.apache.commons.math3.random.UnitSphereRandomVectorGenerator;
import org.apache.commons.math3.random.Well1024a; import org.apache.commons.math3.random.Well1024a;
import org.apache.commons.math3.util.FastMath; import org.apache.commons.math3.util.FastMath;
@ -81,6 +84,35 @@ public class SphericalPolygonsSetTest {
Assert.assertEquals(Location.BOUNDARY, octant.checkPoint(new S2Point(v))); Assert.assertEquals(Location.BOUNDARY, octant.checkPoint(new S2Point(v)));
} }
} }
List<SphericalPolygonsSet.Vertex> loops = octant.getBoundaryLoops();
Assert.assertEquals(1, loops.size());
boolean xFound = false;
boolean yFound = false;
boolean zFound = false;
Vertex first = loops.get(0);
xFound = first.getLocation().getVector().distance(Vector3D.PLUS_I) < 1.0e-10;
yFound = first.getLocation().getVector().distance(Vector3D.PLUS_J) < 1.0e-10;
zFound = first.getLocation().getVector().distance(Vector3D.PLUS_K) < 1.0e-10;
int count = 1;
for (Vertex v = first.getOutgoing().getEnd(); v != first; v = v.getOutgoing().getEnd()) {
++count;
Assert.assertTrue(v == v.getIncoming().getStart().getOutgoing().getEnd());
Assert.assertEquals(0.5 * FastMath.PI, v.getIncoming().getLength(), 1.0e-10);
xFound = xFound || v.getLocation().getVector().distance(Vector3D.PLUS_I) < 1.0e-10;
yFound = yFound || v.getLocation().getVector().distance(Vector3D.PLUS_J) < 1.0e-10;
zFound = zFound || v.getLocation().getVector().distance(Vector3D.PLUS_K) < 1.0e-10;
}
Assert.assertTrue(xFound);
Assert.assertTrue(yFound);
Assert.assertTrue(zFound);
Assert.assertEquals(3, count);
Assert.assertEquals(0.0,
new Vector3D(1, 1, 1).normalize().distance(((S2Point) octant.getBarycenter()).getVector()),
1.0e-10);
Assert.assertEquals(0.5 * FastMath.PI, octant.getSize(), 1.0e-10);
} }
@Test @Test