Kasılma hiyerarşileri - Contraction hierarchies - Wikipedia

İçinde bilgisayar Bilimi yöntemi daralma hiyerarşileri bir hızlandırma tekniği bulmak için en kısa yol içinde grafik. En sezgisel uygulamalar, araba navigasyon sistemleridir: Bir kullanıcı, -e mümkün olan en hızlı rotayı kullanarak. Burada optimize edilen metrik seyahat süresidir. Kesişimler şu şekilde temsil edilir: köşeler onları birbirine bağlayan yol bölümleri kenarlar. Kenar ağırlıkları, yolun bu bölümünde sürüş için geçen süreyi temsil eder. Bir yol -e bir dizi kenar (yol bölümleri); en kısa yol, tüm olası yollar arasında minimum kenar ağırlıkları toplamına sahip olandır. Bir grafikteki en kısa yol kullanılarak hesaplanabilir Dijkstra's algoritma; ancak yol ağlarının on milyonlarca köşeden oluştuğu düşünüldüğünde, bu pratik değildir.[1] Kasılma hiyerarşileri, yol ağlarını temsil eden grafiklerin özelliklerinden yararlanmak için optimize edilmiş bir hızlandırma yöntemidir.[2] Hızlanma, bir ön işleme aşamasında kısayollar oluşturarak ve daha sonra en kısa yol sorgusu sırasında "önemsiz" köşeleri atlamak için kullanılır.[2] Bu, karayolu ağlarının oldukça hiyerarşik olduğu gözlemine dayanmaktadır. Örneğin otoyol kavşakları gibi bazı kavşaklar "daha önemlidir" ve hiyerarşide, örneğin çıkmaza giren bir kavşaktan daha yüksektir. Kısayollar, iki önemli kavşak arasındaki önceden hesaplanmış mesafeyi kaydetmek için kullanılabilir, böylece algoritma sorgu zamanında bu kavşaklar arasındaki tam yolu dikkate almak zorunda kalmaz. Kasılma hiyerarşileri, insanların hangi yolları "önemli" olarak gördüğünü bilmez (ör. Otoyollar), ancak bunlar grafikle girdi olarak sağlanır ve buluşsal yöntemleri kullanarak köşelere önem atayabilir.

Kasılma hiyerarşileri, yalnızca aşağıdaki hızlandırma algoritmalarına uygulanmaz. araba navigasyon sistemleri ama aynı zamanda web tabanlı rota planlayıcıları, trafik simülasyonu ve lojistik optimizasyonu.[3][1][4] Algoritmanın uygulamaları şu şekilde halka açıktır: açık kaynaklı yazılım.[5][6][7][8][9]

Algoritma

Daralma hiyerarşileri (CH) algoritması, iki aşamalı bir yaklaşımdır. en kısa yol problemi oluşan ön işleme aşaması ve bir sorgu aşaması. Karayolu ağları oldukça seyrek olarak değiştiği için, sorulara yanıt verilmeden önce bazı hesaplamaları önceden hesaplamak için daha fazla zaman (saniye ila saat) kullanılabilir. Bu önceden hesaplanmış verileri kullanarak birçok sorgu, her biri çok kısa sürede (mikrosaniye) yanıtlanabilir.[1][3] CH'ler bu hızlanmayı başarmak için kısayollara güveniyor. Bir kısayol iki köşeyi birbirine bağlar ve orijinal grafikte bitişik değil. Kenar ağırlığı, en kısa kenar ağırlıklarının toplamıdır. - yol.

Bir otoyolla birbirine bağlanan iki büyük şehri düşünün. Bu iki şehir arasında, küçük köylere ve banliyölere giden çok sayıda kavşak vardır. Sürücülerin çoğu bir şehirden diğerine - belki daha büyük bir rotanın parçası olarak - gitmek ister ve yoldaki çıkışlardan birini kullanmaz. Bu yol düzenini temsil eden grafikte, her kavşak bir düğüm ile temsil edilir ve komşu kavşaklar arasında kenarlar oluşturulur. Bu iki şehir arasındaki mesafeyi hesaplamak için, algoritmanın yol boyunca tüm kenarları kat ederek uzunluklarını ekleyerek geçmesi gerekir. Bu mesafeyi bir kez önceden hesaplamak ve iki büyük şehir arasında oluşturulan ek bir kenarda depolamak, bu otoyolun bir sorguda değerlendirilmesi gerektiği her seferinde hesaplamaları kaydedecektir. Bu ek kenara "kısayol" denir ve gerçek dünyada karşılığı yoktur. Daralma hiyerarşileri algoritmasının yol türleri hakkında hiçbir bilgisi yoktur, ancak girdi olarak tek başına grafiği kullanarak hangi kısayolların oluşturulması gerektiğini belirleyebilir.

Bir yol bulmak için -e algoritma gri köşeleri atlayabilir ve kesik çizgili kısayol yerine. Bu, algoritmanın bakması gereken köşe sayısını azaltır. Kısayolun kenar ağırlığı -e en kısa kenar ağırlıklarının toplamıdır - yol.

Ön işleme aşaması

CH algoritması, arama alanını azaltmak için ön işleme aşamasında oluşturulan kısayollara dayanır - bu, CH'nin sorgu zamanında bakması gereken köşe sayısıdır. Bunu başarmak için yinelemeli tepe kasılmaları gerçekleştirilir. Bir tepe noktasıyla sözleşme yaparken geçici olarak grafikten kaldırılır ve her çift arasında bir kısayol oluşturulur en kısa yol ise komşu köşelerin -e içerir .[2] Aradaki en kısa yolun olup olmadığını belirleme süreci ve içerir tanık arama denir. Örneğin bir yol hesaplayarak gerçekleştirilebilir. -e yalnızca henüz sözleşmeli olmayan düğümleri kullanarak ileriye doğru arama kullanarak.[3]

Orijinal grafik, çizgidir (katı). Kesikli kenarlar kısayolları temsil eder, gri oklar ilgili kısayolu oluşturmak için hangi iki kenarın birleştirildiğini gösterir. Köşelerin aşağıdan yukarıya doğru daraldığı düğüm sırasını temsil etmek için tepe noktaları çizilmiştir. Akit köşe arasında bir kısayol sunar ve ile . Köşelerin kasılmaları ve sırasıyla bir kısayol tanıtın. Kasılmalar , ve herhangi bir kısayol tanıtmayın ve bu nedenle gösterilmez.

Düğüm sırası

Girdi grafiğinin köşeleri, grafiğe kasılmalarla eklenen kenarların sayısını en aza indirecek şekilde daraltılmalıdır. Optimum düğüm sıralaması NP tamamlandı,[10] Sezgisel kullanılmış.[2]

Altüst ve yukarıdan aşağıya sezgisel yöntemler mevcuttur. Bir yandan, hesaplama açısından daha ucuz olan aşağıdan yukarıya buluşsal yöntem, köşelerin hangi sırayla daraltılacağına karar verir. açgözlü moda; bu, siparişin önceden bilinmediği, bunun yerine bir önceki düğümün bir önceki daraltma tamamlandıktan sonra daraltma için seçildiği anlamına gelir. Diğer yandan yukarıdan aşağıya buluşsal yöntemler, ilk düğüm kısaltılmadan önce tüm düğüm sırasını önceden hesaplar. Bu daha iyi sonuçlar verir, ancak daha fazla ön işleme süresi gerektirir.[2]

İçinde altüst sezgisel tarama, kasılma için bir sonraki tepe noktasını seçmek için faktörlerin bir kombinasyonu kullanılır. Kısayolların sayısı, ön işleme ve sorgu çalışma süresini belirleyen birincil faktör olduğundan, bunu mümkün olduğunca küçük tutmak istiyoruz. Bu nedenle, daralma için bir sonraki düğümü seçmenin en önemli terimi, bir düğümü daraltırken eklenen net kenar sayısıdır. . Bu şu şekilde tanımlanır: nerede oluşturulacak kısayolların sayısıdır sözleşmeli ve meydana gelen kenarların sayısı . Bu kriterin tek başına kullanılması doğrusal bir yolun doğrusal bir hiyerarşi (birçok düzey) ile sonuçlanmasına ve hiçbir kısayol oluşturulmamasına neden olur. Halihazırda tek tip bir daralma ve düz bir hiyerarşi (daha az seviye) ile daraltılmış olan yakın köşelerin sayısı dikkate alınarak elde edilir. Bu, örneğin her bir düğüm için, komşu bir tepe noktasının her daraltılmasında artan bir sayaç muhafaza edilerek yapılabilir. Daha düşük sayaçlara sahip düğümler, daha geniş sayaçlar için düğümlere tercih edilir.[11]

Yukarıdan aşağıya sezgisel tarama ise daha iyi sonuçlar verir ancak daha fazla ön işleme süresine ihtiyaç duyar. En kısa yolların bir parçası olan köşeleri, yalnızca birkaç en kısa yol için gerekli olanlardan daha önemli olarak sınıflandırırlar. Bu olabilir yaklaşık kullanma iç içe diseksiyonlar.[2] İç içe geçmiş bir diseksiyonu hesaplamak için, bir grafiği yinelemeli olarak iki parçaya ayırır; bunlar daha sonra iki parçaya ayrılır ve bu böyle devam eder. Yani, düğümlerin bir alt kümesini bulun grafikten kaldırıldığında ayrı iki ayrı parçaya yaklaşık olarak eşit büyüklükte . Tüm düğümleri yerleştirin son düğüm sıralamasında ve sonra iç içe geçmiş diseksiyonu yinelemeli olarak hesaplayın ve .[12] Önsezi, grafiğin bir yarısından diğer yarısına kadar olan tüm sorguların küçük ayırıcıdan geçmesi gerektiğidir ve bu nedenle bu ayırıcıdaki düğümler çok önemlidir. İç içe geçmiş diseksiyonlar, küçük ayırıcıları nedeniyle yol ağlarında verimli bir şekilde hesaplanabilir.[13]

Sorgu aşaması

Sorgu aşamasında, başlangıç ​​düğümünden başlayarak çift yönlü bir arama gerçekleştirilir. ve hedef düğüm önişleme aşamasında oluşturulan kısayollarla artırılmış orijinal grafikte.[2] Aradaki en kısa yoldaki en önemli köşe ve ikisinden biri olacak veya kendileri veya ikisinden daha önemli ve . Bu nedenle tepe noktası küçültme en kısası orijinal grafikteki yol ve tutar.[2] Bu, kısayolların nasıl oluşturulduğuyla birlikte, hem ileri hem de geri aramanın yalnızca, arama alanını küçük tutan hiyerarşide daha önemli düğümlere (yukarı doğru) giden kenarları gevşetmesi gerektiği anlamına gelir.[3] Tüm yukarı (aşağı-yukarı)-aşağı yollarda, iç (aşağı-yukarı) atlanabilir, çünkü ön işleme aşamasında bir kısayol oluşturulmuştur.

En kısa yolu hesaplarken -e , ileri (turuncu) ve geri (mavi) arama yalnızca hiyerarşide yukarı doğru giden kenarları takip etmelidir. Bulunan yol kırmızıyla işaretlenmiştir ve bir kısayol kullanır (kesikli).

Yol alma

Yukarıda açıklandığı gibi bir CH sorgusu, zaman veya mesafeyi verir -e ama gerçek yol değil. En kısa yoldaki kenarların (yolların) listesini elde etmek için, alınan kısayolların paketinden çıkarılması gerekir. Her kısayol, iki kenarın birleştirilmesidir: orijinal grafiğin iki kenarı veya iki kısayol veya bir orijinal kenar ve bir kısayol. Kasılma sırasında her bir kısayolun orta tepe noktasını saklamak, en kısa rotanın doğrusal zamanlı tekrarlamalı olarak açılmasını sağlar.[2][3]

Özelleştirilmiş kasılma hiyerarşileri

Kenar ağırlıkları ağ topolojisinden daha sık değiştirilirse, CH, ön işleme ve sorgu aşaması arasına bir özelleştirme aşaması dahil edilerek üç aşamalı bir yaklaşıma genişletilebilir. Bu, örneğin en kısa mesafe ile en kısa süre arasında geçiş yapmak için kullanılabilir veya mevcut trafik bilgilerinin yanı sıra belirli yol türlerinden (feribotlar, otoyollar, ...) kaçınmak gibi kullanıcı tercihlerini dahil etmek için kullanılabilir. Ön işleme aşamasında, çalışma süresinin çoğu düğümlerin sözleşmeli olduğu sırayı hesaplamak için harcanır.[3] Ön işleme aşamasındaki bu daraltma işlemleri dizisi, daha sonra özelleştirme aşamasında ihtiyaç duyulduğunda kaydedilebilir. Metrik her özelleştirildiğinde, daraltmalar, özel metrik kullanılarak depolanan siparişte verimli bir şekilde uygulanabilir.[2] Ek olarak, yeni kenar ağırlıklarına bağlı olarak bazı kısayolları yeniden hesaplamak gerekebilir.[3] Bunun işe yaraması için, kasılma sırasının metrikten bağımsız iç içe geçmiş diseksiyonlar kullanılarak hesaplanması gerekir.[1]

Uzantılar ve uygulamalar

Yukarıda açıklandığı gibi CH'ler, bir başlangıç ​​düğümünden bir hedef düğüme en kısa yolu ararlar. Bu denir bire bir en kısa yol ve örneğin araba navigasyon sistemlerinde kullanılır. Diğer uygulamalar arasında eşleştirme bulunur Küresel Konumlama Sistemi yol segmentlerine giden izler ve hızlanma trafik simülatörleri Bir ağdaki tüm sürücülerin izlediği olası yolları göz önünde bulundurması gereken. İçinde rota tahmini başlangıç ​​noktasından herhangi bir olası hedefe kadar mevcut ve geçmiş konumlarının en kısa yoldan ne kadar uyumlu olduğunu hesaplayarak bir aracın muhtemelen nereye gideceğini tahmin etmeye çalışır. Bu, CH'ler kullanılarak verimli bir şekilde yapılabilir.[2]

İçinde bire çok senaryolar, bir başlangıç ​​düğümü ve bir dizi hedef düğüm verilir ve mesafe hepsi için hesaplanmalıdır. Bire çok sorgular için en belirgin uygulama, ilgi noktası aramalarıdır. Tipik örnekler arasında en yakın benzin istasyonunu, restoranı veya postaneyi bulmak yerine gerçek seyahat süresini kullanarak coğrafi uzaklık metrik olarak.[2]

İçinde çoktan çoğa en kısa yol senaryosu, bir dizi başlangıç ​​düğümü ve bir dizi hedef düğüm verilir ve mesafe hepsi için hesaplanmalıdır. Bu, örneğin lojistik uygulamalarda kullanılır.[2] CH'ler, aşağıdaki şekilde çoktan çoğa sorgulara genişletilebilir: İlk olarak, her biri için geriye doğru bir arama yapın . Her köşe için bu arama sırasında tarandı, bir mağaza bir kovada . Daha sonra, her biri ileri doğru bir arama yapar. , boş olmayan her bir kova için, karşılık gelen tepe noktası üzerindeki rotanın en iyi mesafeyi iyileştirip iyileştirmediğini kontrol etme. Yani, eğer herhangi .[2][3]

Hatta bazı uygulamalar bire bir hesaplamalar, yani bir kaynak tepe noktasından mesafeleri bulma grafikteki diğer tüm köşelere. Dijkstra’nın algoritması her kenarı tam olarak bir kez ziyaret ettiğinden ve bu nedenle doğrusal zamanda çalıştığından teorik olarak optimaldir. Dijkstra’nın algoritması, ancak, paralelleştirmek ve değil önbellek için ideal kötü konumu nedeniyle. CH'ler, önbellek açısından daha uygun bir uygulama için kullanılabilir. Bunun için yukarı doğru bir arama ardından kısayolla zenginleştirilmiş grafikte tüm düğümler üzerinde aşağı doğru bir tarama gerçekleştirilir. Daha sonraki işlem, düğümler azalan önem sırasına göre işlendiğinden ve dolayısıyla belleğe buna göre yerleştirilebildiğinden, bellekte doğrusal bir şekilde tarar.[14] Bunun mümkün olduğunu unutmayın çünkü düğümlerin ikinci aşamada işlenme sırası kaynak düğümden bağımsızdır. .[2]

Üretimde, araba navigasyon sistemleri tahmin edilen trafik bilgilerini kullanarak en hızlı seyahat rotalarını hesaplayabilmeli ve alternatif rotaları görüntüleyebilmelidir. Her ikisi de CH'ler kullanılarak yapılabilir.[2] Birincisi, belirli bir sınırın seyahat süresinin artık sabit olmadığı, ancak kenara girerken günün saatinin bir işlevi olduğu zamana bağlı ağlarla yönlendirme olarak adlandırılır. Alternatif rotaların düzgün görünümlü olması, en kısa yoldan önemli ölçüde farklı olması, ancak önemli ölçüde uzun olmaması gerekir.[2]

CH'ler aynı anda birden fazla ölçümü optimize etmek için genişletilebilir; buna denir çoklu kriter rota planlanıyor. Örneğin, hem seyahat maliyeti hem de zaman en aza indirilebilir. Başka bir örnek elektrikli araçlar mevcut pil şarjı, pil boşalmayabileceğinden geçerli yolları kısıtlar.[2]

Referanslar

  1. ^ a b c d Dibbelt, Julian; Strasser, Ben; Wagner, Dorothea (5 Nisan 2016). "Özelleştirilebilir Kasılma Hiyerarşileri". Deneysel Algoritmalar Dergisi. 21 (1): 1–49. arXiv:1402.0402. doi:10.1145/2886843.
  2. ^ a b c d e f g h ben j k l m n Ö p q r Bast, Hannah; Delling, Daniel; Goldberg, Andrew V .; Müller-Hannemann, Matthias; Pajor, Thomas; Sanders, Peter; Wagner, Dorothea; Werneck, Renato F. (2016). "Ulaşım Ağlarında Rota Planlama". Algoritma Mühendisliği. Bilgisayar Bilimlerinde Ders Notları. 9220: 19–80. arXiv:1504.05140. doi:10.1007/978-3-319-49487-6_2. ISBN  978-3-319-49486-9.
  3. ^ a b c d e f g h Geisberger, Robert; Sanders, Peter; Schultes, Dominik; Vetter, Hıristiyan (2012). "Büyük Yol Ağlarında Daralma Hiyerarşilerini Kullanarak Tam Yönlendirme". Ulaşım Bilimi. 46 (3): 388–404. doi:10.1287 / trsc.1110.0401.
  4. ^ Delling, Daniel; Sanders, Peter; Schultes, Dominik; Wagner, Dorothea (2009). "Mühendislik Güzergah Planlama Algoritmaları". Büyük ve Karmaşık Ağların Algoritmaları. Bilgisayar Bilimlerinde Ders Notları. 5515: 117–139. doi:10.1007/978-3-642-02094-0_7. ISBN  978-3-642-02093-3.
  5. ^ "OSRM - Açık Kaynak Yönlendirme Makinesi".
  6. ^ "Wiki - OpenTripPlanner".
  7. ^ "Web - GraphHopper".
  8. ^ "GitHub - Tempus".
  9. ^ "GitHub - RoutingKit".
  10. ^ Bauer, Reinhard; Delling, Daniel; Sanders, Peter; Schieferdecker, Dennis; Schultes, Dominik; Wagner, Dorothea (2010-03-01). "Dijkstra algoritması için hiyerarşik ve hedefe yönelik hızlandırma tekniklerinin birleştirilmesi". Deneysel Algoritmalar Dergisi. 15: 2.1. doi:10.1145/1671970.1671976. ISSN  1084-6654.
  11. ^ Geisberger, Robert; Sanders, Peter; Schultes, Dominik; Delling, Daniel (2008). McGeoch, Catherine C. (ed.). "Kasılma Hiyerarşileri: Yol Ağlarında Daha Hızlı ve Daha Basit Hiyerarşik Yönlendirme". Deneysel Algoritmalar. Bilgisayar Bilimlerinde Ders Notları. Springer Berlin Heidelberg. 5038: 319–333. doi:10.1007/978-3-540-68552-4_24. ISBN  9783540685524.
  12. ^ Bauer, Reinhard; Columbus, Tobias; Rutter, Ignaz; Wagner, Dorothea (2016-09-13). "Daralma hiyerarşilerinde arama alanı boyutu". Teorik Bilgisayar Bilimleri. 645: 112–127. doi:10.1016 / j.tcs.2016.07.003. ISSN  0304-3975.
  13. ^ Delling, Daniel; Goldberg, Andrew V .; Razenshteyn, İlya; Werneck, Renato F. (Mayıs 2011). "Doğal Kesimlerle Grafik Bölümleme". (: unav): 1135–1146. CiteSeerX  10.1.1.385.1580. doi:10.1109 / ipdps.2011.108. ISBN  978-1-61284-372-8.
  14. ^ Delling, Daniel; Goldberg, Andrew V .; Nowatzyk, Andreas; Werneck, Renato F. (2011). "PHAST: Donanım Hızlandırmalı En Kısa Yol Ağaçları". Paralel ve Dağıtık İşleme Sempozyumu (IPDPS), 2011 IEEE International: 921–931. doi:10.1109 / ipdps.2011.89. ISBN  978-1-61284-372-8.

Dış bağlantılar

Açık kaynak uygulamaları