İleriye bakış (geri izleme) - Look-ahead (backtracking)

İçinde geri izleme algoritmalar, ileriye bak için genel bir terimdir alt prosedür seçmenin etkilerini öngörmeye çalışan dallanma değişken değerlerinden birini değerlendirmek için. İleriye bakmanın iki ana amacı, bir sonraki değerlendirme için bir değişken ve ona atanacak değerlerin sırasını seçmektir.

Kısıtlama memnuniyeti

Genel olarak kısıtlama tatmin problemi her değişken bir etki alanında bir değer alabilir. Bir geriye dönük izleme algoritması bu nedenle yinelemeli olarak bir değişken seçer ve olası değerlerinin her birini test eder; her değer için algoritma tekrarlı koşmak. İleriye bakma, belirli bir değişkeni değerlendirmek için seçmenin etkilerini kontrol etmek veya ona verilecek değerlerin sırasına karar vermek için kullanılır.

İleriye bakma teknikleri

Bu örnekte, x1= 2 ve geçici atama x2= 1 kabul edilir.
İleriye doğru kontrol yalnızca atanmamış değişkenlerin her birinin x3 ve x4 dır-dir tutarlı kısmi atamayla, etki alanlarından 2 değerini kaldırır.

Belirli bir atamanın bir değişkene etkisini değerlendirmek için daha basit teknik denir ileri kontrol.[1] Mevcut kısmi çözüm ve değerlendirilmesi için aday atama göz önüne alındığında, başka bir değişkenin tutarlı bir değer alıp alamayacağını kontrol eder. Başka bir deyişle, önce mevcut kısmi çözümü, dikkate alınan değişken için geçici değerle genişletir; daha sonra diğer tüm değişkenleri dikkate alır hala atanmamış ve bir değerlendirme olup olmadığını kontrol eder bu genişletilmiş kısmi çözümle tutarlıdır. Daha genel olarak ileriye doğru kontrol, genişletilmiş ödev ile tutarlıdır.

Ark tutarlılığı ileriye bakma aynı zamanda değerlerin x3 ve x4 birbirleriyle tutarlıdır (kırmızı çizgiler) ayrıca etki alanlarından 1 değerini kaldırır.

Daha fazla zaman alan ancak daha iyi sonuçlar verebilecek bir ileriye dönük teknik, ark tutarlılığı. Yani, yeni bir değişken için bir değerle genişletilmiş kısmi bir çözüm verildiğinde, tüm atanmamış değişkenler için yay tutarlılığını zorlar. Başka bir deyişle, herhangi bir atanmamış değişken için, tutarlı bir şekilde başka bir değişkene genişletilemeyen değerler kaldırılır. İleriye doğru kontrol ve ark tutarlılığı arasındaki fark, birincisinin tutarlılık için yalnızca tek bir atanmamış değişkeni kontrol etmesi, ikincisinin de karşılıklı tutarlılık için atanmamış değişken çiftlerini kontrol etmesidir. Kısıt tatmin problemlerini çözmek için ileriye dönük kullanmanın en yaygın yolu, ark tutarlılığını (MAC) korumak algoritması.[2]

Ark tutarlılığını içeren diğer iki yöntem tam ve kısmi ileriye bakın. Ark tutarlılığını zorlarlar, ancak her değişken çifti için geçerli değildir. Özellikle tam görünüm, atanmamış her değişken çiftini dikkate alır ve aralarındaki ark tutarlılığını zorlar. Bu, muhtemelen bir çift değişkenin birden fazla kez yeniden değerlendirilmesini gerektirebilecek küresel ark tutarlılığını zorlamaktan farklıdır. Bunun yerine, tam ileriye bakmak bir çift değişken arasında ark tutarlılığını zorunlu kıldığında, çift artık dikkate alınmaz. Kısmi ileriye bakmak benzerdir, ancak belirli bir değişken sırası dikkate alınır ve yay tutarlılığı her çift için yalnızca bir kez uygulanır. ile .

Ark tutarlılığına dayalı ileriye bak, yol tutarlılığı ve genel i-tutarlılığı veya ilişkisel yay tutarlılığı ile çalışmak üzere genişletilebilir.

İleriye bakma kullanımı

İleriye bakmanın sonuçları, değerlendirilecek bir sonraki değişkene ve bu değişkene verilecek değerlerin sırasına karar vermek için kullanılır. Özellikle, herhangi bir atanmamış değişken ve değer için, ileriye dönük bakış, bu değişkeni bu değere ayarlamanın etkilerini tahmin eder.

Bir sonraki değişkenin seçimi ve ona verilecek bir sonraki değerin seçimi tamamlayıcıdır, çünkü değer tipik olarak bu şekilde seçilir (varsa), bir sonraki değişken tipik olarak seçilirken, mümkün olduğunca çabuk bir çözüm bulunur (eğer varsa) bu şekilde tatmin edilemezlik (eğer mevcut kısmi çözüm tatmin edici değilse) mümkün olduğu kadar çabuk kanıtlanmıştır.

Değerlendirilecek bir sonraki değişkenin seçimi, çalışma süresinde üstel farklılıklar oluşturabileceğinden özellikle önemlidir. Yetersizliği olabildiğince çabuk kanıtlamak için, atandıktan sonra birkaç alternatif bırakan değişkenler tercih edilenlerdir. Bu fikir, değişken / değer çiftlerinin yalnızca tatmin edilebilirliği veya tatmin edilemezliği kontrol edilerek uygulanabilir. Özellikle, seçilen bir sonraki değişken, mevcut kısmi çözüm ile tutarlı olan minimum sayıda değere sahip olandır. Buna karşılık, tutarlılık, sadece kısmi tutarlılık kontrol edilerek veya yukarıda tartışılan, dikkate alınan ileriye dönük tekniklerden herhangi biri kullanılarak değerlendirilebilir.

Aşağıda, bir değişkene geçici olarak atanacak değerleri sıralamak için üç yöntem verilmiştir:

  1. min-çatışmalar: tercih edilen değerler, ileriye bakılarak değerlendirildiği üzere atanmamış değişkenlerin etki alanından en az toplam değerleri kaldıranlardır;
  2. max-domain-size: Bir değişkenin tercihi, ileriye bakılarak değerlendirildiği gibi, atanmamış değişkenler için ürettikleri en küçük alandaki değerlerin sayısı ile ters orantılıdır;
  3. çözümleri tahmin edin: tercih edilen değerler, atanmamış değişkenlerin alanlarında kalan tüm değerlerin birbiriyle tutarlı olduğu varsayımıyla ileriye bakılarak değerlendirildiği üzere maksimum sayıda çözüm üreten değerlerdir; başka bir deyişle, bir değer tercihi, ileriye bakmadan kaynaklanan tüm alanların boyutlarının çarpılmasıyla elde edilir.

Deneyler, bu tekniklerin büyük sorunlar için, özellikle de minimum çatışmalar için yararlı olduğunu kanıtladı.[kaynak belirtilmeli ]

Randomizasyon, bazen bir değişken veya değer seçmek için de kullanılır. Örneğin, bazı ölçütlere göre iki değişken eşit olarak tercih edilirse, seçim rastgele yapılabilir.

Referanslar

  1. ^ R.M. Haralick ve G.L. Elliot (1980), "Kısıt tatmin sorunları için ağaç arama verimliliğini artırmak ". Yapay zeka, 14, s. 263–313.
  2. ^ Sabin, Daniel ve Eugene C. Freuder (1994), "Kısıt Memnuniyetinde Çelişen Geleneksel Akıl.” Kısıt Programlama İlkeleri ve Uygulaması, s. 10-20.
  • Dechter, Rina (2003). Kısıt İşleme. Morgan Kaufmann. ISBN  1-55860-890-7
  • Ouyang Ming (1998). "DPLL'de Dallanma Kuralları Ne Kadar İyi?". Ayrık Uygulamalı Matematik. 89 (1–3): 281–286. doi:10.1016 / S0166-218X (98) 00045-6.