Форум программистов, компьютерный форум, киберфорум
Зосима
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  

Охват точек линией минимальной длинны в MATLAB

Запись от Зосима размещена 06.10.2021 в 09:38
Показов 4079 Комментарии 3

Как-то давно писал программку и вот она вновь пригодилась.
Может еще кому будет полезна)
Суть в чем? Есть несколько точек и нужно охватить их всех так, чтобы линия имела минимальный периметр.
По-научному такие линии называются "минимально выпуклая оболочка", почитать о них можно например на хабре. Собственно из этой статьи я и взял алгоритм.
Matlab 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
clear, clc
% случайные точки
N = 10;
x = randn(N,1);
y = randn(N,1);
plot(x,y,'.') % рисуем исходные точки
hold on 
p = x + 1i*y; % переводим координаты в комплексный вид, чтобы было проще записывать
% берем самую левую точку - это первая точка оболочки z
z(1) = p( x == min(x) ); 
k = 1; % счетчик точек
% алгоритм Джарвиса
while z(end) ~= z(1) | k == 1 % пока не вернемся к начальной точке (или только первый шаг)
    % находим разности всех точек и текущей: p-z(k) 
    % вычисляем аргумент этих разностей (angle)
    % функция unwrap убирает разрывы:
    f1 = unwrap( angle( p-z(k) ) ) ;
    % игнорируем точки, у которых аргумент получился +/-пи, 
    % то есть они находятся позади, чтобы не возвращалось:
    f1( abs(f1)-pi==0 ) = NaN; 
    % сохраняем в массив z точку с минимальным аргументом:
    z(k+1) = p( f1==min(f1) );
    p( p==z(k+1) ) = []; % убираем из исходного набора эту точку
    k = k + 1; % увеличиваем счетчик
end
plot(z,'d-r') % рисуем оболочку
hold off
% периметр - это сумма (sum) отрезков оболочки,
% длинна каждого равна модулю (abs) разности соседних (diff) точек
P = sum( abs( diff(z) ) );
title(['Периметр P = ',num2str(P)]) % подписываем
Нажмите на изображение для увеличения
Название: 01.png
Просмотров: 575
Размер:	22.5 Кб
ID:	7167 Нажмите на изображение для увеличения
Название: 02.png
Просмотров: 515
Размер:	57.1 Кб
ID:	7168
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 3
Комментарии
  1. Старый комментарий
    Классный алгоритм! Мне правда приходилось решать несколько иную задачу. Заключить множество случайных точек в окружность наименьшего радиуса. А изначально все точки заключались в прямоугольник либо сразу вычислялся минимальный диаметр окружности... В общем программа работала как волк.
    Запись от wer1 размещена 06.10.2021 в 11:08 wer1 вне форума
  2. Старый комментарий
    Уважаемый Зосима,
    мне интересно вот что, как изменится алгоритм вашей программы, если допустим из 100 случайных точек надо заключить в "минимально выпуклую оболочку" например 90% всех точек? Плюс/минус одна точка значения не имеет. Или это совсем другая задача?
    Запись от wer1 размещена 06.10.2021 в 11:14 wer1 вне форума
  3. Старый комментарий
    Там разве нет готового?
    MATLAB convhull и convhulln
    Запись от Excalibur921 размещена 06.10.2021 в 12:46 Excalibur921 вне форума
 
Новые блоги и статьи
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
Модель здравосохранения 18. Чем здоровее работник, тем быстрее выгорает
anaschu 24.05.2026
Имитационная модель корпоративного здравоохранения: что показывает математика Сегодня в модели рабочего коллектива на AnyLogic появились три новые механики — выгорание через накопленную усталость,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru