[rules-users] Re: Independent rule evaluations
Edson Tirelli
tirelli at post.com
Wed Aug 15 08:01:45 EDT 2007
Yuri,
Right now, the only way is to work with different rule bases and working
memories. Even using agenda-groups or rule-flow, rules are still being
eagerly evaluated, as this is how standard Rete works.
The problem of creating and canceling too many activations is a known
problem and the only way around it right now is sequential mode, but
sequential mode has some restrictions on what you can do. For instance, you
must work with a stateless working memory and can not modify/retract facts
in your rules to work with sequential mode, but it will give you big
performance boosts.
We are evaluating the possibility of creating physical network
partitions for next version, but that will require some R&D yet.
[]s
Edson
2007/8/14, Yuri <ydewit at gmail.com>:
>
> Dr. Gernot Starke <gs <at> gernotstarke.de> writes:
> > can you detail your problem a little?
>
> I basically need to find perfect matches between two different sets of
> objects.
> If perfect matches are not found, I then create bulks of objects that are
> then
> used in combination with the individual ones to find bulk matches. If no
> matches
> are found I need then to categorize the breaks (around 10 different
> categorizations) and report them.
>
> The matching criteria between two object is specific enough to be fast.
> Once I
> get into break, which basically is removing some criteria components, the
> possible combinations increase exponentially. Bulking just compounds the
> problem
> by adding more matchable/breakable facts into memory.
>
> My bulking logic (I didnt have collect when I started with 3.0) starts a
> bulk
> looking for two diff objects with the same bulkling criteria (this is my
> first
> potential cross product since drools would produce C!/N!(C-N)!
> combinations).
> Then once the bulk for a given criteria is create I have a second rule
> that
> expands or contracts the bulks as new facts are asserted causing many
> different
> side effects.
>
> What I am basically seeing is that asserting a fact that would for
> instance be a
> perfect match, causes many of the bulking and breaking rule activations to
> be
> created and then cancelled. Considering that I am talking about tens or
> hundreds
> of thousands of facts I thought that if I could stage the activation
> creations I
> would increase processing speed.
>
> With 15K objects on each side I have been seeing something like 1
> assertion per
> second.
>
> I am aware that this could be cross product somewhere but I have already
> revised
> the rules many many times so now I am looking for other alternatives.
>
> I am now trying to understand looking I basically need to find perfect
> matches
> between two different sets of objects. If perfect matches are not found, I
> then
> create bulks of objects that are then used in combination with the
> individual
> one to find bulk matches. If no matches are found I need then to
> categorize the
> breaks (around 10 different categorizations) and report them.
>
>
> _______________________________________________
> rules-users mailing list
> rules-users at lists.jboss.org
> https://lists.jboss.org/mailman/listinfo/rules-users
>
--
Edson Tirelli
Software Engineer - JBoss Rules Core Developer
Office: +55 11 3529-6000
Mobile: +55 11 9287-5646
JBoss, a division of Red Hat @ www.jboss.com
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.jboss.org/pipermail/rules-users/attachments/20070815/b8a5f2b3/attachment.html
More information about the rules-users
mailing list