WikiDer > R * дерево
R * дерево | |||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Изобрел | 1990 | ||||||||||||||||
Изобретенный | Норберт Бекманн, Ханс-Петер Кригель, Ральф Шнайдер и Бернхард Зигер | ||||||||||||||||
Сложность времени в нотация большой O | |||||||||||||||||
|
В обработка данных R * -деревья являются вариантом R-деревья используется для индексации пространственной информации. R * -деревья имеют немного более высокую стоимость строительства, чем стандартные R-деревья, так как данные могут потребовать повторной вставки; но получившееся дерево обычно будет иметь лучшую производительность запроса. Как и стандартное R-дерево, оно может хранить как точечные, так и пространственные данные. Это было предложено Норбертом Бекманном, Ханс-Петер Кригель, Ральф Шнайдер и Бернхард Зигер в 1990 году.[1]
Разница между R * -деревьями и R-деревьями
Минимизация покрытия и перекрытия имеет решающее значение для производительности R-деревьев. Перекрытие означает, что при запросе или вставке данных необходимо расширить более одной ветви дерева (из-за способа разделения данных на области, которые могут перекрываться). Минимизированное покрытие улучшает производительность отсечения, позволяя чаще исключать целые страницы из поиска, в частности, для запросов с отрицательным диапазоном. R * -дерево пытается уменьшить оба, используя комбинацию пересмотренного алгоритма разделения узлов и концепции принудительного повторного вставления узла переполнение. Это основано на наблюдении, что структуры R-tree очень восприимчивы к порядку, в котором их записи вставляются, поэтому структура, построенная путем вставки (а не загруженная массово), вероятно, будет неоптимальной. Удаление и повторная вставка записей позволяет им «найти» место в дереве, которое может быть более подходящим, чем их исходное местоположение.
Когда узел переполняется, часть его записей удаляется из узла и повторно вставляется в дерево (чтобы избежать неопределенного каскада повторных вставок, вызванного последующим переполнением узла, подпрограмму повторной вставки можно вызывать только один раз на каждом уровне дерево при вставке любой новой записи.) Это дает эффект создания более хорошо сгруппированных групп записей в узлах, уменьшая охват узла. Кроме того, фактическое разделение узлов часто откладывается, что приводит к увеличению средней занятости узлов. Повторную вставку можно рассматривать как метод возрастающей оптимизации дерева, запускаемой при переполнении узла.
Спектакль
- Благодаря улучшенной эвристике разделения страницы становятся более прямоугольными и, следовательно, лучше подходят для многих приложений.
- Метод повторной вставки оптимизирует существующее дерево, но увеличивает сложность.
- Эффективно поддерживает точечные и пространственные данные одновременно.
- Влияние различных эвристик разделения на базу данных с почтовыми округами Германии
R-дерево с квадратичным расщеплением Гутмана.[2]
Есть много страниц, которые простираются с востока на запад по всей Германии, и страницы сильно перекрываются. Это невыгодно для большинства приложений, которым часто требуется только небольшая прямоугольная область, пересекающаяся со многими срезами.R-Tree с линейным разбиением Ang-Tan.[3]
Хотя фрагменты не растягиваются так далеко, как в случае с Guttman, проблема нарезки затрагивает почти каждую конечную страницу. Листовые страницы немного перекрываются, но страницы каталогов имеют место.R * дерево топологическое расщепление.[1]
Страницы очень мало перекрываются, так как R * -дерево пытается минимизировать перекрытие страниц, а повторные вставки дополнительно оптимизировали дерево. Стратегия разделения также не предпочитает срезы, поэтому получаемые страницы гораздо более полезны для обычных картографических приложений.
Алгоритм и сложность
- R * -дерево использует тот же алгоритм, что и обычный R-дерево для операций запроса и удаления.
- При вставке R * -дерево использует комбинированную стратегию. Для конечных узлов перекрытие минимизировано, а для внутренних узлов минимизированы увеличение и площадь.
- При разделении R * -дерево использует топологическое разделение, которое выбирает ось разделения на основе периметра, а затем минимизирует перекрытие.
- В дополнение к улучшенной стратегии разделения, R * -дерево также пытается избежать разделения, повторно вставляя объекты и поддеревья в дерево, вдохновленное концепцией балансировки B-дерево.
Таким образом, сложность запроса наихудшего случая и удаления идентична R-дереву. Стратегия вставки в R * -дерево с сложнее, чем стратегия линейного разделения () R-дерева, но менее сложна, чем стратегия квадратичного расщепления () для размера страницы объектов и мало влияет на общую сложность. Общая сложность вставки по-прежнему сравнима с R-деревом: повторные вставки затрагивают не более одной ветви дерева и, следовательно, повторные вставки, сравнимые с выполнением разбиения на обычном R-дереве. Таким образом, в целом сложность R * -дерева такая же, как и у обычного R-дерева.
Реализация полного алгоритма должна учитывать множество угловых и связанных ситуаций, не обсуждаемых здесь.
Рекомендации
- ^ а б Beckmann, N .; Кригель, Х.; Schneider, R .; Сигер, Б. (1990). «R * -дерево: эффективный и надежный метод доступа для точек и прямоугольников». Материалы международной конференции ACM SIGMOD по управлению данными 1990 г. - SIGMOD '90 (PDF). п. 322. Дои:10.1145/93597.98741. ISBN 0897913655.
- ^ Гуттман А. (1984). "R-деревья: динамическая структура индекса для пространственного поиска". Материалы международной конференции ACM SIGMOD 1984 по управлению данными - SIGMOD '84 (PDF). п. 47. Дои:10.1145/602259.602266. ISBN 0897911288.
- ^ Ang, C.H .; Тан, Т. С. (1997). «Новый алгоритм разделения линейных узлов для R-деревьев». В Шолле, Мишель; Voisard, Agnès (ред.). Материалы 5-го Международного симпозиума по достижениям в области пространственных баз данных (SSD '97), Берлин, Германия, 15–18 июля 1997 г.. Конспект лекций по информатике. 1262. Springer. С. 337–349. Дои:10.1007/3-540-63238-7_38.
внешняя ссылка
- СМИ, связанные с R * дерево в Wikimedia Commons