Packet Classification
First Claim
Patent Images
1. A method comprising:
- using a classifier table having a plurality of rules, the plurality of rules having at least one field, building a decision tree structure including a plurality of nodes, each node representing a subset of the plurality of rules;
for each node of the decision tree, (a) determining a number of cuts that may be made on each at least one field creating child nodes equal to the number of cuts;
(b) selecting a field on which to cut the node based on a comparison of an average of a difference between an average number of rules per child node created and an actual number of rules per child node created per each at least one field;
(c) cutting the node into a number of child nodes on the selected field; and
storing the decision tree structure.
6 Assignments
0 Petitions
Accused Products
Abstract
A packet classification system, methods, and corresponding apparatus are provided for enabling packet classification. A processor of a security appliance coupled to a network uses a classifier table having a plurality of rules, the plurality of rules having at least one field, to build a decision tree structure including a plurality of nodes, the plurality of nodes including a subset of the plurality of rules. The methods may produce wider, shallower trees that result in shorter search times and reduced memory requirements for storing the trees.
26 Citations
89 Claims
-
1. A method comprising:
-
using a classifier table having a plurality of rules, the plurality of rules having at least one field, building a decision tree structure including a plurality of nodes, each node representing a subset of the plurality of rules; for each node of the decision tree, (a) determining a number of cuts that may be made on each at least one field creating child nodes equal to the number of cuts; (b) selecting a field on which to cut the node based on a comparison of an average of a difference between an average number of rules per child node created and an actual number of rules per child node created per each at least one field; (c) cutting the node into a number of child nodes on the selected field; and storing the decision tree structure. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 74, 75, 76, 77, 78, 79, 80, 81)
-
-
23-27. -27. (canceled)
-
28. An apparatus comprising:
-
a memory; a processor coupled to the memory, the processor configured to use a classifier table having a plurality of rules stored in the memory, the plurality of rules having at least one field, the processor further configured to build a decision tree structure including a plurality of nodes, the plurality of nodes representing a subset of the plurality of rules; the processor further configured to determine, for each node of the decision tree, a number of cuts that may be made on each at least one field creating child nodes equal to the number of cuts; upon determining the number of cuts that may be made on each at one least field, the processor further configured to select a field on which to cut the node based on a comparison of an average of a difference between an average number of rules per child node created and an actual number of rules per child node created per each at least field; and the processor further configured to cut the node into a number of child nodes on the selected field and to store the decision tree structure in the memory. - View Dependent Claims (29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 82, 83, 84, 85, 86, 87, 88, 89)
-
-
47. A non-transient computer-readable medium having encoded thereon a sequence of instructions which, when executed by a processor, causes the processor to:
-
use a classifier table having a plurality of rules, the plurality of rules having at least one field; build a decision tree structure including a plurality of nodes, the plurality of nodes including a subset of the plurality of rules; determine, for each node of the decision tree, a number of cuts that may be made on each at least one field creating child nodes equal to the number of cuts; select, upon determining the number of cuts that may be made on each at one least field, a field on which to cut the node based on a comparison of an average of a difference between an average number of rules per child node created and an actual number of rules per child node created per each at least one field; cut the node into a number of child nodes on the selected at least field; and store the decision tree structure. - View Dependent Claims (48)
-
-
49-73. -73. (canceled)
Specification