gpt4 book ai didi

javascript - 如何计算两个纬度和经度之间的距离

转载 作者:行者123 更新时间:2023-12-03 07:27:15 25 4
gpt4 key购买 nike

我正在尝试使用温哥华和多伦多的纬度和经度来计算它们之间的距离。我正在使用haversine公式。我预计距离约为 4390 公里。有人可以告诉我我犯了什么错误吗?这是我的代码:

<!DOCTYPE html> 
<html>
<head>
<title></title>
</head>
<body onload="getDistance()">
<script>
// Convert Degress to Radians
function Deg2Rad( deg ) {
return deg * Math.PI / 180;
}

function getDistance()
{
//Toronto Latitude 43.74 and longitude -79.37
//Vancouver Latitude 49.25 and longitude -123.12
lat1 = Deg2Rad(43.74);
lat2 = Deg2Rad(49.25);
lon1 = Deg2Rad(-79.37);
lon2 = Deg2Rad(-123.12);
latDiff = lat2-lat1;
lonDiff = lon2-lon1;
var R = 6371000; // metres
var φ1 = lat1;
var φ2 = lat2;
var Δφ = Deg2Rad(latDiff);
var Δλ = Deg2Rad(lonDiff);

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

var d = R * c;
alert('d: ' + d);

var dist = Math.acos( Math.sin(φ1)*Math.sin(φ2) + Math.cos(φ1)*Math.cos(φ2) * Math.cos(Δλ) ) * R;
alert('dist: ' + dist);
}
</script>
</body>
</html>

当我运行这段代码时,我得到了完全不同的数字。

最佳答案

我认为你应该期望更多的是 3358 公里。 http://www.distancefromto.net/distance-from/Toronto/to/Vancouver

这是一个正确结果的 fiddle :https://jsfiddle.net/Lk1du2L1/

在这种情况下,如果您从次要结果中删除 deg2rad,那么您就是正确的 - 您这样做得太频繁了:

 <!DOCTYPE html> 
<html>
<head>
<title></title>
</head>
<body onload="getDistance()">
<script>
// Convert Degress to Radians
function Deg2Rad( deg ) {
return deg * Math.PI / 180;
}

function getDistance()
{
//Toronto Latitude 43.74 and longitude -79.37
//Vancouver Latitude 49.25 and longitude -123.12
lat1 = Deg2Rad(43.74);
lat2 = Deg2Rad(49.25);
lon1 = Deg2Rad(-79.37);
lon2 = Deg2Rad(-123.12);
latDiff = lat2-lat1;
lonDiff = lon2-lon1;
var R = 6371000; // metres
var φ1 = lat1;
var φ2 = lat2;
var Δφ = latDiff;
var Δλ = lonDiff;

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

var d = R * c;
alert('d: ' + d);

var dist = Math.acos( Math.sin(φ1)*Math.sin(φ2) + Math.cos(φ1)*Math.cos(φ2) * Math.cos(Δλ) ) * R;
alert('dist: ' + dist);
}
</script>
</body>
</html>

关于javascript - 如何计算两个纬度和经度之间的距离,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35949220/

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