public class OverlapsEvaluatorDefinition extends Object implements EvaluatorDefinition
The implementation of the overlaps evaluator definition.
The overlaps evaluator correlates two events and matches when the current event
starts before the correlated event starts and finishes after the correlated event starts, but before
the correlated event finishes. In other words, both events have an overlapping period.
Lets look at an example:
$eventA : EventA( this overlaps $eventB )
The previous pattern will match if and only if:
$eventA.startTimestamp < $eventB.startTimestamp < $eventA.endTimestamp < $eventB.endTimestamp
The overlaps operator accepts 1 or 2 optional parameters as follow:
$eventA : EventA( this overlaps[ 5s ] $eventB )Will match if and only if:
$eventA.startTimestamp < $eventB.startTimestamp < $eventA.endTimestamp < $eventB.endTimestamp && 0 <= $eventA.endTimestamp - $eventB.startTimestamp <= 5s
$eventA : EventA( this overlaps[ 5s, 10s ] $eventB )Will match if and only if:
$eventA.startTimestamp < $eventB.startTimestamp < $eventA.endTimestamp < $eventB.endTimestamp && 5s <= $eventA.endTimestamp - $eventB.startTimestamp <= 10s
| Modifier and Type | Class and Description |
|---|---|
static class |
OverlapsEvaluatorDefinition.OverlapsEvaluator
Implements the 'overlaps' evaluator itself
|
EvaluatorDefinition.Target| Modifier and Type | Field and Description |
|---|---|
static Operator |
OVERLAPS |
static Operator |
OVERLAPS_NOT |
static String |
overlapsOp |
| Constructor and Description |
|---|
OverlapsEvaluatorDefinition() |
| Modifier and Type | Method and Description |
|---|---|
Evaluator |
getEvaluator(ValueType type,
Operator operator)
Returns the evaluator instance for the given type and the
defined parameterText
|
Evaluator |
getEvaluator(ValueType type,
Operator operator,
String parameterText)
Returns the evaluator instance for the given type and the
defined parameterText
|
Evaluator |
getEvaluator(ValueType type,
String operatorId,
boolean isNegated,
String parameterText)
Returns the evaluator instance for the given type and the
defined parameterText
|
Evaluator |
getEvaluator(ValueType type,
String operatorId,
boolean isNegated,
String parameterText,
EvaluatorDefinition.Target left,
EvaluatorDefinition.Target right)
Returns the evaluator instance for the given type and the
defined parameterText
|
String[] |
getEvaluatorIds()
Returns the list of identifies this
evaluator implementation supports
|
EvaluatorDefinition.Target |
getTarget()
There are evaluators that operate on *fact* attributes,
evaluators that operate on *fact handle* attributes, and
evaluators that operate on both.
|
boolean |
isNegatable()
My apologies to English speakers if the word "negatable" does not
exist. :)
This method returns true if this evaluator supports negation.
|
void |
readExternal(ObjectInput in) |
boolean |
supportsType(ValueType type)
Returns true in case this evaluator supports operations over values
of that specific type.
|
void |
writeExternal(ObjectOutput out) |
public static final String overlapsOp
public static Operator OVERLAPS
public static Operator OVERLAPS_NOT
public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException
readExternal in interface ExternalizableIOExceptionClassNotFoundExceptionpublic void writeExternal(ObjectOutput out) throws IOException
writeExternal in interface ExternalizableIOExceptionpublic Evaluator getEvaluator(ValueType type, Operator operator)
EvaluatorDefinitiontype - the type of the attributes this evaluator will
operate on. This is important because the evaluator
may do optimisations and type coercion based on the
types it is evaluating. It is also possible that
this evaluator does not support a given type.operator - the operator implemented by the evaluatorpublic Evaluator getEvaluator(ValueType type, Operator operator, String parameterText)
EvaluatorDefinitiontype - the type of the attributes this evaluator will
operate on. This is important because the evaluator
may do optimisations and type coercion based on the
types it is evaluating. It is also possible that
this evaluator does not support a given type.operator - the operator implemented by the evaluatorparameterText - some evaluators support parameters and these
parameters are defined as a String that is
parsed by the evaluator itself.public Evaluator getEvaluator(ValueType type, String operatorId, boolean isNegated, String parameterText)
EvaluatorDefinitiontype - the type of the attributes this evaluator will
operate on. This is important because the evaluator
may do optimisations and type coercion based on the
types it is evaluating. It is also possible that
this evaluator does not support a given type.operatorId - the string identifier of the evaluatorisNegated - true if the evaluator instance to be returned is
the negated version of the evaluator.parameterText - some evaluators support parameters and these
parameters are defined as a String that is
parsed by the evaluator itself.public Evaluator getEvaluator(ValueType type, String operatorId, boolean isNegated, String parameterText, EvaluatorDefinition.Target left, EvaluatorDefinition.Target right)
EvaluatorDefinitiontype - the type of the attributes this evaluator will
operate on. This is important because the evaluator
may do optimisations and type coercion based on the
types it is evaluating. It is also possible that
this evaluator does not support a given type.operatorId - the string identifier of the evaluatorisNegated - true if the evaluator instance to be returned is
the negated version of the evaluator.parameterText - some evaluators support parameters and these
parameters are defined as a String that is
parsed by the evaluator itself.left - the target of the evaluator on the Left side,
i.e., on Rete terms, the previous binding or
the actual value on the right side of the operator.right - the target of the evaluator on the Right side,
i.e., on Rete terms, the current pattern field.public String[] getEvaluatorIds()
EvaluatorDefinitionpublic boolean isNegatable()
EvaluatorDefinitionpublic EvaluatorDefinition.Target getTarget()
EvaluatorDefinitionpublic boolean supportsType(ValueType type)
EvaluatorDefinitionCopyright © 2001–2019 JBoss by Red Hat. All rights reserved.