Қарапайым көпбұрыштың дөңес корпусы - Convex hull of a simple polygon

Қарапайым көпбұрыштың дөңес корпусы (көк). Оның төрт қалтасы сары түспен көрсетілген; барлық түсі көлеңкеленген аймақ дөңес корпус болып табылады.

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

Қарапайым көпбұрыштың дөңес корпусын берілген көпбұрыштың өзіне және көпбұрышқа бөлуге болады қалталар шектелген көпбұрышты тізбек көпбұрыштың бір дөңес корпус шетінен. Осы дөңес корпустың жиегіне ерікті түрде таңдалған қалтаны бірнеше рет шағылыстыру үлкен қарапайым көпбұрыштардың дәйектілігін тудырады; сәйкес Эрдис-Наджи теоремасы, бұл процесс соңында дөңес көпбұрышпен аяқталады.

Құрылым

Қарапайым көпбұрыштың дөңес корпусының өзі а дөңес көпбұрыш. Түпнұсқа қарапайым көпбұрышты оның дөңес корпус бөлімдеріне қабаттастыру, бұл дөңес көпбұрышты аймақтарға бөлу, олардың бірі - бастапқы көпбұрыш. Қалған аймақтар деп аталады қалталар. Әрбір қалта өзі қарапайым көпбұрыш болып табылады, оның көмегімен шектеледі көпбұрышты тізбек берілген қарапайым көпбұрыштың шекарасында және дөңес корпустың бір шетінен. Онсыз да дөңес көпбұрыштың қалталары жоқ.[1]

Кез келген берілген көпбұрыштың иерархиялық сипаттамасын оның корпусын және оның қалталарын осылай тұрғызу арқылы, содан кейін әр қалта үшін бірдей типтегі иерархияны қалыптастыру арқылы жасауға болады.[1] Бұл құрылым а деп аталады дөңес айырмашылықтар ағашы, тиімді құрастыруға болады.[2]

Алгоритмдер

Қарапайым көпбұрыштың дөңес корпусын табуға болады сызықтық уақыт. Бұл проблемаға арналған бірнеше ерте басылымдардың дұрыс емес екендігі анықталды, себебі олар көбінесе өткелдермен аралық күйлерге әкеліп соқтырды, бұл олардың бұзылуына себеп болды. Бұл есептің алғашқы дұрыс сызықтық уақыт алгоритмі берілген McCallum & Avis (1979).[3] Жарияланғаннан кейін де басқа қате алгоритмдер жариялауды жалғастырды.[4] Brönnimann & Chan (2006) есептің жарияланған алгоритмдерінің көпшілігі дұрыс емес деп жазыңыз,[5] Грег Алупис жинаған кейінгі тарих он бес алгоритмнің жетеуін ғана қате деп санайды.[6]

Бұл мәселенің қарапайым алгоритмін жариялады Грэм және Яо (1983) және Ли (1983). Сияқты Грэм сканері нүктелік жиынтықтың дөңес корпусының алгоритмі, ол а-ға негізделген стек деректер құрылымы. Алгоритм көпбұрышты дөңес корпуста екендігі белгілі шыңнан бастап (мысалы, оның сол жақ нүктесі) сағат тілінің бағыты бойынша өтеді. Осылайша, ол шоқтардың дөңес дәйектілігін сақтауда сақтайды, олар әлі қалтада екені анықталмаған. Бұл тізбектегі нүктелер - оның дөңес көпбұрыштың төбелері (бұған дейін көрген барлық төбелердің корпусы емес), оның кейбір шеттеріне қалталары бекітілген болуы мүмкін. Әрбір қадамда алгоритм көпбұрыш бойымен стектің жоғарғы жағынан келесі шыңға дейінгі жолмен жүреді, ол стек төбесіне жақын орналасқан екі қалтаның бірінде емес. Содан кейін, стектегі жоғарғы екі шың және осы жаңа шыңдар дөңес күйде болмаса да, ол стекке шығады, ал соңында жаңа шыңдарды стекке итермелейді. Сағат тілімен жүру бастапқы нүктеге жеткенде, алгоритм аяқталады және стекте сағат тілінің ретімен дөңес корпустың шыңдары болады. Алгоритмнің әрбір қадамы шыңды стекке итереді немесе оны стектен шығарады, ал әр шың ең көп дегенде бір рет итеріліп, шығарылады, сондықтан алгоритмнің жалпы уақыты сызықтық болады.[7][8] Егер кіріс шыңдары жиым бойынша сағат тілінің бағытымен берілсе, онда нәтижені аралық сақтау ретінде қосымша айнымалылардың тек тұрақты санын пайдаланып, сол массивте қайтаруға болады.[5]

Ұқсас әдісті дөңес корпусты салу үшін де қолдануға болады кесек тегіс жазықтықтағы жабық қисықтар.[9]А пайдалану арқылы дек стектің орнына ұқсас алгоритмді кез-келген көпбұрышты тізбектің дөңес корпусына жалпылауға болады, ал қарапайым көпбұрыштардың алгоритмін бастан жоғары шың ретінде талап етпестен, көпбұрыштың кез келген шыңынан бастауға болады.[10]

Қалталарды аудару

A аудару қалта қалтаны қалтаның дөңес корпус шетінен шектейтін көпбұрышты тізбекті шағылыстыру арқылы берілген жаңа полигонды салады. Әрбір флип периметрі бірдей және үлкен ауданы бар тағы бір қарапайым көпбұрышты шығарады, дегенмен бірнеше синхронизация қиылыстарды енгізуі мүмкін. Ерікті түрде таңдалған қалтаны аударып, содан кейін осы процесті әр қатарынан қалыптасқан көпбұрыштың қалтасымен қайталау қарапайым көпбұрыштардың тізбегін тудырады. Сәйкес Эрдис-Наджи теоремасы, бұл айналдыру процесі соңында дөңес көпбұрышқа жету арқылы аяқталады. Дөңес корпустың құрылысы проблемасында болғандай, бұл мәселе ұзақ уақыт бойы дұрыс емес дәлелдемелер жасаған.[11]

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

  1. ^ а б Тор, С.Б .; Миддлидч, А.Э. (1984), «Қарапайым көпбұрыштардың дөңес ыдырауы», Графика бойынша ACM транзакциялары, 3 (4): 244–265, дои:10.1145/357346.357348
  2. ^ Rappoport, Ari (1992), «Қарапайым көпбұрыштың дөңес айырмашылықтар ағашын құрудың тиімді адаптивті алгоритмі», Компьютерлік графика форумы, 11 (4): 235–240, дои:10.1111/1467-8659.1140235
  3. ^ МакКаллум, Дункан; Авис, Дэвид (1979), «Қарапайым көпбұрыштың дөңес корпусын табудың сызықтық алгоритмі», Ақпаратты өңдеу хаттары, 9 (5): 201–206, дои:10.1016/0020-0190(79)90069-3, МЫРЗА  0552534
  4. ^ Туссен, Годфрид (1991), «Көпбұрыштардың дөңес корпус алгоритміне қарсы мысал», Үлгіні тану, 24 (2): 183–184, дои:10.1016 / 0031-3203 (91) 90087-L, МЫРЗА  1087740
  5. ^ а б Брониман, Эрве; Чан, Тимоти М. (2006), «Сызықтық уақыттағы қарапайым көпбұрышты сызықтың дөңес корпусын есептеудің кеңістіктегі тиімді алгоритмдері», Есептеу геометриясы, 34 (2): 75–82, дои:10.1016 / j.comgeo.2005.11.005, МЫРЗА  2222883
  6. ^ Алупис, Грег, Қарапайым көпбұрыштар үшін сызықты уақытты дөңес корпустың алгоритмдерінің тарихы, МакГилл университеті, алынды 2020-01-01
  7. ^ Грэм, Рональд Л.; Яо, Ф.Франсис (1983), «Қарапайым көпбұрыштың дөңес корпусын табу», Алгоритмдер журналы, 4 (4): 324–331, дои:10.1016/0196-6774(83)90013-5, МЫРЗА  0729228
  8. ^ Ли, Д. Т. (1983), «Қарапайым көпбұрыштың дөңес корпусын табу туралы», Халықаралық компьютерлік және ақпараттық ғылымдар журналы, 12 (2): 87–98, дои:10.1007 / BF00993195, МЫРЗА  0724699
  9. ^ Шаффер, Алехандро А .; Ван Уик, Кристофер Дж. (1987), «Иорданның қисық тегіс емес дөңес қабықтары», Алгоритмдер журналы, 8 (1): 66–94, дои:10.1016/0196-6774(87)90028-9, МЫРЗА  0875326
  10. ^ Мелкман, Авраам А. (1987), «Қарапайым полилинияның дөңес корпусының желілік құрылысы», Ақпаратты өңдеу хаттары, 25 (1): 11–12, дои:10.1016 / 0020-0190 (87) 90086-X, МЫРЗА  0896397
  11. ^ Демейн, Эрик Д.; Гассенд, Блез; О'Рурк, Джозеф; Туссен, Годфрид Т. (2008), «Барлық көпбұрыштар бір-біріне өте жақсы айналады ... солай ма?», Дискретті және есептеу геометриясы бойынша сауалнамалар, Қазіргі заманғы математика, 453, Провиденс, Род-Айленд: Американдық математикалық қоғам, 231–255 б., дои:10.1090 / conm / 453/08801, МЫРЗА  2405683