Двоично разделяне на пространството
В компютърните науки двоичното разделяне на пространството (BSP = Binary Space Partitioning) e метод за разделяне на пространството на изпъкнали региони чрез хиперравнини. Това разделяне поражда представяне на обектите в пространството чрез дървовидна структура известна като BSP-дърво.
Двоичното разделяне на пространството е разработено в контекста на 3D компютърната графика, където структурата на BSP-дървото дава възможност за бързо изчертаване на обектите в сцената, представяйки полезна информация, като например подредбата на обектите в дълбочина по отношение на позицията на наблюдателя. Други приложения включват операции с геометрични форми в CAD-системите, откриване на колизии в роботиката и 3D компютърните игри, проследяването на лъчове и други приложения свързани с обработка на сложни сцени в пространството.
Преглед
Двоичното разделяне на пространството е процесът на рекурсивно разделяне на една сцена на две части, докато разделянето удовлетвори едно или повече условия. На този процес може да се гледа като на обобщение на други дървовидни структури за представяне на пространствена информация като k-d-дървета и quad-дървета, но тук разделящите хиперравнини могат да имат произволна ориентация, а не да са винаги успоредни на координатните равнини (както е при k-d-дърветата и quad-дърветата). Когато се използва в компютърната графика за изобразяване на сцени, съставени от равнинни многоъгълници, разделящите равнини често пъти (но не винаги) се избират да съвпадат с равнините дефинирани от някои от многоъгълниците в сцената.
Конкретния избор на разделяща равнина и критерий за спиране на процеса зависят от предназначението на BSP-дървото. Например, в компютърната графика, сцената се разделя докато многоъгълниците във всеки възел от дървото могат да бъдат начертани в произволен ред. Когато се използва отстраняване на обърнатите повърхности (back-face culling), всеки възел съдържа изпъкнало множество от многоъгълници, докато ако такова отсраняване не се използва, възлите съдържат само многоъгълници лежащи в една равнина. При откриването на колизии или трасирането на лъчи (ray tracing), сцената може да бъде разделена на примитивни обекти за които тестовете за колизия или пресичане с лъч са достатъчно прости.
Двоичното разделяне на пространството възниква от нуждата на компютърната графика за бързо изчертаване на триизмерни сцени съставени от многоъгълници. Един прост метод за това е т.нар. алгоритъм на художника. Той обхожда полигоните на сцената според разстоянието до наблюдателя (по-далечните първи) и ги рисува върху фона и преди това нарисуваните многоъгълници. Този подход има два недостатъка: времето необходимо за подреждане на многоъгълниците и възможността за грешки при застъпващи се многоъгълници. Показано е [1] , че BSP-дървото решава и двата проблема като предоставя възможност за бързо сортиране на многоъгълниците (линейно по броя многоъгълници) и избягва грешките чрез подразделяне на застъпващите се многоъгълници. Надостатък на BSP-дърветата е, че конструирането им може да е сравнително бавно. По тази причина обикновено дървото се конструира еднократно върху статичната геометрия, преди изчертаването и останалите опеарации в реално време. Бавното конструиране на BSP-дървото прави трудно и неефективно директното вмъкване на движещи се обекти в дървното.
BSP-дърветата често се използват в 3D игрите, особено в шутърите от първо лице (FPS) и тези в затворени пространства. Ядра на игри които използват BSP-дървета са например Doom (една от първите използващи BSP) и Quake. В компютърните игри BSP-дърветата съдържащи статичната геометрия често се комбинират със Z-буфер за правилно изчертаване на движещите се обекти. Макар че двоичното разделяне на пространството е удобен начин за съхраняване и извличане на пространствена информация за многоъгълниците в сцената, то не решава проблема за определяне на видимите повърхности.
Създаване
BSP-дърветата се използват за направата на полигони с алгоритъма на художника. Всеки полигон е направен с предна и задна страна които могат да бъдат избрани произволно и касаят само структурата на дървото, но не и нужният резултат. Такова дърво е конструирано от несортиран списък на всички полигони в дадена сцена. Рекурсивният алгоритъм за конструкцията на BSP дърво от списъка на полигони е:
- Избор на полигон 'P' от списъка.
- Правене на възел 'N' в BSP-дървото и добавяне на 'P' в списъкът с полигони при този възел.
- За всеки друг полигон в листа:
- Ако полигонът е изцяло пред равнината съдържаща 'P', преместване на полигона в списъка с възли пред P.
- Ако полигонът е изцяло зад равнината съдържаща 'P', преместване в списъка с възли зад P.
- Ако полигонът е пресечен от равнината съдържаща 'P', разделяне на два полигона и преместване до съответните списъци с полигони пред и зад P.
- Ако полигонът лежи в същата равнина, в която е 'P', добавяне в списъка с полигони при възел N.
- Прилагане на този алгоритъм към листа с полигони пред 'P'.
- Прилагане на този алгоритъм към листа за полигони зад 'P'.
Следната диаграма илюстрира прилагането на този алгоритъм в конвертиране на списък от линии или полигони в едно BSP дърво. На всяка от 8-те стъпки, алгоритъмът по-горе е приложен към списък от линии и се добавя един нов възел към дървото.
Крайният брой полигони или линии често е по-голям от оригиналния списък, тъй като линиите (полигоните), пресичащи делящата равнина трябва да бъдат разделени на две. Желателно е да се намали това увеличаване, но също така, да се забази балансът на крайното дърво. Изборът кой полигон или линия да играе роля на деляща равнина (стъпка 1 на алгоритъма) играе важна роля в създаването на качествено BSP-дърво.
Източници
- ↑ Fuchs. On Visible Surface Generation by A Priori Tree Structures // SIGGRAPH '80 Proceedings of the 7th annual conference on Computer graphics and interactive techniques. ACM, New York, 1980, 124 – 133 с. DOI:10.1145/965105.807481.