In this example, we're determining whether a given airline passenger is eligible to have their coach seat upgraded to a first-class seat. In order to be eligible, a passenger must:
In order to determine this, we must compare a passenger's facts with our rule.
We fetch the rule from our RuleBase, which, for simplicity's sake, is merely a text file with a .rul extension. It's contents are in Reverse Polish Notation (to handle precedence):
# Rule establishing when an airline passenger may be # allowed to upgrade his/her seat. passengerIsEconomy IS true passengerIsGoldCardHolder IS true passengerIsSilverCardHolder IS true OR AND passengerCarryOnBaggageAllowance EQUALS 15.0 passengerCarryOnBaggageWeight EQUALS 10.0 LESSTHANOREQUALTO AND
We get facts pertaining to a Rule from our FactBase, which again is simply a text file. Note the difference between a sql.con file and a txt.con file.
# Format of this file is: # Rule_Element_Type|Rule_Element_Name|SQL_Statement|Expected_Return_Data_Type_from_SQL_Query p|passengerIsEconomy|SELECT if(((SELECT p.class FROM passengers p WHERE p.id = ? ) = 'economy'), 1, 0);|boolean p|passengerIsGoldCardHolder|SELECT if(((SELECT p.card_type FROM passengers p WHERE p.id = ? ) = 'gold'), 1, 0);|boolean p|passengerIsSilverCardHolder|SELECT if(((SELECT p.card_type FROM passengers p WHERE p.id = ? ) = 'silver'), 1, 0);|boolean v|passengerCarryOnBaggageWeight|SELECT b.weight FROM passengers p, baggage b WHERE b.passenger_id = p.id and p.id = ?;|double v|passengerCarryOnBaggageAllowance|SELECT v.value FROM variables v WHERE v.name = 'passengerCarryOnBaggageAllowance';|double
Proposition statement = ( ( passengerCarryOnBaggageWeight <= passengerCarryOnBaggageAllowance ) AND ( ( passengerIsSilverCardHolder OR passengerIsGoldCardHolder ) AND passengerIsEconomy ) ), value = TRUE
Page executed in 0.1954 seconds.