exponenta event banner

Планирование кратчайшего пути

Вы знаете, что кратчайший путь между двумя географическими точками - это большой круг. Моряки и авиаторы заинтересованы в минимизации пройденного расстояния и, следовательно, прошедшего времени. Вы также знаете, что румбная линия - это путь постоянного курса, естественное средство передвижения. В общем, чтобы пройти по великому круговому пути, нужно было бы непрерывно менять курс. Это нецелесообразно. Однако можно аппроксимировать большую траекторию окружности с помощью отрезков римбованной линии так, чтобы добавленное расстояние было меньшим, а количество курсов менялось минимальным.

Удивительно, но для близкой аппроксимации расстояния пути большой окружности требуется очень мало трапа.

Рассмотрим путешествие из Норфолка, штат Виргиния (37 ° N, 76 ° W), на мыс Сент - Винсент, Португалия (37 ° N, 9 ° W), один из наиболее интенсивных маршрутов в Атлантике. Протяжённость трассы с вершиной на восток составляет 3 213 морских миль, в то время как оптимальное большое расстояние от круга составляет 3 141 морскую милю.

Хотя длина пути линии румба лишь немногим более 2%, это дополнительные 72 мили по ходу путешествия. Для 12-узлового танкера это приводит к 6-часовой задержке, а в отгрузке время - деньги. Если для аппроксимации большого круга используются только три отрезка линии румба, общее расстояние поездки составляет 3 147 морских миль. Наш танкер потерпел бы лишь получасовую задержку по сравнению с непрерывным курсом румба. Вот код для вычисления трех типов треков между Норфолком и Сент-Винсентом:

figure('color','w');
ha = axesm('mapproj','mercator',...
           'maplatlim',[25 55],'maplonlim',[-80 0]);
axis off, gridm on, framem on;
setm(ha,'MLineLocation',15,'PLineLocation',15);
mlabel on, plabel on;
load coastlines;
hg = geoshow(coastlat,coastlon,'displaytype','line','color','b');

% Define point locs for Norfolk, VA and St. Vincent, Portugal
norfolk = [37,-76];
stvincent = [37, -9];
geoshow(norfolk(1),norfolk(2),'DisplayType','point',...
    'markeredgecolor','k','markerfacecolor','k','marker','o')
text(-0.61,0.66,'Norfolk','HorizontalAlignment','left')
geoshow(stvincent(1),stvincent(2),'DisplayType','point',...
    'markeredgecolor','k','markerfacecolor','k','marker','o')
text(0.54,0.66,'St. Vincent','HorizontalAlignment','right')

% Compute and draw 100 points for great circle
gcpts = track2('gc',norfolk(1),norfolk(2),...
               stvincent(1),stvincent(2));
geoshow(gcpts(:,1),gcpts(:,2),'DisplayType','line',...
    'color','red','linestyle','--')
text(-0.02,0.85,'Great circle: 3,141 nm (optimal)',...
    'color','r','HorizontalAlignment','center')

% Compute and draw 100 points for rhumb line
rhpts = track2('rh',norfolk(1),norfolk(2),...
                stvincent(1),stvincent(2));
geoshow(rhpts(:,1),rhpts(:,2),'DisplayType','line',...
    'color',[.7 .1 0],'linestyle','-.')
text(-0.02,0.66,'Direct course: 3,213 nm',...
    'color',[.7 .1 0],'HorizontalAlignment','center')

% Compute and draw path along three waypoints
[latpts,lonpts] = gcwaypts(norfolk(1),norfolk(2),...
    stvincent(1),stvincent(2),3);
geoshow(latpts,lonpts,'DisplayType','line',...
    'color',[.4 .2 0],'linestyle','-')
text(-0.02,0.75,'3-leg approximation: 3,149 nm',...
    'color',[.4 .2 0],'HorizontalAlignment','center')
Полученные трассы и расстояния показаны ниже:

Функция Toolbox™ мэппинга gcwaypts вычисляет ППМ в формате навигационной дорожки для аппроксимации большого круга с отрезками линии румба. Он использует следующий синтаксис:

[latpts,lonpts] = gcwaypts(lat1,lon1,lat2,lon2,numlegs)

Все входы для этой функции являются скалярами a (начальная и конечная позиция). numlegs введите требуемое количество ветвей равной длины, которое по умолчанию равно 10. Выходами являются векторы столбцов, представляющие ППМ в формате навигационной дорожки ([heading distance]). Размер каждого из этих векторов равен [(numlegs+1) 1]. Вот пункты для этого примера:

[latpts,lonpts] = gcwaypts(norfolk(1),norfolk(2),...
stvincent(1),stvincent(2),3)   % Compute 3 waypoints
latpts =

   37.0000
   41.5076
   41.5076
   37.0000

lonpts =

  -76.0000
  -54.1777
  -30.8223
   -9.0000

Эти точки представляют ППМ вдоль большой окружности, между которыми аппроксимирующая траектория следует по осенним линиям. Четыре очка нужны для трех ног, потому что финальная точка на мысе Сент-Винсент должна быть включена.

Теперь мы можем вычислить расстояние в морских милях (нм) вдоль каждой дорожки и через ППМ:

drh = distance('rh',norfolk,stvincent); % Get rhumb line dist (deg)
dgc = distance('gc',norfolk,stvincent); % Get gt. circle dist (deg)
% Compute headings and distances for the waypoint legs
[course distnm] = legs(latpts,lonpts,'rh');
Наконец, сравните расстояния:
distrhnm = deg2nm(drh)            % Nautical mi along rhumb line
distgcnm = deg2nm(dgc)            % Nautical mi along great circle
distlegsnm = sum(distnm)          % Total dist along the 3 legs
rhgcdiff = distrhnm - distgcnm    % Excess rhumb line distance
trgcdiff = distlegsnm - distgcnm  % Excess distance along legs
distrhnm =

  3.2127e+003

distgcnm =

  3.1407e+003

distlegsnm =

  3.1490e+003

rhgcdiff =

   71.9980

trgcdiff =

    8.3446
Следование только за тремя ножками линии румба уменьшает пройденное расстояние с 72 нм до 8,3 нм по сравнению с большим курсом круга.

Связанные темы