Эвристический алгоритм сегментации облака точек
Рассматривается эвристический алгоритм сегментации облака точек, описывающего предмет интерьера, с целью получения сегментации, близкой к разбиению объекта на функциональные элементы. Структура алгоритма, проанализирована его вычислительная сложность.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | статья |
Язык | русский |
Дата добавления | 01.02.2019 |
Размер файла | 182,1 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Эвристический алгоритм сегментации облака точек
А.В. Гасилов, А.И. Фролов
В данной статье рассматривается эвристический алгоритм сегментации облака точек, описывающего предмет интерьера, с целью получения сегментации, близкой к разбиению объекта на функциональные элементы. Данный алгоритм применяется как часть метода улучшения результатов трехмерной реконструкции на основе известной структуры объекта для структуризации облака точек, получаемого на одном из этапов метода. Алгоритм заключается в рекурсивном разбиении облака точек на две части, вплоть до достижения заданного критерия остановки разбиения. В статье рассмотрена структура алгоритма, проанализирована его вычислительная сложность, проведены примеры результатов работы, определено направление дальнейших исследований.
Ключевые слова: облако точек; сегментация.
A.V. Gasilov, A.I. Frolov. Heuristic algorithm of point cloud segmentation
The algorithm of point cloud segmentation is proposed in the article. This algorithm aimed to get segmentation similar to segmentation of object by his functional elements in field of interior design. The given algorithm is used as a part of method of dense 3D reconstruction enhancing for point cloud structuration at some point. Main idea of proposed algorithm is recursive division of parent cloud by two parts until exit conditions are met. Algorithm structure is reviewed, computing complexity is analyzed. The field for further investigations of given problems and their solution is suggested.
Keywords: Point cloud; Segmentation
Построение трехмерных моделей на основе изображений - одна из задач компьютерного зрения, заключающаяся в распознавании образов в поданных на вход алгоритму изображениях и построении на их основе трехмерных моделей.
Задача трехмерной реконструкции уже давно решена в общем виде [1]. Однако, есть пути для улучшения качества существующих технологий по таким параметрам, как точность и полнота реконструкции. Одним из таких путей является применение априорно известной структуры реконструируемого объекта для улучшения полноты реконструкции. В рамках конкретной предметной области, в данном случае - дизайна интерьера, возможен следующий подход:
ѕ Описание оператором структуры объекта;
ѕ Проведение плотной трехмерной реконструкции по снимкам объекта с результатом в виде облака точек;
ѕ Автоматическая сегментация полученного облака точек и получение структуры облака точек в таком же виде, как и структура, описанная оператором;
ѕ Сравнение двух структур и выполнение операций для улучшения полноты реконструкции на основе результатов сравнения.
При этом структура объекта описывается оператором на уровне «стул состоит из сиденья, 4 ножек, спинки, имеющих заданные относительные размеры и положения». Таким образом, одним из этапов данного процесса является сегментация реконструированного облака точек с целью получения его структуры в виде похожем на структуру, задаваемую оператором.
В данной статье предлагается эвристический алгоритм решения данной задачи, рассматриваются особенности его реализации, проводится его анализ, строятся предположения о возможных дальнейших его улучшениях.
Постановка задачи. Задача заключается в приведении входной информации в виде облака точек к виду графа структуры объекта, в котором каждая вершина соответствует некоторому элементу логически цельному элементу объекта, описываемому облаком точек, а ребра будут означать факт соседства элементов графа в пространстве.
Например, разбиение стула, изображенного на рисунке 1а может представлять деление на такие элементы как: «сиденье» - вершина v1, «ножки» - вершины v2, v3, v4, v5 и «спинка» - вершина v6 (рисунок 1б).
а) б)
Рисунок 1 - а) пример входных данных, б) пример требуемых выходных данных Таким образом можно выделить две подзадачи: получение вершин графа и определение наличия ребер между полученными вершинами.
эвристический алгоритм сегментация облако
Получение вершин графа. Для получения вершин графа предлагается сегментировать облако точек и сопоставить вершину графа каждому полученному сегменту.
В качестве отправной точки было решено применить подход, рассмотренный в [2], заключающийся в аппроксимации облака точек ограничивающим прямоугольным параллелепипедом минимального объема (MVBB)[3] с последующим рекурсивным разбиением «сверху-вниз» полученного объема на две части с минимизацией целевого функционала на каждом шаге.
Однако, при анализе данного подхода выяснилось, что существуют проблемы, препятствующие его использованию для решения данной задачи. Изначальная цель разработки [2] была задана как «быстрое получение более оптимальной модели для использования ее в алгоритмах координации работы роботизированных манипуляторов». Наиболее важная проблема, которая следует из цели - данный алгоритм оптимизирует разбиение объема с целью аппроксимации его формы в общих чертах, в то время как в данной задаче необходимо сегментировать имеющийся объем на основе семантики его частей.
Коротко алгоритм [2] можно описать следующим образом:
ѕ Вычислить MVBB облака;
ѕ Жадно вычислить наиболее оптимальный разрез полученного MVBB:
ѕ Спроецировать все точки объема на каждую из сторон MVBB;
ѕ Провести разрез параллельно границам MVBB через каждую спроецированную точку;
ѕ Вычислить описывающие прямоугольники для двух наборов точек на плоскости;
ѕ Из всех возможных разбиений выбрать такое, для которого сумма площадей двух описывающих прямоугольников по отношению к площади исходного описывающего прямоугольника - минимальна.
ѕ Разбить входное облако точек на два по вычисленному разрезу и, если критерий остановки еще не достигнут, запустить алгоритм рекурсивно для обоих потомков.
При этом, критерием остановки является выполнение одного из двух условий:
1) Отношение нового объема после разбиения к объему до разбиения достигло порогового значения:
где ? - проверяемый параметр, рекомендуемое значение порога: 0.80-0.95;
V(x) - функция, возвращающая объем MVBB облака точек;
P - исходное облако точек, подлежащее разбиению;
С1, С2, - облака точек, части полученного разбиения;
A\P - остальные листья дерева разбиения на текущий момент, за исключением вершины P.
Что означает, что прирост уменьшения объема с последнего разбиения оказался незначительным
2) Количество точек в одной из частей разбиения оказалось меньше порогового значения.
При анализе алгоритма было выдвинуто предложение, что с некоторыми модификациями он может быть применен к данной задаче, при учете особенностей предметной области, главной из которых является то, что предметы интерьера зачастую имеют большое количество прямых углов и прямых линий и многие части объектов могут быть аппроксимированы параллелепипедом не захватывая объем других частей.
Такой предлагаемой модификацией является улучшение способа вычисления оптимального разреза. В текущей вариации разбиение происходит строго вдоль трех сторон MVBB, Таким образом, в приведенном примере (рисунок 2) он найдет далекий от оптимального результат.
а) б)
Рисунок 2 - а) разрез согласно исходному алгоритму, б) разрез согласно оптимизированному алгоритму
Можно модифицировать алгоритм поиск разреза добавив к каждому просматриваемому разрезу поворот. Таким образом значительно увеличивается качество находимых разрезов, а с учетом специфики предметной области - получаемые разрезы с большой вероятностью будут оптимальны. Тем не менее, подобное улучшение приведет к повышению вычислительной сложности с дополнительным множителем , где k - шаг поворота разреза.
Однако, в постановке [2] важным критерием стоит возможность выполнения в реальном времени, в то время как в поставленной задаче такой критерий не является обязательным, в следствие чего появляется возможность повышать вычислительную сложность алгоритма в некоторых разумных пределах.
Кроме того, как вспомогательное средство повышение производительности, ко входным данным применяется фильтрация на основе дискретизации воксельным объемом.
В результате работы модифицированного алгоритма получается дерево разбиения общего объема на несколько подобъемов. Однако, нас интересуют только листья полученного дерева разбиения, поэтому эти листья и будут вершинами результирующего графа структуры объекта.
Исходный алгоритм [2] состоит из таких этапов как построение MVBB, которое имеет вычислительную сложность , где n - количество вершин в облаке точек, - некоторый параметр алгоритма, а так же вычисления оптимального разреза за например, с помощью дерева отрезков[4], что в сумме дает оценку . Модифицированный же алгоритм за счет дополнительной операции будет иметь сложность .
Нахождение ребер графа. Исходя из определения ребра как «факта соседства описываемых объектов в пространстве», можно получать ребра путем анализа декартова расстояния между описывающими кубами соответствующих вершин: в случае если данное расстояние равно нулю, либо значительно меньше некоторого порогового значения (например, зависящего от размера описывающих кубов вершин), то считается что ребро между двумя данными вершинами присутствует в графе, иначе - нет.
Задача нахождения расстояния между двумя параллелепипедами решается аналитически и имеет сложность для одной пары параллелепипедов. Так как необходимо проверить существование каждого ребра в графе, вычислительная сложность данного этапа достигает, где m - количество вершин полученного графа.
Результаты работы алгоритма. Пример работы предложенного алгоритма представлен на рисунке 3.
а) б)
Рисунок 3 - пример работы алгоритма. а) исходные данные, б) результат работы алгоритма
Как можно заметить, в результате, в данном примере спинка стула и задние его ножки оказались одним единым объектом. Это можно объяснить тем фактом, что на каждом этапе каждый объем бьется ровно на две части, не учитывая тот факт, что одна из частей может быть заполнена у краев и абсолютно не иметь точек в центре объема. Решение данной проблемы является одним из возможных направлений дальнейших исследований.
В виду того, что в рамках задачи , в оценке вычислительной сложности алгоритма в целом, параметром m можно пренебречь. Таким образом, финальная оценка сложности алгоритма составляет
.
Выводы
В ходе данной статьи был рассмотрен эвристический алгоритм сегментации облака точек в рамках заданной предметной области. Рассмотрен возможный подходы к реализации поставленных подзадач. На основе проведенного анализа исходного алгоритма был предложен и реализован способ его улучшения. Перспективным направлением исследования является поиск других возможных путей улучшения качестве сегментации, например, учет возможности разбиения элемента на три различных подобъема.
Список литературы
1. Bradski G.R., Kaehler A. Learning OpenCV. - O'Reilly Media, 2008. - 556 p.
2. Huebner K., Ruthotto S., Kragic D. Minimum volume bounding box decomposition for shape approximation in robot grasping / In IEEE International Conference on Robotics and Automation, 2008. - P. 1628-1633.
3. Barequet G. and Har-Peled S. Efficiently. Approximating the minimum-volume bounding box of a point set in three dimensions. - J. Algorithms, 2001. - Vol. 38(1). - P.91-109
4. Алгоритм построения дерева отрезков [Электронный ресурс]. - URL: http://e-maxx.ru/algo/segment_tree (Дата обращения 05.09.2018)
Размещено на Allbest.ru
...Подобные документы
Компьютерная графика и обработка изображений электронно-вычислительными машинами являются наиболее важным аспектом использования ЭВМ во всех сферах человеческой деятельности. Разработка "подсистемы линейной сегментации", описание алгоритма и логики.
дипломная работа [1,1 M], добавлен 23.06.2008Сущность понятия "алгоритм". Дискретность, детерминированность и сходимость (результативность). Механический, гибкий, стохастический и эвристический алгоритм. Блок-схемное описание алгоритма. Разработка приложений. Код программы на языке Паскаль.
курсовая работа [1,2 M], добавлен 21.01.2015Использование информационных технологий для планирования размещения оптимальных точек водоснабжения, используя теорию графов. Функциональные возможности разрабатываемого приложения. Программная реализация основных модулей на основе алгоритма Флойда.
курсовая работа [818,3 K], добавлен 31.01.2012Получение вейвлетов Габора из представления путем его поворота и растяжения для известного числа масштабов и ориентаций. Описание процедуры pullback. Детектор края, реализация алгоритма. Генерация представления изображения с помощью вейвлетов Габора.
курсовая работа [1021,4 K], добавлен 29.10.2017Необходимость применения систем электронного документооборота. Выводы по ценам, функциональным возможностям, сегментации рынка. Схема обработки информации автоматизированной системой. Нормативно-справочная информация для системы, структура алгоритмов.
дипломная работа [2,9 M], добавлен 24.06.2009Выбор методов обработки и сегментации изображений. Математические основы примененных фильтров. Гистограмма яркости изображения. Программная реализация комплексного метода обработки изображений. Тестирование разработанного программного обеспечения.
курсовая работа [1,3 M], добавлен 18.01.2017Разработка алгоритма, который может выполнить расчет определения координат точек кинематической схемы и выполнить анимацию (визуальное отображение перемещений объектов) кинематической схемы с использованием пакета MathCad. Расчет кинематической схемы.
курсовая работа [1,1 M], добавлен 10.07.2012Понятие алгоритма как набора инструкций, описывающего порядок действий. Поиск в ширину - метод обхода графа и поиска пути в нем. Пример работы алгоритма поиска в ширину, его неформальное и формальное описание. Реализация с помощью структуры "очередь".
курсовая работа [684,8 K], добавлен 05.04.2015Проектирование приложения на языке С# в среде Microsoft Visual Studio 2008: составление алгоритмов сегментации текста документа и распознавания слова "Указ" в нем, создание архитектуры и интерфейса программного обеспечения, описание разработанных классов.
курсовая работа [2,4 M], добавлен 05.01.2011Поиск по заданному критерию, содержание данного процесса и особенности его использования для решения головоломки "игра в восемь". Методы экономии пространства для поиска по заданному критерию, потребность алгоритма А в ресурсах времени и пространства.
презентация [121,6 K], добавлен 17.10.2013Проект оболочки моделирования кривошипно-шатунного механизма в среде MS Visual Studio. Разработка его математической модели. Исследование кинематики точек В, С, М. Алгоритм и код программы. Анимация движения механизма и график движения основных точек.
курсовая работа [422,2 K], добавлен 13.03.2016Анализ существующих алгоритмов фильтрации и сегментации изображений. Разработка алгоритмов обработки видеопотока на основе выделенных быстрых методов. Реализация принимающей части цепочки сервер-клиент, получающую видеопоток с мобильного устройства.
дипломная работа [337,5 K], добавлен 24.01.2016Программная реализация алгоритма составления каталога товаров из сети электронных магазинов с выявлением одинаковых, используя сравнение по изображениям. SURF-метод в основе алгоритма: поиск особых точек на изображении и составление их дескрипторов.
дипломная работа [3,1 M], добавлен 27.06.2012Общее понятие алгоритма и меры его сложности. Временная и емкостная сложность алгоритмов. Основные методы и приемы анализа сложности. Оптимизация, связанная с выбором метода построения алгоритма и с выбором методов представления данных в программе.
реферат [90,6 K], добавлен 27.11.2012Исследование вертикальных проекций яркости и размаха яркости. Программная реализация алгоритма автоматического анализа цифровых изображений номерных знаков с целью сегментации цифробуквенных символов. Разработка графического пользовательского интерфейса.
дипломная работа [1,5 M], добавлен 12.04.2013Темы исследований в информатике. Основные идеи, которые лежат в основе работы компьютеров. Первая отечественная ЭВМ. Вычислительная сложность алгоритма. Протокол передачи данных. Понятие компьютерной программы. Вычислительная мощность компьютера.
презентация [271,0 K], добавлен 01.11.2014Постановка задачи и ее математическая модель. Блок-схема алгоритма обработки массивов координат точек. Тестирование алгоритма сортировки. Используемые глобальные и локальные переменные. Листинг программы на языке Си. Анализ результатов. Пример работы.
курсовая работа [1,8 M], добавлен 08.11.2012Общие требования к изображению отрезка с помощью цифрового дифференциального анализатора. Сравнительный анализ обычного и несимметричного алгоритмов и алгоритма Брезенхема для генерации векторов (соединения двух точек изображения отрезком прямой).
презентация [65,3 K], добавлен 14.08.2013Определение корней трансцендентного уравнения. Формулы для расчета координат точек графика. Расчет точного значения корня. Решение задачи линейного программирования с использованием Excel. Алгоритм расчета шлицевого соединения с прямобочными шлицами.
курсовая работа [437,3 K], добавлен 21.03.2016Граф - совокупность точек и линий, в которой каждая линия соединяет две точки. Представление графов в ЭВМ. Составление алгоритм Краскала с использованием графов с оперделением оптимального пути прокладки телефонного кабеля в каждый из 8 городов.
курсовая работа [241,5 K], добавлен 23.12.2009