A data stream is a continuous and dynamic sequence of data (information) in the process of being transmitted between nodes across interconnected communication channels in the form of events, messages, and so on. A data stream is typically data that has not yet been stored in storage such as disk memory. A data stream can be massive and is potentially unbounded in size, time-varying, and in many cases, of high throughput.
A good example of massive, high throughput and dynamic data is Internet traffic data. As per the Internet Live Stats website, a few thousands of petabytes of Internet traffic data is generated every day. Some other examples of data streams are telecommunication data, satellite data, stock market/financial trade data.
Internet of Things/Machine to Machine (IoT/M2M) applications generate a large amount of data streams as well. With the increasing number of “things/machines” in IoT/M2M systems, the volume of the streaming data to and from the IoT/M2M devices is increasing exponentially.
A data stream ‘S’ can be denoted as a sequence of tuples, where each tuple is of the format <a1, a2, . . . , an> where ‘ai’ is the i-th attribute (or property) of the tuple.
In many applications, making sense of data while it is still in the process of streaming is of great importance so that necessary actions or measures can be taken in real time based on the information retrieved from the data stream.
With the exponential growth of streaming data, it is becoming increasingly important to derive meaningful insights from the data in real time. Data stream analytics (or stream analytics or streaming data analytics) is the process of extracting and deriving useful information from continuous and streaming data in real time. Stream analytics include, but is not limited to, detecting or identifying events, patterns or trends from the data streams, computing statistical aggregation over the data streams, and performing correlation and predictive analysis over the data streams. One example application where real time stream analytics finds great usage is the domain of network security where identifying and predicting network attacks in real time can avoid a node or a network of nodes from being compromised. Some other important example applications of data stream analytics are in stock price prediction, dynamic network performance monitoring and tuning, and real time fraud detection.
With the evolution of IoT/M2M and the growing dependence of the world on sensors and devices, there is also a growing need to analyze the rich data generated by these devices, almost as fast as they are generated. For most of this data, the real value lies in exploiting the information hidden in the data in real time and taking instantaneous actions based on the insights provided by the data. Hence, real time data analytics is starting to become an integral part of IoT/M2M systems.
Consider the example of an Intelligent Intersection Traffic System (IITS) which is a framework for efficient and safe management of traffic at the intersection. An efficient implementation of IITS can reduce the traffic collisions at an intersection drastically by taking real time decisions depending on the traffic conditions at the intersection, and generating necessary real time alerts.
Due to the dynamic nature of the data stream, i.e. the time-varying properties of the data stream, processing and analyzing the stream using traditional methods poses several challenges. Analytics is challenging over dynamic data for a number of reasons.
On-the-fly processing—The most fundamental concept of the data stream is that it is in a continuous streaming state, and not stored in any disk or database during the time of its observation. This makes multiple passes over a data stream, i.e. backtracking a data stream, almost impossible. Hence, all the necessary information required for streaming analytics need to be retrieved from the data in a single pass in an incremental fashion.
Massive size of data stream, small processing time and limited main memory constraint—Due to the large, possibly unbounded, size of the data stream, it is generally practically infeasible to temporarily store the entire data stream in disk for real time analysis. In order to perform real time analysis, the data stream needs to be processed and analyzed within a small processing time (depending on the application). Further, the additional requirement of having to analyze the data in real time using a very small processing time, makes it even more infeasible to store the data in the disk for analysis. The overhead of reading data from and/or writing data into the disk (also called disk Input/Output or disk I/O) is very high and adds significant delay to the processing time of data when compared to processing data in main memory (for instance, in Random Access Memory or RAM), also called in-memory processing of data. This additional overhead renders the storage of data unsuitable for real time analysis.
Further, due to the massive size of the data stream and limited size of the main memory, it is practically not feasible to store the entire data stream in main memory. The size of main memory today is generally in the order of Gigabytes, or GB, (109 bytes) while the size of the data stream can be in the order of Petabytes, or PB, (106 GB), or more. Hence, in many cases, only the important information from the data, required for the purpose of analytics, is extracted and stored in main memory in a concise fashion.
High throughput of data stream—In many applications, the rate of generation of data can be very high, on the order of Terabytes/second (TB/s) or more. Processing data of such high throughput in a small window of time adds additional challenge to stream analytics.
Due to the dynamic and transient nature of the data stream, it is not practically feasible to use a traditional Database Management System (DBMS) or other traditional batch processing system for stream processing/analysis. The main challenge of using a traditional DBMS for real time analytics arises from the fact that it is not practically feasible to locally store a data stream on a disk or backtrack over a data stream. Hence, the data stream needs to be processed and analyzed in a single pass, unlike in DBMS where stored data can be backtracked over as many times as possible. The single pass constraint over a data stream also implies queries pertaining to the data analysis needs to be long running, continuous and persistent so that the data stream is incrementally analyzed as soon as it is observed. This is contrary to the traditional DBMS where data is generally static and hence the queries can be ad hoc. Table 1 shows the key differences in requirements for processing data stream as compared to the disk resident data (stored in disk).
The DSPS 302 generates stream state depending on the queries running in the DSPS 302. These queries, as discussed above, are long standing and continuous, i.e. the queries need to be predefined so that DSPS generates the corresponding synopsis accordingly. Since the stream state is only the summary of an entire stream, the answers to the query may be approximate. Generally in the case of approximate queries, users or applications interested in deriving results from such queries are given a resource vs. accuracy tradeoff. The larger the size of the memory (and/or processing capacity) allocated for the analytical operation pertaining to the query, the higher the answer.
In order to understand the data stream processing system we consider one of the most fundamental and basic problems: counting. We consider the example of the Intelligent Traffic Intersection System (IITS) with a DSPS 302 installed on the centralized server, known as the traffic control hub. This traffic control hub, for instance, can be a gateway. The traffic control hub uses a DSPS 302 to track the number of cars crossing the intersection in each direction in real time. One of the potential benefits of counting the number of cars is to manage the traffic phase change in real time, i.e., changing the traffic signal from red to green and so on in real time, depending on the traffic flow status at the intersection. Traffic cameras are installed at the intersection, facing each side of the intersection, to capture the video of the surroundings. From a stream analytics context, the video generated by each traffic camera can be considered as a data stream, and each video frame as one data element.
In this case, let us assume that the data stream processing system gets the following query: count the number of cars crossing the intersection in each direction. The traffic control hub 302 uses video analytics techniques to identify cars in the video stream by extracting useful features from the video in real time. The cars are identified and a count of the cars crossing the intersection from each direction is maintained in real time. In this case, the stream state stored in memory maybe as simple as a single integer variable, say count, for each direction of traffic flow.
For every car that crosses the intersection from left to right, the DSPS 302 at the control hub identifies the car by analyzing the video stream and increases the ‘count’ variable stored in the memory of the DSPS 302 by 1. For instance, in
The above example is a very simple one. Here, the stream state is directly used to answer the query. But in many complex queries, the stream state generally does not contain the answer directly but is used to compute the answer as and when required. A lot of work is being done to design efficient algorithms to maintain small space stream state in memory for real time stream analytics even for different problems of varying complexities.
A distributed data stream processing system is when one or more data streams is processed and analyzed across multiple stream processing nodes to answer a single or multiple queries. Generally, a distributed stream processing system has a coordinator node that coordinates the data communication between the distributed nodes. In the above example (
On the other hand, suppose that some of the video analytics operations are also performed by the traffic cameras instead of the entire analytics being done at the control hub, as shown in
This kind of a system significantly reduces the communication cost by sending only the necessary information across the communication channel instead of the entire data stream. A distributed data stream processing system also helps in balancing the load of data stream analytics across the distributed system, since now the control hub gets to manage a data stream of significantly lower volume, hence improving the efficiency of the system.
Current Data Stream Processing Platforms
Work has been done on solving important problems, such as finding maximum/minimum, number of unique elements, frequent items, etc. from a large data stream in real time, using small memory cost. There are many stream processing platforms, open source as well as proprietary, which provide an abstraction to the business or the users to perform data stream analytics, without getting into the intricacies of the architectural details of data stream processing. Such intricacies may include message queueing, scalability, fault tolerance, parallelism, etc.
Examples of data stream processing platforms include Apache Storm, IBM Infosphere Stream and Apache Spark Streaming. These stream processing platforms provide means to capture data in a streaming fashion and provide a platform for fault tolerant and reliable stream processing. These platforms may not directly map to the above data stream processing system (shown in
Apache Storm is an open source distributed stream processing platform. It is a reliable, fault tolerant and scalable system. As shown in
Apache Storm uses three abstractions:
IBM Infosphere Streams is another popular distributed stream processing platform. It is a fault-tolerant, reliable and scalable system. All the nodes in the IBM Infosphere Streams distributed cluster may equally participate in executing a streams application. Infosphere Streams has the following main concepts:
The concept of writing a data stream application in IBM Infosphere Stream is very similar to Apache Storm. We use the same word count example as used for Apache storm below in
Apache Spark Streaming is another distributed stream processing platform, which has become very popular recently. It is also a fault-tolerant, reliable and scalable system. However, the approach used by Apache Spark Streaming is different as compared to that of the above mentioned platforms. Apache Spark Streaming 1002 uses micro batch processing in order to process data streams, i.e. dividing the data stream into tiny batches and using the batch processing system, Apache Spark Engine 1004, to process the tiny batches of data, as shown in
Apache Spark Streaming provides a high level abstraction called discretized stream (D-Stream). D-streams are data streams chopped into batches of small time intervals, called Resilient Distributed Dataset (RDD) and run as small deterministic batch jobs.
The importance of data stream analytics is growing significantly in the IoT/M2M domain. With more and more number of devices connecting to the internet and the growing number of deployments of interconnected IoT/M2M devices, the dependence of these devices and their users on the data is growing too. It is becoming increasingly important to derive some quick insights from these various data streams almost as soon as they are generated. Some of the importance of real time analytics in IoT/M2M are as follows:
The above points are also applicable for most of the other domains requiring stream analytics, but these requirements can be strongly related with an IoT/M2M system. There are many vendors/companies that provide robust IoT platforms supporting data stream analytics. The following are the main benefits provided by most of these IoT infrastructures, either via the IoT platform or the integrated stream processing system:
These features form an integral and important part of adding data stream analytics as a robust service to an IoT/M2M architecture. Below we discuss about a few popular IoT architectures with data stream analytics capabilities. While Microsoft Azure Stream Analytics (
The IoT platform uses Microsoft Azure Streaming service for data stream processing. Microsoft Azure Streaming is a Microsoft proprietary stream processing cloud service used for real time analytics. This system uses complex data stream analytics modules such as a machine learning module. The IoT devices can be registered to this system using the device registration capabilities. As an alternative, this platform also gives the flexibility of adding Apache Storm as a stream processing system in the infrastructure.
This section briefly introduces the background information related to the service layer 1602. From a protocol stack perspective, a service layer 1602 is typically situated above the application protocol layer 1606 and provides value added services (e.g. device management, data management, etc.) to applications 1604 (see
An example deployment of an M2M/IoT service layer 1602, instantiated within a network, is shown in
An M2M service layer 1602 can provide applications and devices access to a collection of M2M-oriented service capabilities. A few examples of such capabilities include security, charging, data management, device management, discovery, provisioning, and connectivity management. These capabilities are made available to applications via Application Programming Interfaces (APIs) which make use of message primitives defined by the M2M service layer 1602.
The goal of oneM2M is to develop technical specifications which address the need for a common service layer that can be readily embedded within hardware apparatus and software modules in order to support a wide variety of devices in the field. The oneM2M common service layer supports a set of Common Service Functions (CSFs) (i.e. service capabilities), as shown in
Initially, oneM2M service layer was developed to be compliant to the Resource-Oriented Architecture (ROA) (oneM2M-TS-0001 oneM2M Functional Architecture-V-2.4.0) design principles, in the sense that different resources are defined within the oneM2M ROA RESTful architecture (as shown in
Recently, oneM2M has started developing an M2M Service Component Architecture (as shown in
Data Stream analytics (or real time analytics) involves processing and analyzing the streaming data in real time. It is the process of extracting and deriving useful information from continuous and streaming data in real time. A few types of real time analytics operations that can be performed on a data stream include pattern/anomaly detection, statistical aggregation, predictive analysis, machine learning. Data stream analytics plays a key role in IoT/M2M system due to the need to extract insightful information from the IoT/M2M device generated data in real time.
Since the IoT service layer acts as a middleware between the M2M devices and the enterprise infrastructure servers, responsible for data management and other services in all the intermediate nodes, the stream analytics capabilities can be integrated at the IoT/M2M service layer. The real time analysis can be performed on the data stream close to the source of generation of data, before the data is stored by the service layers at the data collection points (which is different from the traditional data analytics that are conducted normally after data get stored).
Existing IoT/M2M platforms depend on cloud services at different levels (such as the cloud services connected to the edge devices or the gateways) of the IoT platforms for data stream analytics. No modular design for physical service layer nodes is described in the literature for data stream analytics. A modular and distributed architecture for data stream processing and analysis is described to incorporate data stream analytics capabilities, called Data Stream Analytics Service (DSAS) in the IoT/M2M service layer. Each service layer node hosting DSAS can be been split into two independent modules, Stream Forwarder and Stream Analytics Engine. Stream Forwarder is a light weight processing modules that can be responsible for data preprocessing and routing, whereas Stream Analytics Engine can be responsible for performing actual analytics on the data stream. Separating the two functionalities enables the service layer nodes to efficiently distribute stream analytics tasks across multiple nodes.
Current service layers, such as oneM2M, lack a standardized service to provide data stream analytics capabilities. Data analytics capabilities are enabled only for the data that has already been stored. A detailed end to end solution of a standard service is described to enable distributed stream analytics capabilities at the IoT/M2M service layer. Having a standard solution for integrating data stream analytics in the service layer will enable data stream real time analysis across multi-domain applications and across different vendors.
Embodiments include:
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. Furthermore, the claimed subject matter is not limited to limitations that solve any or all disadvantages noted in any part of this disclosure.
A more detailed understanding may be had from the following description, given by way of example in conjunction with accompanying drawings wherein:
In this section, we review the Intelligent Intersection Traffic System (IITS) case with more details in order to justify why service layer needs stream analytics capability and how it can help in this IITS use case or other realistic applications.
The IITS can be implemented at different levels. At the simplest level, the traffic lights at the intersection are made smart to automatically change phases based on the traffic conditions, and the alert systems are made intelligent to generate real time alerts to warn cars and pedestrians of any possible collisions based on the traffic situation. At the most complex level, the intersection does not have a traffic or stop signal and the vehicles are all expected to be autonomous. A central coordinator at the intersection, say we call it the Intersection Management Gateway, directly communicates with all the vehicles within the communication range from the intersection, guiding them to change lanes, reduce/increase speed or take other necessary actions to cross the intersection efficiently, avoiding collision with other vehicles, bicycles or pedestrians.
In this system, the end devices, such as the GPS probes and the sensors installed in the vehicles, the traffic cameras at the intersection and other road sensors, transmit continuous stream of traffic data (for instance, GPS data stream by GPS probes, video stream by traffic cameras, etc) to the Intersection Management Gateway, that in turn analyzes the traffic data received from the devices to make real time decisions for efficient traffic management at the intersection. The Intersection Management Gateway generally also forwards this traffic data to the infrastructure servers and cloud servers for further analysis for better future predictions and correlational analysis, and possible permanent storage. In this use case shown in
The Intersection Management Gateway is able to perform real time decision making due to the stream analytics services hosted at the gateway. The streaming analytics service at the gateway equips the gateway to process and analyze the traffic data. The stream analytics is mainly performed based on the queries that it receives from devices, users or applications.
Just for illustration, below are two simple example queries made on this system:
The service layer of an IoT/M2M system plays a key role as a middleware, acting as a bridge between the end devices, infrastructure servers and providing necessary services and infrastructure to improve operational efficiencies. The IoT/M2M service layer is responsible for managing data between the end devices and the enterprise infrastructure, along with each intermediate node, via data management and other services, providing needed reliability and security during the entire lifecycle of the data.
In order to implement the IITS, and similarly other smart IoT/M2M solutions, such that the intersection is efficiently managed in real time, the service layer is given stream analytics capabilities because the data is managed by the service layer during the entire lifecycle of the data. For example, as shown in
As stressed before, real time analytics has received a lot of focus by most of the enterprises and industries, in the context of an IoT/M2M system. Hence, it is very important to integrate data stream analytics capabilities in an IoT/M2M system, which has been discussed in the previous use case. Now, since the IoT service layer provides various services for the entire lifecycle of the data within an end to end IoT system, it is very useful to add the data stream analytics capabilities to the service layer of an IoT/M2M system.
By adding data stream analytics as another service at the IoT/M2M service layer, necessary services can be availed to derive useful insights from the data in real time, and it can be ensured that real time analytics is performed on the data stream before the data is stored at any of the intermediate service layer nodes or permanent storage nodes at the infrastructure servers. There are many studies, such as Fog Computing and Cloudlet, that have proposed techniques to enable real time analytics as close to the data source (edge) as possible. However, the following issues have not been fully addressed by the existing solutions and are the major focus of this work.
In the current existing IoT platforms, most of the techniques to enable efficient real time analytics in IoT are implemented on cloud servers or virtual machines. The cloud system is built in a hierarchical and federated fashion to optimize data stream analytics near the edge. However, there is almost no focus on building a modular system for incorporating stream analytics capabilities on the physical service layer nodes of IoT/M2M system near the edges, such as on gateways or routers.
In fact, within IoT/M2M service layer scenario, it is very important to build a modular streaming analytics system at the service layer nodes, with defined independent functionalities for each separate module so that the streaming analytics architecture can be incorporated into service layer with high flexibility and robustness. Back to the example shown In
Current IoT/M2M service layer standardization efforts do not support data stream analytics—As discussed before, several proprietary as well as open source architectures have been proposed to integrate stream analytics in IoT. However, existing deployments are mostly proprietary and specific to a certain industry. Currently, there is no standard streaming analytics service in IoT/M2M service layer that can enable streaming analytics capabilities across multi domain applications. Current IoT/M2M service layer standards, such as, oneM2M, provide mechanisms to store the data retrieved from the sensors or other M2M devices to the M2M servers for later retrieval, reasoning and analysis. A service can extract useful information from the data in real time before it is stored anywhere.
In
In general, DSAS 2202 mainly has the following four main components, DSAS Stream Forwarder (DSAS-SF) 2212, DSAS Stream Analytics Engine (DSAS-SAE) 2210, DSAS Manager 2206, DSAS API 2208.
DSAS Stream Forwarder (DSAS-SF) 2212 is a light weight stream processing module that
DSAS Stream Analytics Engine (DSAS-SAE) 2210 is the module that performs main stream analytics operation such as statistical aggregation, pattern/event detection and predictive analysis. This module receives data stream for analysis from a DSAS-SF 2212 or another DSAS-SAE 2210.
DSAS Manager 2206 is the main management module of DSAS 2202, which
DSAS API 2208 contains the implementation of the Application Programming Interfaces (APIs) for DSAS 2202. The DSAS API 2208 can be used for the following purposes:
It is understood that the functionality illustrated in
DSAS Stream Forwarder (DSAS-SF) 2212: As discussed above, DSAS-SF 2212 is a light weight stream processing component of DSAS 2202. Preprocessing may be done for cleaning data before storage and analysis, discarding unrequired data before being sent to the storage nodes and reducing the dimension of the data stream, per the requirement of DSAS-SAE 2210, before being forwarded to the DSAS-SAE 2210. It may also act as a simple router. The following modules run in DSAS-SF 2212:
DSAS Stream Analytics Engine (DSAS-SAE) 2210 can include:
DSAS Manager 2206: As discussed above, the primary functions of DSAS Manager 2206 includes resource management and allocation within DSAS hosting node, managing fault tolerance in case of process failures, monitoring management services within DSAS 2202 and in the case of a distributed system, communicating with other DSAS hosting nodes via their respective DSAS Managers 2206.
DSAS Application Programming Interface (API 2208): DSAS API 2208 is an interface built on both the client end and DSAS hosting node end, comprising of a set of routines and protocols that decide how DSAS client 2216 components will interact with DSAS components hosted on the same or different nodes. DSAS API 2208 is used to establish connection between the DSAS hosting SL node and the clients (e.g. IoT devices, applications, users) who are interested in deriving useful insights from the data using DSAS 2202. This connection is qualified by ACP functionality (that can either be pre-defined at the service layer or dynamically configured) to validate client 2216 access into DSAS hosting node.
The working details of
To facilitate the data stream analytics service, some metadata is stored in the form of tables or repositories in the DSAS hosting SL node, such as the Stream ID store (maintains list of unique streams analyzed by DSAS 2202), Query store 3218 (maintains list of queries being processed by DSAS 2202) and Job table 2320 (maintains list of jobs being handled by DSAS 2202 to process the queries). The resources used by these tables are managed by the DSAS manager 2206 and are shared across all the components of DSAS 2202.
It is understood that the functionality illustrated in
A basic scenario has only one DSAS 2202 in place. As described below, in a distributed scenario, multiple DSAS can be deployed in the system.
It is understood that the entities performing the steps illustrated in
Procedure A: Stream Ingestion
In general, the Stream Ingestion will have the following three major steps: 1) Data Source Registration, 2) Data Stream Identification and 3) Data Stream Parsing, which will be descried in details as follows.
Data Source Registration
This is the initial set up process for a data source in the IoT/M2M system to register to the service layer node hosting the DSAS 2202. The procedural detail of Data Source Registration has been shown in
In step 1 of
In step 2 of
In step 3 of
It is understood that the entities performing the steps illustrated in
Data Stream Identification
This is the process of identifying each unique stream that is received by DSAS 2202 and assign a unique ID, called Unique Identifier, if not already assigned, to each of the unique streams. The data stream identification is done by the Stream Identification Manager/Parser (SIM/P) 2304.
In particular, it can be done in one of two ways in DSAS 2202: Out-of-Band Stream Provisioning and In-Band Stream Provisioning, which will be described below.
Out-of-Band Stream Provisioning
Each stream can be uniquely identified in DSAS-SF 2212 by a Stream Identification Manager, using the information provided by the client 2216 based on the IoT device guidelines and the pre-provisioning documents. The DSAS 2202 do not depend on the data sources, i.e. the IoT/M2M devices, to obtain stream information for identification. DSAS-SF 2212 does not receive any information from the data source. In this case, the data sources may be completely oblivious about the existence of data stream analytics system in the service layer. More information about Out-of-Band Stream Provisioning can be found in the procedural description shown in
In step 1 of
In step 2 of
In step 3 of
In step 4 of
In step 5 of
In step 6 of
In step 7 of
In step 8 of
In step 9 of
In step 10 of
In step 11 of
It is understood that the entities performing the steps illustrated in
In-Band Stream Provisioning
In the case of In-band stream provisioning, DSAS-SF 2212 uses the information/metadata directly sent by the data sources to uniquely identify each stream. This information is sent out once a connection is established between the data sources and DSAS-SF 2212, even before the devices start sending out the actual data to the DSAS 2202. In this set up, it is assumed that DSAS 2202 makes itself discoverable on being deployed within the service layer so that the data sources are able to establish a connection with the DSAS 2202. Hence, in this case, the data sources are generally aware of the existence of data stream analytics tool in the system and explicitly send them information about their respective streams. The data stream information is received by the Stream Identification Manager which makes an entry in the Stream ID Store corresponding to the information received for each unique stream. More information about this technique can be found in
For step 0 of
In step 1 of
In step 2 of
In step 3 of
In step 4 of
In step 5 of
It is understood that the entities performing the steps illustrated in
Data Stream Parsing
It is the process of breaking down each stream tuple (or message) of the data stream into individual attributes, so that the attributes are identifiable by the stream processing system. It is also used to retrieve the Stream ID of the concerned data stream for authorization check and used by later analytics operation.
For instance, consider the following stream tuple <37, 145, 9:41:00.01, 30, A1, VH>.
In step 1 of
In step 2 of
In step 3 of
In step 4 of
In step 5 of
It is understood that the entities performing the steps illustrated in
Procedure B: Query Deployment
Query Deployment procedure in DSAS 2202 comprises of the following activities:
Adding a new query to DSAS 2202—a DSAS client 2216 adds a new query to DSAS 2202 via DSAS API module 2208 which contains API implementation for the clients to interact with the resources pertaining to the query, such as the Query Store 2318 and the Query operators 2312. Upon adding a new query to DSAS 2202, all the information sent by the client 2216 pertaining to the query are added to the Query Store 2318 (shown in Table 4) and the implementation of the query is saved as a Query Operator. All the properties specified in the Query Store 2318 (described in Table 4) are specified by the client 2216. For instance, adding a query “Calculate the time to collision between any two vehicles within the communication range of an intersection” to DSAS 2202 of the service layer of the Intersection Management System in the IITS use case, creates a new entry in the Query Store 2318 as the example shown in Table 5. When a query is added to DSAS 2202, the default value of the Switch property of the corresponding query in the Query Store 2318 can be set as “Enable” or “Disable” depending on the requirement of the application.
Modifying an existing query in DSAS 2202—a DSAS client 2216 modifies an existing query. Modifying an existing query implies updating the corresponding query entry in the Query Store 2318 and/or updating the corresponding Query Operator. E.g.: Modify the above query to “Calculate the time to collision between any two vehicles, and generate an alert if the time to collision goes below 10 s”. The modification of an existing query also includes enabling or disabling a query in the system by updating the value of the Switch in the Query Store 2318 for the concerned query.
Deleting an existing query from DSAS 2202—a DSAS client 2216 may delete a query from DSAS 2202 via DSAS API, which leads to deleting corresponding entry from the Query Store 2318 and deleting the corresponding Query Operator.
In step 1 of
In step 2 of
In step 3 of
In step 4 of
In step 5 of
In step 6 of
Based on the kind of query deployment the client is interested in performing, the client may send out corresponding query information, which may have the following different cases:
In step 7 of
In step 8 of
In step 9 of
In step 10 of
In step 11 of
Besides the above procedures, some more discussions are presented for Intelligent Query Deployment: As described above, a query can be deployed in DSAS 2202 by an external client, who can create, modify, delete or enable/disable a query in DSAS 2202. However, it is possible to introduce a smart Query manager 2316 in DSAS 2202. A query manager 2316 can be made intelligent by implementing machine learning algorithms in the system, and using the machine learning techniques to train the query manager 2316 to make smart decisions regarding the query.
A smart query manager 2316 can be used to check for queries, which have not been used for a long time and remove them from the system to free up resources. If required by the applications, it can also be used to make sure that query modifications in DSAS 2202 are not done frequently. Very frequent query modifications may affect the quality of the results generated and may not be desirable for certain applications. If the DSAS 2202 also has a batch analytics services incorporated in it, then the smart query manager 2316 may also be used identify the appropriate queries which are frequently used in batch analytics, and propose that these be deployed in the streaming analytics scenario, or deploy these queries automatically, if the translation of query from batch analytics to stream analytics is feasible.
Batch Analytics is a way of processing data, where large volumes of data is collected over a period of time and then, processed and analyzed in a batch. Hence, for batch analytics, data is generally stored in a data repository, such as database or a data warehouse.
It is understood that the entities performing the steps illustrated in
Procedure C: Data Stream Analytics
As mentioned earlier, Data Stream Analytics are performed in order to process all the queries in the Query Store 2318 which have been set to ‘Enabled’.
In step 1 of
In step 2 of
In step 3 of
It is understood that the entities performing the steps illustrated in
Procedure D: Output Triggering
We know that the query in a data stream processing system is long standing and continuously running. Though the memory state for a query is maintained continuously, the state may not be used continuously to answer a query. An answer to the query may be generated continuously or may be required occasionally only when an event is triggered. Output triggering is the step that answers a query based on the requirement of the application. Let us review the Query 1 and Query 2 as discussed in the IITS use case:
In the above example, output for the Query 1 is triggered continuously because the intersection management hub needs to continuously keep track of the time before collision between any two vehicles close to the intersection. However, output for Query 2 is triggered only when a pedestrian is detected at the intersection, about to cross the intersection. In this case, the event that triggers an output for Query 2 is the detection of a pedestrian at an intersection.
However a query output may also be triggered manually by a client 3202. For instance, consider a vehicle driver using a smart app to find out the condition of the traffic flow in an intersection. In this case, the smart app may be considered as a client 3202. The driver handling the app may explicitly request for the traffic condition at the intersection. In this example, though the traffic condition is continuously being analyzed in the backend, but it is shown on the app only on being explicitly requested by the driver/app.
If a client 3202 connects to the DSAS 2202 to trigger a result from the query, its permission is validated over ACP, and then given information about each query by DSAS via DSAS API 2208. The detailed description of Output Triggering procedure is given below.
If a client 3202 connects to the DSAS 2202 to trigger a query, its permission is validated over ACP, and then given information about each query by DSAS 2202 via DSAS API 2208. The detailed description of Query Triggering procedure is given below.
In step 1 of
In step 2 of
In step 3 of
In step 4 of
In step 5 of
In step 6 of
Table 10 shows the parameters that the Client 3202 sends to trigger output for specific queries. The client 3202 can submit request to trigger output for one or more queries
In step 7 of
In step 8 of
In step 9 of
In step 10 of
In step 11 of
In step 12 of
It is understood that the entities performing the steps illustrated in
Procedure E: Data Storage
In most of the cases, the data is stored at different data collection points of the service layer for management reasons. In many applications, these data are further forwarded to cloud or infrastructure nodes for warehousing the data for the purpose of later and/or deeper analysis.
Hence, once the SIM/P 2304 module of DSAS has parsed the data stream, the data is passed via the preprocessor 2306 and the Storage filter 2308 for storage, if applicable.
The Storage filter 2308 is used to reduce the dimension of the data stream by pruning out the unnecessary attributes from each tuple, such as attributes which are generated by IoT devices for their own specific usage and may be of no importance in the later part of transmissions. This filter also may use compression techniques, based on the storage policy, to optimize the data for storage. Storage filter 2308 provides the following two benefits to the IoT service layer:
Storage filter 2308 that reduces the data stream before sending it out for data storage is configured by the client, based on the storage policy of the storage nodes or the device guidelines. These policies define rules that specify which attributes in a data stream and/or the extracted from the pre-processor are stored. For instance, some attributes of a data stream may not be required later, and are present only for the reference of the device generating the data. Using the device guidelines, these attributes can be pruned out from the data stream using the pre-processor.
Data Stream Analytics Service as a Distributed Service
In this section, we consider the distributed scenario, in which multiple DSAS can be deployed in the system. In particular, a distributed DSAS service is needed for the below reasons:
A distributed set up of DSAS hosting SL nodes will provide the above mentioned advantages to the service layer. Data stream can be communicated to different nodes over light weight message passing models such as MQTT, Extensible Messaging and Presence Protocol (XMPP) etc. These models also ensure reliability on message delivery. All or few of these SL nodes may also be connected to the light weight cloud services, so that the system is robust and may move the analytics operations to cloud as required. A distributed set up of the SL nodes, along with distributed cloud services add flexibility and robustness to DSAS 2202 in the context of data stream analytics.
We have identified the following 3 generic layouts of multiple distributed DSAS nodes in the IoT/M2M service layer.
The DSAS node with DSAS-SAE 2210 component maybe hierarchically connected to DSAS-SAE 2210 components of other DSAS nodes or to the cloud nodes with stream analytics capabilities, to distribute and parallelize the analytics operation across multiple nodes for faster and efficient data analysis.
In the
However, the communication between DSAS-SF 2212 and DSAS-SAE 2210 follows the same procedural details as specified above for single DSAS hosting node, with the difference that now the components would be hosted in different nodes and communicate with each other via DSAS Manager 2206.
A distributed system needs to operate in coordination with each other. This coordination is required for communication across distributed system, load balancing of services and streaming analytics operation across distributed system, parallelization of streaming analytics operation of streaming analytics system, scalability, such that the system can be scaled up or down based on the load on the system, and fault recovery, such that in case of failure of services or operations in a node other nodes can resume the failed services or operations. There are two ways to manage coordination between distributed nodes: Centralized Monitoring and Peer-to-Peer monitoring:
Distributed System with Centralized Monitoring: In the case of centralized monitoring, a single centralized node act as a coordinator for the distributed system. It is responsible for load balancing, fault recovery and communication across distributed system. This setup requires an additional management service in the coordinator node to perform the coordination across distributed node.
In a distributed system with centralized monitoring, the client connects to the coordinator to deploy query or request for analytical results and the coordinator distributes job across the system. One of the DSAS hosting SL node within the IoT/M2M service layer located on the network or in cloud may act as the coordinator. This node will have an additional component within DSAS 2202, called Coordinator module. The client communicates with DSAS via this Coordinator module using the DSAS API 2208. This coordinator is used to coordinate communication amongst all the distributed DSAS hosting SL nodes through DSAS Manager 2206 of each node. In this setup, the processes and services running within individual DSAS hosting node are still managed by the DSAS Manager 2206, but in case the DSAS Manager 2206 is unable to recover the failed processes or jobs, it communicates with the coordinator node, so that if possible, the failed job can be resumed in other node(s) by the Coordinator.
The Host ID field in the Query Store 2318 shown in Table 4 should be the host address of the coordinator node. DSAS-SF 2212 sends out the filtered data stream via the DSAS Manager 2206 to the DSAS-SAE 2210 component of the coordinator node which then deploys it across the distributed system via Coordinator 3402 component.
It is understood that the functionality illustrated in
A possible architecture for DSAS with the Coordinator 3402 component has been shown in
Distributed System with Peer-to-Peer Monitoring: In the case of peer to peer monitoring, each node in the system act as a coordinator 3402 for the distributed system. The client may connect to any of the node to deploy query or request for analytical results and that node is fully responsible for load balancing, fault recovery and communication across distributed system for the query that it receives. In this setup, the DSAS Manager 2206 within the node acts as a coordinator 3402 across the distributed system for the query it received. The Host ID field in the Query Store 2318 shown in Table 4 should be the host address of the DSAS hosting node where the query was deployed. DSAS-SF 2212 sends out the filtered data stream via the DSAS Manager 2206 to the DSAS-SAE 2210 component of the node specified in the host address, which is then responsible for distributing the analytics operation related to the query to other DSAS hosting nodes in the system via DSAS Manager 2206.
In this setup, the processes and services running within individual DSAS hosting node are still managed by the DSAS Manager 2206, but in case the DSAS Manager 2206 is unable to recover the failed processes or jobs, it communicates with the DSAS Manager 2206 of other DSAS hosting nodes, so that if possible, the failed job can be resumed in other node(s) by the respective DSAS Manager 2206.
Ease of Enabling/Disabling DSAS in Service Layer
Similar to any other service, DSAS 2202 will require some amount of resources in order to provide data stream analytics capabilities. This overhead might not always be desirable within a service layer. Hence, based on the current requirement of a service layer to process and analyze, it should be flexible to enable or disable DSAS 2202 within a service layer.
This section presents the embodiments of the DSAS functionalities within the oneM2M architecture. First, the DSAS 2202 can be integrated as a CSF in the CSE. Then DSAS 2202 related resources and attributes are presented to show the integration with the oneM2M resource tree. Finally, oneM2M procedures are provided to realize the various DSAS procedures.
It is understood that the functionality illustrated in
DSAS as a New CSF
Common Service Functions (CSF) is defined as informative architectural construct which conceptually groups together a number of sub-functions. Each oneM2M Common Service Entity (CSE) is an instantiation of a set of CSFs of oneM2M environment. A realization of the Data Stream Analytics Service (DSAS) can be as a new CSF to the oneM2M CSE (DSAS CSF 3702) as shown in
Architectural Layout of DSAS in oneM2M Service Layer
Data Stream Analytics Service (DSAS) 2202 can be integrated into the oneM2M service layer architecture as shown in
In this architecture, DSAS 2202 is used to analyze a data stream before even the data is stored for the first time as a <contentInstance> resource, for faster and real time analysis of data. Hence, DSAS 2202 is hosted in a CSE that lies in between an AE and the data storage CSE. The DSAS 2202 may be hosted within the data storage CSE as well. In that case, data stream analytics is performed before data is stored in the storage node. A DSAS client 2216 interested in deriving useful insights from the data stream may be an AE or a CSE from the same network or a different network.
It is understood that the functionality illustrated in
oneM2M Resource for DSAS
A new oneM2M resource type for DSAS 2202, called <DSAS>, is described within the oneM2M system as shown in
The attribute switch shall be used to enable or disable DSAS 2202 within the CSE and can assume two values—0 or 1. The value 0 disables DSAS 2202 in the oneM2M service layer as shown in
The resource <streamDescriptor> shall describe each unique data stream received by the DSAS 2202. It contains the metadata and additional information of the stream it is describing. It is the mapping of the Stream ID Store 2321 shown in Table 3 to the oneM2M system. The resource <queryDescriptor> shall be used to store all the information pertaining to the queries built into the DSAS 2202, one resource per query. It is the mapping of the Query Store 2318 shown in Table 4 to the oneM2M system.
The <streamDescriptor> Resource
The resource tree for the <streamDescriptor> resource is shown in
The list of attributes of the <streamDescriptor> resource are described in Table 13.
The child resource of the <streamDescriptor> resource is described in Table 14.
The <queryDescriptor> Resource
The resource tree for the <queryDescriptor> resource is shown in
The list of attributes of the <queryDescriptor> resource are described in Table 15.
The child resource of the <queryDescriptor> resource is described in Table 16.
The <streamInfo> Resource
The resource tree of the <streamInfo> resource is shown in
The attributes of the <streamInfo> resource are described in Table 17.
1.1.1.1 The <output> Resource
The resource tree of the <streamInfo> resource is shown in
The attributes of the <output> resource are described in Table 18.
The child resource of the <output> resource is described in Table 19.
oneM2M Procedures for Data Stream Identification and Provisioning
In step 0 of
In step 1 of
In step 2 of
In step 3 of
In step 4 of
It is understood that the entities performing the steps illustrated in
In step 0 of
In step 1 of
In step 2 of
In step 3 of
In step 4 of
In step 5 of
In step 6 of
In step 7 of
It is understood that the entities performing the steps illustrated in
oneM2M Procedures for Query Deployment, Data Stream Analytics and Output Triggering
In step 0 of
In step 1 of
In step 2 of
In step 3 of
In step 4 of
In step 5 of
In step 6 of
In step 7 of
In step 8 of
In step 9 of
In step 10 of
In step 11 of
In step 12 of
In step 13 of
It is understood that the entities performing the steps illustrated in
Interfaces, such as Graphical User Interfaces (GUIs), can be used to assist user to control and/or configure functionalities related to data stream analytics in the service layer.
The GUI to deploy a query can be interactive, where based on the kind of query deployment the client is interested in performing (assuming the client has necessary authorization), the GUI gives different options to the client. Exemplary interfaces provided to the client based on the kind of deployment they are interested in performing are shown in
It is to be understood that interfaces such as that of
Example M2M/IoT/WoT Communication System
The various techniques described herein may be implemented in connection with hardware, firmware, software or, where appropriate, combinations thereof. Such hardware, firmware, and software may reside in apparatuses located at various nodes of a communication network. The apparatuses may operate singly or in combination with each other to effect the methods described herein. As used herein, the terms “apparatus,” “network apparatus,” “node,” “device,” and “network node” may be used interchangeably.
The service layer may be a functional layer within a network service architecture. Service layers are typically situated above the application protocol layer such as HTTP, CoAP or MQTT and provide value added services to client applications. The service layer also provides an interface to core networks at a lower resource layer, such as for example, a control layer and transport/access layer. The service layer supports multiple categories of (service) capabilities or functionalities including a service definition, service runtime enablement, policy management, access control, and service clustering. Recently, several industry standards bodies, e.g., oneM2M, have been developing M2M service layers to address the challenges associated with the integration of M2M types of devices and applications into deployments such as the Internet/Web, cellular, enterprise, and home networks. A M2M service layer can provide applications and/or various devices with access to a collection of or a set of the above mentioned capabilities or functionalities, supported by the service layer, which can be referred to as a CSE or SCL. A few examples include but are not limited to security, charging, data management, device management, discovery, provisioning, and connectivity management which can be commonly used by various applications. These capabilities or functionalities are made available to such various applications via APIs which make use of message formats, resource structures and resource representations defined by the M2M service layer. The CSE or SCL is a functional entity that may be implemented by hardware and/or software and that provides (service) capabilities or functionalities exposed to various applications and/or devices (i.e., functional interfaces between such functional entities) in order for them to use such capabilities or functionalities.
As shown in
As shown in
Exemplary M2M terminal devices 18 include, but are not limited to, tablets, smart phones, medical devices, temperature and weather monitors, connected cars, smart meters, game consoles, personal digital assistants, health and fitness monitors, lights, thermostats, appliances, garage doors and other actuator-based devices, security devices, and smart outlets.
Referring to
Similar to the illustrated M2M service layer 22, there is the M2M service layer 22′ in the Infrastructure Domain. M2M service layer 22′ provides services for the M2M application 20′ and the underlying communication network 12 in the infrastructure domain. M2M service layer 22′ also provides services for the M2M gateways 14 and M2M terminal devices 18 in the field domain. It will be understood that the M2M service layer 22′ may communicate with any number of M2M applications, M2M gateways and M2M devices. The M2M service layer 22′ may interact with a service layer by a different service provider. The M2M service layer 22′ by one or more nodes of the network, which may comprises servers, computers, devices, virtual machines (e.g., cloud computing/storage farms, etc.) or the like.
Referring also to
The methods of the present application may be implemented as part of a service layer 22 and 22′. The service layer 22 and 22′ is a software middleware layer that supports value-added service capabilities through a set of Application Programming Interfaces (APIs) and underlying networking interfaces. Both ETSI M2M and oneM2M use a service layer that may contain the connection methods of the present application. ETSI M2M's service layer is referred to as the Service Capability Layer (SCL). The SCL may be implemented within an M2M device (where it is referred to as a device SCL (DSCL)), a gateway (where it is referred to as a gateway SCL (GSCL)) and/or a network node (where it is referred to as a network SCL (NSCL)). The oneM2M service layer supports a set of Common Service Functions (CSFs) (i.e. service capabilities). An instantiation of a set of one or more particular types of CSFs is referred to as a Common Services Entity (CSE) which can be hosted on different types of network nodes (e.g. infrastructure node, middle node, application-specific node). Further, connection methods of the present application can implemented as part of an M2M network that uses a Service Oriented Architecture (SOA) and/or a resource-oriented architecture (ROA) to access services such as the connection methods of the present application.
In some embodiments, M2M applications 20 and 20′ may be used in conjunction with the disclosed systems and methods. The M2M applications 20 and 20′ may include the applications that interact with the UE or gateway and may also be used in conjunction with other disclosed systems and methods.
In one embodiment, the logical entities such as service layer 1602, data source 2218, DSAS 2202, DSAS-SF 2212, DSAS-SAE 2210, DSAS Manager 2206, DSAS API 2208, data storage node 2214, security manager 2302, manager/parser 2304, preprocessor 2306, storage filter 2308, analytics filter 2310, query store 2318, job table 2320, log store 2323, Stream ID Store 2321, SAE source 2314, query operators 2312, client 2216 and 3202, coordinator 3402, DSAS CSF 3702, DSAS hosting CSE 3704, data source AE 4402, DSAS Client AE 4502 and 4602, CSE 4504 and logical entities to produce interfaces such as the interfaces of
The M2M applications 20 and 20′ may include applications in various industries such as, without limitation, transportation, health and wellness, connected home, energy management, asset tracking, and security and surveillance. As mentioned above, the M2M service layer, running across the devices, gateways, servers and other nodes of the system, supports functions such as, for example, data collection, device management, security, billing, location tracking/geofencing, device/service discovery, and legacy systems integration, and provides these functions as services to the M2M applications 20 and 20′.
Generally, the service layers 22 and 22′ define a software middleware layer that supports value-added service capabilities through a set of Application Programming Interfaces (APIs) and underlying networking interfaces. Both the ETSI M2M and oneM2M architectures define a service layer. ETSI M2M's service layer is referred to as the Service Capability Layer (SCL). The SCL may be implemented in a variety of different nodes of the ETSI M2M architecture. For example, an instance of the service layer may be implemented within an M2M device (where it is referred to as a device SCL (DSCL)), a gateway (where it is referred to as a gateway SCL (GSCL)) and/or a network node (where it is referred to as a network SCL (NSCL)). The oneM2M service layer supports a set of Common Service Functions (CSFs) (i.e., service capabilities). An instantiation of a set of one or more particular types of CSFs is referred to as a Common Services Entity (CSE) which can be hosted on different types of network nodes (e.g. infrastructure node, middle node, application-specific node). The Third Generation Partnership Project (3GPP) has also defined an architecture for machine-type communications (MTC). In that architecture, the service layer, and the service capabilities it provides, are implemented as part of a Service Capability Server (SCS). Whether embodied in a DSCL, GSCL, or NSCL of the ETSI M2M architecture, in a Service Capability Server (SCS) of the 3GPP MTC architecture, in a CSF or CSE of the oneM2M architecture, or in some other node of a network, an instance of the service layer may be implemented as a logical entity (e.g., software, computer-executable instructions, and the like) executing either on one or more standalone nodes in the network, including servers, computers, and other computing devices or nodes, or as part of one or more existing nodes. As an example, an instance of a service layer or component thereof may be implemented in the form of software running on a network node (e.g., server, computer, gateway, device or the like) having the general architecture illustrated in
Further, logical entities such as service layer 1602, data source 2218, DSAS 2202, DSAS-SF 2212, DSAS-SAE 2210, DSAS Manager 2206, DSAS API 2208, data storage node 2214, security manager 2302, manager/parser 2304, preprocessor 2306, storage filter 2308, analytics filter 2310, query store 2318, job table 2320, log store 2323, Stream ID Store 2321, SAE source 2314, query operators 2312, client 2216 and 3202, coordinator 3402, DSAS CSF 3702, DSAS hosting CSE 3704, data source AE 4402, DSAS Client AE 4502 and 4602, CSE 4504 and logical entities to produce interfaces such as the interfaces of
The processor 32 may be a general purpose processor, a special purpose processor, a conventional processor, a digital signal processor (DSP), a plurality of microprocessors, one or more microprocessors in association with a DSP core, a controller, a microcontroller, Application Specific Integrated Circuits (ASICs), Field Programmable Gate Array (FPGAs) circuits, any other type of integrated circuit (IC), a state machine, and the like. In general, the processor 32 may execute computer-executable instructions stored in the memory (e.g., memory 44 and/or memory 46) of the node in order to perform the various required functions of the node. For example, the processor 32 may perform signal coding, data processing, power control, input/output processing, and/or any other functionality that enables the M2M node 30 to operate in a wireless or wired environment. The processor 32 may run application-layer programs (e.g., browsers) and/or radio access-layer (RAN) programs and/or other communications programs. The processor 32 may also perform security operations such as authentication, security key agreement, and/or cryptographic operations, such as at the access-layer and/or application layer for example.
As shown in
The transmit/receive element 36 may be configured to transmit signals to, or receive signals from, other M2M nodes, including M2M servers, gateways, device, and the like. For example, in an embodiment, the transmit/receive element 36 may be an antenna configured to transmit and/or receive RF signals. The transmit/receive element 36 may support various networks and air interfaces, such as WLAN, WPAN, cellular, and the like. In an embodiment, the transmit/receive element 36 may be an emitter/detector configured to transmit and/or receive IR, UV, or visible light signals, for example. In yet another embodiment, the transmit/receive element 36 may be configured to transmit and receive both RF and light signals. It will be appreciated that the transmit/receive element 36 may be configured to transmit and/or receive any combination of wireless or wired signals.
In addition, although the transmit/receive element 36 is depicted in
The transceiver 34 may be configured to modulate the signals that are to be transmitted by the transmit/receive element 36 and to demodulate the signals that are received by the transmit/receive element 36. As noted above, the M2M node 30 may have multi-mode capabilities. Thus, the transceiver 34 may include multiple transceivers for enabling the M2M node 30 to communicate via multiple RATs, such as UTRA and IEEE 802.11, for example.
The processor 32 may access information from, and store data in, any type of suitable memory, such as the non-removable memory 44 and/or the removable memory 46. For example, the processor 32 may store session context in its memory, as described above. The non-removable memory 44 may include random-access memory (RAM), read-only memory (ROM), a hard disk, or any other type of memory storage device. The removable memory 46 may include a subscriber identity module (SIM) card, a memory stick, a secure digital (SD) memory card, and the like. In other embodiments, the processor 32 may access information from, and store data in, memory that is not physically located on the M2M node 30, such as on a server or a home computer. The processor 32 may be configured to control visual indications on the display to reflect the status of the system or to obtain input from a user or display information to a user about capabilities or settings. A graphical user interface, which may be shown on the display, may be layered on top of an API to allow a user to interactively do functionality described herein.
The processor 32 may receive power from the power source 48, and may be configured to distribute and/or control the power to the other components in the M2M node 30. The power source 48 may be any suitable device for powering the M2M node 30. For example, the power source 48 may include one or more dry cell batteries (e.g., nickel-cadmium (NiCd), nickel-zinc (NiZn), nickel metal hydride (NiMH), lithium-ion (Li-ion), etc.), solar cells, fuel cells, and the like.
The processor 32 may also be coupled to the GPS chipset 50, which is configured to provide location information (e.g., longitude and latitude) regarding the current location of the M2M node 30. It will be appreciated that the M2M node 30 may acquire location information by way of any suitable location-determination method while remaining consistent with an embodiment.
The processor 32 may further be coupled to other peripherals 52, which may include one or more software and/or hardware modules that provide additional features, functionality and/or wired or wireless connectivity. For example, the peripherals 52 may include various sensors such as an accelerometer, biometrics (e.g., fingerprint) sensors, an e-compass, a satellite transceiver, a digital camera (for photographs or video), a universal serial bus (USB) port or other interconnect interfaces, a vibration device, a television transceiver, a hands free headset, a Bluetooth® module, a frequency modulated (FM) radio unit, a digital music player, a media player, a video game player module, an Internet browser, and the like.
The node 30 may be embodied in other apparatuses or devices, such as a sensor, consumer electronics, a wearable device such as a smart watch or smart clothing, a medical or eHealth device, a robot, industrial equipment, a drone, a vehicle such as a car, truck, train, or airplane. The node 30 may connect to other components, modules, or systems of such apparatuses or devices via one or more interconnect interfaces, such as an interconnect interface that may comprise one of the peripherals 52. Alternately, the node 30 may comprise apparatuses or devices, such as a sensor, consumer electronics, a wearable device such as a smart watch or smart clothing, a medical or eHealth device, a robot, industrial equipment, a drone, a vehicle such as a car, truck, train, or airplane.
In operation, CPU 91 fetches, decodes, and executes instructions, and transfers information to and from other resources via the computer's main data-transfer path, system bus 80. Such a system bus connects the components in computing system 90 and defines the medium for data exchange. System bus 80 typically includes data lines for sending data, address lines for sending addresses, and control lines for sending interrupts and for operating the system bus. An example of such a system bus 80 is the PCI (Peripheral Component Interconnect) bus.
Memories coupled to system bus 80 include random access memory (RAM) 82 and read only memory (ROM) 93. Such memories include circuitry that allows information to be stored and retrieved. ROMs 93 generally contain stored data that cannot easily be modified. Data stored in RAM 82 can be read or changed by CPU 91 or other hardware devices. Access to RAM 82 and/or ROM 93 may be controlled by memory controller 92. Memory controller 92 may provide an address translation function that translates virtual addresses into physical addresses as instructions are executed. Memory controller 92 may also provide a memory protection function that isolates processes within the system and isolates system processes from user processes. Thus, a program running in a first mode can access only memory mapped by its own process virtual address space; it cannot access memory within another process's virtual address space unless memory sharing between the processes has been set up.
In addition, computing system 90 may contain peripherals controller 83 responsible for communicating instructions from CPU 91 to peripherals, such as printer 94, keyboard 84, mouse 95, and disk drive 85.
Display 86, which is controlled by display controller 96, is used to display visual output generated by computing system 90. Such visual output may include text, graphics, animated graphics, and video. Display 86 may be implemented with a CRT-based video display, an LCD-based flat-panel display, gas plasma-based flat-panel display, or a touch-panel. Display controller 96 includes electronic components required to generate a video signal that is sent to display 86.
Further, computing system 90 may contain communication circuitry, such as for example a network adaptor 97, that may be used to connect computing system 90 to an external communications network, such as network 12 of
User equipment (UE) can be any device used by an end-user to communicate. It can be a hand-held telephone, a laptop computer equipped with a mobile broadband adapter, or any other device. For example, the UE can be implemented as the M2M terminal device 18 of
It is understood that any or all of the systems, methods, and processes described herein may be embodied in the form of computer executable instructions (i.e., program code) stored on a computer-readable storage medium which instructions, when executed by a machine, such as a node of an M2M network, including for example an M2M server, gateway, device or the like, perform and/or implement the systems, methods and processes described herein. Specifically, any of the steps, operations or functions described above, including the operations of the gateway, UE, UE/GW, or any of the nodes of the mobile core network, service layer or network application provider, may be implemented in the form of such computer executable instructions. Logical entities such as service layer 1602, data source 2218, DSAS 2202, DSAS-SF 2212, DSAS-SAE 2210, DSAS Manager 2206, DSAS API 2208, data storage node 2214, security manager 2302, manager/parser 2304, preprocessor 2306, storage filter 2308, analytics filter 2310, query store 2318, job table 2320, log store 2323, Stream ID Store 2321, SAE source 2314, query operators 2312, client 2216 and 3202, coordinator 3402, DSAS CSF 3702, DSAS hosting CSE 3704, data source AE 4402, DSAS Client AE 4502 and 4602, CSE 4504 and logical entities to produce interfaces such as the interfaces of
In describing preferred embodiments of the subject matter of the present disclosure, as illustrated in the Figures, specific terminology is employed for the sake of clarity. The claimed subject matter, however, is not intended to be limited to the specific terminology so selected, and it is to be understood that each specific element includes all technical equivalents that operate in a similar manner to accomplish a similar purpose.
This written description uses examples to disclose the invention, including the best mode, and also to enable any person skilled in the art to practice the invention, including making and using any devices or systems and performing any incorporated methods. The patentable scope of the invention is defined by the claims, and may include other examples that occur to those skilled in the art. Such other examples are intended to be within the scope of the claims if they have elements that do not differ from the literal language of the claims, or if they include equivalent elements with insubstantial differences from the literal language of the claims.
This application is a Continuation of U.S. patent application Ser. No. 16/096,510, filed Oct. 25, 2018, which is a National Stage Application filed under 35 U.S.C. § 371 of International Application No. PCT/US2017/029341 filed Apr. 25, 2017, which claims the benefit of U.S. Provisional Patent Application Ser. No. 62/326,894, filed Apr. 25, 2016, the disclosures of which are hereby incorporated by reference as if set forth in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
8301645 | Crook et al. | Oct 2012 | B1 |
10853359 | Waugh | Dec 2020 | B1 |
11431785 | Spaven | Aug 2022 | B2 |
20040004631 | Debique | Jan 2004 | A1 |
20040117157 | Bantz et al. | Jun 2004 | A1 |
20050175029 | Cheung | Aug 2005 | A1 |
20050249221 | Remi et al. | Nov 2005 | A1 |
20070005576 | Cutrell | Jan 2007 | A1 |
20070143386 | Nguyen | Jun 2007 | A1 |
20100288157 | Lefebvre et al. | Nov 2010 | A1 |
20120151345 | McClements, IV | Jun 2012 | A1 |
20130029599 | Santori et al. | Jan 2013 | A1 |
20130042327 | Chow | Feb 2013 | A1 |
20130121282 | Liu | May 2013 | A1 |
20130124484 | Hoffman | May 2013 | A1 |
20140194657 | Wadhwa | Jul 2014 | A1 |
20140280338 | Metz et al. | Sep 2014 | A1 |
20140304006 | Korpman et al. | Oct 2014 | A1 |
20140330926 | Nano et al. | Nov 2014 | A1 |
20140359035 | Wang | Dec 2014 | A1 |
20150271033 | Srivastava et al. | Sep 2015 | A1 |
20150317363 | Manzano Macho | Nov 2015 | A1 |
20160191591 | Rider | Jun 2016 | A1 |
20160234022 | Motika et al. | Aug 2016 | A1 |
20170109266 | Chee | Apr 2017 | A1 |
20170171165 | Britt | Jun 2017 | A1 |
20170177546 | Heinz et al. | Jun 2017 | A1 |
20170230402 | Greenspan et al. | Aug 2017 | A1 |
20190065683 | Korpman et al. | Feb 2019 | A9 |
Number | Date | Country |
---|---|---|
2674876 | Dec 2013 | EP |
2801935 | Nov 2014 | EP |
9843178 | Oct 1998 | WO |
Entry |
---|
“Http://storm.apache.org/”, Retrieved Jan. 7, 2020, 3 pages. |
“http://www.enterprisetech.com/2014/12/10/intel-rolls-iot-platform/”, Dec. 10, 2014, 3 pages. |
“https://docs.microsoft.com/en-us/azure/iot-fundamentals/iot-introduction”, downloaded Apr. 8, 2020, 37 pages. |
“https://opensource.com/business/15/4/guide-to-apache-spark-streaming”, Apr. 23, 2015, 7 pages. |
“https://www.ibm.com/support/knowledgecenter/SSCRJU_4.0.0/com.ibm.streams.welcome.doc/doc/kc-homepage.html” Retrieved Apr. 8, 2020, 3 pages. |
Aazam et al., “Fog Computing and Smart Gateway Based Communication for Cloud of Things”, 2014 International Conference on Future Internet of Things and Cloud, Retrieved on Jun. 29, 2016, 7 pages. |
AIM Autonomous Intersection Management, University of Texas at Austin, http://www.cs.utexas.edu/˜aim/, retrieved Apr. 8, 2020, 6 pages. |
Campbell, “How to Process Google Data in Real Time with Azure Stream Analytics”, BlueGranite business Insights, Feb. 26, 2015, 1 pages. |
Guillaume Leduc, JRC Technical Notes, “Road Traffic Data: Collection Methods and Applications”, JRC 47967-2008, 55 pages. |
OneM2M Technical Specification TS-0001 V2.3.0, “Functional Architecture”, Aug. 2015, 352 pages. |
OneM2M Technical Specification, TS-0007 V0.3.0, Service Component Architecture, Jun. 2014, 105 pages. |
Satyanarayanan, et al., “Edge Analytics in the Internet of Things”, Apr.-Jun. 2015, 8 pages. |
Number | Date | Country | |
---|---|---|---|
20210240719 A1 | Aug 2021 | US |
Number | Date | Country | |
---|---|---|---|
62326894 | Apr 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16096510 | US | |
Child | 17175100 | US |