172 похожих чатов

Есть path состоящий из массива координат(lat, lng), проецированная от дорог,

естественно для уменьшения размера массива в прямых дорогах координаты только в начале и конце, в поворотах они учащаются.
Вопрос такой: нужно определить, находится ли пользователь в этом path или поблизости какой либо точки(учитывая точки будут каждые 6 метров, напр 15км=2500 точек) этой path до 30 метров.
Есть вариант прогона 2ух массивов(по lat+-x и lng+-x) , ставя в цикл начальную и конечную точку дорог, но мне кажется это будет слишком ресурсоемко. Есть ли у кого опыт с подобным поиском?

2 ответов

7 просмотров

Генерируешь из линии полигон с нужной тебе шириной(30 метров). На каждый сегмент этого полигона строишь свой bbox. В цикле прогоняешь попадание точки в эти получившиеся bbox'ы. Если попадание есть, то проверяешь попадание в полигон. Перед началом цикла можно проверить попадание в общих bbox полигона. Работать будет очень быстро даже на сотнях тысяч точек.

Есть еще и третий вариант. Генерализируешь линию(упрощаешь) алгоритмом дугласа-пекера, от 2500 точек может остаться 100-200 всего. Потом уже решать проще.

Похожие вопросы

Обсуждают сегодня

Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
32
А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Дорогие любители Прекрасной Джулии! Есть кто-то имеющий практический опыт построения ML для Систем Управления? Нам нужно сделать нейросеть для автоматической подстройки пара...
Roman Timo
4
С той же поддержкой Android в тулчейне, если кому интересно. На Swift Forums шло убогое обсуждение всякой херни годами, но ничего годного так и не появлялось. Пришел vgorloff ...
iMike
1
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Приветствую ребята,у меня база есть,прорешал много задач с литкода,там деревья,списки, бэктрэкинг и все остальное,что мне сейчас делать?есть может куда устроиться поработать,е...
Aקuст Lеתסuд Aקuст Lеתסuд
5
Всех приветствую. Направьте меня в нужное русло. Постепенно переписываю проект с delphi на lazarus. Приложение - обычный windows/linux клиент для бд firebird. Тут все хорошо. ...
Mishutka
4
Anybody want this chat app? If anybody interested dm  me.. Note - Firstly payment then i send you code but i will show work on gmeet.
Rayyan Ahmad
5
Карта сайта