根据前端传递的精度和纬度计算出来km

/***
* 根据前端 传递的
* @param lat1前端 经度
* @param lng1前端 维度
* @param lat2 数据库 经度
* @param lng2数据库 维度
* @return 计算出来的km
*/
public static double getDistance(double lat1, double lng1, double lat2, double lng2) {
double radLat1 = rad(lat1);
double radLat2 = rad(lat2);
double a = radLat1 - radLat2;
double b = rad(lng1) - rad(lng2);
double s = 2 * Math.asin(Math.sqrt(
Math.pow(Math.sin(a / 2), 2) + Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)));
s = s * EARTH_RADIUS;
s = Math.round(s * 10000d) / 10000d;
s = s * 1000;
return s;
}

在C++中,精度地计算磁偏角通常需要借助于科学计算库,如C++ Standard Template Library (STL) 中的 `<cmath>` 一些地理定位库,比如`geoposition`或第三方的`proj4cpp`。以下是一个简化版的例子,展示了如何利用`<cmath>`库进行基本的精度计算: ```cpp #include <iostream> #include <cmath> // 定义地球半径常量 const double EARTH_RADIUS_KM = 6371; // 单位: 公里 // 给定纬度计算磁偏角辅助函数 double magnetic_correction(double latitude, double mu_0, double declination_at_eq, double eccentricity) { const double pi = M_PI; double lat_rad = std::atan(std::tan(latitude * pi / 180) / (1 - eccentricity * ecc * std::cos(lat_rad))); double r = 1 + eccentricity * ecc * std::sin(lat_rad) * std::sin(lat_rad); return (mu_0 - declination_at_eq) / r * std::cos(lat_rad); } int main() { double latitude = 30.0; // 需要计算的纬度 double mu_0 = 57.29577951308232; // 每度弧度数 double declination_at_eq = 0.0; // 平均赤道磁偏角 double eccentricity = 0.08181919084262145; double magnetic_deviation_degrees = magnetic_correction(latitude, mu_0, declination_at_eq, eccentricity) * 180 / mu_0; std::cout << "在 " << latitude << " 度纬度处的磁偏角约为 " << magnetic_deviation_degrees << " 度。\n"; return 0; } ``` 请注意,这个例子中的计算仍然是基于简单模型的,并未考虑到地形、海洋等地磁影响以及高度变化的影响。实际应用中可能需要结合更复杂的地理信息系统(GIS)库进行精确计算。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值