ETALIS_RuleML_2011_Retractions

18
Retractable Complex Event Processing and Stream Reasoning Darko Anicic , Sebastian Rudolph, Paul Fodor, Nenad Stojanovic RuleML : Proceedings of the 5th International Symposium on Rules, Barcelona, Spain

description

A talk given at RuleML 2011, Barcelona, Spain. See the paper related to this talk: https://sites.google.com/site/darkoanicic/Anicic_RuleML11_Retractions.pdf

Transcript of ETALIS_RuleML_2011_Retractions

Page 1: ETALIS_RuleML_2011_Retractions

Retractable Complex Event Processing and Stream Reasoning

Darko Anicic, Sebastian Rudolph, Paul Fodor, Nenad StojanovicRuleML : Proceedings of the 5th International Symposium on Rules, Barcelona, Spain

Page 2: ETALIS_RuleML_2011_Retractions

Agenda

Introduction, Motivation

ETALIS Language for Events• Syntax;

• Semantics;

• Experimental Results;

Conclusion.

Page 3: ETALIS_RuleML_2011_Retractions

Logic-based Complex Event Processing in ETALIS

Knowledge-

based CEP

Use background (contextual) knowledge to explore semantic relations between events, and detect otherwise undetectable complex situation.

ψ = ? π ← φ ∨ ¬ ψ. φ = true.

CEP with on-the-fly knowledge evaluation and stream reasoning:

• Complex situation based on explicit data (events) and implicit/ explicit knowledge

• Classification and filtering

• Context evaluation

• Intelligent recommendation

• Predictive analysis

Event Sources

PatternDefinitions

Detected Situations

CEP

Page 4: ETALIS_RuleML_2011_Retractions

Motivation

Knowledge-based CEP & Stream Reasoning

• Today’s CEP systems are focused mostly on throughput and timeliness;

• Time critical actions/decisions are supposed to be taken upon detection of complex events;

• These actions additionaly require evaluation of background knowledge;• Knowledge captures the domain of interest or context related to

actions/decisions;• The task of reasoning over streaming data (events) and the background

knowledge constitutes a challenge known as Stream Reasoning.

Current CEP systems provide on the-fly analysis of data streams, but mainly fall short when it comes to combining streams with evolving knowledge and performing reasoning tasks.

Page 5: ETALIS_RuleML_2011_Retractions

Motivation

• Events in today’s CEP systems are assumed to be immutable and therefore always correct;

• In some situations however revisions are required:• an event was reported by mistake, but did not happen in reality;• an event was triggered and later revoked due to a transaction

failure.• As recognised in [Ryvkina et al. ICDE’06], event stream sources may

issue revision tuples that amend previously issued events.

Current CEP systems provide on the-fly analysis of data streams, but typically don’t take these revision tuples into account and produce correct revision outputs.

Non-blocking Event Revision – Transactional Events

Page 6: ETALIS_RuleML_2011_Retractions

Related WorkDSMS Approaches for retractions in CEP:

D. Carney et al. Monitoring streams: a new class of data management applications. In VLDB’02

A. S. Maskey et al. Replay-based approaches to revision processing in stream query engines. In SSPS’02.

based on archives of recent data and replyingwhole recent history is kept archived

R. S. Barga et al. Consistent streaming through time: A vision for event stream processing. In CIDR’07.

based on blocking, buffering and synchronisation point

Stream Reasoning approaches: D. F. Barbieri et al. An execution environment for C-SPARQL queries. In

EDBT’10.A. Bolles et al. Streaming SPARQL – Extending SPARQL to Process

Data Streams. In ESWC’10.

Page 7: ETALIS_RuleML_2011_Retractions

Agenda

Introduction, Motivation

ETALIS: Retractable CEP and Stream Reasoning• Syntax;

• Semantics;

• Experimental Results;

Conclusion.

Page 8: ETALIS_RuleML_2011_Retractions

ETALIS: Language Syntax

ETALIS Language for Events is formally defined by:

• pr - a predicate name with arity n;• t(i) - denote terms; • t - is a term of type boolean; • q - is a nonnegative rational number;• BIN - is one of the binary operators: SEQ, AND, PAR, OR,

EQUALS, MEETS, STARTS, or FINISHES.

Event rule is defined as a formula of the following shape:

where p is an event pattern containing all variables occurring in

Page 9: ETALIS_RuleML_2011_Retractions

ETALIS: Interval-based Semantics

Page 10: ETALIS_RuleML_2011_Retractions

ETALIS: Formal Semantics

Page 11: ETALIS_RuleML_2011_Retractions

ETALIS: Operational Semantics (SEQ)

a SEQ b SEQ c → ce1

((a SEQ b) SEQ c) → ce1

3. Binarization

2. Decoupling

a SEQ b → ie

ie SEQ c → ce1

4. Event-driven backward chaining rules

1. Complex pattern (not event-driven rule)

Page 12: ETALIS_RuleML_2011_Retractions

ETALIS: Operational Semantics (rSEQ)

Page 13: ETALIS_RuleML_2011_Retractions

100 1000 10000 1000000

10000

20000

30000

Throughput Change

Recursion depth

Thro

ughp

ut (1

000

x Ev

ents

/Sec

)

Tests I: CEP with Stream Reasoning

Intel Core Quad CPU Q9400 2,66GHz, 8GB of RAM, Vista x64; ETALIS on SWI Prolog 5.6.64 and YAP Prolog 5.1.3 vs. Esper 3.3.0

Page 14: ETALIS_RuleML_2011_Retractions

Tests II: Throughput Comparison

Figure: Throughput (a) Various operaors (b) Negation

SEQ AND PAR OR0

5000

10000

15000

20000

25000

30000

35000

Revision Flag off Revision Flag on

Operator

Th

rou

gh

pu

t (1

00

0 x

Eve

nts

/Se

c)

5% 10% 20%0

10000

20000

30000

Revision Flag off Revision Flag on

Percentage of revised events

Th

rou

gh

pu

t (1

00

0 x

Eve

nts

/Se

c)

Page 15: ETALIS_RuleML_2011_Retractions

Tests III: Stock price change on a real data set

• Yahoo Finance: IBM stocks from 1962 up to now

• 5% revision tulples introduced

0.00% 0.50% 1.00% 2.00% 5.00% 10.00%0

2000400060008000

1000012000140001600018000

with revision without revision

Price Increase

Th

rou

gh

pu

t (1

00

0 x

eve

nts

/se

c)

Page 16: ETALIS_RuleML_2011_Retractions

Agenda

Introduction, Motivation

ETALIS Language for Events• Syntax;

• Semantics;

• Experimental Results;

Conclusion.

Page 17: ETALIS_RuleML_2011_Retractions

Conclusion: A Common Framework for Event Processing in ETALIS

17

ETALIS

A deductive

rule framework

for CEP

Integration with the domain

knowledge and

databases

Reasoning over

streaming data and

background knowledge

ETALIS: A Common Framework for Event Processing

Retractable CEP -

an extensible framework

for CEP

Page 18: ETALIS_RuleML_2011_Retractions

Thank you! Questions…

ETALIS

Open source:

http://code.google.com/p/etalis

[email protected]