主要内容

本页采用了机器翻译。点击此处可查看英文原文。

geodetic2enu

将大地坐标转换为局部东北天坐标

说明

[xEast,yNorth,zUp] = geodetic2enu(lat,lon,h,lat0,lon0,h0,spheroid) 将由 latlonh 指定的大地坐标转换为由 xEastyNorthzUp 指定的局部东北天 (ENU) 笛卡尔坐标。使用大地坐标系中的 lat0lon0h0 坐标指定局部 ENU 坐标系的原点。每个坐标输入参数的大小必须与其他参数一致,或为标量。将 spheroid 指定为大地坐标系的参考椭球体。

示例

[xEast,yNorth,zUp] = geodetic2enu(___,angleUnit) 指定经纬度的单位。将 angleUnit 指定为 'degrees'(默认值)或 'radians'

示例

全部折叠

根据其大地坐标,求瑞士采尔马特地区马特洪峰的 ENU 坐标。

首先,将参考椭球体指定为 WGS84。有关 WGS84 的更多信息,请参阅Comparison of Reference Spheroids。椭球高和 ENU 坐标的单位必须与参考椭球体 LengthUnit 属性所指定的单位一致。由 wgs84Ellipsoid 创建的参考椭球体的默认长度单位是 'meter'

wgs84 = wgs84Ellipsoid;

指定局部原点的大地坐标。在此示例中,局部原点为瑞士采尔马特。将 h0 指定为椭球高(单位:米)。

lat0 = 46.017;
lon0 = 7.750;
h0 = 1673;

指定目标点的大地坐标。在这个示例中,焦点是马特洪峰。将 h 指定为椭球高(单位:米)。

lat = 45.976;
lon = 7.658;
h = 4531;

然后,计算马特洪峰相对于采尔马特的 ENU 坐标。通过将显示格式指定为 shortG,以标准记法查看结果。

format shortG
[xEast,yNorth,zUp] = geodetic2enu(lat,lon,h,lat0,lon0,h0,wgs84)
xEast = 
      -7134.8

yNorth = 
      -4556.3

zUp = 
       2852.4

使用 enu2geodetic 函数逆转转换。

[lat,lon,h] = enu2geodetic(xEast,yNorth,zUp,lat0,lon0,h0,wgs84)
lat = 
       45.976

lon = 
        7.658

h = 
        4531

输入参数

全部折叠

一个或多个点的大地纬度,指定为标量、向量、矩阵或 N 维数组。请以度为单位指定数值。要使用弧度值,请将 angleUnit 参数指定为 'radians'

数据类型: single | double

一个或多个点的大地经度,指定为标量、向量、矩阵或 N 维数组。请以度为单位指定数值。要使用弧度值,请将 angleUnit 参数指定为 'radians'

数据类型: single | double

一个或多个点的椭球高,指定为标量、向量、矩阵或 N 维数组。请使用与 spheroid 对象的 LengthUnit 属性匹配的单位指定数值。例如,由 wgs84Ellipsoid 创建的参考椭球体的默认长度单位是 'meter'

有关椭球高(ellipsoidal height)的更多信息,请参阅从正高推算椭球高

数据类型: single | double

局部原点的大地纬度,指定为标量、向量、矩阵或 N 维数组。局部原点可以指一个点或一系列点(例如移动平台)。请以度为单位指定数值。要使用弧度值,请将 angleUnit 参数指定为 'radians'

数据类型: single | double

局部原点的大地经度,指定为标量、向量、矩阵或 N 维数组。局部原点可以指一个点或一系列点(例如移动平台)。请以度为单位指定数值。要使用弧度值,请将 angleUnit 参数指定为 'radians'

数据类型: single | double

局部原点的椭球高度,指定为标量、向量、矩阵或 N 维数组。局部原点可以指一个点或一系列点(例如移动平台)。请使用与 spheroid 对象的 LengthUnit 属性匹配的单位指定数值。例如,由 wgs84Ellipsoid 创建的参考椭球体的默认长度单位是 'meter'

有关椭球高(ellipsoidal height)的更多信息,请参阅从正高推算椭球高

数据类型: single | double

参考椭球体,指定为 referenceEllipsoid 对象、oblateSpheroid 对象或 referenceSphere 对象。术语“参考球体”与“参考椭球体”同义,可互换使用。要创建参考椭球体,请使用该对象的创建函数。要指定 WGS84 参考椭球体,请使用 wgs84Ellipsoid 函数。

有关参考椭球体的更多信息,请参阅Comparison of Reference Spheroids

示例: spheroid = referenceEllipsoid('GRS 80');

角度单位,指定为 'degrees'(默认值)或 'radians'

输出参量

全部折叠

局部东北天 (ENU) 坐标系中一个或多个点的 ENU x 坐标,以标量、向量、矩阵或 N 维数组形式返回。单位由 spheroid 参数的 LengthUnit 属性指定。例如,由 wgs84Ellipsoid 创建的参考椭球体的默认长度单位是 'meter'

局部东北天 (ENU) 坐标系中一个或多个点的 ENU y 坐标,以标量、向量、矩阵或 N 维数组形式返回。单位由 spheroid 参数的 LengthUnit 属性指定。例如,由 wgs84Ellipsoid 创建的参考椭球体的默认长度单位是 'meter'

局部东北天 (ENU) 坐标系中一个或多个点的 ENU z 坐标,以标量、向量、矩阵或 N 维数组形式返回。单位由 spheroid 参数的 LengthUnit 属性指定。例如,由 wgs84Ellipsoid 创建的参考椭球体的默认长度单位是 'meter'

扩展功能

全部展开

C/C++ 代码生成
使用 MATLAB® Coder™ 生成 C 代码和 C++ 代码。

版本历史记录

在 R2012b 中推出

全部展开