Package org.apache.lucene.spatial3d.geom
Class PlanetModel
java.lang.Object
org.apache.lucene.spatial3d.geom.PlanetModel
- All Implemented Interfaces:
- SerializableObject
Holds mathematical constants associated with the model of a planet.
- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classUtility class for encoding / decoding from lat/lon (decimal degrees) into sortable doc value numerics (integers)
- 
Field SummaryFieldsModifier and TypeFieldDescriptionfinal doubleSemi-major axisfinal doubleSemi-minor axisstatic final PlanetModelPlanet model corresponding to Clarke 1866 ellipsoidfinal doublescalar value used to decode from integer back into double spaceutility class used to encode/decode from lat/lon (decimal degrees) into doc value integersfinal doubleThe inverse of scalefinal doubleThe inverse of xyScalingfinal doubleThe square of the inverse of xyScalingfinal doubleThe inverse of zScalingfinal doubleThe square of the inverse of zScalingfinal intMax encoded valuefinal doublemaximum magnitude value for *this* planet modelfinal GeoPointMax X polefinal GeoPointMax Y polefinal doubleThe mean radius of the planetfinal intMin encoded valuefinal GeoPointMin X polefinal GeoPointMin Y polefinal doubleMinimum surface distance between polesfinal GeoPointNorth polefinal doubleThe scale of the planetfinal doubleThe scaled flattening valuefinal GeoPointSouth polestatic final PlanetModelPlanet model corresponding to sphere.final doubleThe square ratiostatic final PlanetModelPlanet model corresponding to WGS84 ellipsoidfinal doubleThe x/y scaling factorfinal doubleThe z scaling factor
- 
Constructor SummaryConstructorsConstructorDescriptionPlanetModel(double semiMajorAxis, double semiMinorAxis) * Construct a Planet Model from the semi major axis, semi minor axis=.PlanetModel(InputStream inputStream) Deserialization constructor.
- 
Method SummaryModifier and TypeMethodDescriptionCompute a GeoPoint that's a bisection between two other GeoPoints.createSurfacePoint(double x, double y, double z) Compute a GeoPoint that's based on (x,y,z) values, but is scaled to actually be on the planet surface.createSurfacePoint(Vector vector) Compute a GeoPoint that's scaled to actually be on the planet surface.doubledecodeValue(int x) Decodes a given integer back into the radian value according to the defined planet modelintencodeValue(double x) encode the provided value from double to integer spacebooleanreturn reference to the DocValueEncoder used to encode/decode Geo3DDocValuesdoubleFind the maximum magnitude of all points on the ellipsoid.doubleFind the maximum x value.doubleFind the maximum y value.doubleFind the maximum z value.doublereturn the calculated mean radius (in units provided by ab and c)doubleFind the minimum magnitude of all points on the ellipsoid.doubleFind the minimum x value.doubleFind the minimum y value.doubleFind the minimum z value.inthashCode()booleanisSphere()Does this planet model describe a sphere?booleanpointOnSurface(double x, double y, double z) Check if point is on surface.booleanCheck if point is on surface.booleanpointOutside(double x, double y, double z) Check if point is outside surface.booleanCheck if point is outside surface.doublesurfaceDistance(GeoPoint pt1, GeoPoint pt2) Compute surface distance between two points.surfacePointOnBearing(GeoPoint from, double dist, double bearing) Compute new point given original point, a bearing direction, and an adjusted angle (as would be computed by the surfaceDistance() method above).toString()voidwrite(OutputStream outputStream) Serialize to output stream.
- 
Field Details- 
SPHEREPlanet model corresponding to sphere.
- 
WGS84Planet model corresponding to WGS84 ellipsoid
- 
CLARKE_1866Planet model corresponding to Clarke 1866 ellipsoid
- 
apublic final double aSemi-major axis
- 
bpublic final double bSemi-minor axis
- 
xyScalingpublic final double xyScalingThe x/y scaling factor
- 
zScalingpublic final double zScalingThe z scaling factor
- 
inverseXYScalingpublic final double inverseXYScalingThe inverse of xyScaling
- 
inverseZScalingpublic final double inverseZScalingThe inverse of zScaling
- 
inverseXYScalingSquaredpublic final double inverseXYScalingSquaredThe square of the inverse of xyScaling
- 
inverseZScalingSquaredpublic final double inverseZScalingSquaredThe square of the inverse of zScaling
- 
scaledFlatteningpublic final double scaledFlatteningThe scaled flattening value
- 
squareRatiopublic final double squareRatioThe square ratio
- 
meanRadiuspublic final double meanRadiusThe mean radius of the planet
- 
scalepublic final double scaleThe scale of the planet
- 
inverseScalepublic final double inverseScaleThe inverse of scale
- 
NORTH_POLENorth pole
- 
SOUTH_POLESouth pole
- 
MIN_X_POLEMin X pole
- 
MAX_X_POLEMax X pole
- 
MIN_Y_POLEMin Y pole
- 
MAX_Y_POLEMax Y pole
- 
minimumPoleDistancepublic final double minimumPoleDistanceMinimum surface distance between poles
- 
MAX_VALUEpublic final double MAX_VALUEmaximum magnitude value for *this* planet model
- 
DECODEpublic final double DECODEscalar value used to decode from integer back into double space
- 
MAX_ENCODED_VALUEpublic final int MAX_ENCODED_VALUEMax encoded value
- 
MIN_ENCODED_VALUEpublic final int MIN_ENCODED_VALUEMin encoded value
- 
docValueEncoderutility class used to encode/decode from lat/lon (decimal degrees) into doc value integers
 
- 
- 
Constructor Details- 
PlanetModelpublic PlanetModel(double semiMajorAxis, double semiMinorAxis) * Construct a Planet Model from the semi major axis, semi minor axis=.- Parameters:
- semiMajorAxis- is the semi major axis (in meters) defined as 'a' in projection formulae.
- semiMinorAxis- is the semi minor axis (in meters) defined as 'b' in projection formulae.
 
- 
PlanetModelDeserialization constructor.- Parameters:
- inputStream- is the input stream.
- Throws:
- IOException
 
 
- 
- 
Method Details- 
writeDescription copied from interface:SerializableObjectSerialize to output stream.- Specified by:
- writein interface- SerializableObject
- Parameters:
- outputStream- is the output stream to write to.
- Throws:
- IOException
 
- 
isSpherepublic boolean isSphere()Does this planet model describe a sphere?- Returns:
- true if so.
 
- 
getMinimumMagnitudepublic double getMinimumMagnitude()Find the minimum magnitude of all points on the ellipsoid.- Returns:
- the minimum magnitude for the planet.
 
- 
getMaximumMagnitudepublic double getMaximumMagnitude()Find the maximum magnitude of all points on the ellipsoid.- Returns:
- the maximum magnitude for the planet.
 
- 
getMinimumXValuepublic double getMinimumXValue()Find the minimum x value.- Returns:
- the minimum X value.
 
- 
getMaximumXValuepublic double getMaximumXValue()Find the maximum x value.- Returns:
- the maximum X value.
 
- 
getMinimumYValuepublic double getMinimumYValue()Find the minimum y value.- Returns:
- the minimum Y value.
 
- 
getMaximumYValuepublic double getMaximumYValue()Find the maximum y value.- Returns:
- the maximum Y value.
 
- 
getMinimumZValuepublic double getMinimumZValue()Find the minimum z value.- Returns:
- the minimum Z value.
 
- 
getMaximumZValuepublic double getMaximumZValue()Find the maximum z value.- Returns:
- the maximum Z value.
 
- 
getMeanRadiuspublic double getMeanRadius()return the calculated mean radius (in units provided by ab and c)
- 
encodeValuepublic int encodeValue(double x) encode the provided value from double to integer space
- 
decodeValuepublic double decodeValue(int x) Decodes a given integer back into the radian value according to the defined planet model
- 
getDocValueEncoderreturn reference to the DocValueEncoder used to encode/decode Geo3DDocValues
- 
pointOnSurfaceCheck if point is on surface.- Parameters:
- v- is the point to check.
- Returns:
- true if the point is on the planet surface.
 
- 
pointOnSurfacepublic boolean pointOnSurface(double x, double y, double z) Check if point is on surface.- Parameters:
- x- is the x coord.
- y- is the y coord.
- z- is the z coord.
 
- 
pointOutsideCheck if point is outside surface.- Parameters:
- v- is the point to check.
- Returns:
- true if the point is outside the planet surface.
 
- 
pointOutsidepublic boolean pointOutside(double x, double y, double z) Check if point is outside surface.- Parameters:
- x- is the x coord.
- y- is the y coord.
- z- is the z coord.
 
- 
createSurfacePointCompute a GeoPoint that's scaled to actually be on the planet surface.- Parameters:
- vector- is the vector.
- Returns:
- the scaled point.
 
- 
createSurfacePointCompute a GeoPoint that's based on (x,y,z) values, but is scaled to actually be on the planet surface.- Parameters:
- x- is the x value.
- y- is the y value.
- z- is the z value.
- Returns:
- the scaled point.
 
- 
bisectionCompute a GeoPoint that's a bisection between two other GeoPoints.- Parameters:
- pt1- is the first point.
- pt2- is the second point.
- Returns:
- the bisection point, or null if a unique one cannot be found.
 
- 
surfaceDistanceCompute surface distance between two points.- Parameters:
- pt1- is the first point.
- pt2- is the second point.
- Returns:
- the adjusted angle, when multiplied by the mean earth radius, yields a surface
     distance. This will differ from GeoPoint.arcDistance() only when the planet model is not a
     sphere. @see GeoPoint.arcDistance(Vector)
 
- 
surfacePointOnBearingCompute new point given original point, a bearing direction, and an adjusted angle (as would be computed by the surfaceDistance() method above). The original point can be anywhere on the globe. The bearing direction ranges from 0 (due east at the equator) to pi/2 (due north) to pi (due west at the equator) to 3 pi/4 (due south) to 2 pi.- Parameters:
- from- is the starting point.
- dist- is the adjusted angle.
- bearing- is the direction to proceed.
- Returns:
- the new point, consistent with the bearing direction and distance.
 
- 
equals
- 
hashCodepublic int hashCode()
- 
toString
 
-