Ruleset optimization through blocked and concurrent rule dispatch
First Claim
Patent Images
1. A computer-implemented method comprising:
- receiving an abstract rule having (i) a conditional statement and (ii) a consequential statement defining a particular result returned by the abstract rule for a given set of input data supplied to the abstract rule, wherein the conditional statement is composed from one or more logical fields, and wherein the logical fields are defined in a data abstraction model modeling an underlying physical database;
receiving a set of query results comprising a plurality of data records, each including one or more input values;
sorting the plurality of data records into one or more groups, wherein each group includes data records having a common set of input values; and
for each group of data records, processing the input values associated with the group against the abstract rule, wherein processing the input values comprises determining whether the abstract rule is deterministic, and setting, as an output of processing the input values, a result returned by the abstract rule for each data record in the group.
1 Assignment
0 Petitions
Accused Products
Abstract
Embodiments of the invention provide techniques for optimizing the processing of abstract rules. In general, the results of executing an abstract query may be used as data inputs for processing an abstract rule. In one embodiment, query results may be sorted according to input field values required for processing a deterministic abstract rule. If a record of the sorted query results includes the same input values as a preceding record, then the rule output of the preceding record may be reused, rather than processing the abstract rule again. Accordingly, the demand load placed on a rule engine may be reduced.
8 Citations
18 Claims
-
1. A computer-implemented method comprising:
-
receiving an abstract rule having (i) a conditional statement and (ii) a consequential statement defining a particular result returned by the abstract rule for a given set of input data supplied to the abstract rule, wherein the conditional statement is composed from one or more logical fields, and wherein the logical fields are defined in a data abstraction model modeling an underlying physical database; receiving a set of query results comprising a plurality of data records, each including one or more input values; sorting the plurality of data records into one or more groups, wherein each group includes data records having a common set of input values; and for each group of data records, processing the input values associated with the group against the abstract rule, wherein processing the input values comprises determining whether the abstract rule is deterministic, and setting, as an output of processing the input values, a result returned by the abstract rule for each data record in the group. - View Dependent Claims (2, 3, 4, 5, 6)
-
-
7. A computer readable storage medium containing a program which, when executed, performs an operation comprising:
-
receiving an abstract rule having (i) a conditional statement and (ii) a consequential statement defining a particular result returned by the abstract rule for a given set of input data supplied to the abstract rule, wherein the conditional statement is composed from one or more logical fields, and wherein the logical fields are defined in a data abstraction model modeling an underlying physical database; receiving a set of query results comprising a plurality of data records, each including one or more input values; sorting the plurality of data records into one or more groups, wherein each group includes data records having a common set of input values; and for each group of data records, processing the input values associated with the group against the abstract rule, wherein processing the input values comprises determining whether the abstract rule is deterministic, and setting, as an output of processing the input values, a result returned by the abstract rule for each data record in the group. - View Dependent Claims (8, 9, 10, 11, 12)
-
-
13. A system comprising:
-
a processor; and a memory containing a program, which, when executed on the processor, is configured to perform the steps of; receiving an abstract rule having (i) a conditional statement and (ii) a consequential statement defining a particular result returned by the abstract rule for a given set of input data supplied to the abstract rule, wherein the conditional statement is composed from one or more logical fields, and wherein the logical fields are defined in a data abstraction model modeling an underlying physical database, receiving a set of query results comprising a plurality of data records, each including one or more input values, sorting the plurality of data records into one or more groups, wherein each group includes data records having a common set of input values, and for each group of data records, processing the input values associated with the group against the abstract rule, wherein processing the input values comprises determining whether the abstract rule is deterministic, and setting, as an output of processing the input values, a result returned by the abstract rule for each data record in the group. - View Dependent Claims (14, 15, 16, 17, 18)
-
Specification