-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcl_distance.m
67 lines (52 loc) · 1.67 KB
/
cl_distance.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
% This function calculates the distance between two sets of geographical coordinates
% (longitude and latitude) using the m_map library. It supports single-element and
% multi-element inputs for the reference coordinates.
%
% SPDX-FileCopyrightText: 2021-2024 Helmholtz-Zentrum hereon GmbH
% SPDX-FileContributor: Carsten Lemmen <[email protected]>
% SPDX-License-Identifier: CC0-1.0
% Variables:
% - lon, lat: Longitude and latitude of the first set of coordinates
% - lon0, lat0: Longitude and latitude of the reference coordinates
% - n: Number of elements in the latitude array
% - dlat, dlon: Arrays for reshaped latitude and longitude values
% - dists: Calculated distances between the coordinates
function distance = cl_distance(lon, lat, lon0, lat0)
% distance=cl_distance(lon,lat,lon0,lat0)
if nargin < 2
error('At least two input arguments are required');
end
if ~exist('lon0', 'var')
lon0 = lon;
end
if ~exist('lat0', 'var')
lat0 = lat;
end
if length(size(lon)) ~= 2
error('lon/lat must have at most 2 dimensions');
end
if length(size(lat)) ~= 2
error('lon/lat must have at most 2 dimensions');
end
if numel(lon0) == 1 && numel(lat0) == 1
lon0 = repmat(lon0, size(lon, 1), size(lon, 2));
lat0 = repmat(lat0, size(lat, 1), size(lat, 2));
else
error('Multi-element reference lon/lat not implemented yet');
end
n = numel(lat);
lat = reshape(lat, n, 1);
lat0 = reshape(lat0, n, 1);
lon = reshape(lon, n, 1);
lon0 = reshape(lon0, n, 1);
dlat = [lat lat0];
dlon = [lon lon0];
dlat = reshape(dlat', 2 * n, 1);
dlon = reshape(dlon', 2 * n, 1);
dists = m_lldist(dlon, dlat);
dists = dists(1:2:end);
if nargout > 0
distance = dists;
end
return;
end