gpt4 book ai didi

javascript - 在距离方面,我无法获得与 Google map 相同的准确度?

转载 作者:行者123 更新时间:2023-11-29 10:13:17 26 4
gpt4 key购买 nike

我正在开发一个计算两点之间距离的应用程序。我无法使用 Google Maps API。

我在下面的 map 中找到了每个标记的坐标。

然后我使用 haversine 公式来计算每个点之间的距离。例如1 -> 2、2 -> 3、3 -> 4 ... 等等,直到最后一点。我将这些距离相加以检索路线的总距离。

问题是谷歌地图说它是 950-1000 米,但我的应用程序说长度是 1150-1200 米。我已经尝试添加更多坐标,删除坐标,但我仍然得到大约 200 米长的路线。

出于好奇,我计算了起点和终点(2 颗绿色星星)之间的距离,这与 Google map 上的距离相符(准确地说是 998 米)。

这是否意味着 Google map 在计算距离时不考虑道路/路径等。

这是我的代码:

var coordinates = [
[1,51.465097,-3.170893,1,0],
[2,51.465526,-3.170714,0,0],
[3,51.465853,-3.170526,0,0],
[4,51.466168,-3.170338,0,0],
[5,51.466305,-3.170236,0,0],
[6,51.466534,-3.170157,0,0],
[7,51.466798,-3.170159,0,0],
[8,51.467042,-3.170232,0,0],
[9,51.467506,-3.170580,0,0],
[10,51.468076,-3.171532,0,0],
[11,51.468863,-3.172170,0,0],
[12,51.469284,-3.172841,0,0],
[13,51.469910,-3.174732,0,0],
[14,51.470037,-3.174930,0,0],
[15,51.470350,-3.175091,0,0],
[16,51.472447,-3.176151,1,0]
];

function distanceBetweenCoordinates() //calculates the distance between each of the coordinates
{
for (var i=0; i<coordinates.length-1; i++)
{
var firstClosestPoint = [0,0,6371];
var secondClosestPoint = [0,0,6371];
var lng1 = (coordinates[i][1]);
var lat1 = (coordinates[i][2]);
var lng2 = (coordinates[i+1][2]);
var lat2 = (coordinates[i+1][2]);
var d = haversine(lat1, lng1, lat2, lng2);
routeLength = routeLength + d;
}

return distanceBetweenCoordinatesArray; //returns the array which stores the 2 points and the distance between the 2 points
}

编辑

这是我用来计算 2 点之间距离的 haversine forumla:

来源:here

  Number.prototype.toRad = function() //to rad function which is used by the haversine formula
{
return this * Math.PI / 180;
}

function haversine(lat1, lng1, lat2, lng2) { //haversine foruma which is used to calculate the distance between 2 coordinates

lon1 = lng1;
lon2 = lng2;
var R = 6371000; // metres
var a = lat1.toRad();
var b = lat2.toRad();
var c = (lat2-lat1).toRad();
var d = (lon2-lon1).toRad();

var a = Math.sin(c/2) * Math.sin(c/2) +
Math.cos(a) * Math.cos(b) *
Math.sin(d/2) * Math.sin(d/2);
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));

var d = R * c;
return d;
}

enter image description here

最佳答案

如果我正确输入了您的起点和终点,则半正弦公式的此实现(我已经在现实世界中测试过)产生了 895 米(直线)的距离。

var lt = 51.472447;
var lt1 = 51.465097;
var ln = -3.176151;
var ln1 = -3.170893;
var dLat = (lt - lt1) * Math.PI / 180;
var dLon = (ln - ln1) * Math.PI / 180;
var a = 0.5 - Math.cos(dLat) / 2 + Math.cos(lt1 * Math.PI / 180) * Math.cos(lt * Math.PI / 180) * (1 - Math.cos(dLon)) / 2;
d = Math.round(6371000 * 2 * Math.asin(Math.sqrt(a)));

$('#distance').html(d);
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<div id="distance"></div>

关于javascript - 在距离方面,我无法获得与 Google map 相同的准确度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28542133/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com