matlab求两点距离的函数
时间: 2023-08-23 07:26:35 浏览: 65
在Matlab中,可以使用以下代码计算两点之间的距离:
```matlab
function dist = distance(x1, y1, x2, y2)
dist = sqrt((x2 - x1)^2 + (y2 - y1)^2);
end
```
其中,x1、y1为第一个点的坐标,x2、y2为第二个点的坐标。函数返回值为两点之间的距离。
相关问题
MATLAB计算两点相干函数代码
以下是MATLAB计算两点相干函数的代码:
```matlab
% 定义参数
lambda = 0.6328e-6; % 波长
d = 1e-3; % 两点间距离
L = 10e-3; % 透镜直径
f = 100e-3; % 透镜焦距
N = 512; % 网格数
% 生成网格
x = linspace(-L/2, L/2, N);
[X,Y] = meshgrid(x);
% 计算两点光源的复振幅
U1 = exp(1i*pi*d/lambda*(X.^2 + Y.^2)/f);
% 计算透镜传递函数
H = exp(-1i*pi*lambda*f*(X.^2 + Y.^2));
% 计算透镜输出场
U2 = H.*U1;
% 计算两点相干函数
G = abs(U2).^2;
% 绘制结果
figure;
imagesc(x, x, G);
axis square;
colormap(jet);
colorbar;
xlabel('x (m)');
ylabel('y (m)');
title('Two Point Coherence Function');
```
在这个代码中,我们首先定义了一些参数,包括波长、两点间距离、透镜直径、透镜焦距和网格数。然后,我们生成一个正方形网格,并计算两点光源的复振幅,透镜传递函数以及透镜输出场。最后,我们计算了两点相干函数,并绘制了结果。
需要注意的是,这个代码中使用了理想的透镜传递函数,实际情况下,透镜的传递函数可能会有一些畸变。
matlab已知两点经纬度求距离
可以使用 MATLAB 自带的 geodetic2ecef 和 distance 函数来计算两点之间的距离。
假设有两个点的经纬度分别为 (lat1, lon1) 和 (lat2, lon2),则可以按照以下步骤计算它们之间的距离:
1. 将经纬度转换为地心坐标系下的坐标。可以使用 geodetic2ecef 函数来实现:
```
[x1, y1, z1] = geodetic2ecef(lat1, lon1, 0);
[x2, y2, z2] = geodetic2ecef(lat2, lon2, 0);
```
2. 计算两点之间的距离。可以使用 distance 函数来计算:
```
dist = distance('gc', lat1, lon1, lat2, lon2);
```
其中,'gc' 表示计算大圆航线距离。注意,distance 函数的输入参数是经纬度,而不是地心坐标系下的坐标。
完整的 MATLAB 代码如下:
```
lat1 = 39.9; % 第一个点的纬度
lon1 = 116.4; % 第一个点的经度
lat2 = 31.2; % 第二个点的纬度
lon2 = 121.5; % 第二个点的经度
[x1, y1, z1] = geodetic2ecef(lat1, lon1, 0);
[x2, y2, z2] = geodetic2ecef(lat2, lon2, 0);
dist = distance('gc', lat1, lon1, lat2, lon2);
fprintf('两点之间的距离为 %.2f 千米\n', dist);
```
注意,这只是一个简单的示例,实际应用中需要考虑更多的因素,例如地球的椭球形状等。