örneğin ?
İfadeler sıradan lise cebirindendir, ancak ters, çıkarma veya bölme olmadan aritmetik toplama ve çarpma (örn. ) ile sınırlıdır . Harfler değişkenlerdir.
Eğer yardımcı olursa, dışındaki sayısal değerlerle temsil edilen herhangi bir ifadeyi yasaklayabiliriz ; yani x 2 veya 3 x veya 4 değil :
- çok hatlı , 1'den başka güç yok : x + x y ≡ x 1 + x 1 y 1 tamam, ancak x 2 + x 3 y 4 değil ve toplam olarak tam bir genişlemede olduğu gibi temsil edilebilecek hiçbir şey değil -of-ürün olup, örneğin x ( x + y ) ≡ x 2 + y ;
- hepsi bir , 1'den başka katsayı yok : x + x y ≡ 1. x + 1. x y tamam, ancak 2 x + 3 x y değil ve tam bir genişlemede olduğu gibi temsil edilebilecek hiçbir şey değil ürün toplamı örneğin bir ( x + y ) + x ( a + b ) ≡ 2 a x + a y + b x değil ; ve
- 1'den başka sabit yok : yine, tamamen genişletilmiş ürün toplamında, örneğin ( a + 1 ) + ( b + 1 ) ≡ a + b + 2
İki ifadenin eşdeğer olup olmadığını belirlemek için etkili bir algoritma var mı?
Bunu göstermek için, üstel zamana sahip verimsiz bir kaba kuvvet algoritması:
her iki ifadeyi de eşdeğerlik açısından kolayca kontrol edilebilecek ürün toplamına kadar genişletin (işe gidip gelme / ilişkilendirme yeniden sipariş verebildiğinden siparişi dikkate almayın).
örneğin
a ( x + y ) + b ( x + y ) → a x + a y + b x + b y
Bu iyi bilinen bir sorun gibi görünüyor - lise öğrencilerine bile bunu çözmek için manuel yollar öğretiliyor. Ayrıca otomatik teorem kanıtlayıcıları / denetleyicileri tarafından çözüldü, ancak daha sofistike yönlere odaklanıyorlar.
: Burada çalışan bir çevrimiçi otomatik teoremi prover var http://tryacl2.org/ , gösterileri gidip / ilişkili bir dizi bularak denklik / vb dağıtmak:
? --- 188 adım
(thm (= (+ (* x y) x y) (+ x (* y (+ x 1))) ))
? --- 325 adım
(thm (= (+ y (* x (+ y 1))) (+ x (* y (+ x 1))) ))
Bu benim ilk sorum, bu yüzden lütfen yanlış yeri, yanlış etiketleri, açıklama / sorma yanlış yolunu seçtiysem bana bildirin. Teşekkürler!
Not: Bu soru yorumlara yanıt olarak yeniden yazılmıştır
Tüm yanıtlayanlara teşekkürler! Çok şey öğrendim.