The event-based computation paradigm has grown in importance for enterprises. For example, many business applications and system control applications can be developed based on event-based computation. Generally, event processing applications receive events, analyze the events, and output results (e.g., proposed actions) based on the analysis of the events.
Current event processing systems often use structured query language (SQL) queries to analyze events. Due to the fluid nature of event streams, the relational algebra underlying traditional SQL may not be well-suited for processing events at a high rate. Additionally, performing time-based calculations using the relational operators provided by SQL may be difficult. Further, the semantics of a SQL query may require recitation of specific data sources, rendering a particular SQL query that recites a particular data source unsuitable for use with a different data source.
The present disclosure describes an event processing framework that utilizes queries based on reusable XML query templates. A single XML query template may be reused with respect to multiple event sources and sinks. For example, an XML query template may be instantiated and bound to a particular input adapter for a particular source and to a particular output adapter for a particular sink. To run the same query against another source and another sink, the XML query template may be re-instantiated and bound to another input adapter and another output adapter. Input adapters and output adapters for various sources and sinks may be user-defined to handle conversion to and from proprietary data formats associated with various sources and sinks.
An XML query template may include a directed graph of operators. The operators may be relational algebra operators, time-based operators, or any other type of operator.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
In a particular embodiment, a system is disclosed that includes an input adapter, a query engine, and an output adapter. The input adapter is configured to receive an event from a source and to generate an event object based on the event. The event object includes a payload, a validity start time, and a validity end time. The query engine is configured to execute a query with respect to the event object to produce a result object. The query is represented by an extensible markup language (XML) file that is based on a reusable XML query template. The XML query template is bindable to a plurality of input adapters and to a plurality of output adapters. Result objects are produced based on applying at least one operator of the query to an input of the event objects. The output adapter is configured to generate results based on the result objects and to transmit the results to a sink.
In another particular embodiment, a computer-readable medium is disclosed. The computer-readable medium includes instructions, that when executed by a computer, cause the computer to receive at least one event from a source at an event processing system. Each event is represented in a first data format that is native to the source. The computer-readable medium also includes instructions, that when executed by the computer, cause the computer to convert the at least one event from the first data format to at least one event object formatted in a second data format. Each event object includes a payload, a validity start time, and a validity end time. The computer-readable medium further includes instructions, that when executed by the computer, cause the computer to execute a query with respect to the at least one event object to produce a result object. The query is executed without storing the at least one event object and is represented by an XML file based on a reusable XML query template. The result object is based on an application of at least one operator of the query to the event object and is formatted in the second data format. The computer-readable medium includes instructions, that when executed by the computer, cause the computer to convert the result object from the second data format into a result formatted in a third data format that is native to a sink and to transmit the result to the sink.
The CEP input adapter 106 at the system 100 is configured to receive events, such as the event 104 from the source 102. For example, the source 102 may include a database, a server, an event ticker, a network port, a sensor, or some other event source that provides events to the CEP input adapter 106 periodically, randomly, or intermittently in bursts. The CEP input adapter 106 is also configured to generate (e.g., via translation or conversion) event objects (e.g., the illustrative event object 110) based on the events and to transmit the generated event objects to the CEP query engine 116 via an input stream 108. In a particular embodiment, the events received from the source 102 are formatted in a first data format (e.g., a proprietary data format) that is native to the source, and the event objects are formatted in a second data format that is native to the system 100. In a particular embodiment, the second data format that is native to the system 100 specifies that each event object 110 includes an event payload 112, an event validity start time and an end time 114.
The CEP query engine 116 is configured to receive event objects via the input stream 108 and to execute a query 118 with respect to the event objects to produce result objects (e.g., an illustrative result object 124). The CEP query engine 116 is also configured to transmit the result object 124 to the CEP output adapter 126 via an output stream 132.
The query 118 may be represented by an XML file based on a reusable XML query template that is bindable to multiple input adapters and multiple output adapters. Thus, the query template may be reusable with multiple sources and multiple sinks, where usage of the query template with a particular source includes binding the query template to a particular input adapter for the particular source and usage of the query template with a particular sink includes binding the query template to a particular output adapter for the particular sink. An adapter may be user-defined and may be written in a .NET programming language against an adapter application programming interface (API). Query template bindings are further described with respect to
In a particular embodiment, executing the query 118 at the CEP query engine 116 includes comparing event objects to static reference data retrieved from a static data source 122. Event objects may also be compared to historical data (e.g., historical data of the source 102, historical data of the sink 130, historical data of the query 118, or some other historical data) from the static data source 122. In another particular embodiment, executing the query 118 at the CEP query engine 116 includes storing data to the static data source 122.
In a particular embodiment, the query 118 represents a declarative query. Generally, declarative programming languages indicate “what” is to be done (e.g., what particular inputs will be provided and what particular outputs will be generated) rather than “how” it is done (e.g., the underlying algebra functions and the programmatic steps to convert the inputs into the outputs). Thus, it may be easier for users to specify declarative queries as compared to non-declarative queries, because event-level implementation details of declarative queries may not influence the result of declarative queries. For example, a declarative query may be defined in a language integrated query (LINQ) language, a .NET programming language other than LINQ, or a complex event detection and response (CEDR) algebra. For example, an illustrative LINQ query may include:
An illustrative XML file representation of the above LINQ query may include:
In a particular embodiment, executing the query 118 at the CEP query engine 116 includes parsing the XML file representing the query in accordance with one or more XML schema definition (XSD) files. For example, such XSD files useable to parse XML queries may be available from Microsoft Corp. at 1, Microsoft Way Redmond, Wash. 98052.
In a particular embodiment, the CEP query engine 116 is configured to provide “in-flight” processing of event objects. That is, the CEP query engine 116 may receive event objects, execute the query 118, and transmit produced result objects without storing the event objects or the result objects in a memory of the system 100. In a particular embodiment, support for in-flight processing enables the system 100 to process hundreds of thousands of event objects per second, or more.
The CEP output adapter 126 at the system 100 is configured to transmit results such as the result 128 to the sink 130. The CEP output adapter 126 is also configured to generate (e.g., via translation or conversion) the results based on result objects (e.g., the result object 124) received from the CEP query engine 116 via the output stream 132. In a particular embodiment, result objects received from the query engine are in the second data format native to the system 100 and the results are formatted in a third data format (e.g., another proprietary data format) that is native to the sink 130. The sink 130 may include a communications device, a mobile device, a computer system, a database, a server, an event store, or some other consumer of results produced by the system 100.
In a particular embodiment, the CEP input adapter 106 and the CEP output adapter 126 are coupled to network interfaces, such as a wired interface (e.g., Ethernet), a wireless interface (e.g., IEEE 802.11a/b/g/n), or some other network interface. In another particular embodiment, one or more of the source 102 and the sink 130 may be local to a computer system that includes the system 100 of
In a particular embodiment of operation, the CEP input adapter 106 may receive the event 104 from the source 102 and generate an event object 110 based on the event 104. The event object includes an event payload 112 and validity start/end times 114. The CEP query engine 116 may execute the query 118 with respect to the event object 110 to generate the result object 124. The query may be represented by an XML file that is based on a reusable XML query template (e.g., generated based on a LINQ query). The CEP output adapter 126 may generate a result 128 based on the result object 124 and may transmit the result 128 to the sink 130
It will be appreciated that the system 100 of
A first CEP input adapter 212 at the system 200 may receive events from the first source 202, produce event objects 216 based on the events, and transmit the event objects 216 to the CEP query engine 218 as described herein with reference to the CEP input adapter 106 of
The CEP query engine 218 is configured to receive event objects 216 from the CEP input adapters and execute the CEP queries 220, 222 with respect to the event objects 216 to produce result objects 236. The CEP query engine 218 is also configured to transmit the result objects 236 to the CEP output adapters 224, 226. The CEP queries 220, 222 may be represented by XML files and may be based on the same XML query template. That is, the first CEP query 220 may be an instantiation of the XML query template bound to the first CEP input adapter 212 and the first CEP output adapter 224, and the second CEP query 222 may be an instantiation of the XML query template bound to the second CEP input adapter 214 and the second CEP output adapter 226.
It should be noted that CEP queries may not be limited to producing a single result object for each event object. Depending on the particular operator(s) in the query, any number of result objects may be produced from a single event object, and any number of event objects may be consumed in producing a single result object. For example, a result object may be produced by executing a query with respect to multiple events objects of a particular stream (e.g., a first event object based on the first event 204 and a second event object based on the third event 206).
In a particular embodiment, when the CEP queries 220, 222 are instantiations of the same XML query template, the event objects 216 produced by the CEP input adapters 212, 214 are identically typed. The result objects 236 transmitted to the CEP output adapters 224, 226 are also identically typed. For example, if a directed graph of operators in the XML query template accepts as input one integer value and two floating point values, each of the CEP input adapters 212, 214 produce event objects that include one integer value and two floating values as the event object payload. As another example, if the directed graph of operators in the XML query template produces as an output a single Boolean value, each of the CEP output adapters 224, 226 will accept result objects that include a single Boolean value as the result object payload. Thus, any user-defined input adapter (and by extension, event source) may be bound to an XML query template, provided that the user-defined input adapter produces event objects that fulfill data type expectations of the XML query template. Similarly, any user-defined output adapter (and by extension, result sink) may be bound to an XML query template, provided that the user-defined output adapter accepts result objects that include data types produced by the XML query template. It should be noted that although the particular embodiment illustrated in
An illustrative embodiment of an XML file that represents a bound query may include:
The first CEP output adapter 224 at the system 200 may receive result objects 236 from the query engine 218, produce results (e.g., the first result 228) based on the result objects 236, and transmit the results to the first sink 230 as described herein with reference to the CEP output adapter 126 of
In a particular embodiment of operation, the first CEP input adapter 212 may generate event objects 216 based on events (e.g., the first event 204 and the third event 206) received from the first source 202, and the second CEP input adapter 214 may generate event objects 216 based on events (e.g., the second event 210) received from the second source 208. The event objects 216 are identically typed. The CEP query engine may execute a first CEP query 220 bound to the first CEP input adapter 212 and to the first CEP output adapter 224 to generate result objects 236 that are transmitted to the first CEP output adapter 224. The CEP query engine may also execute a second CEP query 222 bound to the second CEP input adapter 214 and to the first CEP output adapter 226 to generate result objects 236 that are transmitted to the second CEP output adapter 226. The result objects 236 may be identically typed. The first CEP output adapter 224 may transmit results (e.g., the first result 228) to the first sink 230 and the second CEP output adapter 226 may transmit results (e.g., the second result 232) to the second sink 234
In a particular embodiment, the first CEP query 220 and the second CEP query 222 execute simultaneously. In another particular embodiment, the first CEP query 220 executes during a first time period and the second CEP query 222 executes during a second time period (e.g., subsequent to the first time period).
It will be appreciated that the system 200 of
A query template may be viewed as a computational assembly line, where the input of the assembly line is attached to an input adapter and the output of the assembly line is attached to an output adapter. To illustrate the use of the query template 300, consider a plurality of power meters configured to measure power consumption (in watts) by a particular machine component. Each of the power meters may function as an event source for an event processing system and my transmit power data 302 to the event processing system in the form of events, where events from a particular power meter include wattage readings from the particular power meter. The power meters may produce multiple event objects per second.
An input adapter 304 of the event processing system may generate event objects (e.g., the illustrative event object 306) based on the power data 302. Each such event object may include as payload an integer power meter identifier (ID) and an integer wattage reading (W, a fixed point reading measured in tenths of Watts), where the ID identifies the particular power meter that produced the wattage reading W. Each such event object includes a validity start time and a validity end time (not shown).
The event objects generated by the input adapter 304 may be transmitted to a query execution engine that is configured to execute a query based on the query template 300. That is, the query execution engine may be configured to execute an instantiation of the query template that is bound to the input adapter 304 and to an output adapter 322. The query template 300 may include a directed graph of operators. For example, in the particular embodiment illustrated in
In accordance with the above logic, during operation of the event processing system, the projection operator 308 may generate an intermediate value “Wattage=W/10.” Next, the hopping window operator 310 may apply a one second window to the calculation (e.g., collect event objects with validity start times within the last second). The grouping operator 312 may then partition the collection of event objects by power meter ID, and the aggregation operator 314 may compute a value “w” for each power meter, where “w” for a particular power meter represents the average power consumption of the particular power meter over the previous one second. The second aggregation operator 316 may compute a value “wSum” that represents a sum of the “w” value for all power meters. Finally, a join operator 318 may compute a value “Ratio=w/wSum” representing the ratio of power consumption reported by the power meter associated with the event object 306 to total power consumption of all power meters.
The query template 300 may produce result objects (e.g., the illustrative result object 320) having as payload an integer power meter identifier (ID), a floating point wattage reading (W), and a floating point power consumption ratio (Ratio). The result objects may be transmitted by the query execution engine to an output adapter 322, and the output adapter may transmit result data 324 to a client of the event processing system. For example, the client may be a power throttling computer configured to selectively down-throttle power provided to a particular machine component in response to receiving result data 324 indicating that the particular machine component is consuming over 50% of total power.
The method 400 includes, at a system including a processor and a memory, receiving a plurality of events from a source, at 402. For example, the plurality of events may be received periodically, randomly, intermittently in bursts, or in some other fashion. For example, in
The method 400 also includes generating a plurality of event objects based on the plurality of events, at 404. For example, in
The method 400 further includes, at the processor, executing a query with respect to the plurality of event objects to produce a plurality of result objects, at 406. The query is executed without storing any of the plurality of event objects at the memory and the query is represented by an XML file that is based on a reusable XML query template. Each of the plurality of result objects is based on an application of at least one operator of the query. For example, in
The method 400 includes generating a plurality of results based on the plurality of result objects, at 408. For example, in
The method 500 includes, at a system, receiving at least one event from a source, where the event is represented in a first data format that is native to the source, at 502. For example, in
The method 500 also includes converting the at least one event from the first data format to at least one event object formatted in a second data format, at 504. The at least one event object includes a payload, a validity start time, and a validity end time. For example, in
The method 500 further includes executing a query with respect to the at least one event object to produce a result object, at 506. The query is executed without storing the at least one event object, and the query is represented by an XML file that is based on a reusable XML query template. The result object is produced based on an application of at least one operator of the query and is formatted in the second data format. For example, in
The method 500 includes converting the at least one result object from the second data format to at least one result formatted in a third data format that is native to a sink, at 508. For example, in
It will be appreciated that with a reusable query template, the method 500 of
The computing device 610 includes at least one processor 620 and a system memory 630. Depending on the configuration and type of computing device, the system memory 630 may be volatile (such as random access memory or “RAM”), non-volatile (such as read-only memory or “ROM,” flash memory, and similar memory devices that maintain stored data even when power is not provided), or some combination of the two. The system memory 630 typically includes an operating system 632, one or more application platforms 634, one or more applications (e.g., a query engine 636), and may include program data 638 associated with the one or more applications. In an illustrative embodiment, the query engine 636 is the CEP query engine 116 of
The computing device 610 may also have additional features or functionality. For example, the computing device 610 may also include removable and/or non-removable additional data storage devices such as magnetic disks, optical disks, tape, and standard-sized or miniature flash memory cards. Such additional storage is illustrated in
The computing device 610 also contains one or more communication connections 680 that allow the computing device 610 to communicate with other computing devices (e.g., an input source 690, an output sink 692, and a static data source 694) over a wired or a wireless network. In an illustrative embodiment, the communication connections 680 include the adapters 106, 126 of
It will be appreciated that not all of the components or devices illustrated in
The illustrations of the embodiments described herein are intended to provide a general understanding of the structure of the various embodiments. The illustrations are not intended to serve as a complete description of all of the elements and features of apparatus and systems that utilize the structures or methods described herein. Many other embodiments may be apparent to those of skill in the art upon reviewing the disclosure. Other embodiments may be utilized and derived from the disclosure, such that structural and logical substitutions and changes may be made without departing from the scope of the disclosure. Accordingly, the disclosure and the figures are to be regarded as illustrative rather than restrictive.
Those of skill would further appreciate that the various illustrative logical blocks, configurations, modules, and process or instruction steps described in connection with the embodiments disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. Various illustrative components, blocks, configurations, modules, or steps have been described generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present disclosure.
The steps of a method described in connection with the embodiments disclosed herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. A software module may reside in computer readable media, such as random access memory (RAM), flash memory, read only memory (ROM), registers, a hard disk, a removable disk, a CD-ROM, or any other form of storage medium known in the art. An exemplary storage medium is coupled to the processor such that the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor or the processor and the storage medium may reside as discrete components in a computing device or computer system.
Although specific embodiments have been illustrated and described herein, it should be appreciated that any subsequent arrangement designed to achieve the same or similar purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all subsequent adaptations or variations of various embodiments.
The Abstract of the Disclosure is provided with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, various features may be grouped together or described in a single embodiment for the purpose of streamlining the disclosure. This disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter may be directed to less than all of the features of any of the disclosed embodiments.
The previous description of the embodiments is provided to enable a person skilled in the art to make or use the embodiments. Various modifications to these embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments without departing from the scope of the disclosure. Thus, the present disclosure is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope possible consistent with the principles and novel features as defined by the following claims.
This application is a continuation application of U.S. patent application Ser. No. 12/603,308 (now U.S. Pat. No. 9,158,816), entitled “EVENT PROCESSING WITH XML QUERY BASED ON REUSABLE XML QUERY TEMPLATE,” filed on Oct. 21, 2009, the entire disclosure of which is hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5321837 | Daniel et al. | Jun 1994 | A |
5528516 | Yemini et al. | Jun 1996 | A |
5546570 | McPherson et al. | Aug 1996 | A |
5691917 | Harrison | Nov 1997 | A |
5765037 | Morrison et al. | Jun 1998 | A |
5805782 | Foran | Sep 1998 | A |
5809235 | Sharma et al. | Sep 1998 | A |
5891046 | Cyrus | Apr 1999 | A |
5999908 | Abelow | Dec 1999 | A |
6145009 | Miyazawa et al. | Nov 2000 | A |
6236998 | Lehtinen | May 2001 | B1 |
6253313 | Morrison et al. | Jun 2001 | B1 |
6327587 | Forster | Dec 2001 | B1 |
6336139 | Feridun et al. | Jan 2002 | B1 |
6449618 | Blott et al. | Sep 2002 | B1 |
6477562 | Nemirovsky et al. | Nov 2002 | B2 |
6484203 | Porras | Nov 2002 | B1 |
6496831 | Baulier | Dec 2002 | B1 |
6507840 | Ioannidis | Jan 2003 | B1 |
6601058 | Forster et al. | Jul 2003 | B2 |
6604102 | Klein et al. | Aug 2003 | B2 |
6629106 | Narayanaswarny et al. | Sep 2003 | B1 |
6633910 | Rajan | Oct 2003 | B1 |
6681230 | Blott et al. | Jan 2004 | B1 |
6763353 | Li | Jul 2004 | B2 |
6775658 | Zothner | Aug 2004 | B1 |
6782379 | Lee | Aug 2004 | B2 |
6920468 | Cousins et al. | Jul 2005 | B1 |
6925631 | Golden | Aug 2005 | B2 |
6941557 | Jakobson | Sep 2005 | B1 |
6954757 | Zargham | Oct 2005 | B2 |
7013289 | Horn | Mar 2006 | B2 |
7020618 | Ward | Mar 2006 | B1 |
7028324 | Shimizu | Apr 2006 | B2 |
7065561 | Fry et al. | Jun 2006 | B2 |
7065566 | Menard | Jun 2006 | B2 |
7103556 | Del Rey | Sep 2006 | B2 |
7107224 | Weller | Sep 2006 | B1 |
7310638 | Blair | Dec 2007 | B1 |
7349675 | Karr et al. | Mar 2008 | B2 |
7349925 | Cherkauer et al. | Mar 2008 | B2 |
7383255 | Desai | Jun 2008 | B2 |
7409428 | Barbec et al. | Aug 2008 | B1 |
7457728 | Chen et al. | Nov 2008 | B2 |
7467018 | Callaghan | Dec 2008 | B1 |
7523190 | Bickerstaff et al. | Apr 2009 | B1 |
7525646 | Sullivan et al. | Apr 2009 | B1 |
7590644 | Matsakis | Sep 2009 | B2 |
7657540 | Bayliss | Feb 2010 | B1 |
7676461 | Chkdrov | Mar 2010 | B2 |
7702689 | Forstmann et al. | Apr 2010 | B2 |
7840592 | Muras | Nov 2010 | B2 |
7890923 | Elaasar | Feb 2011 | B2 |
7996388 | Jain | Aug 2011 | B2 |
8019390 | Sindhu | Sep 2011 | B2 |
8060614 | Goldstein et al. | Nov 2011 | B2 |
8132184 | Gerea et al. | Mar 2012 | B2 |
8224805 | Lee | Jul 2012 | B2 |
8291005 | Lang et al. | Oct 2012 | B2 |
8296331 | Chkodrov et al. | Oct 2012 | B2 |
8296434 | Miller | Oct 2012 | B1 |
8315990 | Barga et al. | Nov 2012 | B2 |
8447859 | Bobak | May 2013 | B2 |
8775482 | Chkodrov et al. | Jul 2014 | B2 |
9035880 | Elyada et al. | May 2015 | B2 |
9158816 | Schindlauer et al. | Oct 2015 | B2 |
9229986 | Goldstein et al. | Jan 2016 | B2 |
20020016771 | Carothers | Feb 2002 | A1 |
20020032676 | Reiner et al. | Mar 2002 | A1 |
20020059183 | Chen | May 2002 | A1 |
20020062237 | Matsumoto | May 2002 | A1 |
20020083049 | Forster et al. | Jun 2002 | A1 |
20020099578 | Eicher, Jr. | Jul 2002 | A1 |
20020129024 | Lee | Sep 2002 | A1 |
20020147711 | Hattori | Oct 2002 | A1 |
20030120450 | Ernst | Jun 2003 | A1 |
20030163465 | Morrill | Aug 2003 | A1 |
20030181991 | Chau | Sep 2003 | A1 |
20030236677 | Casati | Dec 2003 | A1 |
20040068428 | Mitchell | Apr 2004 | A1 |
20040098390 | Bayliss et al. | May 2004 | A1 |
20040111396 | Musayev et al. | Jun 2004 | A1 |
20040137954 | Engstrom et al. | Jul 2004 | A1 |
20040153329 | Casati | Aug 2004 | A1 |
20040158429 | Bary | Aug 2004 | A1 |
20040172409 | James | Sep 2004 | A1 |
20040172599 | Calahan | Sep 2004 | A1 |
20040177053 | Donoho | Sep 2004 | A1 |
20040205082 | Fontoura et al. | Oct 2004 | A1 |
20040205110 | Hinshaw | Oct 2004 | A1 |
20040220791 | Lamkin | Nov 2004 | A1 |
20040260829 | Husak et al. | Dec 2004 | A1 |
20050052427 | Wu et al. | Mar 2005 | A1 |
20050055631 | Scardina et al. | Mar 2005 | A1 |
20050138081 | Alshab et al. | Jun 2005 | A1 |
20050165724 | West | Jul 2005 | A1 |
20050182758 | Seitz | Aug 2005 | A1 |
20060017692 | Wehrenberg et al. | Jan 2006 | A1 |
20060033625 | Johnson et al. | Feb 2006 | A1 |
20060059268 | Victor et al. | Mar 2006 | A1 |
20060069942 | Brasilerio et al. | Mar 2006 | A1 |
20060074741 | Orumchian et al. | Apr 2006 | A1 |
20060100969 | Wang et al. | May 2006 | A1 |
20060123119 | Hill et al. | Jun 2006 | A1 |
20060130070 | Graf | Jun 2006 | A1 |
20060136448 | Cialini et al. | Jun 2006 | A1 |
20060149849 | Raz | Jul 2006 | A1 |
20060161523 | Dettinger | Jul 2006 | A1 |
20060161528 | Dettinger et al. | Jul 2006 | A1 |
20060230071 | Kass et al. | Oct 2006 | A1 |
20060248182 | Glassco et al. | Nov 2006 | A1 |
20060253831 | Harper | Nov 2006 | A1 |
20060265406 | Chkodrov | Nov 2006 | A1 |
20060277253 | Ford | Dec 2006 | A1 |
20060282695 | Mital et al. | Dec 2006 | A1 |
20070043856 | Morris et al. | Feb 2007 | A1 |
20070118545 | Chandrasekharan et al. | May 2007 | A1 |
20070136239 | Lee et al. | Jun 2007 | A1 |
20070168990 | Alshab et al. | Jul 2007 | A1 |
20070237410 | Cormode et al. | Oct 2007 | A1 |
20070255529 | Biazetti et al. | Nov 2007 | A1 |
20070276815 | Naibo et al. | Nov 2007 | A1 |
20070294217 | Chen et al. | Dec 2007 | A1 |
20080016095 | Bhatnagar et al. | Jan 2008 | A1 |
20080021666 | Goode et al. | Jan 2008 | A1 |
20080065590 | Castro | Mar 2008 | A1 |
20080065666 | Rose et al. | Mar 2008 | A1 |
20080114803 | Chinchwadkar | May 2008 | A1 |
20080120283 | Liu | May 2008 | A1 |
20080129491 | Ruperto | Jun 2008 | A1 |
20080133891 | Salz et al. | Jun 2008 | A1 |
20080134135 | Elaasar | Jun 2008 | A1 |
20080134158 | Salz et al. | Jun 2008 | A1 |
20080214902 | Lee | Sep 2008 | A1 |
20080215428 | Ramer | Sep 2008 | A1 |
20080256384 | Branson et al. | Oct 2008 | A1 |
20080284738 | Hovden | Nov 2008 | A1 |
20080301124 | Alves et al. | Dec 2008 | A1 |
20080301135 | Alves et al. | Dec 2008 | A1 |
20080301175 | Applebaum | Dec 2008 | A1 |
20090012867 | Lerman et al. | Jan 2009 | A1 |
20090037370 | Mishra | Feb 2009 | A1 |
20090052341 | Enqvist | Feb 2009 | A1 |
20090070765 | Alves et al. | Mar 2009 | A1 |
20090070786 | Alves | Mar 2009 | A1 |
20090100029 | Jain et al. | Apr 2009 | A1 |
20090106190 | Srinivasan et al. | Apr 2009 | A1 |
20090106218 | Srinivasan et al. | Apr 2009 | A1 |
20090125550 | Barga et al. | May 2009 | A1 |
20090125635 | Barga et al. | May 2009 | A1 |
20090150367 | Melnik et al. | Jun 2009 | A1 |
20090178059 | Lang et al. | Jul 2009 | A1 |
20090204551 | Wang et al. | Aug 2009 | A1 |
20090219166 | MacFarlane | Sep 2009 | A1 |
20090222793 | Frank et al. | Sep 2009 | A1 |
20090228465 | Krishnamurthy et al. | Sep 2009 | A1 |
20090265336 | Suntinger et al. | Oct 2009 | A1 |
20090278828 | Fletcher et al. | Nov 2009 | A1 |
20090319501 | Goldstein et al. | Dec 2009 | A1 |
20090319687 | Goldstein et al. | Dec 2009 | A1 |
20100017214 | Ambrosio et al. | Jan 2010 | A1 |
20100017379 | Naibo et al. | Jan 2010 | A1 |
20100041391 | Spivey et al. | Feb 2010 | A1 |
20100088325 | Goldstein et al. | Apr 2010 | A1 |
20100121744 | Belz et al. | May 2010 | A1 |
20100123737 | Williamson et al. | May 2010 | A1 |
20100125545 | Navas | May 2010 | A1 |
20100131538 | Jones et al. | May 2010 | A1 |
20100138285 | Leonard | Jun 2010 | A1 |
20100141571 | Chiang | Jun 2010 | A1 |
20100141658 | Danton et al. | Jun 2010 | A1 |
20100280857 | Liu et al. | Nov 2010 | A1 |
20100331146 | Kil | Dec 2010 | A1 |
20110016123 | Pandey et al. | Jan 2011 | A1 |
20110029393 | Apprendi | Feb 2011 | A1 |
20110032268 | Takei | Feb 2011 | A1 |
20110040808 | Joy et al. | Feb 2011 | A1 |
20110059775 | Choi et al. | Mar 2011 | A1 |
20110093162 | Nielsen et al. | Apr 2011 | A1 |
20110093306 | Nielsen | Apr 2011 | A1 |
20110093490 | Schindlauer et al. | Apr 2011 | A1 |
20110093631 | Gerea | Apr 2011 | A1 |
20110093723 | Brown et al. | Apr 2011 | A1 |
20110093866 | Grabs et al. | Apr 2011 | A1 |
20110169823 | Barenburg | Jul 2011 | A1 |
20110176720 | Van Osten | Jul 2011 | A1 |
20110213664 | Osterhout | Sep 2011 | A1 |
20110261048 | Lee | Oct 2011 | A1 |
20110283144 | Nano | Nov 2011 | A1 |
20120036485 | Watkins | Feb 2012 | A1 |
20120041825 | Kasargod | Feb 2012 | A1 |
20120084322 | Goldstein et al. | Apr 2012 | A1 |
20120268391 | Somers | Oct 2012 | A1 |
20130014094 | Chkodrov et al. | Jan 2013 | A1 |
20130031567 | Nano et al. | Jan 2013 | A1 |
20130201303 | Shimotani | Aug 2013 | A1 |
20130229406 | Elyada et al. | Sep 2013 | A1 |
20130262645 | Akchurin et al. | Oct 2013 | A1 |
20150134698 | Schindlauer et al. | May 2015 | A1 |
Number | Date | Country |
---|---|---|
11-259578 | Sep 1999 | JP |
2003-308333 | Oct 2003 | JP |
2004-240766 | Aug 2004 | JP |
9215066 | Sep 1992 | WO |
2007035452 | Mar 2007 | WO |
Entry |
---|
U.S. Appl. No. 13/438,836, Non-Final Office Action mailed May 11, 2015, 11 pages. |
Abadi, “Aurora: A New Model and Architecture for Data Stream Management”, In The VLDB Journal, Aug. 2003. |
Abadi, “The Design of the Borealis Stream Processing Engine”, In Proceedings of the 2nd Conference on Innovative Data Systems Research, Jan. 4-7, 2005. |
Ali, “Microsoft CEP Sever and Online Behavioral Targeting,” In Proceedings of the ACM International Conference on Very Large Data Bases, Aug. 24-28, 2009. |
Arasu, “CQL: A Language for Continuous Queries over Streams and Relations”, 9th International! Workshop on Database Programming Languages, Sep. 6-8, 2003. |
Arasu, “STREAM: The Stanford Stream Data Manager”, In Proceedings of the ACM SIGMOD International Conference on Management of Data, Jun. 9-12, 2003. |
Arasu, “The CQL Continuous Query Language: Semantic Foundations and Query Execution”, In The VLDB Journal, Jun. 2006. |
Arasu, et al. “STREAM: The Standford Data Stream Management System,” book chapter, Stanford University, 21 pages, USA. |
Babcock, et al.; “Models and Issues in Data Stream Systems”; Proceedings of the 21st ACM SIGMOD-SIGACT-SIGART Symposium on Principles of Database Systems (PODS *02); 2002; pp. 1-30. |
Babu, “A Data Stream Management System for Network Traffic Management”, In Proceedings of the Workshop on Network-Related Data Management, May 25, 2001. |
Babu, et al. “StreaMon: An Adaptive Engine for Stream Query Processing”; ACM International Conference on Management of Data (SIGMOD 2004); 2004; pp. 931-932. |
BAM API (BizTalk Server Sample), Microsoft, Published on or Before 2007. |
Barga et al, “Consistent Streaming Through Time: A Vision for Event Stream Processing”, retrieved at <<http://www. cs.Cornell.edu/˜mshong/papers/cidr%2007%20cedr.pdf>>, Jan. 7-10, 2007. pp. 12. |
Barga, “CEDR—Complex Event Detection and Response; Research Brief (CEDR)”, Microsoft TechFest, Mar. 1-2, 2006. |
Barga, “Event Correlation and Pattern Detection in CEDR”, In Proceedings of the Extending Database Technology Workshops, Reactivity on the Web, Mar. 26-31, 2006. |
Barga, et al.; “Coping with Variable Latency and Disorder in Distributed Event Streams”; 26th IEEE International Conference on Distributed Computing Systems Workshops *ICDCSW'06); 2006; pp. 6. |
Barish et al.; “Speculative Execution for Information Gathering Plans”; 2002; pp. 184-193. |
Barish et al.; “Speculative Plan Execution for Information Gathering”; 2008; pp. 1-50. |
Baulier, “A Database System for Real-Time Event Aggregation in Telecommunication”, In Proceedings of the 24th Conference on Very Large Data Bases, Aug. 24-27, 1998. |
Berenson, “Microsoft SQL Server Query Processor Internals and Architecture”, Microsoft, Jan. 2000. |
Bernhardt, et al. “Complex Event Processing Made Simple Using Esper”, Retrieved at <<http://www.theserverside.com/tt/articles/article. tss?l=ComplexEventProcessing>>, Apr. 2008. pp. 5. |
BizTalk Server 2004: BizTalk Server Business Rules Framework, Microsoft White Paper, Dec. 2003. |
BizTalk Server 2006 R2, Microsoft, 2006. |
Bonnet, “Towards Sensor Database Systems”, In Proceedings of the 2nd International Conference on Mobile Data Management, Jan. 8-10, 2001. |
Bry et al, “A High-Level Query Language for Events”, retrieved at <<http://www.pms.ifi.lmu.de/mitarbeiter/eckert/ publications/EDA-PS2006.pdf>>, 2006. pp. 8. |
C# Version 3.0 Specification, Microsoft, May 2006. |
Carlson, “An Event Detection Algebra for Reactive Systems”, In Proceedings of the 4th ACM International Conference on Embedded Software, Sep. 27-29, 2004. |
Chakravarthy, “Composite Events for Active Databases: Semantics, Contexts and Detection”, In Proceedings of the 20th International Conference on Very Large Data Bases, Sep. 12-15, 1994. |
Chandrasekaran, “TelegraphCQ: Continuous Dataflow Processing for and Uncertain World”, In Proceedings of the 1st Conference on Innovative Data Systems Research, Jan. 5-8, 2003. |
Chen, et al. “NiagaraCQ: A Scalable Continuous Query System for Internet Databases”; Proceedings of the 2000 ACM SIGMOD International Conference on Management of Data; 2000; pp. 379-390. |
Cherniack, et al.; “Scalable Distributed Stream Processing”; Proceedings of the 2003 CIDR Conference; 2003; pp. 1-12. |
Complex Event Processing (CEP), retrieved at <<http://www.progress.com/psm/apama/data-streams/index.ssp>>, Mar. 9, 2007. pp. 2. |
Complex Event Processing Made Simple Using Esper; The Server Side.com; Apr. 2008; 6 pages. |
Complex Event Processing Tutorial; retrieved from http://www.eventstreamprocessina.com/CEP-tutorial.htm; Jun. 2007; 2 pages. |
Cranor, “Gigascope: A Stream Database for Network Applications”, In Proceedings of the ACM SIGMOD International Conference on Management of Data, Jun. 9-12, 2003 . . . . |
Dean, “MapReduce: Simplified Data Processing on Large Clusters”, In Proceedings of the 6th Symposium on Operating Systems Design and Implementation, Dec. 6-8, 2004. |
Demers, “Cayuga: A General Purpose Event Monitoring System”, Third Biennial Conference on Innovative Data Systems Research, Jan. 7-10, 2007. |
Demers, “Towards Expressive Publish/Subscribe Systems”, In Proceedings of the 10th International Conference on Extending Database Technology, Mar. 26-31, 2006. |
Elyada, et al., “Controlling Images at Mobile Devices Using Sensors,” New US Patent Application filed Today. |
Event Stream Intelligence with Esper and NEsper; retrieved from http://esper.codehaus.ora: retrieved Mar. 7, 2011; 4 pages. |
Event-Driven Models and Complex Event Processing, retrieved at <<http://www.cxo.eu.com/article/Event-driven- models-and-complex-event-processing/>>, 2009. pp. 3. |
Franklin, “Design Considerations for High Fan-In Systems: The HiFi Approach”, In Proceedings of the 2nd Conference on Innovative Data Systems Research, Jan. 4-7, 2005. |
Ghanem, “Exploiting Predicate-Window Semantics Over Data Streams”, In Proceedings of the ACM SIGMOD International Conference on Management of Data, Jun. 27-29, 2006. |
Ghanem, “Incremental Evaluation of Sliding-Window Queries Over Data Streams”, In Proceedings of the IEEE Transactions on Knowledge and Data Engineering, Jan. 2007. |
Goldstein, “Operator Algorithm Design for Speculative Stream Processing”, Microsoft Research Technical Report MSR-TR-2007-158, Dec. 2007. (Previously titled as “Consistency Sensitive Operators in CEDR”.). |
Goldstein, J. et al.; “Flying Fixed-Point: Recursive Processing in Stream Queries”; VLDB '08; Aug. 24-30, 2008; Auckland, New Zealand. |
Grabs et al, “Introducing Microsoft StreamInsight”, Sep. 2009. pp. 27. |
Grabs et al, “Introducing Microsoft's Platform for Complex Event Processing”, May 2009. pp. 24. |
Gyllstrom, “On Supporting Kleene Closure over Event Streams”, Proceedings of the 24th International Conference on Data Engineering, Apr. 7-12, 2008. |
Gyllstrom, D. et al.; “SASE: Complex Event Processing over Streams”; 3'a Biennial Conference on Innovative Data Systems Research (CIDR); Jan. 2007; pp. 407-411. |
Hammad, “Nile: A Query Processing Engine for Data Streams”, Proceedings of the 20th International Conference on Data Engineering, Mar. 30-Apr. 2, 2001. |
Integration Services Architecture, Microsoft, Published on or Before Jul. 17, 2006. |
Interactive Advertising Bureau Mobile Rich-media Ad Interface Definitions (MRAID) v 1.0, Published on: Oct. 20, 2011, Available at: http://www.iab.net/media/file/IAB—MRAID—VersionOne—final.pdf. |
Isard, “Dryad: Distributed Data-Parallel Programs from Sequential Building Blocks”, In Proceedings of EuroSys, Mar. 21-23, 2007. |
JadeDragon, “iPad Game Review: CF Defense HD,” Retrieved at: http://www.mobiletechreview.com/ubbthreads/showflat.php?Cat=0&Number=37978&an=0&page=13, Jul. 26, 2010. |
Jensen, “Temporal Specialization”, In Proceedings of the 8th International Conference on Data Engineering, Feb. 3-7, 1992. |
Jiang et al, “Anatomy of a Data Stream Management System”, retrieved at <<http://ftp.informatik.rwth-aachen.de/ Publications/CEUR-WS/Vol-215/paper12.pdf>>, 2004. pp. 16. |
Jiang, et al, “Estreams: Towards an Integrated Model for Event and Stream Processing”, retrieved at <<http:// ariana.uta.edu/research/Publications/Downloads/CSE-2004-3.pdf>>, Jul. 1, 2004. pp. 25. |
Johnson et al, “A Heartbeat Mechanism and its Application in Gigascope”, retrieved at <<http://www.vldb.org/ conf/2005/papers/p1079-johnson.pdf>>, 2005. pp. 10. |
LePage, P. “This End Up: Using Device Orientation,” Retrieved at: http://www.html5rocks.com/en/tutorials/device/orientation/, Apr. 29, 2011. |
Li, “Semantics and Evaluation Techniques for Window Aggregates in Data Streams”, in Proceedings of the ACM SIGMOD International Conference on Management of Data, Jun. 14-16, 2005. |
Li, “Study on Smoothing Browser in Multi-View Virtual Space Based on Panorama”, In Proceedings of the International Archives of the Photogrammetry, Remote Sensing and Spatial Information Sciences, Jul. 3-11, 2008. |
Loddengaard, A.; “FoneDoktor, A WibiData Application”; retrieved from http://www.clouders.com/blog/2011/12/fonedoktor-a-wibidata-application; Dec. 6, 2011; 5 pages. |
Madden, “Continuously Adaptive Continuous Queries Over Streams”, In Proceedings of the ACM SIGMOD International Conference on Management of Data, Jun. 4-6, 2002. |
Maier, “Semantics of Data Streams and Operators”, Proceedings of the 10th International Conference on Database Theory, . . . Jan. 5-7, 2005. |
Microsoft StreamInsight, retrieved at <<http://msdn.microsoft.com/en-us/library/ee362541(SQL.105,printer).aspx, pp. 1. Retrieved Date: Mar. 7, 2011. |
Milner, “BizTalk Server 2004: A Messaging Engine Overview”, May 2005. |
Nasiri, et al. “Motion Processing: The Next Breakthrough Function in Handsets,” In Proceedings of InvenSense Inc., Jul. 2009, 10 pages. |
Naughton, “The Niagara Internet Query System”, IEEE Database Engineering Bulletin, Jun. 2001. |
Nichols, “Smoothing Sensor Data with a Low-Pass Filter,” Apr. 24, 2011. |
Oberoi, et al.; “Integrating DDS and COTS Complex-Event Processing Engines”; Proceedings of Object Management Group Workshop; Jul. 2007; 42 pages. |
Oracle CEP 11gR1—official support for CQL, retrieved at <<http://adcalves.wordpress.com/2009/07/01/oracle- cep-11gr1-official-support-for-cql/>>, Jul. 1, 2009. pp. 3. |
Pallickara; “A Grid Event Service”; Graduate School of Syracuse University; Jun. 2001; pp. 110. |
PCT International Search Report and Written Opinion for Application No. PCT/US2008/070359, Jan. 19, 2009. |
Preiss et al.; “On the Trade-off between Tim and Space in Optimistic Parallel Discrete-Event Simulation”; 1992; pp. 1-10. |
Raizman, et al.; “An Extensible Test Framework for the Microsoft Streamlnsight Query Processor”; Proceedings of the Third International Workshop on Testing Database Systems; Jun. 7, 2010; 6 pages. |
Ramskrishnan, “Efficient Bottom-Lip Evaluation of Logic Programs”, Computer Systems and Software Engineering, Kluwer Academic Publishers, 1992. |
Ravindran et al, “A Resource Management Model for Dynamic, Scalable, Dependable, Real-Time Systems”, retrieved at <<http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.40.5779&rep=rep1&type=ps>>, Apr. 11, 2006. pp. 6. |
Smith, M.; “Support for Speculative Execution in High-Performance Processors”; 1992; pp. 7-89. |
Snoeren et al, “Mesh-Based Content Routing using XML”, retrieved at <<http://xml.coverpages.org/SnoerenMESH- XML.pdf>>, 18in ACM Symposium on Operating System Principles; 2001; pp. 160-173. |
Sooksanan, “Validation Rules for Exporting Business Process Diagram to Business Process Execution Language”, In Proceedings of the 4th International Conference on eBusiness, Nov. 19-20, 2005. |
SQL Server 2008 R2—Streaminsight Technology, retrieved at <<http://www.microsoft.com/sqlserver/2008/en/us/R2- complex-event.aspx>>, pp. 2. |
Srinivasan, “Airborne Traffic Surveillance Systems: Video Surveillance of Highway Traffic”, In Proceedings of the 2nd ACM International Workshop on Video Surveillance and Sensor Networks, Oct. 15, 2004. |
Srivastava, et al.; “Flexible Time Management in Data Stream Systems”; Proceedings of the Twenty-Third ACM SIGMOD-SIGACT-SIGART Symposium on Principles of Database Systems; Jun. 14-16, 2004; Paris, France; pp. 263274. |
Srivastava, et al.; “Operator Placement for In-Network Stream Query Processing”; Technical Report; 2004; pp. 10. |
StreamBase Server, Published on or Before May 7, 2007, 3 pages, StreamBase Systems, Inc., USA. |
StreamBase Studio, Published on or Before May 7, 2007, 5 pages, StreamBase Systems, Inc. USA. |
StreamInsight SQL Server 2008 R2; retrieved from httD://www.rnicrosoft.com/salserver/2008/en/us/R2-comDlex-event.asDx; 2009; 2 pages. |
StreamSQL, Published on or Before Nov. 13, 2006, 2 pages, StreamBase Systems, Inc., USA. |
System Center Operations Manager 2007 End to End Service Management Without the Day to Day Drama, Microsoft, 2006. |
Tucker et al., “Exploiting Punctuation Semantics in Continuous Data Streams”, IEEE Transactions on Knowledge & Data Engineering, vol. 15, No. 3, May/Jun. 2003. |
Uncover Your World with AdMob Rich Media and the Google Search App, Published on: Aug. 26, 2011, Available at: http://googlemobileads.blogspot.com/2001/08/uncover-you-world-with-admob-rich.html. |
U.S. Appl. No. 11/779,574, Notice of Allowance mailed Oct. 28, 2009, 19 pages. |
U.S. Appl. No. 11/937,118, Final Office Action dated Dec. 3, 2010; 19 pages. |
U.S. Appl. No. 11/937,118, Final Office Action dated Oct. 14, 2011; 20 pages. |
U.S. Appl. No. 11/937,118, Non-Final Office Action dated Mar. 18, 2011; 22 pages. |
U.S. Appl. No. 11/937,118, Non-Final Office Action dated May 28, 2010; 21 pages. |
U.S. Appl. No. 11/937,118, Notice of Allowance dated Jun. 12, 2012; 13 pages. |
U.S. Appl. No. 11/937,118, Notice of Allowance dated Oct. 5, 2012; 24 pages. |
U.S. Appl. No. 11/937,011, Advisory Action mailed Sep. 10, 2010, 3 pages. |
U.S. Appl. No. 11/937,011, Amendment and Response filed Feb. 27, 2012, 11 pages. |
U.S. Appl. No. 11/937,011, Amendment and Response filed Mar. 29, 2010, 13 pages. |
U.S. Appl. No. 11/937,011, Amendment and Response filed Mar. 29, 2011, 11 pages. |
U.S. Appl. No. 11/937,011, Amendment and Response filed Aug. 23, 2011, 14 pages. |
U.S. Appl. No. 11/937,011, Amendment and Response filed Aug. 24, 2010, 13 pages. |
U.S. Appl. No. 11/937,011, Final Office Action mailed May 25, 2012, 23 pages. |
U.S. Appl. No. 11/937,011, Final Office Action mailed Jun. 23, 2011, 22 pages. |
U.S. Appl. No. 11/937,011, Final Office Action mailed Jun. 24, 2010, 22 pages. |
U.S. Appl. No. 11/937,011, Non-Final Office Action mailed Nov. 25, 2011, 21 pages. |
U.S. Appl. No. 11/937,011, Non-Final Office Action mailed Nov. 29, 2010, 19 pages. |
U.S. Appl. No. 11/937,011, Non-Final Office Action mailed Dec. 30, 2009, 16 pages. |
U.S. Appl. No. 11/937,118, Advisory Action mailed Feb. 15, 2011, 3 pages. |
U.S. Appl. No. 11/937,118, Amendment and Response filed Feb. 2, 2011, 13 pages. |
U.S. Appl. No. 11/937,118, Amendment and Response filed Feb. 13, 2012, 14 pages. |
U.S. Appl. No. 11/937,118, Amendment and Response filed Jul. 18, 2011, 16 pages. |
U.S. Appl. No. 11/937,118, Amendment and Response filed Sep. 28, 2010, 10 pages. |
U.S. Appl. No. 12/246,509, Non-Final Office Action dated Mar. 17, 2011; 22 pages. |
U.S. Appl. No. 12/246,509, Notice of Allowance dated Aug. 28, 2012; 24 pages. |
U.S. Appl. No. 12/246,509, Notice of Allowance dated Sep. 9, 2011; 23 pages. |
U.S. Appl. No. 12/246,509, Amendment and Response filed Jul. 7, 2011, 17 pages. |
U.S. Appl. No. 12/603,308, Amendment and Response filed Feb. 9, 2012, 18 pages. |
U.S. Appl. No. 12/603,308, Amendment and Response filed Aug. 15, 2012, 15 pages. |
U.S. Appl. No. 12/603,308, Amendment and Response filed Oct. 20, 2014, 11 pages. |
U.S. Appl. No. 12/603,308, Final Office Action mailed May 15, 2012, 18 pages. |
U.S. Appl. No. 12/603,308, Non-Final Office Action mailed Jul. 18, 2014, 22 pages. |
U.S. Appl. No. 12/603,308, Non-Final Office Action mailed Nov. 9, 2011, 16 pages. |
U.S. Appl. No. 12/603,308, Notice of Allowance mailed Dec. 3, 2014, 16 pages. |
U.S. Appl. No. 12/603,445, Amendment and Response filed Sep. 6, 2012, 9 pages. |
U.S. Appl. No. 12/603,445, Non-Final Office Action mailed Jun. 6, 2012, 8 pages. |
U.S. Appl. No. 12/603,445, Notice of Allowance mailed Sep. 20, 2012, 5 pages. |
U.S. Appl. No. 12/603,445, Notice of Allowance mailed Dec. 12, 2012, 6 pages. |
U.S. Appl. No. 12/694,062, Notice of Allowance mailed Jul. 27, 2012, 10 pages. |
U.S. Appl. No. 13/189,566 to Nano et al., filed Jul. 25, 2011; 41 pages. |
U.S. Appl. No. 13/189,566, Amendment and Response filed Mar. 13, 2014, 13 pages. |
U.S. Appl. No. 13/189,566, Amendment and Response filed May 1, 2013, 18 pages. |
U.S. Appl. No. 13/189,566, Amendment and Response filed Sep. 19, 2013, 22 pages. |
U.S. Appl. No. 13/189,566, Final Office Action mailed May 22, 2014, 7 pages. |
U.S. Appl. No. 13/189,566, Final Office Action mailed Jun. 20, 2013, 20 pages. |
U.S. Appl. No. 13/189,566, Non-Final Office Action mailed Feb. 1, 2013, 18 pages. |
U.S. Appl. No. 13/189,566, Non-Final Office Action mailed Dec. 13, 2013, 18 pages. |
U.S. Appl. No. 13/298,159, Amendment and Response filed Jan. 23, 2014, 9 pages. |
U.S. Appl. No. 13/298,159, Amendment and Response filed May 29, 2013, 10 pages. |
U.S. Appl. No. 13/298,159, Amendment and Response filed Oct. 18, 2013, 10 pages. |
U.S. Appl. No. 13/298,159, Final Office Action mailed Nov. 15, 2013, 10 pages. |
U.S. Appl. No. 13/298,159, Non-Final Office Action mailed Jan. 29, 2013, 15 pages. |
U.S. Appl. No. 13/298,159, Non-Final Office Action mailed Jul. 2, 2013, 11 pages. |
U.S. Appl. No. 13/298,159, Notice of Allowance mailed Feb. 14, 2014, 9 pages. |
U.S. Appl. No. 13/298,159, Notice of Allowance mailed Aug. 18, 2014, 11 pages. |
U.S. Appl. No. 13/409,443, Amendment and Response filed Dec. 4, 2014, 16 pages. |
U.S. Appl. No. 13/409,443, Final Office Action mailed Dec. 29, 2014, 29 pages. |
U.S. Appl. No. 13/409,443, Non-Final Office Action mailed Sep. 4, 2014, 23 pages. |
U.S. Appl. No. 13/409,495, Amendment and Response filed Apr. 21, 2014, 12 pages. |
U.S. Appl. No. 13/409,495, Amendment and Response filed Sep. 8, 2014, 13 pages. |
U.S. Appl. No. 13/409,495, Amendment and Response filed Dec. 23, 2014, 15 pages. |
U.S. Appl. No. 13/409,495, Final Office Action mailed Jun. 6, 2014, 10 pages. |
U.S. Appl. No. 13/409,495, Non-Final Office Action mailed Sep. 23, 2014, 9 pages. |
U.S. Appl. No. 13/409,495, Non-Final Office Action mailed Dec. 20, 2013, 7 pages. |
U.S. Appl. No. 13/409,495, Notice of Allowance mailed Jan. 20, 2015, 5 pages. |
U.S. Appl. No. 13/438,836 to Akchurin et al., filed Apr. 3, 2012; 36 pages. |
U.S. Appl. No. 13/438,836, Amendment and Response filed Jun. 12, 2014, 12 pages. |
U.S. Appl. No. 13/438,836, Amendment and Response filed Oct. 27, 2014, 13 pages. |
U.S. Appl. No. 13/438,836, Final Office Action mailed Jul. 25, 2014, 12 pages. |
U.S. Appl. No. 13/438,836, Non-Final Office Action mailed Mar. 12, 2014, 11 pages. |
U.S. Appl. No. 13/614,184, Amendment and Response filed Jan. 22, 2014, 1 page. |
U.S. Appl. No. 13/614,184, Non-Final Office Action mailed Nov. 21, 2013, 8 pages. |
U.S. Appl. No. 13/614,184, Notice of Allowance mailed Feb. 26, 2014, 9 pages. |
Using the Query Binder—SQL Server 2008 R2; Explicit Server Development Model: retrieved from httD://msdn. microsoft.com/en-us/librarv/ ee391319(SQl.105lasDx; 2009; 5 pages. |
Wei et al, “ReCEPtor: Sensing Complex Events in Data Streams for Service-Oriented Architectures”, retrieved at <<http://www.hpl.hp.com/techreports/2007/HPL-2007-176.pdf>>, Nov. 2, 2007. pp. 22. |
Witkowski, “Continuous Queries in Oracle”, Proceedings of the 33rd International Conference on Very Large Data Bases, Sep. 23-28, 2007. |
Wong, “The Emerging Trend: Smartphone Ad and In-App Ad,” Retrieved on: Dec. 13, 2011, Available at: http://www.slideshare.net/Madhouse/the-emerging-trend-smartphone-ad-and-in-app-ad. |
Wu et al, “High-Performance Complex Event Processing over Streams”, retrieved at <<http://www.cs.umass.edu/ ˜yanlei/publications/sase-sigmod2006.pdf>>, 2006. pp. 12. |
Yahoo! Living Ads: Where Motion and Emotion Meet, Retrieved on: Dec. 13, 2011, Available at: http://advertising.yahoo.com/blogs/events-blog/yahoo-living-ads-where-motion-emotion-meet-024820497.html. |
Yoneki, “Unified Semantics for Event Correlation Over Time and Space in Hybrid Network Environments”, 2005. |
Zimmer, “On the Semantics of Complex Events in Active Database Management Systems”, In Proceedings of the 15th International Conference on Data Engineering, Mar. 23-26, 1999. |
U.S. Appl. No. 13/298,159, Notice of Allowance mailed Mar. 11, 2015, 9 pages. |
U.S. Appl. No. 12/603,308, Notice of Allowance mailed Apr. 2, 2015, 16 pages. |
U.S. Appl. No. 12/603,308, Notice of Allowance mailed Jun. 2, 2015, 15 pages. |
U.S. Appl. No. 13/409,443, Amendment and Response filed Jun. 29, 2015, 18 pages. |
U.S. Appl. No. 13/438,836, Amendment and Response filed Aug. 10, 2015, 16 pages. |
U.S. Appl. No. 13/298,159, Notice of Allowance mailed Sep. 25, 2015, 10 pages. |
U.S. Appl. No. 13/409,443, Amendment and Response filed Feb. 25, 2016, 20 pgs. |
U.S. Appl. No. 13/409,443, Office Action mailed Nov. 25, 2015, 32 pgs. |
U.S. Appl. No. 13/438,836, Office Action mailed Feb. 11, 2016, 13 pgs. |
U.S. Appl. No. 13/409,443, Final Office Action mailed Mar. 31, 2016, 34 pages. |
Number | Date | Country | |
---|---|---|---|
20150134698 A1 | May 2015 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12603308 | Oct 2009 | US |
Child | 14602742 | US |