БК стабло
Овај чланак је започет или проширен кроз пројекат семинарских радова. Потребно је проверити превод, правопис и вики-синтаксу. Када завршите са провером, допишете да након |проверено=. |
БК стабло, или Буркхард-Келлер стабло, је структура података пројектована за брзо налажење најближег суседа или нејасну претрагу ниски (енгл. фуззy стринг сеарцхинг), најчешће коришћену приликом провере правописа (енгл. спелл-цхецкинг). Ово стабло је први пут предложено од стране W. А. Буркхард-а и Р. M. Келлер-а 1973. године, у раду "Соме аппроацхес то бест матцх филе сеарцхинг", објављеном у магазину “Цоммуницатионс оф тхе АЦМ”.
БК стабло за рад са нискама
[уреди | уреди извор]Одређивање методе
[уреди | уреди извор]Пре дефинисања БК стабла, потребно је одредити неколико ствари[1]. Да би било могуће индексирати и претраживати неки дати речник, потребан је метод поређивања две ниске. Најчешће коришћен метод је Левенштајново растојање, које за дате две ниске враћа минималан број измена (уметања, брисања или замењивања слова), потребних да се једна ниска претвори у другу. Могуће је користити и друге методе, докле год оне формирају метрички простор.
Код неке метрике д важи следеће:
- д(x, y) ≥ 0 (ненегативност)
- д(x, y) = 0 ако и само ако x = y
- д(x, y) = д(y, x) (симетрија)
- д(x, з) ≤ д(x, y) + д(y, з) (неједнакост троугла).
Из неједнакости троуглова види се да је пут од x до з увек мањи или једнак било ком путу који пролази кроз неку додатну тачку y.
Нека је дато неко q које се тражи у речнику, и н која је највећа дозвољена даљина између ниске q и неке ниске која се ставља у скуп решења. Тада, д је раздаљина између ниске q и неке насумично изабране ниске т. Пошто важи неједнакост троуглова, све ниске из скупа решења морају бити највише удаљене за д+н измена, и најмање за д-н од ниске т.
Изградња
[уреди | уреди извор]Сваки чвор у БК стаблу има произвољан број чворова потомака, и свака грана има придружен број који одговара Левенштајновом растојању између њена два чвора, односно између чвора родитеља и чвора потомка.
Примера ради, ако родитељ чвор има вредност “боок”, и има два чвора потомка “роок” и “ноокс”, онда грана између “боок” и “роок” ће имати вредност 1, а грана између “боок” и “ноокс” це имати вредност 2.
Приликом изградње стабла, насумично се изабере нека ниска и поставља се као корен стабла. Када се убацује нова ниска у стабло, мери се Левенштајново растојање између нове ниске и ниске корена, тј. д(нованиска, корен) = к. Нова ниска се даље рекурзивно пореди са чвором потомком до којег води грана са вредношћу к. Када се дође до тренутка да поменута грана не постоји, прави се нови чвор који се поставља као потомак, и грани која води до њега се даје вредност Левенштајновог растојања између тог чвора и његовог родитеља.
Примера ради, код убацивања речи “боон” у претходно стабло, рачуна се раздаљина д("боок", "боон") = 1. Даље се испитује чвор потомак до којег води грана тежине 1, што је у примеру реч “роок”. Рачуна се даљина д("роок", "боон") = 2, па се ниска “боон” убацује као потомак чвора “роок”, са тежином гране која води до њега 2.
Претрага
[уреди | уреди извор]Приликом претраге стабла, рачуна се Левенштајново растојање између дате ниске q и ниске корена, тј. д(q, корен) = д и рекурзивно се испитује свако подстабло до које води грана са вредношћу између д-н и д+н, инклузивно. Ако је даљина између чвора који се испитује и датог q мања од н, тај чвор (односно ниска), се додаје у скуп решења.
Сложеност
[уреди | уреди извор]Овакав алгоритам претраживања је, оквирно гледано, временске сложености О(лог н)[2]. Проценат стабла које се обилази се драстично мења у зависности од највеће дозвољене даљине н, а и зависи од самих ниски које су у саставу речника.
Референце
[уреди | уреди извор]Види још
[уреди | уреди извор]- К неарест неигхборс алгоритхм (Wикипедиа чланак на енглеском)
- Аппроxимате стринг матцхинг (Wикипедиа чланак на енглеском)
Спољашње везе
[уреди | уреди извор]- Нуллwордс Блог: Тхе БК-Трее – А Дата Струцтуре фор Спелл Цхецкинг (Имплементација стабла у C#)
- ГитХуб: Генериц БК-Трее (Буркхард-Келлер) фор фуззy матцхинг ин дисцрете метриц спацес. (Имплементација стабла у C#)
- ГитХуб: Буркхард-Келлер Трее имплементатион ин Цоммон Лисп.
- Ерленд Хамберг: БК-Треес (Имплементација стабла у Хаскелл-у)
- Адам Хупп: Буркхард-Келлер (БК) Треес Ин Пyтхон Архивирано на сајту Wayback Machine (6. септембар 2014)
- Фуззy Тхинг: Аппроxимате Стринг Матцхинг (Интро & БКТрее)
.