K-D-B ағашы - K-D-B-tree - Wikipedia

Жылы есептеу техникасы, а K-D-B ағашы (к-өлшемді B ағашы ) а-ны бөлуге арналған ағаштардың құрылымы к-өлшемді іздеу кеңістігі. Мақсаты K-D-B ағашы теңдестірілген іздеу тиімділігін қамтамасыз ету болып табылады k-d ағашы, сыртқы жадқа қол жетімділікті оңтайландыру үшін B-ағашының блоктық-бағдарланған сақтауын қамтамасыз ету.[1]

Ресми емес сипаттама

Көп сияқты к-d ағашы, K-D-B ағашы нүктелерді ұйымдастырады к- ауқымды іздеу және көп өлшемді мәліметтер базасына сұраныстар сияқты тапсырмалар үшін пайдалы өлшемді кеңістік. K-D-B ағаштары бір домендегі элементтерді салыстыру арқылы кеңістікті екі кіші кеңістікке бөледі. Мысал ретінде 2-D-B ағашын (2-өлшемді K-D-B ағашы) пайдаланып, кеңістік те сол сияқты бөлінеді к-d ағашы: домендердің біреуіндегі нүктені немесе осьтерді бұл жағдайда қолдана отырып, қалған барлық мәндер ағымдағы мәннен кіші немесе үлкен болады және сәйкесінше бөлу жазықтығының сол және оң жағына түседі.

Айырмашылығы а к-d ағаш, әрбір жарты кеңістік өзінің түйіні емес. Оның орнына, B-ағашындағы сияқты, K-D-B ағашындағы түйіндер парақтар ретінде сақталады және ағаш сілтеме түбірлік параққа сақтайды.

Құрылым

K-D-B-ағашының негізгі құрылымы.

K-D-B ағашында екі парақ бар:

  • Аймақ беттері: жинағы (аймақ, бала) шекаралас аймақтың сипаттамасын және сол аймаққа сәйкес келетін баланың бетіне нұсқағышты қамтитын жұптар.
  • Негізгі беттер: жиынтығы (нүкте, орналасқан жері) жұп. Деректер базасына қатысты, орналасқан жері нүктелер үшін деректер базасының жазбасының индексін көрсетуі мүмкін к-өлшемдік кеңістік, оны сол кеңістіктегі нүктенің координаттары ретінде қарастыруға болады.

Парақтың толып кетуі элементті K-D-B ағашына енгізу кезінде пайда болады, бұл түйіннің өлшемі оның оңтайлы өлшемінен асып түседі. K-D-B ағашының мақсаты қатты жадтағыдай жадқа сыртқы қол жетімділікті оңтайландыру болғандықтан, егер түйін өлшемі сыртқы жад парағының өлшемінен асып кетсе, парақ толып кетті немесе толтырылған болып саналады.

Енгізу / жою операциялары кезінде K-D-B ағашы белгілі бір қасиеттер жиынтығын сақтайды:

  • График - көп бағытты ағаш. Аймақтық беттер әрдайым еншілес беттерді көрсетеді және бос бола алмайды. Нүктелі беттер - бұл ағаштың жапырақ түйіндері.
  • B ағашы сияқты, ағаштың жапырақтарына дейінгі жолдың ұзындығы барлық сұраныстар үшін бірдей.
  • Аймақ бетін құрайтын аймақтар біріктірілген.
  • Егер түбір аймақ парағы болса, оның аймақтарының бірлестігі бүкіл іздеу кеңістігін құрайды.
  • Қашан бала а (аймақ, бала) аймақ бетіндегі жұп - бұл аймақ беті, баладағы барлық аймақтардың бірігуі аймақ.
  • Керісінше жоғарыдағы жағдайда, егер бала нүктелік бет, барлық нүктелер бала ішінде болуы керек аймақ.

K-D-B ағашындағы операциялар

Сұрақтар

K-D-B ағашындағы сұраулар - бұл барлық домендердегі немесе осьтердегі интервалдар бойынша ауқымды іздеу. Бұл интервалдар жиынтығы деп аталады сұрау аймағы. Жылы к-кеңістік, сұрау аймағы тұтастай кейбір ішкі кеңістіктің айналасындағы шектік көлем ретінде көрінуі мүмкін к-өлшемді іздеу кеңістігі. Сұрау үш санаттың біріне жатуы мүмкін:

  • Кейбір аралықтар бүкіл доменді немесе осьті қамтып, а сұрауын жасайды ішінара диапазон сұрау.
  • Кейбір интервалдар - нүктелер, ал басқалары - толық домендер, сондықтан сұрау - а ішінара матч сұрау.
  • Аралықтар - бұл барлық нүктелер, сондықтан шекті көлем де тек нүкте болады. Бұл дәл сәйкестік сұрау.

Алгоритм

  1. Егер тамыр ағаштың мәні нөлге тең, тоқтатыңыз, әйтпесе рұқсат етіңіз бет болуы тамыр.
  2. Егер бет нүктелік бет болып табылады, әрқайсысын қайтарыңыз нүкте ішінде (нүкте, орналасқан жері) ішінде орналасқан жұп сұрау аймағы.
  3. Әйтпесе, бет бұл аймақ парағы, сондықтан барлығына арналған (аймақ, бала) жұптар қайда аймақ және сұрау аймағы қиылысады, орнатылады бет болу бала және 2-қадамнан бастап қайталаңыз.

Кірістер

K-D-B ағашына кірістіру парақ толып кеткен жағдайда бетті бөлуді қажет етуі мүмкін болғандықтан, алдымен бөлу әрекетін анықтау маңызды.

Бөлу алгоритмі

Біріншіден, аймақ беті екі жазықтық бойына бөлініп, екі жаңа аймақтық бетті, сол және оң беттерді жасайды. Бұл беттер ескі аймақ бетінен аймақтармен толтырылып, ескі аймақ парағы жойылады. Содан кейін, әрбір үшін (аймақ, бала) есте сақтап, бастапқы аймақтық бетте бала бұл бет және аймақ нақты шекара аймағын көрсетеді:

  1. Егер аймақ толығымен бөлу жазықтығының сол жағында жатыр, қосыңыз (аймақ, бала) сол жақ бетке.
  2. Егер аймақ толығымен бөлінетін жазықтықтың оң жағында жатыр, қосыңыз (аймақ, бала) оң бетке.
  3. Әйтпесе:
    1. Рекурсивті бөліну бала бөліну жазықтығы бойынша, нәтижесінде парақтар пайда болады жаңа_сол_бет және жаңа_құқық_беті
    2. Сызат аймақ бөлінетін жазықтықта, нәтижесінде пайда болады сол_аймақ және оң_аймақ
    3. Қосу (сол_аймақ, жаңа_сол_бетте) сол жақ бетке және (оң_аймақ, жаңа_құқық_беті) оң бетке.

Кірістіру алгоритмі

Бөлу доменін дұрыс таңдаудың маңыздылығы.

Бөлу алгоритмін қолдану, жаңасын енгізу (нүкте, орналасқан жері) жұпты келесідей жүзеге асыруға болады:

  1. Егер түбір парағы нөл болса, жай ғана түбір парағын жаңа нүкте парағы етіңіз (нүкте, орналасқан жері)
  2. Егер дәл сәйкестік сұранысы қосылса нүкте деген бетті табу үшін нүктесін 'қосу керек. Егер ол бетте бұрыннан бар болса, тоқтатыңыз.
  3. Қосу (нүкте, орналасқан жері) параққа. Егер парақ толып кетсе, рұқсат етіңіз бет сол бетті белгілеңіз.
  4. Келіңіздер ескі_бет тең болу бет. Бөлу үшін жазықтықты анықтау үшін кейбір элементтер мен доменді / осьті таңдаңыз бет нәтижесінде екі парақ пайда болады, бұл жаңа парақ қосумен парақтардың біреуі артық толтырылмайды. Сызат бет екі жаңа парақ жасау үшін ұшақпен, жаңа_сол_бет және жаңа_құқық_бетіжәне екі жаңа аймақ сол_аймақ және оң_аймақ.
  5. Егер бет 6-қадамға өтіңіз, әйтпесе, бет ата-анасына айналады бет. Ауыстыру (аймақ, old_page) жылы бет бірге (сол_аймақ, жаңа_сол_бетте) және (оң_аймақ, жаңа_құқық_беті). Егер бет толып кетеді, 4-қадамды қайталаңыз, әйтпесе тоқтатыңыз.
  6. Келіңіздер сол_аймақ бөлу жазықтығының сол жағындағы бүкіл іздеу кеңістігі болыңыз және оң_аймақ 4-қадамда бөліну нәтижесінде оң жақтағы іздеу кеңістігі болыңыз, түбірлік бетті аймақтарға арналған парақ етіп қойыңыз сол_аймақ және оң_аймақ.

Бөлу үшін таңдалған домен мен элемент туралы мұқият болу маңызды бет арқылы, өйткені бөлу жазықтығының екі жағындағы нүктелер санын теңестіруге тырысқан жөн. Кейбір жағдайларда бөлу доменінің дұрыс таңдалмауы жағымсыз бөлінулерге әкелуі мүмкін. Сондай-ақ, бетті белгілі бір доменмен бөлу мүмкін емес.

Жойулар

K-D-B ағашынан жою өте қарапайым, егер сақтау үшін минималды талаптар қойылмаса. А табу үшін дәл сәйкестік сұрауын қолдану (нүкте, орналасқан жері) жұп, егер ол бар болса, жазбаны ағаштан алып тастаймыз.

Қайта құру алгоритмі

Өшіру нәтижесінде мәліметтер өте аз болатын беттер пайда болуы мүмкін болғандықтан, K-D-B ағашын сақтаудың минималды өлшемдеріне сәйкес қайта құру қажет болуы мүмкін. Бетте деректер аз болған кезде қолданылатын қайта құру алгоритмі келесідей:

  1. Келіңіздер бет ата-анасы болу P, құрамында (аймақ, P).
  2. Аймақты табу бет аймақтар жақын орналасқан және олардың бірігуі тікбұрышты аймақты құрайтындай. Бұл аймақтар «біріктірілетін» болып саналады. Келіңіздер R осы аймақтар жиынтығын белгілеңіз.
  3. Жинақты біріктіру R бір параққа Sжәне егер S толып жатыр, алынған парақтардың ешқайсысы артық болмайынша бірнеше рет бөлінеді.
  4. Жинақты ауыстырыңыз R облыстар бет алынған парақтар бөлінуден S.

Осыған байланысты жұмыс

Сияқты к-d ағашы, K-D-B ағашындағы жаңартулар бірнеше түйіндерді рекурсивті түрде бөлу талабын тудыруы мүмкін. Бұл керемет тиімсіз және жадыны оңтайлы пайдалануға әкелуі мүмкін, себебі көптеген бос жапырақтар пайда болуы мүмкін. Ломет пен Зальцберг құрылымын ұсынды hB-ағаш (ағаштан жасалған кірпіш ағаш) K-D-B ағаштарының өнімділігін тек тамырдан-жапыраққа соққаннан кейін пайда болатын бөлуді шектеу арқылы жақсарту. Бұған аймақтарды тек тіктөртбұрыш ретінде ғана емес, сонымен қатар центрден тіктөртбұрыш алынып тіктөртбұрыш түрінде сақтау арқылы қол жеткізілді.[2]

BKD ағашы

Жақында Bkd ағашы жылдам сұраныстарды ұсыну құралы және статикалық K-D-B ағашын 100% кеңістікті пайдалану құралы ретінде ұсынылды. Жалғыз ағашты ұстап тұру және қайта теңгеру орнына, жиынтығы K-D-B ағаштары белгілі бір уақыт аралығында күтіліп, қайта құрылады.[3] Бұл жағдайда, - нүкте саны бойынша жад буферінің өлшемі.

Әдебиеттер тізімі

  1. ^ Робинсон, Джон (1981). K-D-B-ағашы: үлкен өлшемді динамикалық индекстерді іздеу құрылымы. Деректерді басқару бойынша 1981 жылғы ACM SIGMOD Халықаралық конференциясының материалдары. Сигмод '81. 10-18 бет. дои:10.1145/582318.582321. ISBN  978-0897910408. Алынған 8 сәуір, 2014.
  2. ^ Ломет, Дэвид; Бетти Зальцберг (1990 ж. Желтоқсан). «HB-ағаш: кепілдендірілген өнімділігі бар мультисайталы индекстеу әдісі». Деректер базасындағы ACM транзакциялары. 15 (4): 625–658. CiteSeerX  10.1.1.63.2056. дои:10.1145/99935.99949.
  3. ^ Прокопий, октавиан; Агарвал, Панкай; Ардж, Ларс; Виттер, Джеффри Скотт (2003). Bkd-Tree: динамикалық масштабталатын kd-Tree. Кеңістіктік және уақытша мәліметтер базасындағы жетістіктер. Информатика пәнінен дәрістер. 2750. бет.46–65. CiteSeerX  10.1.1.134.3206. дои:10.1007/978-3-540-45072-6_4. ISBN  978-3-540-40535-1.