public void mainTest() { String rulefile = getRoot("share_5nodes.clp"); //bool keepopen = false; int fcount = 50000; Console.WriteLine("Using file " + rulefile); RulesetBenchmark2 mb = new RulesetBenchmark2(); long begin = DateTime.Now.Ticks; long totalET = 0; long parseET = 0; ArrayList facts = new ArrayList(50000); // Runtime rt = Runtime.getRuntime(); long total1 = GC.GetTotalMemory(true); //long free1 = rt.freeMemory(); //long used1 = total1 - free1; int loopcount = 5; Console.WriteLine("Used memory before creating engine " + total1 + " bytes " + (total1 / 1024) + " Kb"); for (int loop = 0; loop < loopcount; loop++) { Console.WriteLine(" ---------------------------------- "); Rete engine = new Rete(); facts.Clear(); // declare the objects engine.declareObject(typeof(Account), "account"); engine.declareObject(typeof(Transaction), "transaction"); long total2 = GC.GetTotalMemory(true); //long free2 = rt.freeMemory(); //long used2 = total2 - free2; Console.WriteLine("Used memory after creating engine " + total2 + " bytes " + (total2 / 1024) + " Kb"); try { StreamReader freader = new StreamReader(rulefile); CLIPSParser parser = new CLIPSParser(engine, freader); long start = DateTime.Now.Ticks; mb.parse(engine, parser, facts); long end = DateTime.Now.Ticks; long el = end - start; parser.close(); //rt.gc(); parseET += el; long total3 = GC.GetTotalMemory(true); //long free3 = rt.freeMemory(); //long used3 = total3 - free3; Console.WriteLine("Used memory after loading rules, and parsing data " + (total3 / 1024) + " Kb " + (total3 / 1024 / 1024) + " Mb"); Console.WriteLine("elapsed time to parse the rules and data " + el + " ms"); Console.WriteLine("Number of rules: " + engine.CurrentFocus.RuleCount); // now create the facts Account acc = new Account(); acc.AccountType = "standard"; facts.Add(acc); for (int i = 0; i < fcount; i++) { Transaction tx = new Transaction(); tx.AccountId = "acc" + i; tx.Exchange = "NYSE"; tx.Issuer = "AAA"; tx.Shares = 100.00; tx.SecurityType = "stocks"; tx.SubIndustryID = 25201010; facts.Add(tx); } IEnumerator itr = facts.GetEnumerator(); long start2 = DateTime.Now.Ticks; while (itr.MoveNext()) { Object d = itr.Current; if (d is Account) { engine.assertObject(d, "account", false, true); } else { engine.assertObject(d, "transaction", false, false); } } int actCount = engine.ActivationList.size(); long end2 = DateTime.Now.Ticks; long et2 = end2 - start2; totalET += et2; // now fire the rules long start3 = 0; long end3 = 0; int fired = 0; try { start3 = DateTime.Now.Ticks; fired = engine.fire(); end3 = DateTime.Now.Ticks; } catch (Exception e) { Console.WriteLine(e.Message); } facts.Clear(); long total4 = GC.GetTotalMemory(true); //long free4 = rt.freeMemory(); //long used4 = total4 - free4; Console.WriteLine(""); Console.WriteLine("Number of facts - " + engine.ObjectCount); Console.WriteLine("Time to assert facts " + et2 + " ms"); Console.WriteLine("Used memory after assert " + (total4 / 1024) + " Kb " + (total4 / 1024 / 1024) + " Mb"); engine.printWorkingMemory(true, false); Console.WriteLine("number of activations " + actCount); Console.WriteLine("rules fired " + fired); Console.WriteLine("time to fire rules " + (end3 - start3) + " ms"); } catch (FileNotFoundException e) { Console.WriteLine(e.Message); } catch (AssertException e) { Console.WriteLine(e.Message); } engine.close(); engine = null; //rt.gc(); } long finished = DateTime.Now.Ticks; Console.WriteLine("average parse ET - " + parseET / loopcount + " ms"); Console.WriteLine("average assert ET - " + totalET / loopcount + " ms"); Console.WriteLine("total run time " + (finished - begin) + " ms"); }
public void mainTest() { String rulefile = getRoot("share_5nodes.clp"); //bool keepopen = false; int fcount = 50000; Console.WriteLine("Using file " + rulefile); RulesetBenchmark2 mb = new RulesetBenchmark2(); long begin = DateTime.Now.Ticks; long totalET = 0; long parseET = 0; ArrayList facts = new ArrayList(50000); // Runtime rt = Runtime.getRuntime(); long total1 = GC.GetTotalMemory(true); //long free1 = rt.freeMemory(); //long used1 = total1 - free1; int loopcount = 5; Console.WriteLine("Used memory before creating engine " + total1 + " bytes " + (total1/1024) + " Kb"); for (int loop = 0; loop < loopcount; loop++) { Console.WriteLine(" ---------------------------------- "); Rete engine = new Rete(); facts.Clear(); // declare the objects engine.declareObject(typeof (Account), "account"); engine.declareObject(typeof (Transaction), "transaction"); long total2 = GC.GetTotalMemory(true); //long free2 = rt.freeMemory(); //long used2 = total2 - free2; Console.WriteLine("Used memory after creating engine " + total2 + " bytes " + (total2/1024) + " Kb"); try { StreamReader freader = new StreamReader(rulefile); CLIPSParser parser = new CLIPSParser(engine, freader); long start = DateTime.Now.Ticks; mb.parse(engine, parser, facts); long end = DateTime.Now.Ticks; long el = end - start; parser.close(); //rt.gc(); parseET += el; long total3 = GC.GetTotalMemory(true); //long free3 = rt.freeMemory(); //long used3 = total3 - free3; Console.WriteLine("Used memory after loading rules, and parsing data " + (total3/1024) + " Kb " + (total3/1024/1024) + " Mb"); Console.WriteLine("elapsed time to parse the rules and data " + el + " ms"); Console.WriteLine("Number of rules: " + engine.CurrentFocus.RuleCount); // now create the facts Account acc = new Account(); acc.AccountType = "standard"; facts.Add(acc); for (int i = 0; i < fcount; i++) { Transaction tx = new Transaction(); tx.AccountId = "acc" + i; tx.Exchange = "NYSE"; tx.Issuer = "AAA"; tx.Shares = 100.00; tx.SecurityType = "stocks"; tx.SubIndustryID = 25201010; facts.Add(tx); } IEnumerator itr = facts.GetEnumerator(); long start2 = DateTime.Now.Ticks; while (itr.MoveNext()) { Object d = itr.Current; if (d is Account) { engine.assertObject(d, "account", false, true); } else { engine.assertObject(d, "transaction", false, false); } } int actCount = engine.ActivationList.size(); long end2 = DateTime.Now.Ticks; long et2 = end2 - start2; totalET += et2; // now fire the rules long start3 = 0; long end3 = 0; int fired = 0; try { start3 = DateTime.Now.Ticks; fired = engine.fire(); end3 = DateTime.Now.Ticks; } catch (Exception e) { Console.WriteLine(e.Message); } facts.Clear(); long total4 = GC.GetTotalMemory(true); //long free4 = rt.freeMemory(); //long used4 = total4 - free4; Console.WriteLine(""); Console.WriteLine("Number of facts - " + engine.ObjectCount); Console.WriteLine("Time to assert facts " + et2 + " ms"); Console.WriteLine("Used memory after assert " + (total4/1024) + " Kb " + (total4/1024/1024) + " Mb"); engine.printWorkingMemory(true, false); Console.WriteLine("number of activations " + actCount); Console.WriteLine("rules fired " + fired); Console.WriteLine("time to fire rules " + (end3 - start3) + " ms"); } catch (FileNotFoundException e) { Console.WriteLine(e.Message); } catch (AssertException e) { Console.WriteLine(e.Message); } engine.close(); engine = null; //rt.gc(); } long finished = DateTime.Now.Ticks; Console.WriteLine("average parse ET - " + parseET/loopcount + " ms"); Console.WriteLine("average assert ET - " + totalET/loopcount + " ms"); Console.WriteLine("total run time " + (finished - begin) + " ms"); }