经纬度计算两地距离

目前能提供经纬度距离的算法有很多,以下方法是将地球看为椭圆进行处理计算。具体算法过程不详解(感兴趣的可以网上搜索具体计算过程),这里只列出代码实现部分,代码可以直接植入单片机中,进行计算。


:由于地球是不规则的椭球体,并且实际地理位置还需考虑海拔情况,因此计算会存在一定误差。
实际使用情况:本人采用了NEO-M8N的GPS&BD双模定位模块,测量有一定的距离误差,不适于高精度场合,合适长距离估算。


#define PI  3.1415926

//度转换成幅度值
double rad(double d)  
{  
     return d * PI / 180.0;  
}
/*******************************************************************************
* 函数名 : Get_GPSdistance
* 描述   : 计算经纬度距离
* 输入   : 参数:第一点经度,纬度 ,第二点经度,纬度
* 返回   : 返回距离,单位M
* 注意   : 
*******************************************************************************/
double Get_GPSdistance(double lon1, double lat1,double lon2, double lat2)
{
        double EARTH_RADIUS = 6378137;
        double x1 =0;
        double y1 =0; 
        double z1=0;
        double x2 =0;
        double y2 =0; 
        double z2=0;
        double d=0;

        double theta=0;
        double dist=0;



        double radLat1 = rad(lat1);  
        double radLat2 = rad(lat2);  

        double radLon1 = rad(lon1);  
        double radLon2 = rad(lon2);  

        if (radLat1 < 0)  
                radLat1 = PI / 2 + abs(radLat1);// south  
        if (radLat1 > 0)  
                radLat1 = PI / 2 - abs(radLat1);// north  
        if (radLon1 < 0)  
                radLon1 = PI * 2 - abs(radLon1);// west  
        if (radLat2 < 0)  
                radLat2 =  PI / 2 + abs(radLat2);// south  
        if (radLat2 > 0)  
                radLat2 =  PI / 2 -  abs(radLat2);// north  
        if (radLon2 < 0)  
                radLon2 =  PI * 2 -  abs(radLon2);// west  

         x1 = EARTH_RADIUS *  cos(radLon1) *  sin(radLat1);  
         y1 = EARTH_RADIUS *  sin(radLon1) *  sin(radLat1);  
         z1 = EARTH_RADIUS *  cos(radLat1);  

         x2 = EARTH_RADIUS *  cos(radLon2) *  sin(radLat2);  
         y2 = EARTH_RADIUS *  sin(radLon2) *  sin(radLat2);  
         z2 = EARTH_RADIUS *  cos(radLat2);  

         d =  sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2)+ (z1 - z2) * (z1 - z2));  
        //余弦定理求夹角  
        theta =  acos((EARTH_RADIUS * EARTH_RADIUS + EARTH_RADIUS * EARTH_RADIUS - d * d) / (2 * EARTH_RADIUS * EARTH_RADIUS));  
        dist = theta * EARTH_RADIUS;  

        return dist/100.0;   //比实际算法小100倍数 (M)

}
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值