我有一个规则来检查是否有 5 个具有相同值的事实(过去 7 天中具有相同值的 5 个事实)。现在我正在处理 40 个事实,因此规则会检查 40 个事实的问题。与前20名没有问题,但每次都需要更长的时间。21 未执行,因为 Java 发送 OutOfMemory 异常。
这是我的规则:
rule "MUL_04"
no-loop true
when
r_A:Fact(viewed==false)
r_B:Fact(viewed==true, INT_IP==r_A.INT_IP, Tools.check(SOL_FEC, r_A.SOL_FEC)<=7)
r_C:Fact(viewed==true, INT_IP==r_A.INT_IP, Tools.check(SOL_FEC, r_A.SOL_FEC)<=7, r_B!=r_C)
r_D:Fact(viewed==true, INT_IP==r_A.INT_IP, Tools.check(SOL_FEC, r_A.SOL_FEC)<=7, r_C!=r_D, r_B!=r_D)
r_E:Fact(viewed==true, INT_IP==r_A.INT_IP, Tools.check(SOL_FEC, r_A.SOL_FEC)<=7, r_B!=r_E, r_C!=r_E, r_D!=r_E)
r_F:Fact(viewed==true, INT_IP==r_A.INT_IP, Tools.check(SOL_FEC, r_A.SOL_FEC)<=7, r_B!=r_F, r_C!=r_F, r_D!=r_F, r_E!=r_F)
then
modify (r_A) {
setViewed(true),
setEST_EST_FRA(1),
setEST_PRO_EST(1)
}
end
任何人都知道如何解决 Java 内存问题或如何优化此规则?
预先感谢
更新::
我正在使用这个查询进行测试:
query multipleRequests(Fact r_A, Integer exits)
$exits := Number(intValue>=5) from accumulate(
r_B:Fact(viewed==true,INT_IP == r_A.INT_IP,Tools.check(SOL_FEC, r_A.SOL_FEC) <=7),
count(r_B)
)
end
而这条规则:
rule "MUL_04_WithQuery"
no-loop true
when
r_A:Fact(viewed==false)
$numbers : multipleRequests(r_A;)
then
modify (r_A) {
setViewed(true),
setEST_EST_FRA(1),
setEST_PRO_EST(1)
}
end
但我无法获得预期的性能。此外,当我尝试处理 100 多个事实时,我也会遇到 Java 堆问题。
我不明白。这是我的问题的正确查询吗???