Jess (programlama dili) - Jess (programming language) - Wikipedia

Jess
Geliştirici (ler)Sandia Ulusal Laboratuvarları
Kararlı sürüm
7.1p2 / 5 Kasım 2008; 12 yıl önce (2008-11-05)
PlatformJava
LisansKapalı kaynak / Kamu malı
İnternet sitesiwww.jessrules.com

Jess bir kural motoru için Java tarafından geliştirilen platform Ernest Friedman-Hill nın-nin Sandia Ulusal Laboratuvarları.[1] Bu bir süperset of CLIPS programlama dili.[1] İlk olarak 1995'in sonlarında yazılmıştır.[1] Dil sağlar kural tabanlı programlama bir otomasyon için uzman sistem ve sıklıkla bir uzman sistem kabuğu.[1] Son yıllarda, akıllı ajan benzer bir yeteneğe dayanan sistemler de geliştirildi.

Bir yerine prosedürel paradigma, tek bir programın yalnızca bir kez etkinleştirilen bir döngüsü olduğu durumlarda, bildirimsel paradigma Jess tarafından kullanılan bir işlemle, bir dizi olguyu sürekli olarak bir kurallar derlemesine uygular. desen eşleştirme. Kurallar, bilgi koleksiyonunu değiştirebilir veya herhangi bir Java kodunu çalıştırabilir.

Jess kuralları motoru, Rete algoritması,[1] ve aşağıdakileri oluşturmak için kullanılabilir:

Lisans

CLIPS şu şekilde lisanslanır: açık kaynak, Jess açık kaynak değildir. JESS eğitim ve devlet kullanımı için ücretsizdir ancak JESS'i ticari sistemler için kullanmak için bir lisans gerekir.

Kod örnekleri

Kod örnekleri:

; bir yorum(bağlamak ? x 100); x = 100(ayrılma max (? a ? b)             (Eğer (> ? a ? b) sonra ? a Başka ? b))(deffacts benim odam          (mobilya sandalye)          (mobilya masa)          (mobilya yatak)          )(deftemplate araba             (yuva renk)             (yuva kilometre)             (yuva değer)             )(iddia etmek (araba (renk kırmızı) (kilometre 10000) (değer 400)))

Basit kod:

(açık)(deftemplate kan bağışçısı (yuva isim) (yuva tip))(deffacts kan Bankası ; isimleri ve türlerini [[çalışan bellek]] içine yerleştirin          (kan bağışçısı (isim "Alice")(tip "A"))          (kan bağışçısı (isim "Agatha")(tip "A"))          (kan bağışçısı (isim "Bob")(tip "B"))          (kan bağışçısı (isim "Barbara")(tip "B"))          (kan bağışçısı (isim "Jess")(tip "AB"))          (kan bağışçısı (isim "Karen")(tip "AB"))          (kan bağışçısı (isim "Onan")(tip "Ö"))          (kan bağışçısı (isim "Osbert")(tip "Ö"))          )(defrule can-give-to-same-but-self-self ; A> A, B> B, O> O, AB> AB'yi işler, ancak N1> N1'i değil         (kan bağışçısı (isim isim)(tip tür))         (kan bağışçısı (isim ? isim2)(tip ?Tip 2 &:(eq tür ?Tip 2) &: (neq isim ? isim2) ))         =>         (çıktı t isim "kan verebilir" ? isim2 crlf)         )(defrule Başkalarına-verir ama kendine-değil ; Yukarıdaki kuralda O ila O kapağı         (kan bağışçısı (isim isim)(tip tür &:(eq tür "Ö")))         (kan bağışçısı (isim ? isim2)(tip ?Tip 2 &: (neq tür ?Tip 2) &: (neq isim ? isim2) ))         =>         (çıktı t isim "kan verebilir" ? isim2 crlf)         )(defrule A veya B, AB'ye verir ; O durumu AB'ye verir ve AB, halihazırda ele alınan AB'ye verir         (kan bağışçısı (isim isim)(tip tür &:(veya (eq tür "A") (eq tür "B" ))))         (kan bağışçısı (isim ? isim2)(tip ?Tip 2 &: (eq ?Tip 2 "AB") &: (neq isim ? isim2) ))         =>         (çıktı t isim "kan verebilir" ? isim2 crlf)         ); (tümünü izle)(Sıfırla)(koşmak)

Ayrıca bakınız

İlgili sistemler

Referanslar

  1. ^ a b c d e f g h Hemmer, Markus C. (2008). Kimya Araştırmalarında Uzman Sistemler. CRC Basın. s. 47–48. Alındı 30 Mart, 2012. ISBN  978-1-4200-5323-4

Ek kaynaklar

Dış bağlantılar