No BSD License  

4.5

4.5 | 2 ratings Rate this file 8 Downloads (last 30 days) File Size: 8.58 KB File ID: #9218

EXPERT1

by

 

01 Dec 2005 (Updated )

An easy to use deduction engine useful for small expert systems and embedding complex condition ...

| Watch this File

File Information
Description

An easy to use deduction engine useful for small expert systems and embedding complex condition statements.

Rules are written in a structure (one field for each rule) using a general format easily obtained from "If And Then? rules e.g.
"If bird And ~flies And swims Then penguin" is input as
rules.r1={'~bird' 'flies? '~swims? 'penguin?}
(This is the conjunctive normal form where each term (proposition) in the converted rule is separated by an "or" operator, and each rule by an "and" operator. Any logical conditions can be converted to this form)

Data is entered as a second struct e.g.
data.penguin=false; data.bird=true; data.swims=true

Deduction is done as: results=deduce(rules,data)

Both data and results can be printed e.g.:
printdata(results)

A meaning struct can be created for propositions (in data & results):
info.penguin='The animal is a penguin?; info.bird=?The animal is a bird'
and used with printdata e.g. printdata(data,info)

Rules can be constructed using classical logic, but deduction is done using a two variable logic that includes unknown, partly true, partly false, and if you get it wrong inconsistent, as well as the ordinary true and false. Logic is implemented as "min" for "and" and "max" for "or", which avoids problems with redundant rules and allows efficient simple deductions.

Results give what is known about a proposition as %true and %false. So true is 100% true and 0 %false, while false is 0% true and 100% false. Data can be entered in this format also e.g. data.flies=[50 0].

Deduction is carried out using a more efficient numerical internal format, that can be used in place of the above structs for repeated use of large rule sets e.g.

[r,names]=cnvtrules(rules);
d=cnvtdata(data,names);
d1=deduce(r,d);
results=cnvtd(d1,names)

Let me know if you find this useful, or are interested in getting extensions to it: W.Whiten@uq.edu.au

MATLAB release MATLAB 7 (R14)
Tags for This File   Please login to tag files.
Please login to add a comment or rating.
Comments and Ratings (3)
02 Apr 2012 Ronan CIMADURE  
11 Mar 2010 Bill Whiten

A SIMPLE ALGORITHM FOR DEDUCTION
BILL WHITEN
The ANZIAM Journal , Volume 51 , Issue 01 , Jul 2009 , pp 102-122
doi: 10.1017/S1446181109000352 (About doi), Published online by Cambridge University Press 09 Mar 2010

02 Dec 2005 John D'Errico

Pretty. Even if I don't have a direct use for this tool, I still
recognize something nice when I see it.

Contact us