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

答:首先计算坐标增量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) # 将 角度 转换为 弧度

注意负数角度的转换。

以上这篇python 计算方位角实例(根据两点的坐标计算)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持【听图阁-专注于Python设计】。

python计算方位角_[宜配屋]听图阁相关推荐

  1. python写词法分析器_[宜配屋]听图阁

    编译原理老师要求写一个java的词法分析器,想了想决定用python写一个. 目标 能识别出变量,数字,运算符,界符和关键字,用excel表打印出来. 有了目标,想想要怎么实现词法分析器. 1.先进行 ...

  2. 怎么用python打印照片_[宜配屋]听图阁

    这篇文章主要介绍了Python如何使用字符打印照片,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1. 前言 第一次在学校机房里见到计算机,还是上古 ...

  3. python 判断节假日_[宜配屋]听图阁

    不废话,直接上代码Python3.6 签到代码,只需修改url,账号,密码即可,此处是登录时无验证登录,有验证码的自行补充 # -*- coding:utf-8 -*- import json imp ...

  4. python 内推_[宜配屋]听图阁

    本文实例为大家分享了网易有道2017内推编程题:洗牌,供大家参考,具体内容如下 ''' [编程题] 洗牌 时间限制:1秒 空间限制:32768K 洗牌在生活中十分常见,现在需要写一个程序模拟洗牌的过程 ...

  5. python文件传输模块_[宜配屋]听图阁 - python 使用poster模块进行http方式的文件传输到服务器的方法...

    这几天帮内部人员做一个文件传输的小工具,要用http的方式,在用django搭建了个小框架之后,如何进行传输,特别是大文件的传输,成为主要问题.经过查资料,最后选择了通过poster这个模块来进行文件 ...

  6. python中控脚本_[宜配屋]听图阁

    由于考勤机与OA对接,OA会在每天定时取考勤机数据,但是需要考勤机是连接状态,所以搜索了下相关教程,写了个脚本自动连接.完全是个Python小白,代码烂,仅作为笔记. 理论上支持所有程序的每天自动开启 ...

  7. 用python画雨滴_[宜配屋]听图阁

    本文实例为大家分享了python实现雨滴下落到地面效果的具体代码,供大家参考,具体内容如下 本程序在Windows 64位操作系统下,安装的是Anaconda3-4.2.0 import numpy ...

  8. python 艺术照片滤镜_[宜配屋]听图阁 - Python实现PS滤镜Fish lens图像扭曲效果示例...

    本文实例讲述了Python实现PS滤镜Fish lens图像扭曲效果.分享给大家供大家参考,具体如下: 这里实现 PS 滤镜中的一种几何变换– Fish lens, 对图像做扭曲,感觉就像通过一个凸镜 ...

  9. python计算圆的体积_[宜配屋]听图阁

    在已知DICOM和三维模型对应掩膜的情况下,计算三维模型的体积. 思路: 1.计算每个体素的体积.每个体素为长方体,x,y为PixelSpacing,z为层间距 使用pydicom.read_file ...

最新文章

  1. Kendo UI Professional Q3 2015 Beta发布[附下载]
  2. command exec make executable file not found in %PATH%
  3. C# 用IrisSkin4.dll美化你的WinForm
  4. oracle 递归计算,SQL(Oracle)中的递归计算
  5. lol最克制诺手的英雄_LOL:究竟有没有完美克制诺手的英雄?时光上单或可一战?...
  6. 安装nrm,报错request@2.88.2: request has been deprecated, see https://github.com/request/request/issu
  7. 条件运算符和条件表达式
  8. 软件项目验收汇报ppt_项目验收!万能PPT模板!等你来拿
  9. 【lzy学习笔记-dive into deep learning】数学预备 2.1-2.4
  10. python的拼音_Python返回汉字的汉语拼音(原创) | 学步园
  11. TensorFlow使用GPU
  12. 集成电路光刻机精密运动台控制方法
  13. 主板显卡服务器维修,显卡无显示怎么维修 显卡无显示解决方法【详细介绍】...
  14. 微信小程序消息订阅超详细流程步骤
  15. 各位观众老爷不如点进来随便评论几句QUQ
  16. 小程序后台数据交互-个人中心
  17. 应急响应-敏感信息泄露怎么解决?
  18. 华为瘦胖ap互转_华为V2R3 胖瘦AP 转换
  19. Flex 弹性盒子布局使用教程
  20. 无线传感网络技术实验-实现一种传播协议

热门文章

  1. XTU,C语言,Colombian Number
  2. Word论文排版(2)多级列表和编号
  3. 印度半导体的未来猜想
  4. Linux(debian)常用代理设置
  5. 如何修改mysql表中列的大小?
  6. 钟汉良日记:你相信神话吗?你会背《正气歌》吗
  7. java之更快学习反射
  8. 开启可牛超强保护模式,提示:eset nod32 file on-access scanner无法删除的解决方案
  9. NS-3——学习(3)
  10. 2022年全球市场电加热元件总体规模、主要生产商、主要地区、产品和应用细分研究报告