|
DataMuseum.dkPresents historical artifacts from the history of: Rational R1000/400 |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about Rational R1000/400 Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - download
Length: 12288 (0x3000) Types: Ada Source Notes: 03_class, FILE, R1k_Segment, e3_tag, package body Generic_Rule_Base, package body Generic_Rule_Bundle, package body Rule_Instance, seg_02ccbf, seg_02cf16
└─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000 └─ ⟦5a81ac88f⟧ »Space Info Vol 1« └─⟦this⟧ └─⟦8527c1e9b⟧ Bits:30000544 8mm tape, Rational 1000, Arrival backup of disks in PAM's R1000 └─ ⟦cfc2e13cd⟧ »Space Info Vol 2« └─⟦this⟧
with Calendar; with Constant_String; with Generic_Condition_Element; with Generic_Conflict_Set; with Output_Stream; package body Generic_Rule_Base is package Condition_Elements is new Generic_Condition_Element (Max_Condition_Elements => Max_Condition_Elements, Fact_Query => Fact_Query, Null_Fact_Query => Null_Fact_Query, Fact_Queries => Fact_Queries); ------------------------------------------------------------------------- subtype Premiss_Size is Natural range 0 .. Max_Condition_Elements_By_Rule; subtype Rule_Name is Constant_String.Object; Null_Rule_Name : Rule_Name renames Constant_String.Null_Object; function As_Rule_Name (For_String : String) return Rule_Name renames Constant_String.Make; function Image (Of_Rule_Name : Rule_Name) return String renames Constant_String.Image; ------------------------------------------------------------------------- type Rule (The_Query_Count : Premiss_Size := 0) is record The_Bundle : Rule_Bundles; The_Rule : Natural; The_Name : Rule_Name; The_Premiss : Condition_Elements.Ids (1 .. The_Query_Count); end record; Null_Rule : constant Rule := (The_Query_Count => 0, The_Bundle => Rule_Bundles'First, The_Rule => 0, The_Name => Null_Rule_Name, The_Premiss => (others => 1)); subtype Rule_Index is Rule_Id range 1 .. Rule_Id (Max_Rules); type Rules is array (Rule_Index) of Rule; The_Rules : Rules := (others => Null_Rule); The_Last_Rule : Rule_Id := No_Rule; The_Inference_Count : Natural := 0; The_Elapsed_Time : Duration := 0.0; The_Firings_Per_Second : Natural := 0; ------------------------------------------------------------------------- package Rule_Instance is type Object (Size : Premiss_Size := 0) is record The_Rule : Rule_Id; The_Facts : Fact_Collection (1 .. Size); end record; Null_Object : constant Object := (Size => 0, The_Rule => No_Rule, The_Facts => Empty_Fact_Collection); function "<" (Left, Right : Object) return Boolean; procedure Put (The_Instance : Object; Where : Output_Stream.Object); end Rule_Instance; package body Rule_Instance is separate; package Conflict_Set is new Generic_Conflict_Set (Instance => Rule_Instance.Object, "<" => Rule_Instance."<", Put => Rule_Instance.Put); ------------------------------------------------------------------------- function Count return Natural is begin return The_Last_Rule; end Count; function Valid_Id (R : Rule_Id) return Boolean is begin return R > 0 and then R <= Max_Rules; end Valid_Id; function Get (R : Rule_Id) return Rule_Bundles is begin if Valid_Id (R) then return The_Rules (R).The_Bundle; else raise Illegal_Rule_Id; end if; end Get; function Get (R : Rule_Id) return Rule is begin if Valid_Id (R) then return The_Rules (R); else raise Illegal_Rule_Id; end if; end Get; procedure Null_Action (On : Fact_Collection) is begin null; end Null_Action; procedure Infere is Firing : Boolean; Started_At, Stopped_At : Calendar.Time; use Calendar; begin The_Inference_Count := 0; Started_At := Calendar.Clock; loop Firing := False; for I in The_Rules'First .. The_Last_Rule loop declare Answer : constant Fact_Collection := Retrieve (Filter => Condition_Elements.Get (The_Rules (I).The_Premiss)); begin if Answer /= Empty_Fact_Collection then Do_Action (For_Rule => I, On_Facts => Answer); Firing := True; The_Inference_Count := The_Inference_Count + 1; exit; end if; end; end loop; exit when not Firing; end loop; Stopped_At := Calendar.Clock; The_Elapsed_Time := Stopped_At - Started_At; The_Firings_Per_Second := Natural (Float (Inference_Count) / Float (Elapsed_Time)); end Infere; function Inference_Count return Natural is begin return The_Inference_Count; end Inference_Count; function Elapsed_Time return Duration is begin return The_Elapsed_Time; end Elapsed_Time; function Firings_Per_Second return Natural is begin return The_Firings_Per_Second; end Firings_Per_Second; procedure Put (R : Rule_Id; Where : Output_Stream.Object) is The_Rule : Rule renames The_Rules (R); The_Premiss : constant Fact_Queries := Condition_Elements.Get (The_Rule.The_Premiss); use Output_Stream; begin Put_Line ("Rule'(", Where); Indent_Right (Where); Put ("The_Bundle => ", Where); Put_Line (Rule_Bundles'Image (The_Rule.The_Bundle), Where); Put ("The_rule => ", Where); Put_Line (Image (The_Rule.The_Name), Where); Put ("The_premiss => ", Where); Queries_Put (The_Premiss, Where); Indent_Left (Where); Put_Line (")", Where); end Put; package body Generic_Rule_Bundle is separate; end Generic_Rule_Base;
nblk1=b nid=0 hdr6=16 [0x00] rec0=1d rec1=00 rec2=01 rec3=030 [0x01] rec0=18 rec1=00 rec2=02 rec3=00c [0x02] rec0=00 rec1=00 rec2=0b rec3=00e [0x03] rec0=1a rec1=00 rec2=0a rec3=05e [0x04] rec0=00 rec1=00 rec2=03 rec3=036 [0x05] rec0=2a rec1=00 rec2=04 rec3=018 [0x06] rec0=00 rec1=00 rec2=08 rec3=020 [0x07] rec0=16 rec1=00 rec2=09 rec3=064 [0x08] rec0=02 rec1=00 rec2=05 rec3=01e [0x09] rec0=1f rec1=00 rec2=06 rec3=03e [0x0a] rec0=09 rec1=00 rec2=07 rec3=000 tail 0x21524caca84046fb41455 0x42a00088462063c03