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

答:首先计算坐标增量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的计算_python 计算方位角实例(根据两点的坐标计算)

    知道两点坐标,怎么计算两点方向的方位角? 答:首先计算坐标增量dx,dy(两个对应坐标分量相减,终点的减始点的). 若dx,dy中有一个为零时,根据另一个的正负决定方位角(0,90,180,270这四 ...

  2. python计算两点间距离_python 计算方位角实例(根据两点的坐标计算)

    知道两点坐标,怎么计算两点方向的方位角? 答:首先计算坐标增量dx,dy(两个对应坐标分量相减,终点的减始点的). 若dx,dy中有一个为零时,根据另一个的正负决定方位角(0,90,180,270这四 ...

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

    知道两点坐标,怎么计算两点方向的方位角? 答:首先计算坐标增量dx,dy(两个对应坐标分量相减,终点的减始点的). 若dx,dy中有一个为零时,根据另一个的正负决定方位角(0,90,180,270这四 ...

  4. python计算方位角_实例讲解:用python 计算方位角(根据两点的坐标计算)记得收藏哦...

    今天为大家分享一篇python 计算方位角实例(根据两点的坐标计算),具有很好的参考价值,希望对大家有所帮助.一起来看看吧! 知道两点坐标,怎么计算两点方向的方位角? 答:首先计算坐标增量dx,dy( ...

  5. python 计算方位角(根据两点的坐标计算)

    知道两点坐标,怎么计算两点方向的方位角? 答:首先计算坐标增量dx,dy(两个对应坐标分量相减,终点的减始点的). 若dx,dy中有一个为零时,根据另一个的正负决定方位角(0,90,180,270这四 ...

  6. python根据年月日计算天数_Python基础练习实例4(年月日算天数)

    题目:输入某年某月某日,判断这一天是这一年的第几天? 程序分析:以2018年3月1日为例,应该先把前两个月的加起来(按月分,用一个数组存储之前的天数),然后再加上5天即本年的第几天,特殊情况,闰年且输 ...

  7. python 日期 间隔_Python datetime time 等时间 日期 之间的计算和相互转化

    from datetime importdatetime, date, timedelta, timezonefrom time importtime, ctime, localtime, strft ...

  8. 怎么用python输入计算公式_python怎么把输入的数值代入公式计算

    展开全部 过程如复下: 1.a=int(input("Input a num:")) #python 3.X 2.b=int(input("Input another n ...

  9. python 映射表_python映射列表实例分析

    本文实例讲述了python映射列表.分享给大家供大家参考.具体分析如下: 列表映射是个非常有用的方法,通过对列表的每个元素应用一个函数来转换数据,可以使用一种策略或者方法来遍历计算每个元素. 例如: ...

  10. python生成日历_Python创建日历实例代码

    Python创建日历的方法 以下代码不使用Python提供的calendar实现. 此程序在windows下测试通过,由于python字符编码直接输出给操作系统,so win下以gbk ansi为准, ...

最新文章

  1. javaScript DOM编程常用的方法与属性
  2. C++ 基类和派生类的析构函数
  3. 为什么不是基址寻址适用于数组_微机原理--8种寻址方式
  4. python学生管理系统(函数方法)_(python函数)学生管理系统
  5. pdftk — PDF万用命令行工具
  6. skyline 系列 1 - 简介、下载
  7. ANSYS应力工具与四大强度理论
  8. 操作无法完成 打印后台程序服务没有运行
  9. 项目组织结构的3种类型:职能型、项目型和矩阵型
  10. 实录:记谷歌在微信脚下的一次翻车
  11. 使用GitHub Actions实现Hexo博客自动发布
  12. 华为eNSP防火墙NAT配置
  13. Azkban上传文件报错installation Failed.Error chunking
  14. 分布式与集群的区别?
  15. html中js隐藏div的高度,javascript获取隐藏元素(display:none)的高度和宽度的方法
  16. Easy Excel
  17. 聚焦爬虫与通用爬虫详解
  18. PMP可以自学报考吗
  19. 旅行青蛙破解 无限复活草+抽奖+diy
  20. 2023 电脑PC 素材解析浏览器插件 支持20网

热门文章

  1. android apk很大,从Android Studio生成的Apk文件太大
  2. php 下载excel文件,单独设置工作表(sheet1,sheet2,sheet3....)
  3. 一文读懂 Jmeter - 你以为Jmeter只能用来做压力测试?
  4. 中继器、集线器、网桥、交换机、路由器、网关的超全总结
  5. 清除右键新建中多余菜单
  6. 笔记本锁定计算机怎么解锁,笔记本键盘被锁定了怎么办 笔记本解锁键盘的方法...
  7. Android 状态栏常规操作(状态栏显示,状态栏颜色,沉浸式状态栏)
  8. STM32F103_study43_The punctual atoms(STM32 Echo experiment based on serial communication )
  9. C语言解决渔夫打鱼晒网问题
  10. Qt实现思维导图功能(一)