python 计算方位角实例(根据两点的坐标计算)

作者:JohnieLi 时间:2023-08-01 09:30:54 

知道两点坐标,怎么计算两点方向的方位角?

答:首先计算坐标增量dx,dy(两个对应坐标分量相减,终点的减始点的)。

若dx,dy中有一个为零时,根据另一个的正负决定方位角(0,90,180,270这四个中的一个,可画坐标轴图分析,但不要画为数学坐标哦)。

基本思路:

若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 都是求反正切函数,如:有两个点 point(x1,y1), 和 point(x2,y2);

那么这两个点形成的斜率的角度计算方法分别是:

float angle = atan( (y2-y1)/(x2-x1) );
float angle = atan2( y2-y1, x2-x1 );

atan 和 atan2 区别:

1:参数的填写方式不同;

2:atan2 的优点在于 如果 x2-x1等于0 依然可以计算,但是atan函数就会导致程序出错;

3:atan2(a,b)的取值范围介于 -pi 到 pi 之间(不包括 -pi),而atan(a/b)的取值范围介于-pi/2到pi/2之间(不包括±pi/2)。

另外要注意的是,函数atan2(y,x)中参数的顺序是倒置的,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) 仅仅根据正切值为y/x求出对应的角度 (可以看作仅仅是2象限反正切):

当 y/x > 0 时,atan(y/x)取值范围是 0 ~ pi/2;
当 y/x < 0 时,atan(y/x)取值范围是 -pi/2~0.

如果要实现方位角的计算,代码如下:


# 计算方位角函数
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中关于三角函数常用的操作:


import math
math.acos(x)  # 返回 x 的反余弦 弧度值。  
math.asin(x)  # 返回 x 的反正弦 弧度值。  
math.degrees(x)  # 将 弧度 转换为 角度, 如 degrees(math.pi/2) , 返回90.0  
math.radians(x)  # 将 角度 转换为 弧度
注意负数角度的转换。

来源:https://blog.csdn.net/JohinieLi/article/details/81041550

标签:python,计算,方位角,坐标
0
投稿

猜你喜欢

  • Python 控制终端输出文字的实例

    2021-10-23 21:30:56
  • javascript 屏蔽鼠标键盘的几段代码

    2024-04-30 09:51:19
  • python自带的http模块详解

    2021-11-03 08:59:22
  • 用来武装Firefox的24款Web开发插件

    2010-02-28 12:40:00
  • AJAX打造博客无刷新搜索

    2007-08-23 08:48:00
  • javascript验证只能输入数字和一个小数点示例

    2024-04-22 22:29:11
  • Python使用循环神经网络解决文本分类问题的方法详解

    2022-12-01 16:49:05
  • Oracle 11g安装错误提示未找到wfmlrsvcapp.ear的解决方法

    2023-07-14 14:31:52
  • 让自定义文件下载支持断点续传

    2009-03-11 19:45:00
  • 12种最常用的网页编程语言简介(值得收藏)

    2023-01-29 17:40:48
  • python简单实现图片文字分割

    2023-07-31 23:36:24
  • 基于PyQT实现区分左键双击和单击

    2022-10-30 01:58:47
  • VUE中如何动态绑定类名和样式

    2024-04-26 17:41:35
  • 如何使用Typora+MinIO+Python代码打造舒适协作环境

    2023-11-12 15:12:10
  • python属于哪种语言

    2022-05-30 18:20:07
  • Python OpenCV简单的绘图函数使用教程

    2023-08-02 23:22:22
  • 教你一招完美解决vscode安装go插件失败问题

    2024-05-09 09:47:20
  • mysql优化之慢查询分析+explain命令分析+优化技巧总结

    2024-01-16 03:12:30
  • 解决python打不开文件(文件不存在)的问题

    2021-10-15 02:39:46
  • ASP实现长文章自动分页的函数代码

    2008-10-10 17:09:00
  • asp之家 网络编程 m.aspxhome.com