Matlab之求直角坐标系下两直线的交点坐标

目的:在直角坐标系下,求两个直线的交点坐标

一、函数的参数说明

输入参数:

PointA:直线A上的点坐标;

AngleA:直线A的倾斜角,单位度;

PointB:直线B上的点坐标;

AngleB:直线B的倾斜角,单位度;

输出参数:

TargetPoint:交点坐标

二、函数的Matlab代码

cpp 复制代码
%% 双站测向交叉定位算法
%% 自拟算法,通过左除计算
function [TargetPoint]=DoubleStationCrossLocAlgorithm(PointA,AngleA,PointB,AngleB)
    A=[1,-tand(AngleA);1,-tand(AngleB)];
    b=[PointA(2)-tand(AngleA)*PointA(1);
       PointB(2)-tand(AngleB)*PointB(1)];
   
   TargetPoint=A\b;%左除运算,计算交叉点坐标
end

2.1 方向向量转换为真方位

direction_vector:方向向量

AOA:真方位

cpp 复制代码
% 归一化向量,方向向量
direction_vector = vector / norm(vector);% direction_vector 现在是表示P1到P2方向的单位向量

AOA=mod(atan2(direction_vector(1),direction_vector(2))*180/pi+360,360);

2.2 真方位转换为倾斜角

cpp 复制代码
%% 真方位转换为倾斜角
function [ElevationAngle]=Azimuth2ElevationAngle(Azimuth)

%% 第一步计算正弦和余弦值
sine_values = sind(Azimuth);
cosine_values = cosd(Azimuth);

% 构造斜对角线单位向量
% 斜对角线单位向量的x和y分量分别为正弦值和余弦值
vector_y = cosine_values;
vector_x = sine_values;

% 计算倾斜角对应的正切值
ElevationAngle =mod((180+atan2(vector_y, vector_x)*180/pi),180);

end

三、计算的实例

相关推荐
9稳1 分钟前
基于PLC的液体自动混合加热控制系统设计
开发语言·网络·数据库·labview·plc
Aevget8 分钟前
Python开发利器PyCharm v2025.3全新发布——支持主动数据探索
开发语言·ide·python·pycharm
mangge0817 分钟前
批量把word转图片再转pdf,防止文字被复制
开发语言
小c君tt18 分钟前
QT中treewidget中右键添加QAction方法
开发语言·qt
HUST18 分钟前
C 语言 第九讲:函数递归
c语言·开发语言·数据结构·算法·c#
CodeCraft Studio19 分钟前
国产化Word处理控件Spire.Doc教程:使用C# 编程方式批量转换Word为RTF
开发语言·c#·word·spire.doc·word文档转换·word开发组件·word api库
CSDN_RTKLIB21 分钟前
【类定义系列一】C++ 头文件 / 源文件分离
开发语言·c++
invicinble22 分钟前
arthas
开发语言·python
机器学习之心34 分钟前
基于PSO-GA混合算法的施工进度计划多目标优化,以最小化总成本并实现资源均衡,满足工期约束和资源限制,MATLAB代码
算法·matlab·多目标优化·pso-ga混合算法
lzjava202438 分钟前
Python中的模块和包
linux·开发语言·python