İnçki, KorayArı, İsmail2018-10-012018-10-0120182169-3536http://hdl.handle.net/10679/5984https://doi.org/10.1109/ACCESS.2018.2813887Internet of Things (IoT) systems promise a seamless connected world with machines integrating their services without human intervention. It's highly probable that the entities participating in such autonomous machine to machine interactions are to be provided by different manufactures. Thus, integrating such heterogeneous devices from many providers complicates design and verification of IoT systems at an unprecedented scale. In this paper, we propose a novel runtime verification approach for IoT systems. The contributions of our proposed solution include: exploiting the interactions in message sequence charts (MSC) to specify message exchanges of constrained application protocol-based IoT systems in terms of events, a novel event calculus for formally describing IoT system constraints specified by means of MSCs, and an event processing algebra that uses complex-event processing techniques for detecting failures in the system by monitoring the runtime event occurrences with respect to the system constraints defined by event calculus. We further demonstrate the viability of proposed solution with case studies.engopenAccessA novel runtime verification solution for LoT systemsarticle6135011351200042917480000110.1109/ACCESS.2018.2813887Internet of thingsRuntime verificationEvent calculusComplex-event processingMessage sequence charts2-s2.0-85043358192