AC-3 algoritması - AC-3 algorithm

AC-3 algoritma (kısaltması Ark Tutarlılığı Algoritma # 3), aşağıdakilerin çözümü için kullanılan bir dizi algoritmadan biridir. kısıtlama tatmin sorunları (veya CSP'ler). Tarafından geliştirilmiştir Alan Mackworth Daha önceki AC algoritmaları genellikle çok verimsiz olarak kabul edilir ve sonraki birçok algoritmanın uygulanması zordur ve bu nedenle AC-3, çok basit kısıt çözücülerde en sık öğretilen ve kullanılan algoritmadır.

Algoritma

AC-3 şunlarla çalışır kısıtlamalar, değişkenler ve değişkenlerin alanları (kapsamlar). Bir değişken birkaç farklı değerden herhangi birini alabilir; belirli bir değişken için değerler kümesi, alan adı. Bir kısıtlama bir ilişki bir değişkenin sahip olabileceği değerleri sınırlayan veya kısıtlayan. Kısıtlama, diğer değişkenlerin değerlerini içerebilir.

Algoritma sırasında CSP'nin mevcut durumu bir Yönlendirilmiş grafik, düğümler, simetrik kısıtlamalarla ilişkili değişkenler arasında kenarlar veya yaylar olan, sorunun değişkenleri olduğunda, iş listesindeki her yay, kontrol edilmesi gereken bir kısıtlamayı temsil eder tutarlılık. AC-3, değişken çiftleri arasındaki yayları inceleyerek ilerler (x, y). Bu değerleri etki alanından kaldırır x arasındaki kısıtlamalarla tutarlı olmayan x ve y. Algoritma, henüz kontrol edilmemiş yayların bir koleksiyonunu tutar; Bir değişkenin etki alanında herhangi bir değer kaldırıldığında, bu budanmış değişkene işaret eden tüm kısıt yayları (mevcut kısıtlamanın yayı hariç) koleksiyona eklenir. Değişkenlerin alanları sonlu olduğundan ve her adımda bir yay veya en az bir değer kaldırıldığından, bu algoritmanın bitirmek.

Örnek olarak, çok basit bir kısıtlama problemine bir örnek:X (bir değişken) olası değerlere {0, 1, 2, 3, 4, 5} sahiptir - bu değerlerin kümesi, Xveya D (X). Değişken Y D etki alanına sahiptir (Y) = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}. Kısıtlamalarla birlikte C1 = "X eşit olmalı "ve C2 = "X + Y 4 "e eşit olmalıdır" AC-3'ün çözebileceği bir CSP'ye sahibiz. Bu sorunu temsil eden gerçek kısıtlama grafiğinin iki kenar içermesi gerektiğine dikkat edin. X ve Y dan beri C2 yönsüzdür, ancak AC-3 tarafından kullanılan grafik gösterimi yönlendirilmiştir.

Bunu, ilk önce alanından çift olmayan değerleri kaldırarak yapar. X Tarafından istendiği gibi C1, bırakarak D (X) = {0, 2, 4}. Daha sonra arkadaki yayları inceler X ve Y kastedilen C2. Sadece çiftler (X=0, Y=4), (X=2, Y= 2) ve (X=4, Y= 0) kısıtlama ile eşleşir C2. AC-3 daha sonra D (X) = {0, 2, 4} ve D (Y) = {0, 2, 4}.

AC-3, sözde kodla şu şekilde ifade edilir:

 Giriş: Bir dizi değişkenler X bir dizi etki alanları X'deki her bir x değişkeni için D (x). D (x), vx0, vx1 ... vxn, x değişkeninin olası değerlerini içerir. X değişkeni üzerinde karşılanması gereken bir tekli kısıtlar kümesi R1 (x) Bir dizi ikili kısıtlama Sağlanması gereken x ve y değişkenleri üzerindeki R2 (x, y) Çıktı: Her değişken için tutarlı alanlar yay. ac3 işlevi (X, D, R1, R2)     // İlk etki alanları tekli kısıtlamalarla tutarlı hale getirilir.     her biri için x içinde X D (x): = {vx in D (x) | vx, R1 (x) 'i karşılar} // 'iş listesi' tutarlı olup olmadığını kanıtlamak istediğimiz tüm yayları içerir.     çalışma listesi: = {(x, y) | R2 (x, y) veya R2 (y, x) ilişkisi vardır} yapmak         iş listesi iş listesinden herhangi bir yay (x, y) seçin: = iş listesi - (x, y) Eğer yay azaltma (x, y) Eğer D (x) boş dönüş başarısızlık Başka                 çalışma listesi: = iş listesi + {(z, x) | z! = y ve bir R2 (x, z) veya bir R2 (z, x) ilişkisi vardır} süre çalışma listesi değil boş işlevi yay azaltma (x, y) bool değişim = yanlış     her biri için vx içinde D (x), vx ve vy'nin R2 (x, y) kısıtlamasını sağlaması için D (y) 'de bir vy değeri bulun Eğer böyle bir vy {D (x): = D (x) - vx değişikliği: = yok doğru         }     dönüş değişiklik

Algoritma, en kötü durum zaman karmaşıklığına sahiptir. Ö(ed3) ve uzay karmaşıklığı Ö(e), nerede e yay sayısıdır ve d , en büyük alanın boyutudur.

Referanslar

- -