日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

hive 经纬度距离计算方法

發布時間:2023/12/20 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 hive 经纬度距离计算方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
-- ========== 簡單檢驗距離計算準確度=============== -- 北京經緯度 set hivevar:arrival_lat=39.9; set hivevar:arrival_lon=116.3; -- 上海經緯度 set hivevar:hotel_lat=31; set hivevar:hotel_lon=121; -- 北京上海的直線距離:1069 select 6378.137*2*ASIN(SQRT(POWER(SIN((${arrival_lat}-${hotel_lat})*ACOS(-1)/360),2) +COS(${arrival_lat}*ACOS(-1)/180)*COS(${hotel_lat}*ACOS(-1)/180)*POWER(SIN((${arrival_lon}-${hotel_lon})*ACOS(-1)/360),2))) as distance1 ,6378.137 * ACOS(1 - (POWER((SIN((90 - ${arrival_lat}) * PI() / 180) * COS(${arrival_lon} * PI() / 180) - SIN((90 - ${hotel_lat}) * PI() / 180) * COS(${hotel_lon} * PI() / 180)), 2) + POWER((SIN((90 - ${arrival_lat}) * PI() / 180) * SIN(${arrival_lon} * PI() / 180) - SIN((90 - ${hotel_lat}) * PI() / 180) * SIN(${hotel_lon} * PI() / 180)), 2) + POWER((COS((90 - ${arrival_lat}) * PI() / 180) - COS((90 - ${hotel_lat}) * PI() / 180)), 2)) / 2) AS distance2-- 距離計算結果--===== -- distance1 distance2 -- 1078.0874496030901 1078.0874496030917

因為選擇的sin和cos不同的角度計算的,所以結果會有細微的差別,但差別已經到小數點后10位了,差別非常小。

總結

以上是生活随笔為你收集整理的hive 经纬度距离计算方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。