Next Article in Journal
Public Debt, Governance, and Growth in Developing Countries: An Application of Quantile via Moments
Next Article in Special Issue
Formal Group Fairness and Accuracy in Automated Decision Making
Previous Article in Journal
A New Method for Free Vibration Analysis of Triangular Isotropic and Orthotropic Plates of Isosceles Type Using an Accurate Series Solution
Previous Article in Special Issue
Exploring Online Activities to Predict the Final Grade of Student
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Periodic Behavioral Routine Discovery Based on Implicit Spatial Correlations for Smart Home

1
Department of Electronic Engineering, National Kaohsiung University of Science and Technology, Kaohsiung 80778, Taiwan
2
Department of Computer Science and Information Engineering, National Cheng Kung University, Tainan 701, Taiwan
3
Zsystem Technology Co., Kaohsiung 80457, Taiwan
*
Authors to whom correspondence should be addressed.
Mathematics 2023, 11(3), 648; https://doi.org/10.3390/math11030648
Submission received: 9 December 2022 / Revised: 17 January 2023 / Accepted: 19 January 2023 / Published: 27 January 2023

Abstract

:
As the degree of elders’ social activity and self-care ability depreciates, the potential risk for elderly people who live independently increases. The development of assistive services such as smart homes could likely provide them with a safer living environment. These systems collect sensor data to monitor residents’ daily activities and provide assistance services accordingly. In order to do so, a smart home must understand its residents’ daily activities and identify their periodic behavioral daily routine accordingly. However, existing solutions mainly focus on the temporal feature of daily activities and require prior labeling of where sensors are geographically deployed. In this study, we extract implicit spatial information from hidden correlations between sensors deployed in the environment and present a concept of virtual locations that establishes an abstract spatial representation of the physical living space so that prior labeling of the actual location of the sensors is not required. To demonstrate the viability of this concept, an unsupervised periodic behavioral routine discovery method that does not require any predefined location-specific sensor data for a smart home environment is proposed. The experimental results show that with the help of virtual location, the proposed method achieves high accuracy in activity discovery and significantly reduces the computation time required to complete the task relative to a system without virtual location. Furthermore, the result of simulated anomaly detection also shows that the periodic behavioral routine discovery system is more tolerant to differences in the way routines are performed.

1. Introduction

Internet of Things (IoT) technologies offer a variety of applications [1] that may be beneficial to everyone due to their ability to allows connected devices to interact with other devices or sensors to collect and exchange data in real time. This creates a new context of data that may contain important information that can be used in many ways to improve the quality of life of the general population, for instance, monitoring the daily activities of the elderly using wearable and ambient sensors, tracking drugs through the supply chain by attaching smart labels to them [1], and controlling a robotic wheelchair using a joystick and flex sensor for disabled people [2]. Furthermore, there is an upward trend in the number of elderly people living independently at home [3,4]. A similar trend has also been reported, i.e., that elders prefer to stay at home alone due to the need for privacy, the high cost of hiring nurses, or inadequate medical resources [5]. Thus, the need for independent living has motivated many researchers to accelerate the development of smart home monitoring and automation techniques. For example, smart homes provide residents comfort, convenience, and energy efficiency via remote control and automation features. This technology can also be used to enhance the safety of residents and assist with independent living or elder care by tracking the daily activities of elders in the environment [6,7] or customizing load-shifting and energy-saving suggestions according to residents’ daily occupancy patterns [8]. The authors of [9] present a use case for a smartphone-based augmented reality application that allows the resident to control their smart devices via home automation. More importantly, health-assistive smart homes provide assistance to the elderly to track their physical and mental health status, which may extend their time to live independently in their preferred environment [10]. Considering the contextual information collected from different sensing sources, spatial information, e.g., the resident’s location, is very important to ensure the quality of service provided to residents [11] The resident’s current location in the environment is very useful when investigating their behavior patterns, and it is strongly related to activities performed in their daily life. For instance, activity recognition in a smart home learns residents’ movement patterns based on spatial reasoning. Smart home systems can then provide automated control of different aspects in relevant areas according to residents’ whereabouts that satisfy their daily routine needs. Furthermore, by inferring activities that deviate from daily routine, residents’ behavioral anomalies can be identified to notify and alert residents. To do so, residents’ activities must first be recognized to provide these services. Thus, finding suitable solutions that are viable for recognizing spatial information in a smart home is becoming increasingly important to support the growing aging population [12].
In [13], various sensors such as electromagnetic door contacts and infrared motion sensors were deployed around the environment to capture and collect data in a non-invasive manner when changes were detected. Sensors are usually strategically deployed in a particular location to carry out their tasks, and it is often necessary to know where sensors are deployed in order to track the whereabouts of residents. This requires labeling the deployment location of the sensors in advance (e.g., “motion sensor in the living room”, “door sensor at main entrance”) or assuming that predefined location-specific sensor data are applied [14]. This is either done by a professional installer or manually defined by users [15], which can result in errors in cases of users with no experience. Moreover, data labeling is time-consuming and annoying, and these labels can be unreliable [16]. The authors of [17] discovered that some data in a specific dataset were either unlabeled or contain spurious activities because the data were manually labeled by the resident, and imprecision and labeling noise may occur, increasing the difficulties of applying smart home monitoring techniques to realistic environments. To alleviate this problem, in this study, we propose an approach for periodic behavioral routine discovery that utilizes the virtual location concept to fill the gap in the works of the related literature. The idea is to extract implicit spatial information using hidden correlations between sensors deployed in the smart home environment and divide sensors into clusters called virtual locations based on the correlations among sensors and sensor types. This provides an abstract spatial representation of where sensors are deployed in the smart home environment and assigns a conceptual location to each sensor. For instance, a resident in a smart home environment may trigger a number of sensors while performing their daily activities. As the resident triggers a sensor, a nearby sensor may also be triggered soon after. This indicates a strong correlation between these sensors, which implies that they are likely to be physically close to each other.
The characteristics of different sensors may provide different types of knowledge about the environment. For example, the division of spaces can be inferred by a door contact sensor, and the occurrence of an activity or movement between different spaces in a specific region can be acquired by motion detectors. Thus, utilizing different types of sensors and knowledge of sensor correlations, it is possible to estimate the resident’s location as sensors are being triggered and compose their movement patterns. To validate the viability of this concept, in this study, we propose an unsupervised approach to discover periodic behavioral routines in a smart home where predefined location-specific sensor data are unavailable. The result of this approach can be further utilized to provide automation rules to assist with controlling different aspects of the smart home environment or to identify behavioral anomalies that deviate from periodic behavioral routines.
The main contributions of this study are summarized as follows.
  • Abstract spatial representations of the physical living space are established, i.e., virtual location, which utilize the sensor correlations created by the occurrence and sequence of events. Virtual location does not need predefined or prior labeling of sensor locations in the environment. Our method provides an alternative solution for situations in which sensor locations are not available.
  • A weighted graph is constructed to model the temporal correlations between sensors. Time differences between events can be calculated used to analyze the time correlation between any two sensors. A weight function is adopted to adjust the weight of correlations according to the sensor type.
  • A method to determine transitional probability is developed to determine the probable transitions between activities. A strict sequence of periodic behavioral routines may be challenging, as the formation of the same routine may be irregular or inconsistent. Thus, transitional probability allows for limited deviations from periodic behavioral routines, which may facilitate the identification of daily activities and routine formation.
  • We experimentally explore the validity of the concept of virtual location and demonstrate that this concept works well in a smart home environment without prior knowledge of where sensors are deployed. Hence, the proposed method offers great flexibility in the deployment of sensors in smart homes and can be suitably applied in real situations in which sensor deployment and space division differ.
The remainder of this study is organized as follows. In Section 2, we present the concepts and technologies used in the proposed method. In Section 3, we describe the proposed method and system architecture and provide details about each component when utilized in a smart home application. In Section 4, we present the evaluation methods, the experimental setup, and the experimental results of the proposed method. Finally, in Section 5, we draw conclusions.

2. Related Work

This study explores the value of the virtual location concept to smart home applications and practical deployments. There are various methods and techniques for detecting and monitoring people in an indoor environment, each of which has pros and cons. This study summarizes existing work related to three primary research directions: (1) location tracking, (2) activity recognition, and (3) graph clustering. In this study, we draw upon ideas and methods from these categories.

2.1. Location Tracking

Unique context information called user location [18] has gained recognition for its essential role in the smart home environment [19]. Activity recognition is commonly employed using sensors deployed in a smart home environment or as wearable sensors worn by the resident [20]. These sensors provide location information regarding where the resident triggers sensors. However, most existing solutions do not take spatial aspects into account or incorporate them in a minimal way [21,22]. For example, a smartphone-based localization method was proposed in [23] to explore the logical location of users. This includes using smartphone features such as accelerometers, microphones, cameras, and Wi-Fi to extract information about the sound, color, and lighting of the environment, as well as the user’s motion. The authors of [24] conducted a study to estimate the user’s location using an active sound-probing technique with a built-in speaker and microphone on a smartphone to adaptively disable image capture devices to protect privacy in a public restroom. The authors of [25] designed an active sensing system that utilizes acoustic signatures based on predesigned beep signals emitted by a smartphone to identify location semantics via echoes reflected from different static reflectors. The authors of [26] used stationary objects inside a building, such as pillars, railings, walls, doorways, and electrical equipment, to detect magnetic fingerprints using a magnetometer in a smartphone to perform indoor localization. The authors of [27] developed a system to monitor and assist the elderly in their daily activities using an RFID system for indoor localization. The patient wore multiple active tags, and RFID readers were placed on the walls to detect the patient’s whereabouts. The authors of [28] proposed a crowdsourcing approach to build an indoor positioning and navigation map utilizing Wi-Fi received signal strength (RSS) samples collected by the user’s mobile devices in combination with landmarks to detect and calibrate user location. Some studies require predefined location of sensors to provide location-specific sensor data and enable location prediction [14]. On the other hand, sensors that monitor and track users’ whereabouts using imagery and acoustics are usually perceived as intrusive [29]. Furthermore, providing predefined location-specific sensor data or labeling the location of sensors manually may be very time-consuming because labeling data for training is often an expensive process [16].

2.2. Activity Discovery

Activity discovery (AD) [30] is a data mining process for the discovery of interesting patterns by finding sets of events that frequently occur in sensor data. An example of AD is the episode discovery (ED) Algorithm [31]. An episode is a set of events, and the goal of ED is to identify episodes with a number of occurrences greater than a predefined threshold in an event sequence. An approach based on the minimum description length principle [32] is one example of an ED algorithm. The concept of this approach is that the model with the shortest description is the best model describing the data. ED replaces the occurrences of the episodes with pointers to obtain a more compact representation. ED runs the following steps iteratively: (1) generate a list of candidate episodes; (2) discover the periodicity of each candidate episode; (3) the episode that allows the shortest representation is identified as the pattern of interest. Details of ED are as follows.
First, ED processes the event sequence ( D = d 1 , d 2 , , d n ) generated by sensors using a sliding window with a predefined length to collect candidate episodes. An episode ( E = e 1 , e 2 , , e m ) occurs if there are m events that match the m events in d k D . Formally, there is an occurrence of ( o ) of episode E = e 1 , e 2 , , e a at time t 1 if permutation σ exists in 1 , , a , and timestamp a is t 1 t 2 t a , such that e σ 1 , t 1 , ,   e σ a , t a is a subsequence of d k = e 1 , t 1 , , e b , t b , where a b and d k D .
After obtaining occurrences of each episode, two periodicities are estimated with different time granularities: fine-grained and coarse-grained, indicating that the number of occurrences is truncated to an hour and a day, respectively. The periodicity of an episode is calculated based on repeating cycles of time differences between episodes. In ED, the periodicities of episode E are estimated as follows.
  • Obtain timestamps of occurrences of E : t 1 , t 2 , , t n ;
  • Truncate the timestamps to an hour or a day according to the time granularity: t 1 , t 2 , , t n ;
  • Calculate the time difference between timestamps: δ t 1 , δ t 2 , , δ t n 1 ;
  • Estimate the length ( l ) of the repeating cycle of time differences between episodes using an autocorrelation measure.
The timestamps of occurrences of E are processed according to the length ( l ) of the repeating cycle. For each sequence of l time differences ( δ t k , δ t k + 1 , , δ t k + l 1 ), check whether δ t k is matched against δ t k + l , δ t k + 1 is matched against δ t k + l + 1 , etc. The occurrence is marked as a mistake when the time difference does not match the expected occurrence, and the periodicity is recalculates the time differences for the next sequence of l . Finally, rewrite the data using the periodicity information and select the episode with the shortest data length as the desired pattern. ED was proven effective in the MavHome project [33]. However, it lacks flexibility with respect to the time occurrence of episodes. Furthermore, when unexpected events are marked as mistakes, some important episodes of interest are not considered. Moreover, several articles have introduced probability and machine learning techniques to perform the AD process in a smart home environment. For instance, the authors of [34] proposed a global method based on probabilistic finite-state automata based on the knowledge of the training event logs database and a hierarchical decomposition of activities to monitor actions and moves to conduct AD automatically. A perplexity evaluation utilizing the normalized likelihood is adopted to select the most probable activities of daily living in activity recognition. The authors of [35] introduced a smart home control platform that analyzes the historical usage records of home automation devices to detect residents’ behavior patterns through sensors and IoT devices. The machine learning C4.5 algorithm was applied to generate a decision tree for automatic configuration of devices adjusted according to the user’s preferences.

2.3. Graph Clustering

Graph clustering (GC) is a process that discovers sets of related vertices with specific properties in a graph ( G = V ,   W ) with vertices ( V ) and edges ( W ). GC has been proven effective in various domains, e.g., computer vision, biology, and social sciences. The authors of [36] divided GC methods into five main types:
  • Cohesive subgraph discovery: Search the desired partition with specific structural properties that subgraphs should satisfy under a certain condition, e.g., n-cliques and k-cores;
  • Vertex clustering: Place vertices in a vector space where the pairwise distance between every two vertices can be computed or map the vertices to points in a low-dimensional space using the spectrum of the graph. Then, the graph clustering problem can be solved by traditional clustering methods, e.g., k-means and agglomerative hierarchical clustering;
  • Quality optimization: This method optimizes some graph-based measures of partition quality, such as normalized cut, modularity optimization, and spectral optimization;
  • Divisive: Iteratively identify the edges or vertices positioned between clusters, e.g., min-cut and max-flow;
  • Model-based: Consider an underlying statistical model that can generate partitions of the graph, e.g., the Markov cluster algorithm.
The authors of [37] introduced a community detection method that employs local similarity to form communities by performing similarity measurements between nodes and their neighbors. Then, it utilizes degree clustering information that combines the local neighborhood ratio with the degree ratio. A large number of nodes with a low degree must adopt fewer nodes with a high degree, and each node in small-scale communities must attempt to connect the nodes with a high degree to expand communities. The authors of [38] proposed a community detection algorithm that utilizes the idea of graph clustering and iteratively applies min-cut to divide a community into two smaller communities. Modularity is used after each division as a stopping criterion to stop iterations of community division. In this study, we aim to identify sets of vertices with a high correlation when the number of clusters is not provided in advance. Thus, this study extends the Louvain method for graph clustering. The Louvain method is one of the modularity optimization methods proposed in [39]. It has been proven to outperform many similar optimization methods in terms of both modularity and the cost of time [40].

3. Virtual Location-Based Periodic Behavioral Routine Discovery

In this study, a novel concept called virtual location is introduced and was utilized to discover behavioral routines performed by a resident without prior labeling of the actual location of the sensors. Figure 1 shows the system architecture of a smart home application utilizing the proposed method; it contains two phases: the model construction phase and the real-time process phase. The model construction phase comprises three main processes: data collection, spatial information extraction, and activity and routine discovery. The primary goal of the proposed method is to discover activities ( A k ) in a virtual location ( v l k V L ) in the smart home environment from an event sequence ( E = e 1 ,   e 2 ,   ,   e n ) obtained via sensors data ( D ). To enhance readability and easy reference, we have summarized the major mathematical notations in Table 1.
A set of virtual locations is defined as V L = v l 1 , v l 2 , v l n , where V L denotes a partition of the sensors with the highest modularity, and v l k denotes a set of sensors in a specific virtual location. An event ( e k = t k , i d k , s t a t u s k ) contains a timestamp ( t k ), the sensor ID ( i d k ), and the sensor status ( s t a t u s k ) at time t k . A weighted graph ( G = V , W ) is used to model the correlation between sensors in the environment and to discover V L . Meanwhile, W is a symmetric matrix representing the correlation between each pair of sensors and is adjusted according to the sensor type of each vertex; the partition of V with the highest modularity is regarded as V L . Furthermore, the sensor data ( D ) can be split into D 1 ,   D 2 ,   D n according to the virtual location where sensors are deployed after virtual locations are identified. D k is transformed into event sequence E k and split into maximal episode M E k using a sliding window, where E k denotes the subsequence of E belonging to virtual location v l k . Frequent episodes ( F E k ) are discovered from M E k , where S u p f e k , i S m i n , f e k , i F E k . Activities ( A k ) are found by analyzing the periodicity of each f e k , i F E k , where A c c a k , i A m i n , a k , i A k . Then, M E k is transformed into activity sequence ( A S k ), and routines ( R ) can be discovered from A S , where C o n f r k C O N F m i n , r k R . Based on the discovered routines ( V L , A k , R ), this information can be applied to smart home applications, such as home automation or anomaly detection to identify abnormal behavior of residents or to suggest automation rules that control different aspects of the home environment based on the models constructed from historical sensor data.
In the real-time process phase, real-time sensor data ( D r ) are collected progressively. As with data collection, D r is preprocessed, transformed into an event sequence, and stored in the event database. Events stored in the event database are partitioned with a sliding window into maximal episodes. Furthermore, the system recognizes activities from these maximal episodes and stores them in a recognized activity database ( R A D B ) if any activity is recognized. In the meantime, the virtual location of the resident ( v l c ) is determined by the virtual location of the last triggered sensor. Finally, after obtaining the virtual location of the resident ( v l c ), the activities that the resident has performed stored in the R A D B , the discovered activities ( A k ), and routines ( R ) discovered from the historical sensor data, smart home applications can utilize this information to infer resident behavior of the current virtual location and perform the desired task designed by the application. The details of each component in the system architecture are described in the following sections.

3.1. Data Collection

Data collection is the process that transforms raw sensor data into event sequences. Data collection involves three steps: sensor data collection, data preprocessing, and event extraction.

3.1.1. Sensor Data Collection

Sensors are devices that detect events or changes in the environment and convert them into measurable digital signals. In this study, we use sensors to detect and record the resident’s daily activity in the smart home environment. Thus, sensors are deployed around the environment with unique IDs, and sensor data are sent to the smart home gateway for further analysis. Four types of sensors are used in the proposed method: PIR motion detectors, door contacts, power meters, and binary sensors. A PIR motion detector measures infrared light radiating from objects and generates a record formatted as t i m e s t a m p ,   s e n s o r   I D when triggered. A door contact is used to sense the opening and closing of doors and generates a record periodically formatted as t i m e s t a m p ,   s e n s o r   I D ,   d o o r   s t a t u s , d o o r   s t a t u s o p e n ,   c l o s e . A power meter is used to measure the amount of electric energy consumed by household appliances and generates a record periodically formatted as t i m e s t a m p ,   s e n s o r   I D ,   p o w e r . Finally, binary sensors such as pressure switches, temperature switches, and buttons only have two states: either on or off. The data from the database of the home gateway are raw data. From the home gateway, the data are uploaded periodically to the database in the cloud. All these raw sensor data received by the database in the cloud are analyzed via a data-mining algorithm to generate wellness patterns, which are defined as activities and routines in this study. However, any device or application connected to the Internet is vulnerable to attacks, malware, and tracking software. Maintaining protection for sensors and the system has become a major concern [41]. Therefore, in this study, we adopted and established a chain-of-trust concept to protect data transmission between the home gateway and the cloud. First, a firewall is established to prevent unauthorized or malicious software from accessing the network. A virtual private network (VPN) is utilized to ensure all smart home traffic is transmitted through an encrypted virtual tunnel, and a commercial cloud server is used as the endpoint for traffic originating from the home gateway. We only allow connections via localhost by default and always with TLS, a VPN is utilized to transmit sensor data to the cloud for analysis, and only specific IP addresses are allowed in the environment.

3.1.2. Data Preprocessing

The sensor data collected in the smart home environment might include abnormal data due to sensor malfunction or unexpected environmental inconstancies. As a result, the sensors may produce poor, noisy, and fragmentary data. Thus, to alleviate this situation, sensor data with a status is greater than m e a n + s t a n d a r d   d e v i a t i o n · 3 or less than m e a n s t a n d a r d   d e v i a t i o n · 3 are considered outlier data. Redundant sensor data, outlier data, and incomplete sensor data are be removed. Furthermore, information about the status of sensors, which is not binary, is discretized, such as the status of power meters. For each sensor that needs to be discretized, we apply k-means K = 2 to partition the statuses into two clusters: C m i n and C m a x , where m a x C m i n < m a x C m a x . Then, the statuses in C m i n are transformed into v , and the statuses in C m a x are changed into v + .
To discover virtual locations, the preprocessed data ( D ) and the number of sensors ( n ) are used to extract an event sequence ( E ). They are split into maximal episodes using a sliding window. The event sequence ( E ), time threshold ( T T ), and the weight corresponding to T T ( W T ) are utilized to construct a correlation graph. T T and W T are dynamically determined using the time differences between all sensor events. Then, a weighted graph ( G ) is constructed using the correlations between sensors, and this weight is adjusted according to the sensor type that triggered the event. This weight is stored in a matrix called I D I , and both the weighted graph ( G ) and the correlation matrix ( I D I ) are used together with weights W m , W d , and p ^ in modularity. Sensors are partitioned into virtual locations according to their modularity, and sensors with high modularity are likely to be partitioned into the same virtual location. The procedure of virtual location discovery is illustrated in Figure 2, and details of this procedure are described in the following sections.

3.1.3. Event Extraction

The preprocessed sensor data are transformed into an event sequence ( E ) in the event extraction process. An event represents changing statuses of a sensor, denoted as t i , e i , where e i = s e n s o r   t y p e , s e n s o r   I D , s t a t u s   b e f o r e   c h a n g e , s t a t u s   a f t e r   c h a n g e is an event type. For example, given raw sensor data = {(1:05, TV, 0 W), (1:10, TV, 42 W), (1:15, TV, 46 W), (1:22, TV, 0 W)}, we can retrieve the event sequence = {(1:10, TV, TURN ON), (1:22, TV, TURN OFF)}. Algorithm 1 shows the algorithm that extracts event sequences.
Algorithm 1 Event Sequence Extraction.
Input: D : preprocessed sensor data, n : number of sensors
Output: E : event sequence
1.EArray() /* Initialize an array to store events */
2.S ← HashTable (n) /* Initialize a hash table with length 𝑛 to store latest status of sensors */
3.FOR each d in D′
4.IF S[d.sensorID] d.st atus
5.THEN
6.    c ← (S[d.sensorID],d.status) /* Obtain changing status of sensors */
7.    e ← Event(d.timestamp, d.type, d.ID, c) /* Initialize an event */
8.    E.append(e) /* Append the event to E */
9.   S[d.sensorID] = d.status /*Update latest status of the sensor */
10.ENDIF
11.ENDFOR
12.RETURNE

3.2. Implicit Spatial Information Extraction

The main task of this process is to extract implicit spatial information from the event sequence and form the concept of virtual location.

3.2.1. Correlation Graph Construction

A weighted sensor correlation graph ( G = V , W ) is constructed to model the temporal correlations between sensors, where V is a set of vertices representing all the sensors, and W is an asymmetric V × V matrix representing the correlation between sensors. The higher the correlation between sensors, the greater the similarity between the corresponding vertices. Furthermore, indirect information ( I D I ) is saved in the process of estimating the correlations and stores a set of sensors that are triggered during the time interval between two events. The time correlation between two sensors is calculated based on Equation (1):
w v i , v j = k = 1 N T c i , j k · w t k
where w is the weight function representing the correlation between the two sensors ( v i , v j V ), c i , j k is the time difference between events that are less than the time threshold ( t t k ), and w t k is the weight corresponding to t t k . Figure 3 shows an example of how the weight function works.
A set of time thresholds ( T T ) and a set of weights corresponding to T T ( W T ) are used to increase the weight of the edge between two sensors that are usually triggered together. For example, if a door sensor ( s k ) is always triggered between sensor s i and s j , this may imply that the door sensor ( s k ) is deployed between s i and s j . This inference can be utilized to decrease the weight between two sensors in different locations. Moreover, sensor placement is unique in each environment, and people tend to have different habits in different environments. Thus, T T and W T in this study are dynamically determined according to the actual environment based on the mean value and the standard deviation of time differences between all sensor events. Algorithm 2 presents the algorithm of correlation graph construction.
Algorithm 2 Correlation Graph Construction.
Input: E : event sequence, T T : time thresholds, W T : weight corresponding to T T
Output: G : weighted graph, I D I : matrix stores correlation information of sensor
1.S ← get_sensor_list(E) /* Iterate through event sequence to obtain sensor list */
2.LD ← Array(|S|) /* Initiate an array stores each sensors’ time of last occurrence */
3.TD ← Matrix(|S|, |S|) /* Initiate a matrix stores occurrence time differences between
𠀃 sensors */
4.IDI ← Matrix(|S|, |S|) /* Initiate a matrix stores indirect information */
5.FOR each eE
6.LD[e.ID] ← e.timestamp /* Update last occurrence time of sensor e.ID */
7.  FOR each eE, where e.IDe.ID
8.   te.timestamp−LD [s.ID] /* Obtain the time difference */
9.  𝑇𝐷[𝑠.𝐼𝐷,𝑒.𝐼𝐷].append(𝑡) /* Append time difference to 𝑇𝐷 */
10.  𝑖𝑠𝑑←get_indirect_sensor_list(𝑒.𝑡𝑖𝑚𝑒𝑠𝑡𝑎𝑚𝑝,𝐿𝐷[𝑠.𝐼𝐷]): /* Obtain sensors occurred
                           between 𝑒.𝑡𝑖𝑚𝑒𝑠𝑡𝑎𝑚𝑝 and
                           𝐿𝐷[𝑠.𝐼𝐷] */
11.   FOR each 𝑠′∈𝑖𝑠𝑑
12.     𝐼𝐷𝐼[𝑠.𝐼𝐷,𝑒.𝐼𝐷].append(𝑠′) /* Store the sensors to 𝐼𝐷𝐼 */
13.    ENDFOR
14.  ENDFOR
15.ENDFOR
16.Create an undirected weighted graph 𝐺 with |𝑆| vertices
17.FOR each 𝑠𝑖,𝑠𝑗∈𝑆, where 𝑖<𝑗
18.  𝑤←0 /* Initial an integer to store the sum of weight */
19.  FOR each 𝑡∈TD[𝑠𝑖.𝐼𝐷,𝑠𝑗.𝐼𝐷] or TD[𝑠𝑗.𝐼𝐷,𝑠𝑖.𝐼𝐷]
20.   FOR each 𝑡𝑡𝑘∈𝑇𝑇 /* Iterate through 𝑇𝑇, 𝑡𝑡𝑘∈𝑇𝑇 is in ascending order */
21.    IF 𝑡<𝑡𝑡𝑘
22.   THEN
23.      𝑤=𝑤+𝑤𝑡𝑘 /* Add the weight according to the time difference */
24.     ENDIF
25.   ENDFOR
26.  ENDFOR
27.  Add an edge between 𝑠𝑖 and 𝑠𝑗 with weight 𝑤
28.ENDFOR
29.RETURN 𝐺,𝐼𝐷𝐼 /*Return the weighted graph and matrix storing indirect information */

3.2.2. Virtual Location Discovery

Sensors in the environment are partitioned into clusters based on the sensor correlation graph and form the concept of virtual locations, denoted as v l k V L . However, this process does not attempt to match actual rooms with virtual locations, instead grouping sensors that are physically close to each other or that have strong correlations with other sensors within a set period [42]. Thus, a large space may form more than one virtual location if sensors are deployed far from each other or are not often triggered in correlation with other sensors. Let C = C 1 , , C k be a partition of V , where C 1 C k = V and C i C j = i j . The modularity used to measure the quality of the partition expressed in Equation (2).
Q = 1 2 m i j W i j s w i s w j 2 m δ c i , c j
where W i j represents the edge weight between vertices v i and v j ; s w i and s w j represent the sum of edge weights connected to vertices v i and v j , respectively; m represents the sum of all edge weights in the graph; s w i s w j 2 m represents the probability of the existence of an edge between vertices v i and v j if the edges were randomly connected; and δ c i , c j returns 1 if vertices v i and v j are in the same cluster and returns 0 otherwise. Modularity represents the fraction of the edges in a given virtual location subtracted from the expected fraction if edges were randomly connected, and its value is in the range 1 2 , 1 = Q | 1 2 Q < 1 .
Modularity was designed to measure the quality of the clusters. Thus, clusters with higher modularity imply that sensors are strongly correlated with sensors in the same virtual location. In contrast, sensors with weaker correlations are partitioned into different clusters. Hence, virtual location discovery can be formulated as a modularity optimization problem to find clusters with maximized modularity. Furthermore, there are cases in which sensors may have a strong correlation and are physically deployed near each other but separated by walls. As a result, it is sometimes difficult to distinguish which event occurred in which room. To alleviate this phenomenon, different characteristics of sensors, such as motion detectors and door sensors, can be utilized to improve clustering results. For example, a motion detector event can represent the presence of a resident, but a binary sensor will not be triggered when a resident walks past it. Thus, the correlation between a sensor and a motion detector may be more important than a binary sensor. Moreover, suppose a door sensor is always triggered between two subsequent events generated by the other two sensors. This situation implies that these two sensors are located in different regions of the environment. Based on this principle, the weights of the sensor correlation graph ( G ) may be adjusted according to the type of sensor that triggers the event. The adjustment rule can be formulated as follows: increase the weight between a motion detector and any subsequent sensors triggered after the motion detector and decrease the weight between two sensors that always have a door sensor triggered between them. The virtual location discovery algorithm extends the Louvain method [36] to discover virtual locations, as illustrated in Algorithm 3. The extension was made to adjust the weight of each edge according to sensor type, and door sensors are not situated in any virtual location act as a bridge between locations. This algorithm represents an attempt to improve modularity by removing a sensor from its virtual location and moving it to a neighboring virtual location until increasing modularity becomes impossible.
Algorithm 3 Virtual Location Discovery.
Input: G : weighted graph, I D I : matrix stores correlation information of sensor, W m : weight to increase the edge between a sensor and a motion sensor, W d : weight to decrease the edge between sensors which are split by a door sensor, p ^ : minimal proportion of time differences between a door sensor
Output: C : partition with the highest modularity
1.FOR each node v i , v j V , where i < j
2.IF  v i . t y p e = m o t i o n or v j . t y p e = m o t i o n
3.THEN
4.   w i , j = w i , j · W m /* Increase w i , j weight up to W m -fold */
5.ENDIF
6.FOR each node v k , where v k . t y p e = d o o r , k i , k j
7.  IF proportion of v k in C I L v i . I D , v j . I D > p ^
8.  THEN
9.   w i , j = w i , j · W d /* Decrease w i , j weight down to W d -fold */
10.  ENDIF
11.ENDFOR
12.ENDFOR
13. C Assign each node of G to its own virtual location;
14.REPEAT
15.FOR each node v i
16.   i n c r e a s e 0 ; /*Initial an integer to store the increasing modularity */
17.  FOR each neighbor v j of v i
18.     t modularity_gain ( v i , v i ); /* Compute changes in modularity after remove
                   v i from its own virtual location and move it to
                  virtual location v j */
19.   IF  t > i n c r e a s e
20.   THEN
21.     increase t ; /* Update i n c r e a s e if t is greater than itself */
22.   ENDIF
23.   IF  i n c r e a s e 0
24.   THEN
25.    C remove v i from its own virtual location and move it to the virtual location of v j
26.           with highest i n c r e a s e ;
27.   ELSE
28.    Exit the loop;
29.   ENDIF
30.  ENDFOR
31.ENDFOR
32.UNTIL
33.RETURN C

3.2.3. Probability Matrix Construction

After the virtual locations are discovered, the location of each sensor is known. When a sensor ( s k ) is triggered at time t k , resident occupancy can be inferred at t k in the virtual location of s k . A probability matrix ( P ) can be constructed after dividing 24 h of a day into time slots ( T S ) with equal size. P is a V L × T S matrix, where V L is a set containing all virtual locations, T S is a set containing all time slots, and P [ v l k , t s k ] represents the probability of user occupancy during time slot t s k and in virtual location v l k based on historical data. The concept of the probability matrix is shown in Figure 4.

3.3. Activity and Routine Discovery

In this study, we use an activity to describe a resident’s periodic behavior. Discovery of the activities in each virtual location and the association rules between them involves four steps, namely event sequence segmentation, frequent episode mining, periodicity analysis, and routine discovery. Although each resident may have specific behavioral habits, it is not easy to discover and mine these patterns because considerable randomness in activities and irregular or inconsistent activities may occur in daily living. The next activity is decided by the current activity and previous activities. Any changes may break the periodic nature of an activity. Thus, discovering the activities in each virtual location first, then mining their routines using transitional probability between activities, may alleviate this problem by allocating activities to a location and inferring routines according to different activity combinations and probabilities between activity transitions. In addition, allowing limited deviations from periodic behavioral routines may facilitate the formation of daily activities and routines. As a result, the discovered patterns are more compact than those without the knowledge of sensor location, which means the number of discovered patterns is significantly reduced with the help of the virtual locations. This is because not knowing the location where activities occur makes it impossible to distinguish where the activity happened and makes it difficult to provide an accurate boundary when attempting to discriminate the start and end of a behavior.
Furthermore, a similar pattern with slight deviation will create a significant amount of behavioral activities. This may distract the recommendation decisions made by smart home applications. Figure 5 shows the concept of differences between activity and routine discovery methods with and without the concept of virtual location.
To achieve this, the entropy rate [43] is utilized for similarity measures and to detect the degree of deviation between the sequence of periodic behavioral routines and the activities and routines performed by the resident. Entropy usually serves as a measure of the randomness of a sequence [44]. Thus, it can be applied to the activity and routine sequences performed by the resident, leveraging the already constructed probability matrix ( P ) [45]. The similarity measure is calculated based on Equation (3):
ε = i , j P i j × log P i j
where ε is the entropy value, and P i j is the transitional probability between activities A i and A j from activity sequence A S k . Lower entropy values indicate a greater probability that activity A j occurred after activity A i , and higher entropy values indicate a lower probability. However, it may be insufficient to only consider the transitional probabilities between activities in periodic behavioral routines; the duration of each activity should also be considered to reduce the potential false-positive rate in order improve accuracy when determining whether current activities deviate from periodic behavior routines performed by the resident, i.e., by averaging the duration of each activity and dividing it by the number of times it has occurred. The average duration of an activity is calculated based on Equation (4):
a v g A i = j = 1 m t A i , k m , m = c o u n t A i
where t A i , k represents the duration of the k th occurrence of activity A i , and m is the total number of times that activity i has occurred. Here, cosine similarity is utilized to quantify the similarity relation between the activities and routines performed by the resident and the activities in the periodic behavioral routines considering activity durations. The cosine similarity is calculated based on Equation (5):
S d R d = cos d , R d = i = 1 n t d A i × t b A i i = 1 n t b A i 2 × i = 1 n t d A i 2
where S d R d represents the similarity relation between the activities and routines, R d is the periodic behavioral routines of the same day of the week for which the sequence of activities is being analyzed, d is the day for which the sequence of activities is analyzed, i is equal to hours, 0 < i 24 , t d A i is the duration of activity A i on the day being evaluated, and t b A i is the duration of activity A i in the periodic behavioral routines. A cosine similarity between two vectors close to 1 implies that the activities and routines performed by the resident and the activities in the periodic behavioral routines are similar. A cosine similarity is close to 0 indicates fewer similarities between them. Thus, by comparing the similarity between periodic behavior routines and the activities and routines performed by the resident, knowledge can be obtained about whether the resident has deviated from their periodic behavioral routines.

3.3.1. Event Sequence Segmentation

A sliding window with two parameters ( T E P and C E P ) is used to partition the event sequence ( E k ) in each virtual location ( v l k ) into overlapping maximal episodes. A maximal episode is an episode meeting the two constraints: T E P and C E P , where T E P is the maximal time difference between events in an occurrence of an episode, and C E P is the maximal capacity of an episode. In event sequence segmentation, the events in E k are split into maximal episodes from E k . A sliding window collects the events and generates an episode when the constraints are exceeded. If T E P = , then E k is split into maximal episodes with size C E P . If C E P = , then E k is split only depending on the time difference. Figure 6 shows an example of the procedure of event sequence segmentation.

3.3.2. Frequent Episode Mining

The problem of mining frequent episodes in maximal episodes is similar to the problem of mining frequent item sets in a list of transactions. One of the main differences between these two problems is that the maximal episodes are overlapped, so the number of occurrences of an episode counted in maximal episodes is greater than the actual number of occurrences of this episode.
This study extends the split and merge algorithm (SaM) to discover frequent episodes as shown in Algorithm 4. SaM is a frequent itemset mining algorithm proposed in [46]. The advantages of SaM are its simplicity of data structure and the convenience of running on external storage. The following change is made: instead of using an integer to represent the support of an event, we use an additional list called t _ l i s t , which stores timestamps of occurrences of the event. Therefore, the actual support of the event is the number of distinct timestamps in the list as shown in Algorithm 5. For example, if an event sequence ( a , 1 , b , 8 , c , 9 , d , 14 ) is partitioned into two maximal episodes ( a , 1 , b , 8 , c , 9 , b , 8 , c , 9 , d , 14 ) with T E P = 10, the number of occurrences of episode b , c in maximal episodes is two, but the actual number of occurrences of b , c can be acquired by counting the number of distinct timestamps in t l i s t = 8 , 9 , 8 , 9 , which is one in this case. Figures 10 and 11 show the algorithms of frequent episode mining.
Algorithm 4 Frequent Episode Discovery.
Input: E k : event sequence in virtual location v l k , M E k : maximal episodes in virtual location v l k , S m i n : minimal support
Output: F E k : frequent episodes in virtual location v l k
1.Count the number of occurrences of each event type in E k
2.Remove the duplicate event types in each M E
3.Sort the event types in each M E by their count
4.Sort the M E by the count of their first event type
5.Initialize set of F E k = { }
6. n E S a M ( M E k ,   { } ,   S m i n , F E k )  
7.RETURN  F E k
Algorithm 5 Extended Split and Merge Algorithm.
Input: M E : maximal episodes, P : prefix episode, S m i n : minimal support, F E : frequent episodes
Output: n : the number of frequent episodes
1.Initialize event type i , /* leading event type */
2. integer n , /* the number of frequent episodes */
3. List of timestamp s , /* t _ l i s t store the timestamps */
4. List of maximal episode b , /* store the split result */
5. List of maximal episode c , /* store the split result */
6. List of maximal episode d /* store the output */
7.𝑛←0
8.WHILE  M E is not empty
9. b ←[ ] /* initialize the split result */
10. s ←[ ] /* initialize t l i s t */
11. i M E 0 . events 0 . type /* get the leading event type of the first maximal episode */
12.WHILE  M E is not empty and M E 0 . events 0 . type = i // split data based on this item
13.  Append M E 0 . events 0 . timestamp to s
14.   Remove M E 0 . events 0 from M E 0 . events
15.ENDWHILE
16.IF  M E 0 . events is not empty
17.THEN
18.  Remove M E 0 from M E and append it to b
19.ELSE
20.  Remove M E 0 from M E
21.ENDIF
22. c b /* store the split result */
23. d ←[ ] /* initialize the merge result */
24.WHILE  M E and b are both not empty do /* merge data */
25.  IF  M E 0 . events > b 0 . events
26.  THEN
27.   Remove M E 0 from M E and append it to d
28.  ELSE IF  M E 0 . events < b 0 . events
29.  THEN
30.   Remove b 0 from b and append it to d
31.  ELSE
32.    b 0 . support = b 0   . support + M E 0 . support +
33.   Remove b 0 from b and append it to d
34.   Remove M E 0 from M E
35.ENDIF
36.ENDWHILE
37.WHILE M E is not empty
38.    Remove M E 0 from M E and append it to d
39.ENDWHILE
40.WHILE 𝑏 is not empty
41.    Remove b 0 from 𝑏 and append it to d
42.ENDWHILE
43. M E d
44.IF the number of distinct timestamps in s s m i n /* if the split event is frequent */
45.THEN
46. P P i
47. Append P with s to F E
48. n n + 1 + ESAM c ,   P ,   s m i n ,   F E
49. P P i
50.ENDIF
51.ENDWHILE
52.RETURN 𝑛 /*return the number of frequent episodes */>

3.3.3. Periodicity Analysis

Gaussian distribution describes the time distribution of the occurrences of each frequent episode. A frequent episode with an accuracy that corresponds to the given Gaussian distribution and is greater than the minimal accuracy ( A C C m i n ) is regarded as an activity. For each frequent episode, time intervals are derived from the timestamps of their occurrences with maximal standard deviation ( S D m a x ) and period ( π ). An interval consists of timestamps for which the time difference between every two adjacent timestamps in this interval is less than S D m a x . The concept of finding the intervals is shown in Figure 7. According to the length of the dataset, different periods are tested: 24 h, 7 days, etc.
For each interval of each frequent episode, the parameters of the Gaussian distribution that best describe the interval are estimated. The maximum likelihood method is the standard approach to this problem and requires the maximization of the log-likelihood function. In this study, we use existing and well-developed tools to solve this problem. After two parameters, the mean and the standard deviation μ , σ of the Gaussian distribution are estimated, the accuracy of each frequent episode can be calculated, which is the number of occurrences within the time interval ( μ 2 · σ , μ + 2 · σ ). Every interval with a corresponding accuracy greater than A m i n for each frequent episode forms an activity.

3.3.4. Routine Discovery

A routine ( r i ) is an extended association rule with confidence greater than the minimal confidence ( C O N F m i n ) used to describe the temporal relation between activities. After the activities are discovered, the event sequence ( E k ) in each virtual location ( v l k ) is transformed into the activities sequence ( A S k ), where A S k is a sequence of the occurrences of the activities recognized from E k . Collect all A S k into A S and sort A S by their timestamps. Sequentially iterate through the sorted A S and store each time difference into the matrix T D , where T D [ a i , a j ] stores time differences between each occurrence of a i and a j . For each a i and a j , where i j , if the standard deviation of time differences in T D [ a i , a j ] is less than S D m a x and the confidence is greater than the minimal confidence ( C O N F m i n ), a routine ( r i = ( a i , a j , m e a n , s t d , c o n f )) is generated, where m e a n is the mean value of the time difference in T D [ a i , a j ], s t d is the standard deviation of the time differences in T D [ a i , a j ], and c o n f is the ratio of the number of time differences in T D [ a i , a j ] to the number of occurrences of a i .

4. Experiment and Discussion

In this section, an experiment was designed and conducted to explore the effectiveness of the proposed virtual location-based periodic behavioral routine discovery process and assess the feasibility of a practical application. Thus, the proposed method is evaluated on three smart home datasets: the Kasteren dataset [47], the Aruba dataset [48], and our self-collected dataset. The details of these datasets are depicted in Table 2.
Wireless sensor networks are used to observe residents’ behavior in their homes. Each dataset utilizes different types of sensors; for instance, the Kasteren dataset uses reed switches, mercury contacts, PIR motion detectors, pressure mats, and float sensors; the Aruba dataset utilizes PIR motion detectors, temperature, and door sensors in their experiment; and our dataset uses PIR motion detectors, magnetic door contact switches, and power meter switches. The experiments on all datasets are conducted without predefined sensor locations. House floor plans indicating the locations of the sensors are shown in Figure 8, Figure 9 and Figure 10. The virtual location-based periodic behavioral routine discovery process described in Section 3 is applied to all datasets in four situations: (1) discover the virtual locations without adjusting the weights, (2) discover the virtual locations considering the door sensors, (3) discover the virtual locations considering the motion detectors, and (4) discover the virtual locations considering both the door sensors and the motion detectors.

4.1. Experimental Setup

The parameters used in the proposed method are described in detail in Table 3.

4.2. Evaluation Metrics

In the experiments, we employed widely used metrics, namely homogeneity, completeness, and V-measure, to evaluate the performance of different models in clustering and classification. Because we know the actual location of each sensor, we can use V-measure to evaluate the results of virtual location discovery. The authors of [49] defined homogeneity and completeness as objectives for any clustering result; homogeneity is used to check whether all of the clusters only contain members with a single label, and completeness checks whether every member of a given label is assigned to the same cluster. Furthermore, the best homogeneity scores are always at the bottom of the dendrogram, and completeness favors large clusters and decreases the score if members of the same class are divided into different clusters. Therefore, the top of the dendrogram, where all the sensors reside in a single cluster, always achieves the maximum completeness score. V-measure is computed as the harmonic mean of the homogeneity and completeness scores and is designed to balance them. A high V-measure is achieved by making a cluster with high homogeneity and completeness. The value of all three metrics is between zero and one, where one is the maximum score and vice-versa. These metrics determine how close a given clustering is to its ideal definition by examining the conditional entropy of the class distribution given the proposed clustering. Homogeneity is defined as follows.
H C | K = k = 1 K c = 1 C a c k N l o g a c k c = 1 C a c k
H C = c = 1 C a c k N l o g k = 1 K a c k n
where C is a set of classes ( C i 1 .. n ), K is a set of clusters ( K j 1 .. m ), a c k represents a member of class c that the element of cluster k , and N is the number of the data points. Based on Equations (6) and (7), homogeneity is calculated according to Equation (8):
h = i f   H C | K = 0               t h e n   h = 1                                 e l s e                                                 h = 1 H C | K H C          
Completeness is symmetrical to homogeneity. Therefore, completeness can be calculated based on Equation (9):
c = i f   H K | C = 0               t h e n   c = 1                                 e l s e                                                 c = 1 H K | C H K          
As mentioned previously, V-measure is calculated with the harmonic mean of homogeneity and completeness. Thus, the V-measure can be calculated based on Equation (10):
V M e a s u r e = 1 + β × h × c β × h + c
By assuming β is equal to 1, V-measure can be calculated as follows.
V M e a s u r e = 2 × h × c h + c

4.3. Experimental Result

4.3.1. Experiments for Virtual Location Discovery

Table 4 shows the scores of virtual location discovery applied to four scenarios presented in three datasets. The KA dataset has two actual rooms: the toilet and the kitchen. Before adjusting the weights of G , the washing machine in the kitchen and the toilet flush were in the same cluster. The possible causes include that the use of the washing machine is not likely during dining time. After considering the door contact, the toilet flush was in a cluster alone, and the sensors in the kitchen were in the same cluster. The KB dataset has three actual rooms: kitchen, toilet, and bedroom. Before adjusting the weights of G , the toilet flush and the sensors in the kitchen were in two different clusters. After considering the door contact, the toilet flush was in a cluster alone, but the sensors in the kitchen were still in two different clusters. After considering both door contacts and motion detectors, the sensors in the kitchen were in the same cluster. The KC dataset has five actual rooms, namely the kitchen, living room, and toilet on the first floor and the bathroom and bedroom on the second floor. Before adjusting the weights of G , the sensors on the first floor and the bed pressure mat on the second floor were in the same cluster, and the rest of the sensors on the second floor were in the same cluster. After considering the door contact, the sensors on the first floor were in the same cluster, and the sensors on the second floor were in the same cluster. The possible causes include the sensors in the bedroom having a significant correlation with the sensors in the bathroom. Although the weights between the bedroom and the bathroom sensors were decreased, the sensors in the same room were still not partitioned into the same cluster. After considering both door contacts and motion detectors, the sensors in the bedroom were in the same cluster, as were the sensors in the bathroom. Because there is no door contact or actual boundary around the living room, the couch and the sensors in the kitchen were in the same cluster.
The Aruba dataset has seven actual rooms: two bathrooms, two bedrooms, an office, and a kitchen, with the dining and the living room in the same space. Most sensors are motion detectors, and door contacts were not deployed between rooms. Thus, the score of clusters does not increase even after adjusting the weights of G . The sensors in the bathroom, office, and bedroom were in the same cluster, and the kitchen, dining room, and living room sensors were partitioned into two clusters. Our dataset has four actual locations: the first bedroom, the second bedroom, the living room, and the kitchen. Before adjusting the weights of G , the motion detector in the living room, the motion detection in the kitchen, and the appliance in the first bedroom were in the same cluster, and the rest of the sensors were in the same cluster. After considering the door contact, the second bedroom’s motion detector and the living room sensors were in the same cluster, and the rest of the sensors were in the same cluster. After considering the motion detector, the appliances in the first bedroom were in the same cluster, and the rest of the sensors were in the same cluster. Because there is no sensor between the second bedroom and the living room, the score did not improve after considering both door contacts and motion detectors.
The virtual location is an abstract location that may not be consistent with the actual site. The experiments revealed that the following factors might affect the result of virtual location and cause differences between them:
  • The number of sensor usages: a sensor may be misclassified if the value is low;
  • The number of sensors: a sensor may be easily misclassified as the neighbor’s location if it is the only sensor in its location;
  • The boundary between locations: it is difficult to distinguish between two locations that are close to each other.
Misclassifying a sensor to a location that it does not belong to may cause the following consequences:
  • The discovered activities may lack events created by the misclassified sensors;
  • An activity consisting of many events may be split into many activities consisting of fewer events;
  • The virtual location of the user might be determined incorrectly.
However, the differences between virtual and actual locations may be reduced as more data are collected. The experimental results show that even in the above situations, 81% accuracy is still achieved.

4.3.2. Experiments for Activity Discovery

The activity discovery process described in Section 3.3 is applied to all datasets in two situations: (1) discover activities from all sensors and (2) discover activities from each virtual location. First, to demonstrate the effect of virtual location in the activity discovery process, we perform activity discovery with and without utilizing virtual location, as illustrated in Table 5 and Table 6. Based on the annotation and time distribution of each activity, we can compare discovered activities performed by the resident with annotated activities. In Table 5, KA’s first activity is “going to bed”, and the second activity describes the periodic behavior as “using the toilet”. Moreover, the third activity is “leaving the house”. In KB, the first activity is “leaving the house”, the second is “preparing brunch”, and the third activity is “taking a shower”. In KC, the first activity is “going to bed”, the second activity is “using the toilet”, and the third activity is “preparing dinner”. Lastly, the first activity in Aruba is “going to bed”, the second activity is “meal preparation”, and the third activity is “work”.
By comparing the discovered activities between Table 5 and Table 6, we can see that by assigning activities to virtual locations according to the correlation between sensors and triggered sensor types, events that occurred not within the same location are not discovered as an activity in that virtual location. This not only separates events that occurred in a different location, but a more accurate periodic behavior of the resident can be obtained to help determine the resident action or status. For example, in KA in Table 5, the second activity, “using the toilet”, contains “hall-bedroom door ON”, and the same activity discovered by utilizing the virtual location shown in KA of Table 6 does not. This is because “hall-bedroom door” is assigned to virtual location 0, and both “Hall-Toilet door” and “ToiletFlush” are assigned to virtual location 1. The third activity, “taking a shower”, in KB in Table 5 appears to contain “PIR keuken (kitchen) ON”, and the same discovered activity shown in KB in Table 6 also separated “keuken (kitchen)” from “temp shower” and “toilet door” into different virtual location. The same phenomenon can also be observed in KC in Table 6. As we can see, assigned sensors in virtual locations can increase the accuracy of discovered activities. However, only motion and temperature sensors were installed inside the environment in the Aruba dataset. Door sensors are only placed at different entrances to the environment, not between rooms. Thus, events that occur in the environment contain mostly the trajectory of the resident. The disadvantage of this can be seen in the results of Aruba in Table 6. The first activity, “going to bed”, still contains the sensor event “M008”, which occurred in the hallway just outside the bedroom, and the second activity, “meal preparation” cannot be distinguished from sensor events that occurred in the dining room, which is close to the entrance of the kitchen. However, the proposed method excluded sensor event “M021”, which occurred at the end of the hallway, as well as “M013” in the living room, from the activity discovery process. By doing so, the activity discovery accuracy for Aruba was slightly increased, as shown in Table 6.
To further examine the effectiveness of the proposed method, we evaluated the computational time, the number of activities, and the average accuracy of each situation shown in Table 7. It can be observed that the number of discovered activities is significantly reduced by 78.4%, and the computational time required to perform the task is also significantly reduced after discovering the activities from each virtual location. Among all datasets, the high average accuracy of activities in the Aruba dataset shows the regularity of its user behavior. However, the computational time is relatively long because of the enormous quantity of data. The average accuracy value shows that the user behavior in the KB dataset is much less regular than that in the other datasets. The combinations of activities are ignored in the discovery process by finding the activities according to the virtual location they belong to and obtaining more fine-grained and compact patterns. Thus, the process requires at least two times less computational time to complete the task, and the number of discovered activities was reduced by 27.6%.

4.3.3. Experiments for Routine Discovery

To demonstrate the applicability of the routine discovery process, we simulate a smart home application called behavioral anomaly detection. In this experiment, anomalies can be defined as activity occurring in the incorrect location, at an unexpected time, or at an incorrect time. These situations are determined by whether the current activities deviate from periodic behavior routines performed by the resident. Moreover, this routine is correct only if all its elements, such as time slot, periodicity, frequency, and event sequence, correspond to the dataset’s periodic behavior routines. Specifically, the event sequences of the activities and routines performed by the resident are compared with periodic behavior routines with the same time slot and periodicity. Thus, the discovered routine is considered an anomaly if the sequencing deviates from the periodic behavior pattern. Figure 11 shows that anomalies occurred more often in every dataset when only considering the occurrence of activities without predefined sensor locations. By utilizing virtual location within activities, the number of anomalies decreases because activities are partitioned into more find-grained activities based on the event occurrence location. Similar trends can be seen with regard to the number of anomalies decreasing. However, because transition probabilities among activities are considered in the periodic behavior routines, they are more accurate when determining whether the current activity has deviated from the periodic behavior routines.

5. Conclusions

This study introduces the concept of the virtual location to address the problem of discovering periodic behavior routines for smart home residents without prior knowledge of where sensors are geographically deployed. This concept extracts spatial features from the implicit correlations among sensors, creates an abstract spatial representation of the physical environment, and assigns sensors with strong correlations to the same virtual location. An unsupervised approach to discovering periodic behavioral routines and solutions for potential deviations that considers the length of the discovered activities and transition probabilities among activities create an opportunity for more potential applications in smart homes. Furthermore, with these advantages, the proposed method provides great flexibility for the application of smart home monitoring techniques to households and could be helpful for home automation for the elderly who live independently and require timely interventions. The experimental results show that with the help of virtual location, the proposed method can achieve up to 93% accuracy in activity discovery. The computational time required to complete the task is at least two times less than without the help of the virtual location. In addition, we also demonstrated the applicability of the routine discovery process in behavioral anomaly detection. The results show that virtual location and routine discovery can tolerate variance in behavior routines and provide more accurate inference when determining whether the current activity has deviated from periodic behavior routines.

Author Contributions

Conceptualization, C.-C.L.; methodology, C.-C.L.; writing—original draft preparation, K.-H.H.; software, K.-H.H.; analysis, K.-H.H.; formal analysis, C.-C.L.; investigation, K.-H.H.; writing—review and editing, C.-C.L., S.-C.C., and M.-F.H.; supervision, C.-S.S. and M.-F.H.; funding acquisition, C.-S.S. and M.-F.H. All authors have read and agreed to the published version of the manuscript.

Funding

This research was supported by Minister of Science and Technology, Taiwan, ROC: MOST 109-2221-E-992-073-MY3, Minister of Science and Technology, Taiwan, ROC: MOST 111-2622-8-992-005-TD1, Minister of Science and Technology, Taiwan, ROC: MOST 111-2221-E-992-066-.

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Data Availability Statement

Data supporting the reported results are available upon request.

Acknowledgments

The authors extend their appreciation to the National Science and Technology Council, Taiwan for funding this study. Part of the early findings of this study was presented at the 29th Annual IEEE International Symposium on Personal, Indoor and Mobile Radio Communications (IEEE PIMRC 2018), Bologna, Italy, 9–12 September 2018.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Bandyopadhyay, D.; Sen, J. Internet of Things: Applications and challenges in technology and standardization. Wirel. Pers. Commun. 2011, 58, 49–69. [Google Scholar] [CrossRef] [Green Version]
  2. Akhund, T.M.N.U.; Roy, G.; Adhikary, A.; Alam, M.A.; Newaz, N.T.; Rana Rashel, M.; Abu Yousuf, M. Snappy wheelchair: An IoT-based flex controlled robotic wheel chair for disabled people. In Proceedings of the Fifth International Conference on Information and Communication Technology for Competitive Strategies (ICTCS), Jaipur, India, 11–12 December 2020; pp. 803–812. [Google Scholar]
  3. Kinsella, K.; Beard, J.; Suzman, R. Can populations age better, not just live longer? Generations 2013, 37, 19–26. [Google Scholar]
  4. Huang, T.; Huang, C. Attitudes of the elderly living independently towards the use of robots to assist with activities of daily living. Work 2021, 69, 1–11. [Google Scholar] [CrossRef]
  5. Barigozzi, F.; Turati, G. Human health care and selection effects. Understanding labor supply in the market for nursing. Health Econ. 2012, 21, 477–483. [Google Scholar] [CrossRef] [PubMed]
  6. Yacchirema, D.; de Puga, J.S.; Palau, C.; Esteve, M. Fall detection system for elderly people using IoT and ensemble machine learning algorithm. Pers. Ubiquitous Comput. 2019, 23, 801–817. [Google Scholar] [CrossRef]
  7. Javaid, M.; Haleem, A.; Rab, S.; Pratap Singh, R.; Suman, R. Sensors for daily life: A review. Sens. Int. 2021, 2, 100121. [Google Scholar] [CrossRef]
  8. Akbari, S.; Haghighat, F. Occupancy and occupant activity drivers of energy consumption in residential buildings. Energy Build. 2021, 250, 111303. [Google Scholar] [CrossRef]
  9. Ariano, R.; Manca, M.; Paternò, F.; Santoro, C. Smartphone-based augmented reality for end-user creation of home automations. Behav. Inf. Technol. 2021, 42, 1–17. [Google Scholar] [CrossRef]
  10. Rodrigues, M.J.; Postolache, O.; Cercas, F. Physiological and behavior monitoring systems for smart healthcare environments: A review. Sensors 2020, 20, 2186. [Google Scholar] [CrossRef] [Green Version]
  11. Bakar, U.A.B.U.A.; Ghayvat, H.; Hasanm, S.F.; Mukhopadhyay, S.C. Activity and anomaly detection in smart home: A survey. Next Gener. Sens. Syst. 2016, 16, 191–220. [Google Scholar]
  12. Demiris, G.; Hensel, B.K. Technologies for an aging society: A systematic review of smart home applications. Yearb. Med. Inform. 2008, 17, 33–40. [Google Scholar]
  13. Akl, A.; Taati, B.; Mihailidis, A. Autonomous unobtrusive detection of mild cognitive impairment in older adults. IEEE Trans. Biomed. Eng. 2015, 62, 1383–1394. [Google Scholar] [CrossRef] [Green Version]
  14. Elhamshary, M.; Youssef, M.; Uchiyama, A.; Yamaguchi, H.; Higashino, T. TransitLabel: A crowd-sensing system for automatic labeling of transit stations semantics. In Proceedings of the 14th ACM International Conference on Mobile Systems, Applications, and Services (MobiSys), Singapore, 26–30 June 2016; pp. 193–206. [Google Scholar]
  15. Brush, A.J.; Lee, B.; Mahajan, R.; Agarwal, S.; Saroiu, S.; Dixon, C. Home automation in the wild: Challenges and opportunities. In Proceedings of the International Conference on Human Factors in Computing Systems(CHI), Vancouver, BC, Canada, 7–12 May 2011; pp. 2115–2124. [Google Scholar]
  16. Friedrich, B.; Sawabe, T.; Hein, A. Unsupervised statistical concept drift detection for behaviour abnormality detection. Appl. Intell. 2022, 53, 2527–2537. [Google Scholar] [CrossRef]
  17. Esposito, L.; Leotta, F.; Mecella, M.; Veneruso, S. Unsupervised segmentation of smart home logs for human habit discovery. In Proceedings of the 2022 18th International Conference on Intelligent Environments (IE), Biarritz, France, 20–23 June 2022; pp. 1–8. [Google Scholar]
  18. 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]
  19. Augusto, J.C.; Nugent, C.D. Smart homes can be smarter. Lect. Notes Comput. Sci. 2006, 4008, 1–15. [Google Scholar]
  20. Yao, L.; Sheng, Q.Z.; Benatallah, B.; Dustdar, S.; Wang, X.; Shemshadi, A.; Kanhere, S.S. WITS: An IoT-endowed computational framework for activity recognition in personalized smart home. Computing 2018, 100, 369–385. [Google Scholar] [CrossRef]
  21. Augusto, J.C.; Liu, J.; McCullagh, P.; Wang, H. Management of uncertainty and spatio-temporal aspects for monitoring and diagnosis in a smart home. Int. J. Comput. Intell. 2008, 1, 361–378. [Google Scholar]
  22. Lymberopoulos, D.; Bamis, A.; Savvides, A. Extracting spatiotemporal human activity patterns in assisted living using a home sensor network. Univers. Access Inf. Soc. 2011, 10, 125–138. [Google Scholar] [CrossRef] [Green Version]
  23. Azizyan, M.; Constandache, I.; Choudhury, R.R. SurroundSense: Mobile phone localization via ambience fingerprinting. In Proceedings of the 15th Annual International Conference on Mobile Computing and Networking (MobiCom), Beijing, China, 20–25 September 2009; pp. 261–272. [Google Scholar]
  24. Fan, M.; Adams, A.T.; Truong, K.N. Public restroom detection on mobile phone via active probing. In Proceedings of the 2014 ACM International Symposium on Wearable Computers (ISWC), Seattle, WA, USA, 13–17 September 2014; pp. 27–34.
  25. Chen, C.; Ren, Y.; Liu, H.; Chen, Y.; Li, H. Acoustic-sensing-based location semantics identification using smartphones. IEEE Internet Things J. 2022, 9, 20640–20650. [Google Scholar] [CrossRef]
  26. Gozick, B.; Subbu, K.P.; Dantu, R.; Maeshiro, T. Magnetic maps for indoor navigation. IEEE Trans. Instrum. Meas. 2011, 60, 3883–3891. [Google Scholar] [CrossRef]
  27. Borelli, E.; Paolini, G.; Antoniazzi, F.; Barbiroli, M.; Benassi, F.; Chesani, F.; Chiari, L.; Fantini, M.; Fuschini, F.; Galassi, A.; et al. HABITAT: An IoT solution for independent elderly. Sensors 2019, 19, 1258. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  28. Ji, Y.; Zhao, X.; Wei, Y.; Wang, C. Generating indoor Wi-Fi fingerprint map based on crowdsourcing. Wirel. Netw. 2022, 28, 1053–1065. [Google Scholar] [CrossRef]
  29. Tapia, E.M.; Intille, S.S.; Larson, K. Activity recognition in the home using simple and ubiquitous sensors. Lect. Notes Comput. Sci. 2004, 3001, 158–175. [Google Scholar]
  30. Cook, D.J.; Crandall, A.S.; Thomas, B.L.; Krishnan, N.C. CASAS: A smart home in a box. Computer 2013, 46, 62–69. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  31. Heierman, E.O.; Youngblood, M.; Cook, D.J. Mining temporal sequences to discover interesting patterns. In Proceedings of the KDD Workshop on Mining Temporal and Sequential Data (KDD), Seattle, WA, USA, 22–25 August 2004. [Google Scholar]
  32. Rissanen, J. Stochastic Complexity in Statistical Inquiry; World Scientific Publishing: Singapore, 1989. [Google Scholar]
  33. Cook, D.J.; Youngblood, M.; Heierman, E.O.; Gopalratnam, K.; Rao, S.; Litvin, A.; Khawaja, F. MavHome: An agent-based smart home. In Proceedings of the First IEEE International Conference on Pervasive Computing and Communications (PerCom), Fort Worth, TX, USA, 26 March 2003; pp. 521–524. [Google Scholar]
  34. Viard, K.; Fanti, M.P.; Faraut, G.; Lesage, J.-J. Human activity discovery and recognition using probabilistic finite-state automata. IEEE Trans. Autom. Sci. Eng. 2020, 17, 2085–2096. [Google Scholar] [CrossRef]
  35. Reyes-Campos, J.; Alor-Hernández, G.; Machorro-Cano, I.; Olmedo-Aguirre, J.O.; Sánchez-Cervantes, J.L.; Rodríguez-Mazahua, L. Discovery of resident behavior patterns using machine learning techniques and IoT paradigm. Mathematics 2021, 9, 219. [Google Scholar] [CrossRef]
  36. Papadopoulos, S.; Kompatsiaris, Y.; Vakali, A.; Spyridonos, P. Community detection in social media. Data Min. Knowl. Discov. 2012, 24, 515–554. [Google Scholar] [CrossRef]
  37. Wanga, T.; Yin, L.; Wang, X. A community detection method based on local similarity and degree clustering information. Physica A 2018, 490, 1344–1354. [Google Scholar] [CrossRef]
  38. Shin, H.; Park, J.; Kang, D. A graph-cut-based approach to community detection in networks. Appl. Sci. 2022, 12, 6218. [Google Scholar] [CrossRef]
  39. Blondel, V.D.; Guillaume, J.L.; Lambiotte, R.; Lefebvre, E. Fast unfolding of communities in large networks. J. Stat. Mech.: Theory Exp. 2008, 2008, 10008. [Google Scholar] [CrossRef] [Green Version]
  40. Aynaud, T.; Blondel, V.D.; Guillaume, J.L.; Lambiotte, R. Multilevel local optimization of modularity. In Graph Partitioning; John Wiley & Sons: New York, NY, USA, 2013; pp. 315–345. [Google Scholar]
  41. Newaz, N.T.; Haque, M.R.; Akhund, T.M.N.U.; Khatun, T.; Biswas, M. IoT security perspectives and probable solution. In Proceedings of the 2021 Fifth World Conference on Smart Trends in Systems Security and Sustainability (WorldS4), London, UK, 29–30 July 2021; pp. 81–86. [Google Scholar]
  42. Lo, C.-C.; Hsu, K.-H.; Horng, M.-F.; Kuo, Y.-H. Spatial Information Extraction using Hidden Correlations. In Proceedings of the 2018 IEEE 29th Annual International Symposium on Personal, Indoor and Mobile Radio Communications (PIMRC), Bologna, Italy, 9–12 September 2018; pp. 1–6. [Google Scholar]
  43. Qin, S.M.; Verkasalo, H.; Mohtaschemi, M.; Hartonen, T.; Alava, M. Patterns, entropy, and predictability of human mobility and life. PLoS ONE 2012, 7, e51353. [Google Scholar] [CrossRef] [Green Version]
  44. Kolmogorov, A.N.; Uspenskii, V.A. Algorithms and randomness. Theory Probab. Appl. 1988, 32, 389–412. [Google Scholar] [CrossRef] [Green Version]
  45. Chifu, V.R.; Pop, C.B.; Demjen, D.; Socaci, R.; Todea, D.; Antal, M.; Cioara, T.; Anghel, I.; Antal, C. Identifying and Monitoring the Daily Routine of Seniors Living at Home. Sensors 2022, 22, 992. [Google Scholar] [CrossRef]
  46. Borgelt, C. Simple algorithms for frequent item set mining. In Advances in Machine Learning II; Springer: Berlin/Heidelberg, Germany, 2010; pp. 351–369. [Google Scholar]
  47. van Kasteren, T.L.M.; Englebienne, G.; Kröse, B.J.A. Human activity recognition from wireless sensor network data: Benchmark and software. In Activity Recognition in Pervasive Intelligent Environments of the Atlantis Ambient and Pervasive Intelligence Series; Atlantis Press: Paris, France, 2011; pp. 165–186. [Google Scholar]
  48. Cook, D.J. Learning setting-generalized activity models for smart spaces. IEEE Intell. Syst. 2012, 27, 32–38. [Google Scholar] [CrossRef]
  49. Rosenberg, A.; Hirschberg, J. V-measure: A conditional entropy-based external cluster evaluation measure. In Proceedings of the 2007 Joint Conference on Empirical Methods in Natural Language Processing and Computational Natural Language Learning (EMNLP-CoNLL), Prague, Czech Republic, 28–30 June 2007; pp. 410–420. [Google Scholar]
Figure 1. System architecture of the proposed method for smart home applications.
Figure 1. System architecture of the proposed method for smart home applications.
Mathematics 11 00648 g001
Figure 2. The procedure of virtual location discovery.
Figure 2. The procedure of virtual location discovery.
Mathematics 11 00648 g002
Figure 3. An example of the calculation of the weight function.
Figure 3. An example of the calculation of the weight function.
Mathematics 11 00648 g003
Figure 4. Concept of the probability matrix; darker colors represent higher probability.
Figure 4. Concept of the probability matrix; darker colors represent higher probability.
Mathematics 11 00648 g004
Figure 5. Concept of the differences in activities between activity and routine discovery methods (a) without virtual location and routine and (b) with virtual location and routine.
Figure 5. Concept of the differences in activities between activity and routine discovery methods (a) without virtual location and routine and (b) with virtual location and routine.
Mathematics 11 00648 g005
Figure 6. Example of event sequence segmentation.
Figure 6. Example of event sequence segmentation.
Mathematics 11 00648 g006
Figure 7. The concept of finding the intervals.
Figure 7. The concept of finding the intervals.
Mathematics 11 00648 g007
Figure 8. Floor plans of Kasteren houses; red boxes represent the sensors [47]. (a) House A. (b) House B. (c) House C, first floor. (d) House C, second floor.
Figure 8. Floor plans of Kasteren houses; red boxes represent the sensors [47]. (a) House A. (b) House B. (c) House C, first floor. (d) House C, second floor.
Mathematics 11 00648 g008
Figure 9. The floor plan of the Aruba dataset [48].
Figure 9. The floor plan of the Aruba dataset [48].
Mathematics 11 00648 g009
Figure 10. The floor plan of our dataset.
Figure 10. The floor plan of our dataset.
Mathematics 11 00648 g010
Figure 11. Results of anomaly detection.
Figure 11. Results of anomaly detection.
Mathematics 11 00648 g011
Table 1. Main notations used throughout this study.
Table 1. Main notations used throughout this study.
SymbolDescription
d k An event of d k = t i m e s t a m p ,   s e n s o r   I D ,   s e n s o r   s t a t u s , d k D
V L Virtual location
V A set of vertices representing all sensors
W Symmetric V × V matrix representing the correlation between each pair of sensors
E k The event sequence of k
M E k The maximal episode of k
F E k The frequent episodes of k
S u p f e k ,   i The support of the frequent episodes ( f e k ,   i )
S m i n The minimal support threshold
A c c a k , i The accuracy of a k , i
A m i n The minimal accuracy threshold
A S k The activity sequence of k
C o n f r k The confidence of r k
C O N F m i n The minimal confidence threshold
Table 2. Details of datasets.
Table 2. Details of datasets.
KAKBKCArubaOur Dataset
Age262857Elderly24
GenderMaleMaleMaleFemaleMale
Rooms32674
Duration25 days27 days20 days220 days32 days
Sensors1423213413
Activities10131610Unannotated
No. of Events245838,15045,4001,602,91257,935
Table 3. Overview of the parameters of the proposed method.
Table 3. Overview of the parameters of the proposed method.
NameValue RangeRecommended Value
p ^ 0–100%60%
W m 1.02
W d 0.00.25
T e p 0–24 h30 min
C e p 1.0
S m i n 0–100%40%
S D m a x 0–24 h1 h
A C C m i n 0–100%40%
C O N F m i n 0–100%40%
ε 1.02
P A m i n 0–100%20%
P A m a x 0–100%80%
A L 0–100%60%
Table 4. Scores of virtual location discovery in each dataset.
Table 4. Scores of virtual location discovery in each dataset.
DatasetOriginDoorMotionDoor/Motion
HomogeneityKA0.571.00N/AN/A
KB0.450.750.681.00
KC0.390.580.690.81
Aruba0.70N/A0.70N/A
Ours0.140.690.370.69
CompletenessKA0.371.00N/AN/A
KB0.600.711.001.00
KC0.781.000.861.00
Aruba0.95N/A0.95N/A
Ours0.211.000.541.00
V-measureKA0.451.00N/AN/A
KB0.510.730.811.00
KC0.520.730.770.90
Aruba0.81N/A0.81N/A
Ours0.170.810.440.81
N/A denotes this type of sensor in not available in the evaluation.
Table 5. Results of activity discovery in each dataset without virtual location.
Table 5. Results of activity discovery in each dataset without virtual location.
DatasetActivity Discovered without VLAccuracy
KAHall-Bedroom door OFF, Hall-Bedroom door ON84%
Hall-Toilet door ON, ToiletFlush ON, ToiletFlush OFF, Hall-Toilet door OFF, Hall-Bedroom door ON84%
Frontdoor OFF, Frontdoor ON84%
KBPIR keuken ON, frontdoor OFF,
frontdoor ON, PIR keuken OFF
74%
frontdoor OFF, PIR keuken ON, frontdoor ON,
PIR kachel ON, PIR kachel OFF, PIR keuken OFF
58%
temp shower OFF, temp shower ON, toilet door OFF,
toilet door ON, PIR keuken ON
55%
KCdeur slaapkamer OFF, mat bed rechts, drukmat OFF,
deur slaapkamer ON, mat bed rechts, drukmat ON
89%
deur slaapkamer OFF, badkamer klapdeur links OFF,
badkamer klapdeur links ON
86%
voordeur, reed OFF, voordeur, reed ON,
mat bank, huiskamer OFF, mat bank, huiskamer ON
84%
ArubaM021 ON, M008 ON, M006 ON, M003 ON, M002 ON93%
M013 ON, M014 ON, M019 ON, M015 ON, M019 ON89%
M029 ON, M028 ON, M027 ON, M026 ON, M027 ON88%
Table 6. Results of activity discovery in each dataset with virtual location.
Table 6. Results of activity discovery in each dataset with virtual location.
DatasetVL No.Activity Discovered with VLAccuracy
KA0Hall-Bedroom door OFF, Hall-Bedroom door ON84%
1Hall-Toilet door ON, Hall-Toilet door OFF,
ToiletFlush ON, ToiletFlush OFF
89.50%
2Frontdoor ON, Frontdoor OFF84%
KB0frontdoor ON, frontdoor OFF74%
1PIR keuken ON, PIR kachel ON,
PIR kachel OFF, PIR keuken OFF
72.20%
2toilet door door ON, temp shower ON,
temp shower OFF, toilet door door OFF
67.50%
KC1deur slaapkamer OFF, mat bed rechts,
drukmat OFF, deur slaapkamer ON,
mat bed rechts, drukmat ON
89%
2badkamer klapdeur links OFF,
badkamer klapdeur links ON
94%
3voordeur, reed OFF, voordeur, reed ON, mat bank, huiskamer OFF90%
Aruba2M008 ON, M006 ON, M003 ON, M002 ON95%
1M014 ON, M019 ON, M015 ON, M019 ON93%
0M027 ON, M026 ON, M027 ON90%
Table 7. Results of activity discovery in each dataset.
Table 7. Results of activity discovery in each dataset.
DatasetAD without VLAD with VL
Time (second)KA18521
KB6216
KC2606242
Aruba4751628
Ours1405728
Num. of activitiesKA6547
KB1610
KC3010
Aruba21346
Ours2113
Avg. accuracy (%)KA7781
KB5261
KC8186
Aruba8893
Ours6786
Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content.

Share and Cite

MDPI and ACS Style

Lo, C.-C.; Hsu, K.-H.; Chen, S.-C.; Shieh, C.-S.; Horng, M.-F. Periodic Behavioral Routine Discovery Based on Implicit Spatial Correlations for Smart Home. Mathematics 2023, 11, 648. https://doi.org/10.3390/math11030648

AMA Style

Lo C-C, Hsu K-H, Chen S-C, Shieh C-S, Horng M-F. Periodic Behavioral Routine Discovery Based on Implicit Spatial Correlations for Smart Home. Mathematics. 2023; 11(3):648. https://doi.org/10.3390/math11030648

Chicago/Turabian Style

Lo, Chun-Chih, Kuo-Hsuan Hsu, Shen-Chien Chen, Chin-Shiuh Shieh, and Mong-Fong Horng. 2023. "Periodic Behavioral Routine Discovery Based on Implicit Spatial Correlations for Smart Home" Mathematics 11, no. 3: 648. https://doi.org/10.3390/math11030648

APA Style

Lo, C.-C., Hsu, K.-H., Chen, S.-C., Shieh, C.-S., & Horng, M.-F. (2023). Periodic Behavioral Routine Discovery Based on Implicit Spatial Correlations for Smart Home. Mathematics, 11(3), 648. https://doi.org/10.3390/math11030648

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop