Efficient Execution of Complex Context Queries to Enable Near Real-Time Smart IoT Applications
Abstract
:1. Introduction
- We have designed and developed a mechanism (i.e., Context Query Engine) that allows execution of complex context queries in dynamic IoT ecosystems.
- We have implemented a prototype of the proposed solution.
- We have conducted a comprehensive set of experiments to measure the performance of CQE in the execution of various context queries and compare its performance with a well-known existing CMP (i.e., Fiware Orion).
2. Related Works
- Sensor Data Acquisition. This function is responsible for fetching raw context data from multiple sources. In the context-aware system, it is essential that the system can support a variety of heterogeneous context sources. Based on the computational capability of context sources, pre-processing and data cleaning might be executed locally (on the context source) or externally as a part of the CMP’s functionality.
- Context Storage. This function refers to the mechanism of persisting contextual information in the platform. Two crucial aspects of context storage are: (i) the storage of current context (context caching) and (ii) the storage of historical context. Caching improves the performance of CMPs in answering incoming queries by omitting the process of fetching repeated context. Moreover, a CMP should be capable of storing and indexing historical context. Historical context can be utilised by CMPs to produce valuable insights about IoT entities. For example, the historical data can be used to learn the habits of IoT entities and predict their future states. This can be used both for query serving and platform’s self-adaptation.
- Context Service registration and Discovery. A CMP should provide a mechanism that allows sources of context (i.e., IoT devices and services) to describe and register their offered contextual information. Moreover, it is vital for a CMP to be able to search and find the matching sources of context for an incoming query.
- Privacy, Security & Access Control. This feature is considered as a vital function in CMPs as they might expose sensitive information about IoT devices and their owners to unauthorised third parties. As a result, it is essential for a CMP to have a sophisticated authentication and authorisation mechanism to guarantee the privacy and security of users’ contextual information.
- Context Processing & Reasoning. Sources of context (e.g., sensors) mostly offer raw sensory data to CMPs. Hence, a CMP is required to perform some pre-processing to infer context information from raw sensory data. Moreover, in many use-cases, it is essential to infer high-level context/situation from multiple existing low-level context. Therefore, a CMP should be capable of performing different context inference and situation reasoning techniques such as feature extraction, rule-based reasoning or probabilistic inference.
- Context Querying (Context Diffusion & Distribution). The ultimate objective of a CMP is to facilitate the development of context-aware applications. Each context-aware application has unique contextual requirements. As a result, a CMP should provide a generic approach that allows context-aware applications to request for contextual data based on their unique requirements. This approach should define a comprehensive and flexible query language that allows context-aware applications to query the context of their entities of interest. Moreover, it should support different communication modes, namely push-based queries and pull-based queries. Push-based queries refer to event-driven asynchronous queries (i.e., publish/subscribe) that allows context-aware applications to subscribe for changes in the context of their entities of interest and get notified about context changes. Pull-based queries refer to synchronous on-demand queries.
3. Context-as-a-Service Background
3.1. Definitions
3.2. CoaaS Platform Blueprint Architecture
3.3. Context Definition and Query Language (CDQL)
4. Context Query Engine
4.1. Context Query Parser and Execution Plan Generation
- entityID denotes the unique name (e.g., vehicleA)assigned to the entity.
- type represents the semantic category class the entity belongs to.
- dependency captures the dependency with the other context entities that are referenced in the definition of this entity
- RPNCondition is the Reverse Polish Notation (RPN) representation of the WHERE clause. RPN is a well-known method for the expression notification in a postfix manner, instead of using the usual infix notation.
- contextAttributes consists of an array of context attributes that are used in the CDQL query in the SELECT, WHEN, or WHERE clauses.
4.2. Context Query Execution
5. CQE Implementation
6. Evaluation of CQE
6.1. CQE Experiment Environment
6.2. CQE Experiments Metrics
- The number of parallel queries: The increase in the number of parallel queries can lead to performance degradation due to the resource limitation.
- The richness of a query: The structure of each context query might also influence the execution performance. The main features that can impact the query execution performance are the number of defined entities, the number of constraints, the ratio of ‘ANDs’ to ‘ORs’, the number of functions, and the type of functions.
6.3. CQE Experiments and Results
7. Conclusions
- Auto-Scaling Strategy: In this paper, we have conducted all the experiments on a single instance of CoaaS platform. However, in production environments, context management platforms are needed to be scaled-out to deal with the massive number of requests generated by the billions of IoT devices. To address this challenge, we are planning to investigate and design an auto-scaling strategy for CMPs that automatic scale-out or scale-in based on the scale of incoming requests.
- Context Prediction: Another important aspect of context processing is context prediction. Context prediction is referred to as the process of exploiting expected future context of IoT entities based on the historical context. A CMP that supports context predication offers distinct advantages to the context consumers, which enables a range of new use-cases. Hence, we are planning to investigate, design, and implement a generic mechanism that allows context consumers to predict the future context of IoT entities.
Author Contributions
Funding
Acknowledgments
Conflicts of Interest
References
- Van der Meulen, R. Gartner says 8.4 billion connected ‘Things’ will be in use in 2017 up 31 percent from 2016. Gartner. Letzte Aktual. 2017, 7, 2017. [Google Scholar]
- Dey, A.K. Understanding and using context. Pers. Ubiquitous Comput. 2001, 5, 4–7. [Google Scholar] [CrossRef]
- Perera, C.; Zaslavsky, A.; Christen, P.; Georgakopoulos, D. Context aware computing for the internet of things: A survey. IEEE Commun. Surv. Tutor. 2014, 16, 414–454. [Google Scholar] [CrossRef] [Green Version]
- Li, X.; Eckert, M.; Martinez, J.F.; Rubio, G. Context aware middleware architectures: Survey and challenges. Sensors 2015, 15, 20570–20607. [Google Scholar] [CrossRef] [PubMed] [Green Version]
- Moore, P.; Xhafa, F.; Barolli, L. Context-as-a-service: A service model for cloud-based systems. In Proceedings of the 2014 Eighth International Conference on Complex, Intelligent and Software Intensive Systems, Birmingham, UK, 2–4 July 2014; pp. 379–385. [Google Scholar]
- Hassani, A.; Haghighi, P.D.; Jayaraman, P.P.; Zaslavsky, A.; Ling, S. Querying IoT Services: A Smart Carpark Recommender Use Case. In Proceedings of the 4th IEEE World Forum on Internet of Things WF-IoT, Singapore, 5–8 February 2018. [Google Scholar]
- Baldauf, M.; Dustdar, S.; Rosenberg, F. A survey on context-aware systems. Int. J. Ad Hoc Ubiquitous Comput. 2007, 2, 263. [Google Scholar] [CrossRef] [Green Version]
- Truong, H.-L.; Dustdar, S. A survey on context-aware web service systems. Int. J. Web Inf. Syst. 2009, 5, 5–31. [Google Scholar] [CrossRef] [Green Version]
- Hong, J.y.; Suh, E.h.; Kim, S.J. Context-aware systems: A literature review and classification. Expert Syst. Appl. 2009, 36, 8509–8522. [Google Scholar] [CrossRef]
- Knappmeyer, M.; Kiani, S.L.; Reetz, E.S.; Baker, N.; Tonjes, R. Survey of context provisioning middleware. IEEE Commun. Surv. Tutor. 2013, 15, 1492–1519. [Google Scholar] [CrossRef] [Green Version]
- Hassani, A.; Medvedev, A.; Haghighi, P.D.; Ling, S.; Zaslavsky, A.; Jayaraman, P.P. Context Definition and Query Language: Conceptual Specification, Implementation, and Evaluation. Sensors 2019, 19, 1478. [Google Scholar] [CrossRef] [PubMed] [Green Version]
- Hassani, A.; Haghighi, P.D.; Jayaraman, P.P.; Zaslavsky, A.; Ling, S.; Medvedev, A. CDQL: A Generic Context Representation and Querying Approach for Internet of Things Applications. In Proceedings of the 14th International Conference on Advances in Mobile Computing and Multi Media-MoMM 16, Singapore, 28–30 November 2016; pp. 79–88. [Google Scholar]
- Medvedev, A.; Hassani, A.; Zaslavsky, A.; Haghighi, P.D.; Ling, S.; Jayaraman, P.P. Benchmarking IoT Context Management Platforms: High-Level Queries Matter. In Proceedings of the 2019 Global IoT Summit GIoTS, Aarhus, Denemark, 17–21 June 2019. [Google Scholar]
- Hassani, A.; Medvedev, A.; Zaslavsky, A.; Haghighi, P.D.; Ling, S.; Jayaraman, P.P. Context-as-a-Service Platform: Exchange and Share Context in an IoT Ecosystem. In Proceedings of the 2018 IEEE International Conference on Pervasive Computing and Communications Workshops (PerCom Workshops), Athens, Greece, 19–23 March 2018; IEEE: Piscataway, NJ, USA, 2018. [Google Scholar]
- Want, R.; Hopper, A.; Falcão, V.; Gibbons, J. The active badge location system. ACM Trans. Inf. Syst. 1992, 10, 91–102. [Google Scholar] [CrossRef]
- Gu, T.; Pung, H.K.; Zhang, D.Q. A service-oriented middleware for building context-aware services. J. Netw. Comput. Appl. 2005, 28, 1–18. [Google Scholar] [CrossRef]
- Chen, H.L. COBRA: An Intelligent Broker Architecture for Pervasive Context-Aware Systems. Interfaces 2004, 54, 129. [Google Scholar]
- Chen, G.; Kotz, D. A Survey of Context-Aware Mobile Computing Research. Open Dartmouth: Faculty Open Access Scholarship. 3212 2000. [Google Scholar]
- Perera, C.; Zaslavsky, A.; Christen, P.; Georgakopoulos, D. CA4IOT: Context awareness for Internet of Things. In Proceedings of the 2012 IEEE International Conference on Green Computing and Communications, Besancon, France, 20–23 November 2012; pp. 775–782. [Google Scholar]
- Wei, E.J.Y.; Chan, A.T.S. CAMPUS: A middleware for automated context-aware adaptation decision making at run time. Pervasive Mob. Comput. 2013, 9, 35–56. [Google Scholar] [CrossRef]
- Antipolis, S. ETSI Launches New Group on Context Information Management for Smart City Interoperability. Available online: https://www.etsi.org/news-events/news/1152-2017-01-news-etsi-launches-new-group-on-context-information-management-for-smart-city-interoperability (accessed on 2 December 2018).
- Fiware-Orion. Available online: https://fiware-orion.readthedocs.io/en/master/ (accessed on 31 October 2019).
- NGSI V2. Available online: https://fiware.github.io/specifications/ngsiv2/stable/ (accessed on 31 October 2019).
- ETSI-ETSI ISG CIM Group Releases First Specification for Context Exchange in Smart Cities. Available online: https://www.etsi.org/newsroom/news/1300-2018-04-news-etsi-isg-cim-group-releases-first-specification-for-context-exchange-in-smart-cities (accessed on 18 February 2019).
- Esper-EsperTech. Available online: http://www.espertech.com/esper/ (accessed on 18 February 2019).
- EPL Reference: Clauses. Available online: http://esper.espertech.com/release-5.2.0/esper-reference/html/epl_clauses.html (accessed on 18 February 2019).
- Espressif Systems-Wi-Fi and Bluetooth Chipsets and Solutions. Available online: https://www.espressif.com/ (accessed on 7 March 2019).
- Medvedev, A.; Indrawan-Santiago, M.; Haghighi, P.D.; Hassani, A.; Zaslavsky, A.; Jayaraman, P.P. Architecting IoT context storage management for context-as-a-service platform. In Proceedings of the GIoTS 2017-Global Internet of Things Summit, Geneva, Switzerland, 6–9 June 2017. [Google Scholar]
- Haghighi, P.D.; Krishnaswamy, S.; Zaslavsky, A.; Gaber, M.M. Lecture Notes in Computer Science (including Subser. Lect. Notes Artif. Intell. Lect. Notes Bioinformatics). In Proceedings of the European Conference on Smart Sensing and Context 2008, Zurich, Switzerland, 29–31 October 2008; Reasoning about context in uncertain pervasive computing environments. Springer: Berlin/Heidelberg, Germany, 2008; Volume 5279, pp. 112–125. [Google Scholar]
- Padovitz, A.; Loke, S.W.; Zaslavsky, A. Towards a theory of context spaces. In Proceedings of the Second IEEE Annual Conference on Pervasive Computing and Communications, Orlando, FL, USA, 14–17 March 2004. [Google Scholar]
- Medvedev, A.; Hassani, A.; Haghighi, P.D.; Ling, S.; Indrawan-Santiago, M.; Zaslavsky, A.; Fastenrath, U.; Mayer, F.; Jayaraman, P.P.; Kolbe, N. Situation Modelling Representation and Querying in Context-as-a-Service IoT Platform in GIoTS. In Proceedings of the 2018-Global Internet of Things Summit, Bilbao, Spain, 4–7 June 2018. [Google Scholar]
- Jones, M.; Bradley, J.; Sakimura, N. Rfc 7519: Json web token (jwt). Date Retr. 2015, 5, 2017. [Google Scholar]
- Boytsov, A.; Zaslavsky, A. ECSTRA—Distributed context reasoning framework for pervasive computing systems. In Lecture Notes in Computer Science (Including Subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics); Springer: Berlin, Heidelberg, 2011. [Google Scholar]
- Fiware-Orion. Available online: https://fiware-orion.readthedocs.io/en/develop/ (accessed on 18 February 2019).
Component | Responsibilities |
---|---|
Communication and Security Manager | (iv) Privacy, security and access control |
Context Query Engine | (i) Sensor data acquisition (iii) Context service registration and discovery (vi) Context querying (Context diffusion and distribution) |
Situation Monitoring Engine | (i) Sensor data acquisition (v) Context processing and reasoning |
Context Storage Management System | (i) Sensor data acquisition (ii) Current and historical context storage (iii) Context service registration and discovery |
Context Reasoning Engine | (v) Context processing and reasoning |
Execution Order | Entities |
---|---|
Execution Order 1 | vehicleA |
Execution Order 2 | weatherCondition trafficElements |
Execution Order 3 | (i) Sensor data acquisition (v) Context processing and reasoning |
Usage Type | Strategy | Example * | |
---|---|---|---|
Original Condition | Reformulated Condition | ||
In a condition using set operators (e.g., containsAny, containsAll) | No changes required. | e1.a1 containsAll e2.a1 e1.a1 containsAny e2.a1 | e1.a1 containsAll [1,2,3,4] e1.a1 containsAny [1,2,3,4] |
In an equality condition | The equality operator will be replaced by containsAny. | e1.a1 = e2.a1 | e1.a1 containsAny [1,2,3,4] |
In an inequality condition | The inequality will be broken down into several inequality conditions (one for each instance of dependent entity) that are connected with OR operator. | e1.a1 < e2.a1 | (e1.a1 < 1 or e1.a1 < 2 or e1.a1 < 3 or e1.a1 < 4) |
Inside a function call | The function call will be broken down into several function calls (one for each instance of dependent entity) that are connected with OR operator. | F1 (e1.a1, e2.a1) < 12 | (F1 (e1.a1, 1) = true or F1 (e1.a1, 2) = true or F1 (e1.a1, 3) = true or F1 (e1.a1, 4) = true) |
Inside an entityMatch operator | For each instance of dependent entity, one entityMatch statement will be generated. The OR operator will be used to connect these statements. | entityMatch(e1.a1 = e2.a1 and e1.a2 < e2.a2) | ((e1.a1 = 1 and e1.a2 < 10) or ((e1.a1 = 2 and e1.a2 < 8) or ((e1.a1 = 3 and e1.a2 < 4) or ((e1.a1 = 4 and e1.a2 < 6)) |
Execution Order | Entities |
---|---|
Execution Order 1 | schools |
Execution Order 2 | vehicles |
Address/Method | Short Description | Accepts |
---|---|---|
/rest/cm/token (POST) | Authentication API | Username and Password |
/rest/cm/query (POST) | CDQL query API | • CDQL query
|
/rest/cm/register/ (POST) | Context Service registration API | CSDL Service description |
/rest/cm/event (POST) | Context update API | Context update |
Name | Type | Generation Strategy |
---|---|---|
id | String | A string value generated by concatenating “entity” and a unique number between 0 to total number of entities. |
Attribute1 | String | A string value generated by contacting “value” and a randomly generated number between 0 to 199. |
Attribute2 | Integer | Random Integer between 0 and 99. |
Location | Geo-coordinates (i.e., latitude and longitude) | Randomly generated within a circle where the coordinates of the centre were [−37.8770, 145.0443] and the radius was 1 km. |
Name | Type | Generation Strategy |
---|---|---|
id | String | A string value generated by concatenating “entity” and a unique number between 0 to total number of entities. |
joinAttr0 | String | A string value generated by concatenating “entity” and a randomly generated number between 0 to 199. |
© 2019 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (http://creativecommons.org/licenses/by/4.0/).
Share and Cite
Hassani, A.; Medvedev, A.; Zaslavsky, A.; Delir Haghighi, P.; Jayaraman, P.P.; Ling, S. Efficient Execution of Complex Context Queries to Enable Near Real-Time Smart IoT Applications. Sensors 2019, 19, 5457. https://doi.org/10.3390/s19245457
Hassani A, Medvedev A, Zaslavsky A, Delir Haghighi P, Jayaraman PP, Ling S. Efficient Execution of Complex Context Queries to Enable Near Real-Time Smart IoT Applications. Sensors. 2019; 19(24):5457. https://doi.org/10.3390/s19245457
Chicago/Turabian StyleHassani, Alireza, Alexey Medvedev, Arkady Zaslavsky, Pari Delir Haghighi, Prem Prakash Jayaraman, and Sea Ling. 2019. "Efficient Execution of Complex Context Queries to Enable Near Real-Time Smart IoT Applications" Sensors 19, no. 24: 5457. https://doi.org/10.3390/s19245457
APA StyleHassani, A., Medvedev, A., Zaslavsky, A., Delir Haghighi, P., Jayaraman, P. P., & Ling, S. (2019). Efficient Execution of Complex Context Queries to Enable Near Real-Time Smart IoT Applications. Sensors, 19(24), 5457. https://doi.org/10.3390/s19245457