python 計算方位角實例(根據(jù)兩點的坐標計算)
知道兩點坐標,怎么計算兩點方向的方位角?
答:首先計算坐標增量dx,dy(兩個對應坐標分量相減,終點的減始點的)。
若dx,dy中有一個為零時,根據(jù)另一個的正負決定方位角(0,90,180,270這四個中的一個,可畫坐標軸圖分析,但不要畫為數(shù)學坐標哦)。
基本思路:
若dx,dy都不為零;則
計算a=arcatn(|dy/dx|)(這好像叫象限角)
當dx>0dy>0時方位角=a;
當dx<0dy>0時方位角=180-a;
當dx<0dy<0時方位角=180+a; 負范圍為a-pi
當dx>0dy<0時方位角=360-a; 負范圍為-a
還有一種方法,使用 atan2來計算方位角,范圍為-pi,pi
atan2(y,x)所表達的意思是坐標原點為起點,指向(x,y)的射線在坐標平面上與x軸正方向之間的角的角度。
結果為正表示從 X 軸逆時針旋轉的角度,結果為負表示從 X 軸順時針旋轉的角度。
atan 和 atan2 都是求反正切函數(shù),如:有兩個點 point(x1,y1), 和 point(x2,y2);
那么這兩個點形成的斜率的角度計算方法分別是:
float angle = atan( (y2-y1)/(x2-x1) );
float angle = atan2( y2-y1, x2-x1 );
atan 和 atan2 區(qū)別:
1:參數(shù)的填寫方式不同;
2:atan2 的優(yōu)點在于 如果 x2-x1等于0 依然可以計算,但是atan函數(shù)就會導致程序出錯;
3:atan2(a,b)的取值范圍介于 -pi 到 pi 之間(不包括 -pi),而atan(a/b)的取值范圍介于-pi/2到pi/2之間(不包括±pi/2)。
另外要注意的是,函數(shù)atan2(y,x)中參數(shù)的順序是倒置的,atan2(y,x)計算的值相當于點(x,y)的角度值。
atan2(y, x)是4象限反正切,它的取值不僅取決于正切值y/x,還取決于點 (x, y) 落入哪個象限: 當點(x, y) 落入第一象限時,atan2(y, x)的范圍是 0 ~ pi/2; 當點(x, y) 落入第二象限時,atan2(y, x)的范圍是 pi/2 ~ pi; 當點(x, y) 落入第三象限時,atan2(y, x)的范圍是 -pi~-pi/2; 當點(x, y) 落入第四象限時,atan2(y, x)的范圍是 -pi/2~0. 而 atan(y/x) 僅僅根據(jù)正切值為y/x求出對應的角度 (可以看作僅僅是2象限反正切): 當 y/x > 0 時,atan(y/x)取值范圍是 0 ~ pi/2; 當 y/x < 0 時,atan(y/x)取值范圍是 -pi/2~0.
如果要實現(xiàn)方位角的計算,代碼如下:
# 計算方位角函數(shù) def azimuthAngle( x1, y1, x2, y2): angle = 0.0; dx = x2 - x1 dy = y2 - y1 if x2 == x1: angle = math.pi / 2.0 if y2 == y1 : angle = 0.0 elif y2 < y1 : angle = 3.0 * math.pi / 2.0 elif x2 > x1 and y2 > y1: angle = math.atan(dx / dy) elif x2 > x1 and y2 < y1 : angle = math.pi / 2 + math.atan(-dy / dx) elif x2 < x1 and y2 < y1 : angle = math.pi + math.atan(dx / dy) elif x2 < x1 and y2 > y1 : angle = 3.0 * math.pi / 2.0 + math.atan(dy / -dx) return (angle * 180 / math.pi)
math中關于三角函數(shù)常用的操作:
import math math.acos(x) # 返回 x 的反余弦 弧度值。 math.asin(x) # 返回 x 的反正弦 弧度值。 math.degrees(x) # 將 弧度 轉換為 角度, 如 degrees(math.pi/2) , 返回90.0 math.radians(x) # 將 角度 轉換為 弧度 注意負數(shù)角度的轉換。
以上這篇python 計算方位角實例(根據(jù)兩點的坐標計算)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Python判斷素數(shù)的3種方法及for-else語句的用法介紹
素數(shù)又叫質數(shù),指的是>1的整數(shù)中,只能被1和這個數(shù)本身整除的數(shù),這篇文章主要給大家介紹了關于Python判斷素數(shù)的3種方法及for-else語句的用法介紹的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-05-05神經(jīng)網(wǎng)絡理論基礎及Python實現(xiàn)詳解
這篇文章主要介紹了神經(jīng)網(wǎng)絡理論基礎及Python實現(xiàn)詳解,具有一定借鑒價值,需要的朋友可以參考下。2017-12-12Django-Model數(shù)據(jù)庫操作(增刪改查、連表結構)詳解
這篇文章主要介紹了Django-Model數(shù)據(jù)庫操作(增刪改查、連表結構)詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-07-07Google colab中從kaggle中接入數(shù)據(jù)的操作方法
這篇文章主要介紹了Google colab中如何從kaggle中接入數(shù)據(jù),本文涉及到兩大平臺內(nèi)容,所以我默認你已經(jīng)擁有了,并且使用過了一段時間的google賬號和kaggle賬號,需要的朋友可以參考下2024-03-03Python數(shù)據(jù)可視化實現(xiàn)漏斗圖過程圖解
這篇文章主要介紹了Python數(shù)據(jù)可視化實現(xiàn)漏斗圖過程圖解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-07-07python mysql實現(xiàn)學生成績管理系統(tǒng)
這篇文章主要為大家詳細介紹了python mysql實現(xiàn)學生成績管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10Python之tkinter進度條Progressbar用法解讀
這篇文章主要介紹了Python之tkinter進度條Progressbar用法解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05