This invention relates to a method for detecting activity with a motion sensor. It also relates to a corresponding detection device and computer program.
More specifically, it relates to a method for detecting the activity of a physical system carrying a motion sensor, comprising the following steps:
A method of this type is, for example, described in the article of P. Jallon, entitled “A graph based algorithm for postures estimation based on accelerometers data”, published in Proceedings of 2010 Annual International Conference of the IEEE EMBC, pages 2778-2781. In this article, the sensor is an accelerometer with three measurement axes, worn on the body (waist or torso) of a person being observed: the accelerometer thus provides a sequence of measurements consisting of projections in the three axes thereof of a sum of the acceleration due to the earth's gravitational field and an acceleration specific to the sensor. These vector measurements with three components are not directly interpreted in order to determine the activity of the person being observed, but are first processed in order to separate the information associated with the gravitational acceleration from the information relating to the sensor-specific acceleration. Thus, three low-frequency components of an observation sequence are calculated by low-pass filtering of each vector measurement and three high-frequency components of the observation sequence are calculated by subtracting the three low-frequency components of the vector measurement. The resulting observation sequence is a sequence of vector values with six components. The first three are interpreted as indicating gravitational acceleration projections on the measurement axes of the sensor, so that they indicate the posture (sitting/standing or lying) of the person, while the following three are interpreted as indicating the acceleration specific to the sensor, so that they indicate the degree of activity (none, light, significant, etc.) of the person.
In addition, a statistical model of the components of the observation sequence is defined on the basis of a plurality of possible predetermined states of the person: sitting position, sitting/standing transition, static standing position, walking, standing/sitting transition. In consideration of the constraints of transitions from one state to another, these states are modeled as hidden states of a statistical Markov model and a classic method for analysis by Bayesian inference is applied to determine the activity of the person in the form of a sequence of states corresponding to the observation sequence.
Of course, this analysis method requires preliminary learning on known state sequences in order to define the parameters of the statistical model, in particular those of the laws of probability of observation associated with the different hidden states of the model.
This analysis method and the learning thereof also require calibration of the sensor, in particular in order to know its orientation in a predetermined reference posture such as the standing posture, for example. Then, the successful operation of the method requires that the sensor always be carried in the same way by the person being observed, although with a certain range of variations around the optimal positioning being tolerated. It is also assumed that the values learned under calibration do not vary from one person to another or from one experience to another, making this approximation both rough and restrictive.
Another method of this type is described in the international patent application published under number WO 2010/122174 A1. The same sequence of measurements is obtained from an accelerometer, and an observation sequence of which the values are vector values having four components is deduced therefrom. The first three components correspond to those obtained in the aforementioned article, while the fourth component is the norm of the output of a high-pass filter applied to the measurements sequence. As above, the activity of the person being observed is determined in the form of a sequence of states corresponding to the observation sequence by means of a predefined statistical model. Also as above, the method requires learning and calibration and has the same disadvantages.
It may thus be desirable to provide an activity detection method that makes it possible to overcome at least some of the aforementioned problems and constraints.
The invention therefore relates to a method for detecting activity of a physical system carrying a motion sensor, comprising the following steps:
Thus, by making at least one component of the observation sequence explicitly dependent on a vector reference value indicating a preferred direction and providing means enabling this reference value to be reconsidered on the basis of a likelihood test that can be executed during the observation of the system, the method is made capable of performing a calibration at any time. This method is thus rendered less sensitive to how the sensor is carried by the physical system and more robust with respect to any change in the system observed, experience or arrangement of the motion sensor during an observation.
Optionally, the reference axis can be estimated, via its representative vector, by means of measurements provided by the motion sensor. Thus, the calibration can be performed automatically and autonomously owing to the motion sensor.
Also optionally, a method according to the invention can further comprise a step of invalidating at least some of the sequence of states corresponding to the observation sequence, on the basis of the likelihood value.
This makes it possible not to take into account the determination of an activity, at least in part, when the latter is obtained from observations for which the reference value is not representative of the reference axis.
Also optionally, the observation sequence is deduced from the measurement sequence in the following way:
Also optionally, the statistical model is a single Markov model with hidden states, each hidden state of which corresponds to one of the possible predetermined states of the physical system, the law of conditional probability of the observation of each hidden state being modeled by a sum of normal laws.
Also optionally, the calibration comprises:
where N is the number of observation samples in the observation sequence, O1:N designating the N successive samples,
Also optionally:
Also optionally, the estimation of a new reference value of the vector representing the reference axis comprises steps consisting of:
The invention also relates to the application of a detection method as defined above to the observation, by means of a three-dimensional accelerometer, of a person capable of being located, at each instant, in one of the following predetermined states: a “sitting position” state, a “sitting/standing transition” state, a “static standing position” state, a “walking” state, and a “standing/sitting transition” state; the reference value being the value, in the frame of the measurement axes of the three-dimensional accelerometer, of the components of a vertical downward-oriented unit vector when the person being observed is wearing the three-dimensional accelerometer and is in the “static standing position” or “walking” state.
The invention also relates to a device for detecting the activity of a physical system comprising:
Optionally, the motion sensor is an accelerometer with three measurement axes, the reference axis estimable by means of the measurements provided by the motion sensor being the axis of the earth's gravitational field, the reference value of a vector representing this axis being calculated on the basis of an estimation of the coordinates of an acceleration due to the earth's gravitational field in the frame of reference of the measurement axes of the accelerometer when the physical system is in a predetermined state.
The invention also relates to a system for detecting the activity of a physical system, comprising:
Finally, the invention also relates to a computer program that can be downloaded from a communication network and/or recorded on a computer-readable medium and/or run by a processor, comprising instructions for carrying out the steps of a detection method as defined above, when said program is run on a computer.
The invention will be better understood in view of the following description, provided solely as an example, and with reference to the appended drawings, wherein:
The device 10 shown in
The measurement module 12 comprises one or more sensors, comprising at least one motion sensor, represented by the single reference 18 for the observation of the physical system.
In a non-limiting manner, the sensor 18 can, for example, comprise a motion sensor with one, two or three measurement axes, in particular a three-dimensional accelerometer worn by a person, in order to determine the activity of said person in the form of a sequence of attitudes among a plurality of possible attitudes capable of occurring in succession (for example, sitting, standing, sitting/standing or standing/sitting transition, walking).
More generally, it can comprise a motion sensor for determining the activity of a mobile physical system in the form of a sequence of states among a plurality of predetermined states capable of occurring in succession.
The motion sensor 18 can also comprise a plurality of sensors each providing measurements that, combined, make it possible to envisage detecting more complex situations.
It takes measurements of the physical system in order to provide a measurement signal, transmitted in the form of a sequence M of measurement data to the processing module 14. The measurement data is obtained directly from a sampling of the measurement signal, for example 100 or 200 Hz. In the case of a three-dimensional accelerometer, each measurement data sample is a three-component vector, each component representing the projection of the total acceleration measured by the sensor on one of its three measurement axis. This total acceleration comprises the earth's gravitational acceleration and the acceleration specific to the motion sensor 18.
The motion sensor 18 also has the property of enabling, by means of the measurements that it provides a reference axis to be estimated, represented by a reference vector λ, for example of norm 1, indicating its direction and its sense. As will be described in detail below, the coordinates of this reference vector can be expressed in the frame of reference of the motion sensor 18 and have a particular reference value {circumflex over (λ)}=({circumflex over (λ)}x,{circumflex over (λ)}y,{circumflex over (λ)}z) when the motion sensor 18 is in a predetermined and preferred orientation corresponding, for example, to at least one of the possible states of the physical system. In the case of an accelerometric sensor worn by a person, the reference axis is advantageously the axis of the earth's gravitational field.
The processing module 14 is an electronic circuit, in particular that of a computer. It comprises storage means 20, for example a RAM, a ROM or another type of memory, wherein the parameters of at least one statistical model are stored, for example an HMM hidden-state Markov model.
In general, this statistical model stored in the memory 20, or the structured assembly of these statistical models if a plurality of them are combined, associates a succession of possible observation data values with a succession of states corresponding to at least some of the hidden states of the statistical model HMM and identifying the possible states of the physical system carrying the motion sensor 18.
The processing module 14 also comprises a calculator 22, for example a central computer unit equipped with a microprocessor 24 and a storage space for at least one computer program 26. This calculator 22, and more specifically the microprocessor 24, is connected to the motion sensor 18 and to the memory 20.
The computer program 26 performs four main functions illustrated by modules 28, 30, 32 and 34 in
The first main function, performed by a filtering module 28, is a function for transforming the measurement sequence M provided by the motion sensor 18 into an observation sequence O capable of being checked against the statistical model HMM stored in the memory 20. Like the measurement sequence M, the observation sequence O is formed by a succession of samples, each of these samples being capable of being a vector, each component of which results from a specific processing of the measurement sequence M. In general, according to the invention, at least one component of each sample of the observation sequence O is calculated on the basis of the reference value {circumflex over (λ)}.
As a non-limiting example, when the motion sensor 18 is a three-dimensional accelerometer worn by a person whose activity is to be determined in the form of a sequence of predetermined possible attitudes of the person (comprising: sitting position, sitting/standing transition, static standing position, walking, standing/sitting transition), the sequence M is a sequence of acceleration vectors γn=γng+γnp, n designating the time index of the samples, γng the low-frequency part of these acceleration vectors corresponding to the acceleration due to the earth's gravitational field capable of being obtained by a simple low-pass filtering and γnp the high-frequency part of these acceleration vectors corresponding to the acceleration specific to the sensor capable of being obtained by a simple pass-band filtering. These vectors are known by their components projected in the three measurement axes of the motion sensor 18.
The filtering module 28 can thus separate these two parts γng and γnp and provide an observation sequence O with two components:
More specifically, and as an example:
where , designates the scalar product and ∥ ∥ the Euclidean norm,
On(2)=1 0∥γnp∥.
It is thus noted that the first component On(1) of each sample of the observation sequence O is calculated on the basis of the reference value {circumflex over (λ)} while the second component On(2) is independent of this reference value.
The second main function, performed by an activity detection module 30, for example in the form of an instruction loop, is a function of detecting a sequence of possible predetermined states of the physical system, on the basis of a sequence O of observation data provided by the filtering module 28. More specifically, the activity detection module 30 is programmed to enable the microprocessor 24 to provide an activity A in the form of a sequence of states by processing the observation sequence O by means of the statistical model HMM stored in the memory 20.
The third main function, performed by a test module 32 is a function of calculating a likelihood value of the observation sequence O in view of the model HMM stored in the memory 20 and of comparison of this likelihood value with a threshold δ for a possible update of the reference value {circumflex over (λ)}.
Finally, the fourth main function, performed by a threshold calculation module 32, is a function of calculating the threshold value δ for the HMM model considered.
The interface module 16 has an interface 36 making it possible to display the result of a detection performed by the microprocessor 24, for example in the form of a time diagram of the successive states corresponding to the observation O. As one of the possible benefits of the detection device 10 is optionally also to detect a predetermined critical situation, this interface 36 can in particular comprise an alert activator. The interface 36 or its alert activator can, for example, comprise a screen for displaying results or a warning message, a loudspeaker for emitting a sound signal or a transmitter for transmitting a signal to a remote alarm. The alert activator can be activated upon detection of one or more particular activity or activities. An example of a detectable event/activity capable of activating an alert is, for example, a fall.
It should be noted that the observation 12, processing 14 and interface 16 modules are structurally separable. Thus, the detection device 10 can be designed in one piece or in multiple distinct hardware pieces connected to one another by wire or wireless data transmission means. In particular, the processing 14 and optionally interface 16 modules can be implemented by a computer. Only the observation module 12 is necessarily in the vicinity or even in contact with the physical system observed since it comprises the sensor(s) 18.
In
An example of a statistical model HMM capable of being stored in the memory will now be described in detail in reference to
The hidden states of the model HMM of
It is also noted that this model imposes certain impossible transition constraints, such as, for example, the transition from the “static standing position” to the “sitting position” state, which cannot be performed directly without going through the “standing/sitting transition” state. This results, for example, in the following matrix of transition probabilities:
where the variable ε is, for example, between 10−2 and 10−4.
In
The laws of probability of observation at each instant and for each hidden state are defined by parameters that are of course dependent upon the reference value {circumflex over (λ)} arbitrarily chosen. For example, in the application described above, the reference vector λ is a vertical unit vector oriented downward in the terrestrial reference frame, the reference value {circumflex over (λ)} being the value of the components of this reference vector λ in the coordinates of the frame of the measurement axes of the three-dimensional accelerometer when it is worn by the person being observed and when the person is in the “static standing position” state K3. By choosing such a reference value {circumflex over (λ)}, it is possible to initialize it to a first value obtained by calibration, taking a series of measurements when the person being observed is wearing the motion sensor 18 and is in the static standing position. {circumflex over (λ)} then corresponds in effect to the measured acceleration vector that must simply be averaged over the series measured. More generally, it is advantageous to choose a reference value that can be deduced directly from the measurements associated with one of the predetermined states. It should also be noted that it is possible to initialize {circumflex over (λ)} to an arbitrary value without calibration.
Any one of the laws of conditional probability of observation knowing the state to be determined can be chosen from the family of normal laws. A normal law is defined by its expectation μ and its variance Σ. When the data provided at the input of the model HMM is multi-valued, μ is a vector comprising as many components and Σ is a matrix comprising as many rows and columns as values provided at each instant at the input of the model HMM.
In the above-mentioned example, as the observation sequence has two components, μ is a vector with two components and Σ is a 2×2 matrix. Also in the above-mentioned example, each law of conditional probability of observation knowing the state to be determined is, in practice, advantageously a sum of two normal laws capable of being written in the form:
where the parameters ci,j, μi,j and Σi,j are, for example, defined as indicated by the following table:
The operation of the detection device 10 will now be described in detail in reference to
In a first step 100, the motion sensor 18, in this particular case the three-dimensional accelerometer, transmits a sequence M of measurement data to the calculator 22. This data is vector data with three components indicating the projection of the acceleration measured on each measurement axis of the motion sensor 18.
In a step 102, during reception 100 of the successive data transmitted by the motion sensor 18, the microprocessor 24 of the calculator 22 launches the execution of the filtering module 28 as described above, to produce a sequence of N observation data items denoted O1:N={O1, . . . ON}, wherein each sample On is a vector with two components On(1) and On(2) as defined above.
In the next step 104, the microprocessor 24 of the calculator 22 launches the execution of the activity detection software module 30. By means of the statistical model HMM mentioned above, the activity of the person wearing the motion sensor 18 is determined in the form of a sequence of states (or a sequence of attitudes) corresponding to the observation sequence O1:N. This sequence of states is denoted Â1:N={Â1, . . . ÂN, wherein each sample Ân is a natural integer between 1 and 5 identifying one of the five states of the model (“sitting position”, “sitting/standing transition”, “static standing position”, “walking”, “standing/sitting transition”). In consideration of the hidden state Markov model HMM chosen:
with:
Classically, the sequence of states Â1:N is estimated by means of a Viterbi algorithm.
Then, in a step 106, the microprocessor 24 of the calculator 22 launches the execution of the test module 32 in order to calculate a likelihood value V of the observation sequence O1:N in view of the statistical model HMM. The likelihood value V is, for example, given by the following formula:
wherein the expression p(O1:N) is developed in the form:
where M is the number of states, i.e. 5 in the example considered. N is for example equal to 10 or 20.
In view of the laws of probability mentioned above, this likelihood value V can be calculated directly without any particular difficulty. It is higher as the reference value {circumflex over (λ)} remains adapted to the observation in progress. Indeed, the situation may have changed since the initialization of the reference value or since its last update, due to a change in the position of the accelerometric sensor on the body of the person being observed, due to a change in the person being observed or due to another disruptive event. In this case, the likelihood value V can be degraded. It is therefore beneficial to regularly verify that this value remains greater than a predetermined threshold denoted δ. This threshold δ is dependent only on the model HMM stored in the memory 20 and a method for calculating its value will be described in detail in reference to
In step 106, the likelihood value V is compared to the threshold value δ. If V>δ, the method returns directly to step 100 to process a new measurement sequence. Otherwise, the method activates a step 108 of updating the reference value {circumflex over (λ)} before returning to step 100.
The updating step 108 is performed in parallel with the loop of steps 100 to 106 and is based on sequences of successive states provided at the output of step 104. In the example considered, it is based on the detection of a state wherein a sufficient proper acceleration is measured for a minimal duration. In effect, this proper acceleration is detected by the second component of the samples of the observation sequence, which is independent of the reference value {circumflex over (λ)} and therefore insensitive to its drifts. In addition, by imposing a minimal duration, for example 12 seconds, the walking state is distinguished from the sitting/standing transition or standing/sitting transition states, which do not last as long and which are the only ones, with the walking state, to have a sufficient proper acceleration. Thus, independently of the reference value {circumflex over (λ)}, it is possible to detect precisely when the person being observed is in the walking state. However, this walking state is also a state wherein, as in the static standing position state, the low-frequency portion of the acceleration vector measured must be, on average, co-linear to the reference vector λ in order for the statistical model to be applied optimally, as was defined in the construction of the model.
Thus, step 108 consists, as shown in
To detect a sufficient proper acceleration (even denoted, for example, ACC, the opposite even then being denoted
with, for example, μACC=1.282134 and σACC=1.09, and
with, for example, μ
It is then decided at each instant (i.e. for each sample) that the proper acceleration is sufficient if:
It is therefore necessary for this condition to be verified for at least 12 seconds in order for the update of the reference value {circumflex over (λ)} to be capable of being performed.
Step 108 is optionally but advantageously followed by a step 110 of invalidating the activity determined, at least partially by invalidation of at least some of the sequence of states determined on the basis of the observation sequence in step 104. More specifically, the states determined for which the likelihood value is less than the threshold value δ can be invalidated. Also optionally, information can be generated making it possible to warn the user that an activity has been determined even though the likelihood value was low. This information can be displayed by the interface 36.
The method for calculating the threshold value δ, illustrated in
Then, in a step 302, the likelihood value V is calculated for each of the theoretical observation sequences obtained in step 300.
Finally, in a last step 304, the value of δ is determined so that, for example, 95% of the likelihood values V calculated in step 302 are greater than this value δ. In particular, as indicated above, this gives δ=−8 for the model described above and illustrated in
Three examples of time diagrams of intermediate or output data of the device of
The first diagram provides an example O of an observation data sequence with two components as defined above. The sequence of the first components On(1) is denoted O(1) and the sequence of the second components On(2) is denoted O(2).
The second diagram provides the resulting activity A estimated by the activity detection module 30 in the form of a sequence of states: on the y-axis of this diagram, 1 identifies the sitting position state (hidden state K1), 2 identifies the sitting/standing transition state (hidden state K2), 3 identifies the static standing position state (hidden state K3), 4 identifies the walking state (hidden state K4) and 5 identifies the standing/sitting transition state (hidden state K5).
The third diagram provides a resulting sequence of likelihood values V, estimated by the test module 32 in sliding windows. The likelihood values V are compared at each instant to the threshold δ.
It is noted, in the first and third diagrams, that until around the 25th sample, the reference value {circumflex over (λ)} appears to be poorly adapted to the model since a sitting/standing transition state is detected for an excessive duration, confirmed by the likelihood value V<δ.
After the detection of a sufficiently long proper acceleration period measured between the 15th and 25th samples (cf. curve O(2)), the reference value {circumflex over (λ)} is updated toward the 25th sample, confirmed by the likelihood value V>δ after this instant.
It is then noted that, after another proper acceleration period between the 75th and 80th samples, during which the motion sensor 18 must have been inadvertently moved, the likelihood value again goes below the threshold δ.
The situation is reestablished around the 112th sample, after the detection of a new sufficiently long proper acceleration period (cf. curve O(2)), when the reference value {circumflex over (λ)} is again updated, confirmed by the likelihood value V>δ after this instant.
It is noted that the decisions made while V<δ could alternatively not be indicated in the activity sequence A. It is also noted that this activity sequence A could be directly displayed, or represented in one way or another, on the interface 36.
It appears clearly that a detection device such as that described above is capable of detecting drifts in the estimation of the states observed and consequently being automatically calibrated. It is therefore more robust than similar devices of the prior art.
It should also be noted that the invention is not limited to the embodiment described above.
In particular, the reference value {circumflex over (λ)} is not necessarily that defined above, namely the value, in the frame of the measurement axes of the three-dimensional accelerometer 18, of the components of a unit vector, vertical and oriented downward when the person being observed is wearing the three-dimensional accelerometer and is in the “static standing position” state. This reference value is of course very closely linked to the application chosen as a non-limiting example.
More generally, the reference value is the value, in a frame associated with the motion sensor 18, of the components of a reference vector that can be estimated by means of the measurements provided by the sensor when the physical system being observed is in a predetermined state wherein this reference vector is assumed to be stable, this state preferably being detectable on the basis of observation components independent of the reference value.
It will also appear more generally to a person skilled in the art that various modifications can be made to the embodiments described above, in light of the teaching disclosed above. In the claims below, the terms used must not be interpreted as limiting the claims to the embodiment described in the present description, but must be interpreted so as to include all equivalents that the claims are intended to cover due to their wording and that can be envisaged by a person skilled in the art applying general knowledge to the implementation of the teaching disclosed above.
Number | Date | Country | Kind |
---|---|---|---|
11 59595 | Oct 2011 | FR | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/FR2012/052394 | 10/19/2012 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2013/057447 | 4/25/2013 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
7263472 | Porikli | Aug 2007 | B2 |
20100001949 | Shkolnikov | Jan 2010 | A1 |
20100010383 | Skelton et al. | Jan 2010 | A1 |
20110060215 | Tupin, Jr. | Mar 2011 | A1 |
20120143094 | Jallon | Jun 2012 | A1 |
20140229410 | Jallon et al. | Aug 2014 | A1 |
Number | Date | Country |
---|---|---|
2010 122174 | Oct 2010 | WO |
Entry |
---|
Wang, L. et al. “Recent developments in human motion analysis” Pattern Recognition, vol. 36, pp. 585-601, 2003 XP 004393092. |
Bilmes, J.A. “A Gentle Tutorial of the EM Algorithm and its Application to Parameter Estimation for Gaussian Mixture and Hidden Markov Models” International Computer Science Institute, pp. 1-15, Apr. 1, 1998 XP 002594206. |
Rabiner, L.R. et al. “An Introduction to Hidden Markov Models” IEEE ASSP Magazine, vol. 3, No. 1, Jan. 1986 XP 011353445. |
Jallon, P. “A graph based algorithm for postures estimation based on accelerometers data” Proceedings of 2010 annual international conference of the IEEE EMBC, pp. 2778-2781 (4 pages), 2010. |
International Search Report dated Jan. 4, 2013 in PCT/FR12/052394 Filed Oct. 19, 2012. |
Number | Date | Country | |
---|---|---|---|
20140365163 A1 | Dec 2014 | US |