Geri atlama - Backjumping

İçinde geri izleme algoritmalar, geri atlama azaltan bir tekniktir arama alanı, bu nedenle verimliliği artırır. Geriye dönük izleme her zaman bir seviye yukarı çıkarken arama ağacı bir değişken için tüm değerler test edildiğinde, geri atlama daha fazla seviyeye çıkabilir. Bu makalede, değişkenlerin sabit bir değerlendirme sırası kullanılır, ancak aynı hususlar dinamik bir değerlendirme sırası için de geçerlidir.

Tanım

Geri izleme, bir değişken için tüm değerleri herhangi bir çözüm bulmadan denediğinde, daha önce atanan değişkenlerin sonunu yeniden değerlendirir, değerini değiştirir veya başka hiçbir değer denenmeyecekse daha fazla geriye doğru izleme yapar. Eğer geçerli kısmi atama ve tüm değerler bir çözüm bulamadan denendiğinde, geriye doğru izleme, var. Algoritma daha sonra "yükselir" , değiştirme Mümkünse değeri, aksi takdirde tekrar geriye dönülür.

Kısmi atama, hiçbir değerin olmadığını kanıtlamak için her zaman tam olarak gerekli değildir. bir çözüme götürür. Özellikle, kısmi atamanın bir öneki aynı özelliğe sahip olabilir, yani bir indeks mevcuttur öyle ki değeri ne olursa olsun bir çözüm oluşturmak için genişletilemez . Algoritma bu gerçeği kanıtlayabilirse, doğrudan farklı bir değeri düşünebilir. yeniden düşünmek yerine normalde olduğu gibi.

Geriye atlama değişkenleri-1.svgGeriye atlama değişkenleri-2.svgGeriye atlama değişkenleri-3.svg
Mevcut atamanın bir örnek her olası değerle başarısız bir şekilde denendi . Geri izleme, , ona yeni bir değer atamaya çalışıyor.Algoritma, geriye dönük izleme yerine, daha fazla detaylandırma yaparak değerlendirmelerin , , ve herhangi bir çözümün parçası değildir.Sonuç olarak, şu anki değerlendirme herhangi bir çözümün parçası değildir ve algoritma doğrudan , bunun için yeni bir değer deniyor.

Geri atlama algoritmasının verimliliği, ne kadar yüksek geri sıçrama yapabileceğine bağlıdır. İdeal olarak algoritma, hangi değişkene şu anki atama herhangi bir değeri olan bir çözüm oluşturmak için genişletilemez . Eğer durum buysa, denir güvenli atlama.

Güvenli sıçramalar, algoritmanın bulmaya çalıştığı çözüm kümesi açısından tanımlandığından, bir sıçramanın güvenli olup olmadığını belirlemek her zaman mümkün değildir. Pratikte, geri atlama algoritmaları güvenli bir sıçrama olduğunu etkili bir şekilde kanıtlayabilecekleri en düşük endeksi kullanır. Farklı algoritmalar, bir atlamanın güvenli olup olmadığını belirlemek için farklı yöntemler kullanır. Bu yöntemlerin farklı maliyetleri vardır, ancak daha yüksek bir güvenli sıçrama bulmanın daha yüksek bir maliyeti, arama ağacının bazı bölümlerinin atlanması nedeniyle daha az miktarda aramadan satılabilir.

Yaprak düğümlerinde geri atlama

Geri sıçramanın mümkün olduğu en basit koşul, bir değişkenin tüm değerlerinin daha fazla dallanma olmaksızın tutarsız olduğunun kanıtlanmasıdır. İçinde kısıtlama memnuniyeti kısmi bir değerlendirme tutarlı ancak ve ancak atanan değişkenleri içeren tüm kısıtlamaları karşılarsa ve tutarsız aksi takdirde. Tutarlı bir kısmi çözümün tutarlı bir tam çözüme genişletilemeyeceği bir durum olabilir çünkü atanmamış değişkenlerin bazıları diğer kısıtlamaları ihlal etmeden atanamayabilir.

Belirli bir değişkenin tüm değerlerinin mevcut kısmi çözümle tutarsız denir yaprak çıkmaz. Bu tam olarak değişken arama ağacının bir yaprağıdır (bu makalenin şekillerinde yalnızca çocuk olarak yapraklara sahip düğümlere karşılık gelir.)

Gaschnig'in geri atlama algoritması, yalnızca yaprak çıkmazlarında geri atlama yapar. Başka bir deyişle, yalnızca olası her değerin geri izlemeden farklı şekilde çalışır. başka bir değişkene göre dallanmaya gerek kalmadan test edilmiş ve tutarsız sonuçlanmıştır.

Her değer için basitçe değerlendirilerek güvenli bir sıçrama bulunabilir. , en kısa öneki ile tutarsız . Başka bir deyişle, eğer olası bir değerdir , algoritma aşağıdaki değerlendirmelerin tutarlılığını kontrol eder:

...
...
...

Değerlendirmelerin tutarsız olduğu en küçük indeks (listelemenin en alt kısmı), eğer tek olası değerdi . Her değişken genellikle birden fazla değer alabildiğinden, her bir değer için kontrolden çıkan maksimal indeks güvenli bir sıçramadır ve Gaschnig'in algoritmasının atladığı noktadır.

Uygulamada, algoritma yukarıdaki değerlendirmeleri kontrol edebilir, aynı zamanda tutarlılığını kontrol edebilir. .

Dahili düğümlerde geri atlama

Önceki algoritma, yalnızca bir değişkenin değerleri, daha fazla dallanma olmaksızın mevcut kısmi çözümle tutarsız gösterilebildiğinde geriye atlar. Diğer bir deyişle, yalnızca arama ağacındaki yaprak düğümlerinde bir geri sıçramaya izin verir.

Arama ağacının dahili bir düğümü, öncekilerle tutarlı bir değişken atamasını temsil eder. Hiçbir çözüm bu atamayı genişletmezse, önceki algoritma her zaman geriye doğru izler: bu durumda geri atlama yapılmaz.

İç düğümlerde geri atlama, yaprak düğümlerde olduğu gibi yapılamaz. Nitekim, bazı değerlendirmeler gerekli dallanma, çünkü mevcut atama ile tutarlı olmalarıdır. Sonuç olarak, son değişkenin bu değerleri ile tutarsız olan bir önek aranması başarılı olmaz.

Bu gibi durumlarda, bir değerlendirmeyi kanıtlayan şey mevcut kısmi değerlendirme ile çözümün parçası olmamak ... yinelemeli arama. Özellikle, algoritma bu noktadan sonra hiçbir çözümün olmadığını "bilir" çünkü bir çözüm bulduktan sonra durmak yerine bu düğüme geri döner.

Bu geri dönüş, bir dizi çıkmaz sokaklar, algoritmanın kısmi bir çözümün tutarsız olduğunu kanıtladığı noktalar. Daha fazla geri atlama yapmak için algoritmanın, çözüm bulmanın imkansızlığının bu çıkmazlardan kaynaklandığını hesaba katması gerekir. Özellikle, güvenli sıçramalar, bu çıkmazları tutarsız kısmi çözümler haline getiren öneklerin indeksleridir.

Çıkmaz-1.svgÇıkmaz-1a.svgÇıkmaz-2.svgÇıkmazlar-3.svg
Bu örnekte, algoritma geri dönüyor , tüm olası değerleri denedikten sonra, üç kesişen tutarsızlık noktası nedeniyle.İkinci nokta, değerleri olsa bile tutarsız kalır. ve kısmi değerlendirmesinden çıkarılır (bir değişkenin değerlerinin alt öğelerinde olduğuna dikkat edin)Diğer tutarsız değerlendirmeler, , , ve Algoritma geri atlayabilir çünkü bu, tüm tutarsızlıkları koruyan en düşük değişkenlerdir. İçin yeni bir değer denenecek.

Başka bir deyişle, tüm değerleri denendi, algoritma önceki bir değişkene geri atlayabilir mevcut doğruluk değerlendirmesinin tüm gerçek değerlendirmeleriyle tutarsız düğümün soyundan gelen yaprak düğümlerinde .

Basitleştirmeler

Olası bir geri atlama ararken veya atalarından biri, gölgeli alandaki tüm düğümler göz ardı edilebilir.

Alt ağacında bulunan potansiyel olarak yüksek düğüm sayısı nedeniyle güvenli bir şekilde geri atlamak için gerekli olan bilgiler alt ağacının ziyareti sırasında toplanır. Güvenli bir sıçrama bulmak, iki hususla basitleştirilebilir. Birincisi, algoritmanın güvenli bir sıçramaya ihtiyacı vardır, ancak yine de mümkün olan en yüksek güvenli atlama olmayan bir sıçrayışla çalışır.

İkinci basitleştirme, alt ağacındaki düğümlerin geri atlama ile atlananlar, geri atlama aranırken göz ardı edilebilir. . Daha doğrusu, düğümden geri atlama ile atlanan tüm düğümler düğüme kadar köklü alt ağaçla ilgisizdir ve diğer alt-ağaçları da ilgisizdir.

Gerçekten, bir algoritma düğümden düşerse -e bir yol üzerinden ancak geri atlarsa, o zaman doğrudan -e yerine. Aslında, geri atlama, aradaki düğümlerin ve köklü alt ağaçla ilgisiz . Başka bir deyişle, geri atlama, arama ağacının bir bölgesinin ziyaretinin bir hata olduğunu gösterir. Arama ağacının bu kısmı, bu nedenle, olası bir geri atlama düşünüldüğünde ihmal edilebilir. ya da atalarından birinden.

Değerleri bir düğümde köklenen alt ağaçta yetersizliği kanıtlamak için yeterli olan değişkenler düğümde toplanır ve geri çekilirken yukarıdaki düğüme (düğümün değişkeni kaldırıldıktan sonra) gönderilir.

Bu olgudan, her bir düğümde, daha önce atanmış bir dizi değişken toplanarak, bunların değerlendirilmesi düğümde köklenen alt ağaçta hiçbir çözümün bulunmadığını kanıtlamak için yeterli olabilir. Bu set, algoritmanın yürütülmesi sırasında oluşturulur. Bir düğümden geri çekilirken, bu küme düğümün değişkeni çıkarılır ve geri izleme veya geri atlama hedefi kümesinde toplanır. Geri atlama işleminden atlanan düğümler hiçbir zaman geri çekilmediği için kümeleri otomatik olarak yok sayılır.

Grafik tabanlı geri atlama

Grafik tabanlı geri sıçramanın mantığı, güvenli bir sıçramanın değişkenlerin hangileri olduğunu kontrol ederek bulunabileceğidir. değişkenlerle kısıtlı yaprak düğümlerde örneklenen. Her yaprak düğüm ve her değişken için indeks orada örneklenen, dizinler küçük veya eşit değişkeni ile kısıtlı olan güvenli atlayışlar bulmak için kullanılabilir. Özellikle, tüm değerler için denenmişse, bu set, köklü alt ağaca gidilerek hiçbir çözüm bulunamadığını kanıtlamaya izin veren değerlendirmeleri içeren değişkenlerin dizinlerini içerir. . Sonuç olarak, algoritma bu kümedeki en yüksek dizine geri dönebilir.

Geri atlama ile atlanan düğümlerin, başka bir geri atlama düşünüldüğünde göz ardı edilebilmesi, aşağıdaki algoritma tarafından kullanılabilir. Bir yaprak düğümden geri çekilirken, kendisiyle kısıtlı olan değişkenler kümesi yaratılır ve geri atlama durumunda ebeveynine veya atasına "geri gönderilir". Her dahili düğümde bir dizi değişken korunur. Altlarından veya altlarından birinden bir değişken kümesi her alındığında, değişkenleri korunan kümeye eklenir. Düğümden daha fazla geri izleme veya geri atlama yapıldığında, düğümün değişkeni bu kümeden çıkarılır ve küme, geri izleme veya geri atlama hedefi olan düğüme gönderilir. Bu algoritma çalışır, çünkü bir düğümde tutulan küme, bu düğümün soyundan gelen yapraklarda yetersizliği kanıtlamak için ilgili tüm değişkenleri toplar. Değişken kümeleri yalnızca düğümlerden yeniden izlenirken gönderildiği için, geri atlama ile atlanan düğümlerde toplanan kümeler otomatik olarak göz ardı edilir.

Çatışmaya dayalı geri atlama (diğer bir deyişle çatışmaya yönelik geri atlama (cbj))

Bazen daha büyük geri sıçramalar elde edebilen daha rafine bir geri atlama algoritması, yalnızca aynı kısıtlamadaki iki değişkenin ortak varlığını kontrol etmeye değil, aynı zamanda kısıtlamanın gerçekten tutarsızlığa neden olup olmadığına da dayanır. Özellikle, bu algoritma her yaprakta ihlal edilen kısıtlamalardan birini toplar. Her düğümde, yapraklarda toplanan kısıtlamalardan birinde bulunan bir değişkenin en yüksek indeksi güvenli bir sıçramadır.

Her yaprakta seçilen ihlal edilen sınırlama, sonuçta ortaya çıkan sıçramanın güvenliğini etkilemezken, mümkün olan en yüksek indislerin kısıtlamalarının seçilmesi, sıçramanın yüksekliğini artırır. Bu nedenle, çatışmaya dayalı geri atlama emirleri, daha düşük endeks değişkenleri üzerindeki kısıtlamalar, daha yüksek endeks değişkenlerindeki kısıtlamalara tercih edilir.

Resmi olarak, bir kısıtlama diğerine tercih edilir içindeki bir değişkenin en yüksek indeksi ama içinde değil içindeki bir değişkenin en yüksek indeksinden daha düşüktür ama içinde değil . Diğer bir deyişle, ortak değişkenler hariç, tüm düşük indislere sahip olan kısıt tercih edilir.

Bir yaprak düğümde, algoritma en düşük dizini seçer öyle ki yaprakta değerlendirilen son değişkenle tutarsızdır. Bu değerlendirmede ihlal edilen kısıtlamalar arasından en çok tercih edileni seçer ve tüm endekslerini en az . Bu şekilde, algoritma değişkene geri döndüğünde , toplanan en düşük endeks güvenli bir sıçramayı tanımlar.

Uygulamada, bu algoritma, her bir değer için bir küme oluşturmak yerine, tüm endeksleri tek bir kümede toplayarak basitleştirilmiştir. . Özellikle, algoritma, her düğümde, geri atlama ile atlanmayan soyundan gelen tüm kümeleri toplar. Bu düğümden geri çekilirken, bu küme düğümün değişkeni çıkarılır ve geri izleme veya geri atlama hedefinde toplanır.

Çatışmaya yönelik geri atlama önerildi Kısıt Memnuniyet Sorunları tarafından Patrick Prosser 1993 tarihli makalesinde.

Ayrıca bakınız

Referanslar

  • Dechter, Rina (2003). Kısıt İşleme. Morgan Kaufmann. ISBN  1-55860-890-7.
  • Prosser Patrick (1993). "Kısıt Memnuniyeti Problemi için Hibrit Algoritmalar" (PDF). Hesaplamalı Zeka 9 (3). Alıntı dergisi gerektirir | günlük = (Yardım)