1. Technical Field
Exemplary embodiments of the present invention relate to stream processing, and more particularly, to a general, automatic, and incremental sliding window aggregation framework that can be utilized in stream processing.
2. Discussion of Related Art
Sliding window aggregation is a basic computation in stream processing applications. Streaming operators that compute sliding window aggregates such as, for example, the sum, average, count, and standard deviation of data tuples within a sliding window, are commonly used in streaming applications.
One approach to computing a sliding window aggregate includes recomputing the aggregate against all of the data in the window each time the window is changed due to the sliding in or sliding out of data tuples. However, since a streaming aggregate operator may be computationally intensive, the throughput of a streaming application may be limited. This throughput limitation may be more severe in scenarios in which the window size is large and/or the data rate is high. Another approach to computing a sliding window aggregate includes implementing an incremental method. However, such incremental methods are typically limited to simple aggregate functions such as, for example, sum and average functions, and are not suitable for aggregate functions that do not have an inverse such as, for example, min and max functions.
According to an exemplary embodiment of the present invention, a method of incrementally computing an aggregate function of a sliding window in a streaming application includes receiving a plurality of data tuples in the sliding window, extracting, by a processor, at least one data tuple of the plurality of data tuples from the sliding window, and storing the at least one extracted data tuple in a data structure in a memory. The data structure is a balanced tree and the at least one data tuple is stored in leaf nodes of the balanced tree. The method further includes maintaining, by the processor, at least one intermediate result in at least one internal node of the balanced tree. The at least one intermediate result corresponds to a partial window aggregation. The method further includes generating, by the processor, a final result in the balanced tree based on the at least one intermediate result. The final result corresponds to a final window aggregation. The method further includes outputting the final result from the balanced tree.
In an exemplary embodiment, maintaining the at least one intermediate result includes identifying at least one changed data item in a current data tuple of the plurality of data tuples currently in the sliding window. The at least one changed data item is relative to a previous data tuple of the plurality of data tuples previously in the sliding window. The method further includes extracting the at least one changed data item from the current data tuple, storing the at least one extracted changed data item in at least one of the leaf nodes of the balanced tree, and modifying the at least one intermediate result based on the at least one extracted changed data item.
In an exemplary embodiment, modifying the at least one intermediate result includes modifying a plurality of intermediate results stored in a plurality of internal nodes located at different levels within the balanced tree. The plurality of internal nodes are modified in the balanced tree using a bottom-up traversal.
In an exemplary embodiment, only internal nodes of the plurality of internal nodes affected by the at least one identified changed data item are modified.
In an exemplary embodiment, the at least one changed data item corresponds to new data added to the current tuple in the sliding window or old data removed from the current tuple in the sliding window.
In an exemplary embodiment, the method further includes modifying the final result in the balanced tree based on the at least one modified intermediate result.
In an exemplary embodiment, the method further includes storing the balanced tree in the memory in a pointer-free layout.
In an exemplary embodiment, the balanced tree is stored in the memory in a pointer-free array.
In an exemplary embodiment, the final result is stored in a root node of the balanced tree.
In an exemplary embodiment, the final result includes an output data tuple having an aggregate value based on an aggregation of all of the plurality of data tuples.
In an exemplary embodiment, the balanced tree is a binary tree.
According to an exemplary embodiment of the present invention, a computer program product for incrementally computing an aggregate function of a sliding window in a streaming application, the computer program product including a computer readable storage medium having program instructions embodied therewith, the program instructions executable by a processor to cause the processor to perform a method including receiving a plurality of data tuples in the sliding window, extracting at least one data tuple of the plurality of data tuples from the sliding window, and storing the at least one extracted data tuple in a data structure in a memory. The data structure is a balanced tree and the at least one data tuple is stored in leaf nodes of the balanced tree. The method further maintains at least one intermediate result in at least one internal node of the balanced tree. The at least one intermediate result corresponds to a partial window aggregation. The method further generates a final result in the balanced tree based on the at least one intermediate result. The final result corresponds to a final window aggregation. The method further outputs the final result from the balanced tree.
The above and other features of the present invention will become more apparent by describing in detail exemplary embodiments thereof with reference to the accompanying drawings, in which:
Exemplary embodiments of the present invention will be described more fully hereinafter with reference to the accompanying drawings. Like reference numerals may refer to like elements throughout the accompanying drawings.
Introduction
Stream processing may be used to compute timely insights from continuous data sources. Stream processing has widespread use cases including, for example, use cases in telecommunications, health care, finance, retail, transportation, social media, etc. A streaming application may involve some type of aggregation. For example, a trading application may aggregate the average price over the last 1,000 trades, or a network monitoring application may keep track of the total network traffic in the last 10 minutes.
Streaming aggregation may be performed over sliding windows. In stream processing, a window serves the purpose of defining the scope for an operation. Windows are utilized in stream processing because an application does not store an infinite stream in its entirety. Rather, windows summarize the data in a manner that is intuitive to the user, since the most recent data is typically the most relevant data. A sliding window may be defined in terms of time or the number of data objects in the window.
Referring to
Exemplary embodiments of the present invention provide a sliding window aggregation framework that is general, automatic, and incremental. Referring to the general nature of the framework according to exemplary embodiments, the framework works across a variety of aggregation operations, including, for example, operations that are not invertible (e.g., Min) or not commutative (e.g., First). Referring to the automatic nature of the framework according to exemplary embodiments, the application developer utilizing the framework is only presented with typical declarative choices of aggregations, and the library developer is shielded from lower-level aggregation code. Referring to the incremental nature of the framework, as tuples enter or leave a window, the framework may derive a solution without iterating over the entire window. That is, in an incremental framework according to exemplary embodiments, a sliding window aggregate may be computed without re-computing the aggregate against all of the data in the window each time the window is changed due to the sliding in or sliding out of data tuples.
General aggregations are useful for dealing with non-invertible or non-commutative cases. Examples of non-invertible aggregations include, for example, Min, Max, First, Last, and CollectDistinct. Examples of non-commutative aggregations include, for example, First, Last, Sum<String> (e.g., concatenation), Collect, and ArgMin. According to exemplary embodiments, a streaming application that supports user-defined aggregations may receive non-invertible and non-commutative cases that the streaming application is capable of handling.
Automatic aggregations are useful because aggregation frameworks often deal with a large number of cases and combinations such as, for example, different data types, aggregation functions, time-based vs. counter-based windows, and combined vs. partitioned windows. Performing aggregations automatically instead of manually may allow for the avoidance of the introduction of edge cases, which can potentially introduce maintenance problems. Exemplary embodiments of the framework provide a means for application developers and library developers to write custom aggregation operations.
Incremental aggregations are useful for performance reasons. For example, rescanning a window for every change may reduce performance as a result of causing spurious computation and unnecessarily using memory, which can lead to poor locality. Utilization of an incremental approach according to exemplary embodiments allows for partial results to be reused, which can result in a more efficient aggregation computation having improved algorithmic complexity and memory use.
A sliding window aggregation framework that is general, automatic, and incremental, according to exemplary embodiments of the present invention, may be referred to herein as a reactive aggregator, and may be implemented by combining an efficient data structure with a simplified abstraction for the library developer to program the aggregation operation, as described in further detail below. For example, exemplary embodiments of the present invention utilize custom functions that may be used to represent standard aggregation operations. That is, according to exemplary embodiments, standard aggregation operations may be expressed in terms of custom functions. These custom functions are referred to herein as lift, combine, and lower functions. Exemplary embodiments may implement these functions with a data structure (e.g., a balanced tree) to perform incremental aggregation. According to exemplary embodiments, aggregation operations of the reactive aggregator may be decomposed into lift, combine, and lower functions.
Generally, the lift function corresponds to an operation in which a data value that aggregation is to be applied to is extracted, or “lifted” out of the window, and stored in a data structure (e.g., a balanced tree). The combine function corresponds to an operation in which at least two data values are combined into a partial aggregation. The combine function is associative, and may or may not be commutative or invertible. Herein, the combine function may also be referred to as an op function. The lower function corresponds to an operation in which the data that is to be output is extracted from the data structure. For example, when the data structure is a balanced tree, the lower function corresponds to an operation in which data is taken from the root. Utilization of the lift, lower, and combine functions results in pointer-less operations. For example, according to exemplary embodiments, the reactive aggregator is not required to store pointers. Since the use of pointers may be a costly operation, the reactive aggregator according to exemplary embodiments of the present invention may result in an improved and more efficient application. The lift, combine, and lower functions are described in further detail below.
Referring to
According to exemplary embodiments, the reactive aggregator maintains a small number of partial results in addition to the final result, and responds to changes in the window by modifying a subset of the partial results affected by the changes, and in turn, regenerating the final result. The data structure utilized by the reactive aggregator, which may be referred to herein as the reactive aggregator data structure, may be, for example, a balanced tree, as described in further detail below. Embodying the data structure of the reactive aggregator in a balanced tree is memory efficient and computation efficient for its associated operations. The balanced tree may maintain the data tuples in the sliding window in the leaves of the tree, and may store partial aggregates in the internal nodes of the tree. The balanced tree may be packed into an array in memory in a pointer-free layout, avoiding pointer chasing during incremental aggregation computation.
As described above, the reactive aggregator data structure according to exemplary embodiments includes the custom lift, combine, and lower functions. Utilization of this data structure with these custom functions results in improved algorithmic complexity compared to non-incremental approaches, allowing the sliding window aggregation framework to run efficiently. For example, according to exemplary embodiments, referring to space and time complexity, in O(n) space, the reactive aggregator data structure takes O(m+m log(n/m)) time, where m is the number of window events after the previous firing, and n is the window size at the time of firing. Thus, O(log(n)) corresponds to constant changes to the window, and O(m) corresponds to changes that overwrite the window. Herein, the term “firing” refers to output generation.
Referring to
Reactive Aggregator
Application Developers' Perspective
From an application developer's perspective, the reactive aggregator according to exemplary embodiments of the present invention is platform agnostic. For convenience of explanation, the reactive aggregator is described herein with reference to the Streams Processing Language (SPL), which is used for application development. An SPL program describes a graph of operator instances, where each operator instance configures an operator (from the library or user-defined). It is to be understood that exemplary embodiments of the present invention are not limited to an SPL implementation.
Referring to
In stream computing, a stream is a conceptually infinite sequence of tuples, and a window specifies a finite subsequence of the most recent tuples in a stream at any given point in time. In the example shown in
The output clause in the source code 401 specifies the manner in which each attribute of the output tuple is computed by aggregating over the tuples in the window. This specification is declarative, since it describes which aggregation operation is to be used, rather than how the aggregation operation works. In the example shown in
Library Developers' Perspective
From a library developer's perspective, according to exemplary embodiments, each operation of the reactive aggregator may be described with three types and three functions. For example, the three types are input In, partial aggregation Agg, and output Out. The three functions are lift(v: In), combine(a: Agg, b: Agg), and lower(c: Agg). Referring to lift(v: In), Agg computes the partial aggregation for a single-tuple subwindow. Referring to combine (a: Agg, b: Agg), Agg, which may be rendered in the binary operator notation a⊕b, partial aggregations are transformed for two subwindows into the partial aggregation for the combined subwindow. Referring to lower(c: Agg), Out turns a partial aggregation for the entire window into an output.
Each of the aggregation operations shown in
Referring to
In contrast to the Max operation, the ArgMax operation utilizes the full generality of the three types and three functions. Referring to who=ArgMax(len, caller) as shown in the source code 401 of
The interface according to exemplary embodiments of the present invention is general, as shown by the variety of operations in
Algebraic Properties
Algebraic properties can offer insight into the behavior of an aggregation operation. Algebraic properties set frameworks apart in terms of generality. For example, a framework that only works for invertible operations is less general than one that also works for non-invertible ones. The reactive aggregator according to exemplary embodiments may utilize associativity, and not utilize invertibility or commutativity. For all partial aggregation results x, y, z, a combine function rendered in binary-operator notation as ⊕ is associative if x⊕(y⊕z)=(x⊕y)⊕z. Without associativity, a combine function can only handle insertions one element at a time at the end of the queue. Associativity enables the computation to be broken down in flexible ways including, for example, balanced breakdowns that may improve algorithmic complexity bounds.
A combine function ⊕ is invertible if a known and reasonably computationally cheap function ⊖ exists such that for all partial aggregation results x, y, (x⊕y)⊖y=x. Invertibility enables handling deletions as inverse insertions, and is often used in incremental sliding-window aggregation. However, according to exemplary embodiments of the present invention, invertibility may not be utilized, resulting in a more general approach.
A combine function X is commutative if x⊕y=y⊕x holds for all partial aggregation results x, y. If the combine function is commutative, the order of the input can be ignored when computing aggregation results.
Referring to
Design Considerations
Referring to the Max aggregation function, Max is an example of an aggregation function that does not have an inverse, but is associative and commutative. Because Max is associative, the operator can be applied in any combination. For example, in a sliding window with x1, x2, x3, and x4, the result of max(max(x1, x2), max(x3, x4)) will be identical to max(max(max(x1, x2), x3), x4). However, since Max does not have an inverse form, when x1 leaves the window, there is no way to “subtract” x1 from max(x1, x2, x3, x4) to derive max(x2, x3, x4). That is, there is no equivalent of x2⊕x3⊕x4=(x1⊕x2⊕x3⊕x4)⊖x1.
Exemplary embodiments of the present invention eliminate pointers from the reactive aggregator data structure as described in further detail below, resulting in a reduction in memory usage and an improvement of performance. In addition, according to exemplary embodiments, the memory used for the reactive aggregator data structure is allocated once, at creation, rather than in multiple small requests. Further, when the reactive data structure is embodied in a tree structure, sibling nodes that are accessed together remain in a consecutive block. Further still, the logic used to handle tuple arrival, tuple eviction, and firing is separated, resulting in a modular framework.
Design Overview
A tuple enters into the framework when the window logic informs the reactive aggregator of the tuple's arrival. Upon arrival, the tuple is lifted using the lift function and is stored in a buffer maintained by the reactive aggregator. The lifted tuple remains in the buffer until the window logic instructs the reactive aggregator to evict it. The reactive aggregator can be probed for the current window's aggregate value, which may be derived using the combine function. The result may then be lowered using the lower function and returned to the stream processing system. Although the contents of the window is stored by the reactive aggregator, to support a multitude of window policies, the reactive aggregator may utilize a separate window-logic module to determine when a new tuple arrives, which existing tuple to evict, and when the aggregation value is needed.
Since the reactive aggregator framework according to exemplary embodiments of the present invention utilizes an incremental approach to maintaining the aggregate as the window changes, there is only a small change to the window, and the reactive aggregator performs a decreased amount of work. When utilizing the reactive aggregator with the lift, combine, and lower functions, a number of partial aggregate results is maintained. When the window changes, the partial aggregate results are updated and used to derive the aggregate in a more efficient manner than re-computing all changes in the entire window.
Consider an example in which lift, combine, and lower are constant-time functions, and Agg is a constant-sized data type. In this example, the reactive aggregator data structure takes O(m+m log(n/m)) time, where in is the number of window events after the previous firing, n is the window size at the time of firing, and O(n) space is consumed. Thus, it can be seen that O(log n) time for constant changes to the window and O(m) for changes that completely overwrites the window, an amount that is already needed to make m changes. To meet these bounds, exemplary embodiments include a fixed-capacity data structure that acts as a container holding n values while efficiently maintaining the aggregate of the contained data, as described in further detail below. The fixed-capacity data structure may be embodied, for example, as a balanced tree on n leaves (e.g., a complete binary tree on n leaves), which holds the windows elements. The tree may be efficiently updated and queried by, for example, maintaining, at each internal node of the tree, the aggregate of the data in the leaves below it.
The fixed-capacity data structure may be kept “flat” in consecutive memory in a pointer-free layout, as described in further detail below. For example, the data structure may be stored in a pointer-free array in memory. As a result, necessary memory can be allocated at creation and sibling nodes may be placed next to each other, reducing dynamic memory allocation calls in the overall framework, and improving cache friendliness since these nodes are frequently accessed together.
Fixed-Sized Aggregator
A size-n fixed-sized aggregator (FAT) for ⊕: D×D→D is a fixed-capacity data structure that maintains values a[1], . . . , a[n]εD while allowing for updates to the values and queries for the aggregate value of any prefix and suffix.
An instance of the data structure is created by calling new((val1, . . . , valn)), which initializes a[i]=vali and sets the capacity to n. Once created, the instance of the data structure supports the following operations:
Since exemplary embodiments of the present invention utilize an abstraction implementation, an operation's cost may be measured in terms of the number of ⊕ operations. In the examples described herein, it as assumed that n is a power of two.
A size-n FAT can be maintained such that (i) new makes n−1 calls to ⊕, (ii) for m writes, update requires at most m(1+┌ log(n/m)┐) calls to ⊕, and (iii) prefix(i) and suffix(j) each require at most log2(n) calls to ⊕. Further, aggregate( ) requires no ⊕ calls.
According to exemplary embodiments of the present invention, FAT may be maintained as a complete binary tree T with n leaves, which store the values a[1], a[2], . . . , a[n]. The leaf node containing a[i] (e.g., the i-th leaf) may be referred to as leaf(i). Each internal node v keeps a value T(υ)εD that satisfies the invariant T(v)=T(left(v)) ⊕T(right(v)), where left(v) and right(v) denote the left child and the right child of v, respectively. As a result of associativity, mathematical induction implies that when v is the root of a subtree whose leaves are a[i], a[i+1], . . . , a[j], then T(v)=a[i]⊕ . . . ⊕a[j].
Referring to
It is to be understood that although the example described with reference to
Creating an Instance
A user may create a new FAT instance by invoking new with the values vali, i=1, . . . , n. Once invoked, new builds the tree structure and computes the value for each internal node, satisfying T(v)=T(left(v))⊕T(right(v)).
Referring to
Consider an example in which new is called with <x1, x2, . . . , x8>. In this example, a tree structurally similar to the tree shown in
In general, referring to the cost of new in terms of the number of ⊕ calls, for each level l, the number of ⊕ calls is |Wl| (see line 6). Therefore, to obtain the total number of ⊕ calls, the sizes of all Wl's may be summed. Wl, which corresponds to the sets of the parents of the leaves, is the set of all level-1 nodes, and inductively, Wl, which corresponds to the sets of the parents of Wl−1, is the set of all level-1 nodes. As a result, |Wl|=n/2l. Thus, the number of ⊕ calls is
Updating Values
A user may modify the contents stored in FAT by calling the update function. The update function incorporates a list of changes to be made into FAT by first updating the corresponding a[.] values, and then updating the internal nodes affected by the changes.
According to exemplary embodiments of the present invention, only internal nodes that are affected by changes are updated. Consider an example in which one a[i] is modified. In this example, only the internal nodes whose values depend on a[i] should be updated. Only the nodes that are on the path from a[i] to the root should be updated. These nodes are characterized by T(v)=a[i]⊕ . . . ⊕a[j]. Referring to
In an example in which multiple modifications are made, an internal node should be updated if a leaf in its subtree is modified. However, dependencies may exist between these nodes, and as a result, certain nodes may need to be updated in a certain order. For example, referring to
To resolve this internal dependency, exemplary embodiments utilize the principle of change propagation to identify and update the internal nodes affected by the modifications. For example, when a node is updated, the update may trigger the nodes that depend on this node to be updated.
Referring to
Referring again to
The number of ⊕ calls may be analyzed by upper-bounding the number of calls per level of the tree. The number of calls at level l is |Wl|. Thus, the total number of invocations may be represented as:
To proceed, an upper bound on the size of each Wl is derived as a function of the number of modified leaves m and the level number l:
For 1≦l≦log2n,
|Wl|≦min{m,n/2l}.
Assuming that 1≦l≦log2n, an internal node belongs to Wl if and only if it is on the leaf-to-root path of a modified leaf. Since exactly m leaves were modified, there cannot be more than m leaf-to-root paths passing through level l. Thus, |Wl|≦m. Further, since Wl is a subset of the nodes in level l, |Wl|≦n/2l. Thus, |Wl|≦min{m, n/2l}.
Referring again to:
The summation may be broken into a top part and a bottom part. The top part accounts for level l*=1+┌ log2(n/m)┐ and above, and the bottom part accounts for the levels below l*. Thus:
# of calls=top+bottom,
These two cases may be handled differently since most leaf-to-root paths have yet to merge together in the bottom part of the tree, whereas these paths have sufficiently joined together in the top part. The dashed line in
To analyze the top part, let λ=n/2l*. Since, ┌x┐≧x for x≧0, it follows that:
Thus, the total number of ⊕ calls is at most:
m+┌ log2(n/m)┐·m.
Answering Queries
A user may request the aggregate of the entire data, or any prefix or suffix using the aggregate, prefix, and suffix operations. The aggregate operation requires no additional work, as the function only returns the value at the root of the tree. The prefix and suffix operations may be supported with minimal work since any query may be answered by combining at most log2(n) values in the tree, as described below. According to exemplary embodiments, the prefix and suffix operations may be used to handle non-commutative aggregations.
Referring to the prefix operation, an example is described herein corresponding to answering prefix(7) on FAT with reference to
The process shown in
Referring to FIGS. 7 and 11-12, the initial iteration shows the state of the variables after line 1. Each subsequent iteration shows the state of the variables after line 4. In terms of complexity, the process traverses a leaf-to-root path, making at most one ⊕ call at each node. As a result, the number of ⊕ calls is at most log2(n). After each execution of line 4, a contains the aggregate of all of the leaves to the left of a[i] in the subtree rooted at p.
FlatFAT: Storing FAT in Memory
FlatFAT refers to an efficient implementation of the FAT data structure, according to an exemplary embodiment of the present invention. Since FAT is structurally static, FlatFAT may allocate the necessary memory at creation and ensure that sibling nodes are placed next to each other. Utilizing a FlatFAT implementation may reduce dynamic memory allocation calls in the overall framework, and may improve cache friendliness of these nodes, which tend to be accessed together.
FlatFAT is implemented by adopting a numbering scheme that is frequently used in array-based binary heap implementations. For example, assume T is a size-n FAT (e.g., T is a tree having 2n−1 nodes). These nodes may be represented as an array of length 2n−1 using a recursive numbering scheme in which the root node is at position h(T.root)=1, where for a node v, the left and right children of v are located at:
h(left(υ))=2h(υ) and k(right(υ))=2h(υ)+1.
Referring to
A feature of the mapping used in a FlatFAT implementation is that each of the navigation operations used in FAT processes takes O(1) time. The mapping allows for convenient navigation in both a downward direction (e.g., left, right) and an upward direction (e.g., parent) of the tree, as well as random access to the leaves (e.g., leaf) of the tree. For any node v other than the root:
h(parent(υ))=└h(υ)/2┘
The location of the i-th leaf (e.g., the leaf corresponding to (I[i]) is utilized to access a leaf node. The location of the i-th leaf is h(leaf(i))=n+i−1.
For a constant-time binary operator, a size-n FlatFAT may be maintained such that (i) new takes O(n) time, (ii) for m writes, update takes O(m+m log(n/m) time, (iii) prefix(i) and suffix(j) each take O(log2(n)) time, and (iv) aggregate( ) takes O(1) time.
Reactive Aggregator Using FlatFAT
The reactive aggregator is the interface between the window logic and the internal representation according to exemplary embodiments of the present invention. The reactive aggregator translates window events into actions on FlatFAT in order to respond to the events. The window events may be translated, for example, when a new tuple arrives, when an existing tuple is to be evicted, and when the aggregation value is needed. Herein, the reactive aggregator implementation using FlatFAT will first be described with reference to maintaining the window under tuple arrival and tuple eviction, and then with reference to providing the aggregate upon request.
According to exemplary embodiments, the reactive aggregator pairs the FlatFAT implementation with a resize process that determines the size of FlatFAT. The reactive aggregator views the slots of FlatFAT (e.g., a[1], . . . , a[n]) as an array lf length n. This space may be used to implement, for example, a circular buffer (e.g., a ring buffer), where the lifted elements of the sliding window are stored. It is to be understood that exemplary embodiments are not limited to a circular buffer.
Referring to
Although exemplary embodiments of the present invention store the data structure in memory in a pointer-free layout, in exemplary embodiment that utilize a circular buffer, a front pointer and a back pointer may be utilized to mark the boundaries of the circular buffer. Unfilled FlatFAT slots may be given a special marker, denoted by ⊥, which short-circuits the binary operator to return the other value: x⊕⊥=x and ⊥⊕y=y. This marker may not be utilized in certain implementations (e.g., FIFO windows, as described further below).
In an exemplary embodiment, the reactive aggregator first creates a FlatFAT instance with a default capacity, filling all slots with ⊥. As tuples enter into the window, the tuples are inserted into the circular buffer. As tuples leave the window, the tuples are removed from the buffer, and their locations are marked with ⊥. For example, referring to
In exemplary embodiments in which FIFO is not utilized, holes may exist in the circular buffer. The presence of holes may potentially create a situation in which the buffer is not able to receive more tuples, even though room may exist in the middle of the window. In response, the buffer may be occasionally compacted using a compact operation.
The compact operation, as well as a resize operation, are computationally expensive. For example, the compact operation scans the entire buffer to pack the buffer. Similarly, the resize operation creates a new FlatFAT, packs the data, and copies the data. Thus, according to exemplary embodiments, the compact and resize operations may be used sparingly. For example, assuming that count denotes the number of actual elements in the buffer (e.g., excluding ⊥) and that n is the capacity of FlatFAT, upon receiving a tuple and determining that the buffer is full, if count≦3n/4, the compact operation may be run. Otherwise, resize may be run to double the capacity. Further, after evicting a tuple, if count<n/4, resize may be used to shrink the capacity by half. After a resize operation, the buffer is between 3n/8 and n/2 full, and after a resize or compact operation, there are no holes remaining in the buffer.
Referring to the compact operation, when the compact operation is performed, at least n/4 evictions have occurred since the last time that no holes were present, since the buffer is full and count≦3n/4. The O(n) cost of compacting is charged to the evictions that created the holes, at a cost of O(1) per eviction. No holes exist in the buffer after a resize or compact operation.
Referring to the resize operation, when the capacity is to be doubled, at least n−n/2=n/2 arrivals have occurred since the last resize operation, and since the buffer is full and immediately after the last resize operation, the buffer may only be between 3n/8 and n/2 full. The O(n) cost of doubling is charged to these arrivals at a cost of O(1) per arrival. Similarly, when the capacity is shrunk in half, at least 3n/8−n/4=n/4 evictions have occurred since the last resize operation, and since the buffer is n/4 full and immediately after the last resize operation, the buffer may only be between 3n/8 and n/2 full. The O(n) cost of shrinking to these evictions is charged at O(1) per eviction.
Reporting the Aggregate Result
The manner in which the reactive aggregator derives the aggregate of the current window according to exemplary embodiments of the present invention will be described herein.
The window contents of FlatFAT are stored in the leaves, and its aggregate( ) operation may return the value of a[1]⊕ . . . ⊕a[n] at no cost.
An inverted buffer scenario refers to a scenario in which the ordering in the linear space a[1], a[2], . . . , a[n] differs from the ordering in the circular buffer (e.g., the window order). For example, referring again to
According to exemplary embodiments, the correct aggregate in an inverted buffer scenario may be derived. The correct aggregate may be derived by splitting the circular buffer in the middle due to the linear address space. Thus, the correct aggregate may be indicated by suffix(F)⊕prefix(B). The maximum cost is O(log2n).
FIFO Implementation
Exemplary embodiments of the present invention may be utilized in a FIFO (first-in, first-out) implementation, in which the first tuple to arrive in the window is the first tuple to leave the window. For example, in SPL, both count-based and time-based policies may utilize FIFO ordering.
When exemplary embodiments are utilized with a FIFO window, the area from the front buffer to the back buffer (wrapping around the array boundary) is always occupied (e.g., no holes exist). As a result, the reactive aggregator according to exemplary embodiments does not utilize the compact operation, which results in simplifying the resize operation. Accordingly, ⊥ need not be explicitly stored in unused slots. Rather, the buffer's demarcation may be incorporated into the update operation, resulting in unused slots being automatically skipped. When an inverted buffer scenario occurs, the unoccupied area is located between the leaf-to-root path of the back buffer and that of the front buffer. When the buffer is normal, the occupied area is located between the leaf-to-root path of the front buffer and that of the back buffer.
At block 701, a plurality of data tuples is received in the sliding window. At block 702, at least one data tuple of the plurality of data tuples is extracted from the sliding window. The at least one extracted data tuple is stored in a data structure in a memory at block 703. As described above, the data structure may be a balanced tree, and the at least one data tuple may be stored in leaf nodes of the balanced tree. At block 704, at least one intermediate result is maintained in at least one internal node of the balanced tree. The at least one intermediate result corresponds to a partial window aggregation. At block 705, a final result in the balanced tree is generated based on the at least one intermediate result. The final result corresponds to a final window aggregation. At block 706, the final result is output from the balanced tree.
In an exemplary embodiment, maintaining at least one intermediate result in the balanced tree (block 703) may include identifying at least one changed data item in a current data tuple of the plurality of data tuples currently in the sliding window at block 801. The at least one changed data item is relative to a previous data tuple of the plurality of data tuples previously in the sliding window. At block 802, the at least one changed data item is extracted from the current data tuple. At block 803, the at least one extracted changed data item is stored in at least one of the leaf nodes of the balanced tree. At block 804, the at least one intermediate result is modified based on the at least one extracted changed data item.
According to exemplary embodiments of the present invention, a general and automatic approach to incrementally computing sliding window aggregates in streaming applications is provided. As described above, exemplary embodiments avoid the need to compute the aggregate every time the aggregate is generated, resulting in a more efficient approach. Further, exemplary embodiments are not limited to aggregation-specific solutions (e.g., solutions that only work for specific functions), restricted scenarios (e.g., an insert-only model such as tumbling), or scenarios that are limited to only aggregate functions that have an inverse.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present invention are described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
Referring to
The computer platform 1901 also includes an operating system and micro-instruction code. The various processes and functions described herein may either be part of the micro-instruction code or part of the application program (or a combination thereof) which is executed via the operating system. In addition, various other peripheral devices may be connected to the computer platform such as an additional data storage device and a printing device.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
Having described exemplary embodiments of the present invention, it is noted that modifications and variations can be made by persons skilled in the art in light of the above teachings. It is therefore to be understood that changes may be made in exemplary embodiments of the invention, which are within the scope and spirit of the invention as defined by the appended claims. Having thus described the invention with the details and particularity required by the patent laws, what is claimed and desired protected by Letters Patent is set forth in the appended claims.