當前位置: 首頁>>代碼示例>>Java>>正文


Java Geodesic類代碼示例

本文整理匯總了Java中net.sf.geographiclib.Geodesic的典型用法代碼示例。如果您正苦於以下問題:Java Geodesic類的具體用法?Java Geodesic怎麽用?Java Geodesic使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Geodesic類屬於net.sf.geographiclib包,在下文中一共展示了Geodesic類的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: intercept

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
@Override
public double intercept(Point a, Point b, Point c) {

    if (a.getX() == b.getX() && a.getY() == b.getY()) {
        return 0;
    }
    Intercept inter = new Intercept(Geodesic.WGS84);
    GeodesicData ci =
            inter.intercept(a.getY(), a.getX(), b.getY(), b.getX(), c.getY(), c.getX());
    GeodesicData ai = Geodesic.WGS84.Inverse(a.getY(), a.getX(), ci.lat2, ci.lon2);
    GeodesicData ab = Geodesic.WGS84.Inverse(a.getY(), a.getX(), b.getY(), b.getX());

    return (Math.abs(ai.azi1 - ab.azi1) < 1) ? ai.s12 / ab.s12 : (-1) * ai.s12 / ab.s12;
}
 
開發者ID:bmwcarit,項目名稱:barefoot,代碼行數:15,代碼來源:Geography.java

示例2: interpolate

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
@Override
public Point interpolate(Point a, Point b, double f) {
    GeodesicData inv = Geodesic.WGS84.Inverse(a.getY(), a.getX(), b.getY(), b.getX());
    GeodesicData pos = Geodesic.WGS84.Line(inv.lat1, inv.lon1, inv.azi1).Position(inv.s12 * f);

    return new Point(pos.lon2, pos.lat2);
}
 
開發者ID:bmwcarit,項目名稱:barefoot,代碼行數:8,代碼來源:Geography.java

示例3: azimuth

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
@Override
public double azimuth(Point a, Point b, double f) {
    double azi = 0;
    if (f < 0 + 1E-10) {
        azi = Geodesic.WGS84.Inverse(a.getY(), a.getX(), b.getY(), b.getX()).azi1;
    } else if (f > 1 - 1E-10) {
        azi = Geodesic.WGS84.Inverse(a.getY(), a.getX(), b.getY(), b.getX()).azi2;
    } else {
        Point c = interpolate(a, b, f);
        azi = Geodesic.WGS84.Inverse(a.getY(), a.getX(), c.getY(), c.getX()).azi2;
    }
    return azi < 0 ? azi + 360 : azi;
}
 
開發者ID:bmwcarit,項目名稱:barefoot,代碼行數:14,代碼來源:Geography.java

示例4: envelope

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
@Override
public Envelope2D envelope(Point c, double radius) {
    Envelope2D env = new Envelope2D();

    double ymax = Geodesic.WGS84.Direct(c.getY(), c.getX(), 0, radius).lat2;
    double ymin = Geodesic.WGS84.Direct(c.getY(), c.getX(), -180, radius).lat2;
    double xmax = Geodesic.WGS84.Direct(c.getY(), c.getX(), 90, radius).lon2;
    double xmin = Geodesic.WGS84.Direct(c.getY(), c.getX(), -90, radius).lon2;

    env.setCoords(xmin, ymin, xmax, ymax);

    return env;
}
 
開發者ID:bmwcarit,項目名稱:barefoot,代碼行數:14,代碼來源:Geography.java

示例5: intercept

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
/**
 * Interception of a point <i>b</i> to a geodesic <i>a</i>.
 * <p>
 *
 * @param lata1 latitude of point <i>1</i> of geodesic <i>a</i> (degrees).
 * @param lona1 longitude of point <i>1</i> of geodesic <i>a</i> (degrees).
 * @param lata2 latitude of point <i>2</i> of geodesic <i>a</i> (degrees).
 * @param lona2 longitude of point <i>2</i> of geodesic <i>a</i> (degrees).
 * @param latb1 latitude of point <i>b</i> (degrees).
 * @param lonb1 longitude of point <i>b</i> (degrees).
 * @return a {@link GeodesicData} object, defining a geodesic from point <i>b</i> to the
 *         intersection point, with the following fields: <i>lat1</i>, <i>lon1</i>, <i>azi1</i>,
 *         <i>lat2</i>, <i>lon2</i>, <i>azi2</i>, <i>s12</i>, <i>a12</i>.
 *         <p>
 *         <i>lat1</i> should be in the range [&minus;90&deg;, 90&deg;]; <i>lon1</i> and
 *         <i>azi1</i> should be in the range [&minus;540&deg;, 540&deg;). The values of
 *         <i>lon2</i> and <i>azi2</i> returned are in the range [&minus;180&deg;, 180&deg;).
 */
public GeodesicData intercept(double lata1, double lona1, double lata2, double lona2,
        double latb1, double lonb1) {

    if (lata1 == lata2 && lona1 == lona2) {
        return earth.Inverse(latb1, lonb1, lata1, lona1);
    }

    GeodesicData inv = Geodesic.WGS84.Inverse(lata1, lona1, lata2, lona2);
    GeodesicData est =
            Geodesic.WGS84.Line(inv.lat1, inv.lon1, inv.azi1).Position(inv.s12 * 0.5);
    double latb2 = est.lat2, latb2_ = Double.NaN, lonb2_ = Double.NaN, lonb2 = est.lon2;

    for (int i = 0; i < maxit; ++i) {
        GnomonicData xa1 = gnom.Forward(latb2, lonb2, lata1, lona1);
        GnomonicData xa2 = gnom.Forward(latb2, lonb2, lata2, lona2);
        GnomonicData xb1 = gnom.Forward(latb2, lonb2, latb1, lonb1);

        Vector va1 = new Vector(xa1.x, xa1.y, 1);
        Vector va2 = new Vector(xa2.x, xa2.y, 1);
        Vector la = va1.cross(va2);
        Vector lb = new Vector(la.y, -(la.x), la.x * xb1.y - la.y * xb1.x);
        Vector p0 = la.cross(lb);
        p0 = p0.multiply(1d / p0.z);

        latb2_ = latb2;
        lonb2_ = lonb2;

        GnomonicData rev = gnom.Reverse(latb2, lonb2, p0.x, p0.y);
        latb2 = rev.lat;
        lonb2 = rev.lon;

        if (Math.abs(lonb2_ - lonb2) < eps && Math.abs(latb2_ - latb2) < eps) {
            break;
        }
    }

    return earth.Inverse(latb1, lonb1, latb2, lonb2);
}
 
開發者ID:bmwcarit,項目名稱:barefoot,代碼行數:57,代碼來源:Intercept.java

示例6: ShapeAsPointsBuilder

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
public ShapeAsPointsBuilder() {
    points = new LinkedList<>();
    wgs84 = Geodesic.WGS84;
    step = 1;
}
 
開發者ID:lassana,項目名稱:osmdroid-shape-extension,代碼行數:6,代碼來源:ShapeAsPointsBuilder.java

示例7: distance

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
@Override
public double distance(Point a, Point b) {
    return Geodesic.WGS84.Inverse(a.getY(), a.getX(), b.getY(), b.getX()).s12;
}
 
開發者ID:bmwcarit,項目名稱:barefoot,代碼行數:5,代碼來源:Geography.java

示例8: azimuth

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
private static double azimuth(Point a, Point b, boolean left) {
    GeodesicData geod = Geodesic.WGS84.Inverse(a.getY(), a.getX(), b.getY(), b.getX());
    double azi = left ? geod.azi1 : geod.azi2;
    return azi < 0 ? azi + 360 : azi;
}
 
開發者ID:bmwcarit,項目名稱:barefoot,代碼行數:6,代碼來源:GeographyTest.java

示例9: evaluateSingleSet

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
/**
 * Calculate the precition and median error on a collection of images
 * @param resultFile : file of the results
 * @param collection : collection of image IDs
 * @param minRangeScale : minimum precision range
 * @param maxRangeScale : minimum precision range
 * @param oneLine : print results in one line
 */
private static void evaluateSingleSet(String resultFile, Set<String> collection, 
		int minRangeScale, int maxRangeScale, boolean oneLine){

	// function that calculates the distance between two lat/lon points
	Geodesic geo = new Geodesic(6378.1370D, 298.257223563);		

	// Initialize result containers
	Map<Integer, Integer> estimationResultMap = initializeResultMap(minRangeScale, maxRangeScale);
	List<Double> distances = new ArrayList<Double>();

	// Estimated and total item counters
	int estimations = 0;

	// File reader
	EasyBufferedReader reader = new EasyBufferedReader(resultFile);
	String line;
	while((line = reader.readLine()) != null){
		if(collection == null || collection.contains(line.split("\t")[0])){
			try{
				// Pairs of lat/lon points
				Double[] estimatedLocation = 
					{Double.parseDouble(line.split("\t")[4]),
							Double.parseDouble(line.split("\t")[3])};
				Double[] groundTruthLocation = 
					{Double.parseDouble(line.split("\t")[2]),
							Double.parseDouble(line.split("\t")[1])};


				// calculate distance
				double distance = geo.Inverse(groundTruthLocation[0], groundTruthLocation[1],
						estimatedLocation[0], estimatedLocation[1]).s12;

				// store results
				for(int i=minRangeScale;i<maxRangeScale;i++){
					if(distance < Math.pow(10, i)){
						estimationResultMap.put(i, estimationResultMap.get(i) + 1);
					}
				}
				distances.add(distance);
				estimations++;

			}catch (ArrayIndexOutOfBoundsException e){ // line is not in the right format
				System.out.println(e.getMessage());
			}
		}
	}
	reader.close();

	DecimalFormat df = new DecimalFormat();
	df.setMaximumFractionDigits(2);

	// print results
	if(oneLine){
		logger.info("Items: " + estimations + "\[email protected]: " + df.format(
				(float)estimationResultMap.get(0)/estimations*100) + "%\tm.error: " +
				df.format(Utils.median(distances)) + "km");
	}else{
		logger.info("Total items: " + estimations);
		printPrecisionResults(estimationResultMap, estimations, minRangeScale, maxRangeScale);
		logger.info("Median Distance Error: " + df.format(Utils.median(distances)) + "km");
	}
}
 
開發者ID:socialsensor,項目名稱:multimedia-geotagging,代碼行數:71,代碼來源:Evaluation.java

示例10: Intercept

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
/**
 * Constructor for Intercept.
 * <p>
 *
 * @param earth the {@link Geodesic} object to use for geodesic calculations. By default the
 *        WGS84 ellipsoid should be used.
 */
public Intercept(Geodesic earth) {
    this.earth = earth;
    this.gnom = new Gnomonic(this.earth);
}
 
開發者ID:bmwcarit,項目名稱:barefoot,代碼行數:12,代碼來源:Intercept.java

示例11: Intersect

import net.sf.geographiclib.Geodesic; //導入依賴的package包/類
/**
 * Constructor for Intersect.
 * <p>
 * @param earth
 *          the {@link Geodesic} object to use for geodesic calculations. By
 *          default the WGS84 ellipsoid should be used.
 */
public Intersect(Geodesic earth) {
  this.earth = earth;
  this.gnom = new Gnomonic(this.earth);
}
 
開發者ID:bmwcarit,項目名稱:barefoot,代碼行數:12,代碼來源:Intersect.java


注:本文中的net.sf.geographiclib.Geodesic類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。