Russian Qt Forum
Ноябрь 23, 2024, 08:07
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Программирование
>
С/C++
>
lower_bound_2d (найти ближайшее)
Страниц:
1
[
2
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: lower_bound_2d (найти ближайшее) (Прочитано 10711 раз)
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: lower_bound_2d (найти ближайшее)
«
Ответ #15 :
Октябрь 11, 2014, 12:14 »
Цитата: kramer от Октябрь 11, 2014, 11:52
Как посчитать радиус поиска для заданной точки - я там выше писал.
Наверное имеется ввиду это
Цитата: kramer от Октябрь 08, 2014, 12:28
...но начальный радиус для поиска можно найти так dist=max(min(dx), min(dy), где dx, dy - расстояния между соседними точками в отсортированном массиве.
А что это за радиус? Так, просто взятый с потолка? Пример
Цитировать
*** ****
*** х(запрос) ****
*** ****
Начальный радиус получится маленьким, отсеченный куб - пустым. И что, выходит для запросной точки вообще нет ближайшей?
Записан
kramer
Гость
Re: lower_bound_2d (найти ближайшее)
«
Ответ #16 :
Октябрь 13, 2014, 07:09 »
Цитировать
А что это за радиус? Так, просто взятый с потолка? Пример
Нет, я там в том же комменте поправился, хотя там тоже не совсем верно. Должно быть так:
dist = max(min(abs(lower_bound_x - x), abs(upper_bound_x - x)),
min(abs(lower_bound_y - y), abs(upper_bound_y - y)),
min(abs(lower_bound_z - z), abs(upper_bound_z - z)))
Понятно, случай lower_bound_x - x = 0 и ему подобные надо обрабатывать отдельно.
Записан
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: lower_bound_2d (найти ближайшее)
«
Ответ #17 :
Октябрь 13, 2014, 09:03 »
Цитата: kramer от Октябрь 13, 2014, 07:09
Цитировать
А что это за радиус? Так, просто взятый с потолка? Пример
Нет, я там в том же комменте поправился, хотя там тоже не совсем верно. Должно быть так:
dist = max(min(abs(lower_bound_x - x), abs(upper_bound_x - x)),
min(abs(lower_bound_y - y), abs(upper_bound_y - y)),
min(abs(lower_bound_z - z), abs(upper_bound_z - z)))
Понятно, случай lower_bound_x - x = 0 и ему подобные надо обрабатывать отдельно.
То есть берем соседнюю точку(и) по первой оси. Так они могут оказаться далеко по др осям, в итоге куб большой и содержит много точек которые надо перебирать. Для нахождения "просто ближайшего" это плохо.
Ладно, предлагаю обсудить более интересные вещи. Мы выяснили что если точки распределены "достаточно равномерно" - то любая разумная схема работает прилично и с (примерно) O(log N). А вот что если нет? Предлагали выбирать ось на которой наибольшее проецируемое расстояние. А если будет так
Цитировать
**
**
**
** *
А главное - как оценить "равномерность"? Напр расстояние между 2 точками по оси = 10. И что, много это или мало? Стоит ли разбивать данные на неск структур или нет?
Записан
kramer
Гость
Re: lower_bound_2d (найти ближайшее)
«
Ответ #18 :
Октябрь 14, 2014, 13:20 »
Цитировать
То есть берем соседнюю точку(и) по первой оси. Так они могут оказаться далеко по др осям, в итоге куб большой и содержит много точек которые надо перебирать. Для нахождения "просто ближайшего" это плохо.
Ну, безусловно, метод не без оверхеда. Но если хорошенько подумать, наверняка можно что-нибудь хорошенько соптимизировать.
Цитировать
А главное - как оценить "равномерность"? Напр расстояние между 2 точками по оси = 10. И что, много это или мало? Стоит ли разбивать данные на неск структур или нет?
Это очень волнующая тема, на самом деле. Выбор "разбивающей" эвристики для различных целей - тема многих и многих диссертаций по CS.
Например, можно попробовать разбивать не медианой, а просто срединной точкой по каждой оси, fabs(min_x-max_x)/2. Дерево получится в общем случае несбалансированным, зато будет принимать в расчет расположение точек в пространстве, в отличие от медианного дерева, которое учитывает лишь их порядок. Понятно, тут уже не обойтись без некоторой структуры данных, хранящей это разбиение.
Записан
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: lower_bound_2d (найти ближайшее)
«
Ответ #19 :
Октябрь 14, 2014, 14:11 »
Цитата: kramer от Октябрь 14, 2014, 13:20
Это очень волнующая тема, на самом деле. Выбор "разбивающей" эвристики для различных целей - тема многих и многих диссертаций по CS.
Ну попробую и я "блеснуть эрудицией"
В тех диссерах речь идет не о точках, а о примитивах (часто полигонах). При их разбиении примитив на секущей плоскости оказывается сразу в 2 нодах, что нежелательно и.т.д. Для точек все должно быть попроще (ну это я так думаю).
Цитата: kramer от Октябрь 14, 2014, 13:20
Например, можно попробовать разбивать не медианой, а просто срединной точкой по каждой оси, fabs(min_x-max_x)/2. Дерево получится в общем случае несбалансированным, зато будет принимать в расчет расположение точек в пространстве, в отличие от медианного дерева, которое учитывает лишь их порядок. Понятно, тут уже не обойтись без некоторой структуры данных, хранящей это разбиение.
Часто сцена небольшая, напр 1х1х1, но есть "floor" - плоскость на которой все стоит, и эта подложка большая, напр 1000х1000. В этом случае разбиение "по пространству пополам" оказывается невыгодным - вся силенка уходит в пустые ноды, а на "облако" сил уже не остается - кончилась глубина дерева
Записан
kramer
Гость
Re: lower_bound_2d (найти ближайшее)
«
Ответ #20 :
Октябрь 14, 2014, 16:48 »
Цитировать
Для точек все должно быть попроще (ну это я так думаю).
Для точек тоже наворотили всякого - жуть берет.
Но вообще, вы правы, для точек все действительно попроще, если судить по опыту.
Цитировать
Часто сцена небольшая, напр 1х1х1, но есть "floor" - плоскость на которой все стоит, и эта подложка большая, напр 1000х1000. В этом случае разбиение "по пространству пополам" оказывается невыгодным - вся силенка уходит в пустые ноды, а на "облако" сил уже не остается - кончилась глубина дерева
Хм. Есть еще такая штука, называется sliding midpoint rule. Вот, взгляните:
http://www.cs.umd.edu/~mount/Papers/cgc99-smpack.pdf
Суть в том, что если в одном из поддеревьев при разбиении посередине точек не оказывается, точка разбиения съезжает в ближайшую по соответствующей оси в другом поддереве. Таким образом уже на третьем разбиении по данной оси граница поддерева будет проходить по границе сцены (1х1х1).
Еще как вариант - можно строить обычные деревья пообъектно, выбирать перебором ближайший объект по расстоянию до bounding box, искать в нем ближайшую точку с помощью соотв. дерева, потом опять же отсекать остальные объекты по расстоянию до bounding box (если больше найденного - то выкинуть), среди оставшихся опять искать с помощью их деревьев. Для объектов с количеством вершин меньше некоторого N можно и вовсе просто перебором искать, это будет быстрее за счет кэша.
Записан
Страниц:
1
[
2
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...