The present invention relates, in general terms, to a system and method for motion analysis, such as gait analysis.
In various contexts it is desirable to be able to measure movements of an individual, for example to perform biomechanical assessments to improve athletic performance, or to test for physical behaviours that may be characteristic of an underlying neurological condition.
For example, gait analysis is the measurement of quantities related to human locomotion (for example step time, or stride length). These quantities are known as spatiotemporal gait parameters. Variability of these gait parameters is an important diagnostic indicator of health, correlating with both quality of life and mortality, and is of great interest to both clinicians and researchers. As such, there exists a multitude of technologies for measuring and quantifying gait, including instrumented walking mats, treadmills, motion capture systems, and wearable sensors (such as pressure sensitive foot switches or inertial sensors). These technologies have different strengths and weaknesses.
For example, instrumented walking mats such as the GAITRite of CIR Systems, Inc. (Franklin, N.J.) provide both spatial and temporal gait analysis, at the cost of requiring a relatively large area for use. By contrast, Inertial Measurement Unit (IMU) based wearable sensors such as the Shimmer3 (shimmersensing.com) sacrifice measurement accuracy and comprehensiveness for portability and practicality.
Unlike most walking mats, treadmills, or motion capture clinical gait analysis systems, IMU-based wearable sensors allow for a more convenient and practical way to perform gait analysis outside of a laboratory or hospital setting. As such, these sensors can be used to capture the natural walking of elderly persons or those with neurological conditions. However, some measures of gait variability of clinical interest are difficult to estimate using IMU-based sensors. One reason for this limitation is because the sensors only measure acceleration and rotation, and to infer even simple gait parameters (such as stride length), complicated models must be employed. One important gait parameter that is difficult to estimate with IMU-based sensors is step width, which is an indicator of fall risk. Another is estimating the placement of the foot in terms of base-of-support during walking, which can help in evaluating balance and subsequently fall risk.
Wearable IMU-based sensors are widely used, and have been used to record the gait of healthy elderly people, and those with neurological conditions such as Parkinson's Disease. These systems can measure various gait parameters, including step time, step length, step time variability and step length variability. However, other gait parameters are harder to estimate reliably, such as swing time or step width. Additionally, sensor location, speed, and the algorithms employed in analysis have a direct effect on the accuracy of any gait parameter estimation.
It would be desirable to overcome or alleviate at least one of the above-described problems, or at least to provide a useful alternative.
Disclosed herein is a system for motion analysis of a subject, including:
Also disclosed herein is a method of motion analysis of a subject, including:
Further disclosed herein is at least one computer-readable medium storing machine-readable instructions that, when executed by at least one processor, cause the at least one processor to perform a method as disclosed herein.
Embodiments of the present invention will now be described, by way of non-limiting example, with reference to the drawings in which:
Embodiments of the invention generally relate to the use of multiple, wearable time-of-flight (TOF) ranging sensors to measure distances, at a succession of times, between parts of a subject that are in motion relative to each other. For example, the sensors may be attached to the feet of the subject to conduct gait analysis.
The TOF ranging sensors may be RF-based sensors, such as Ultra Wideband (UWB) radio sensors. Alternatively, they may be laser ranging, infrared or ultrasonic sensors.
Measurements recorded by the TOF sensors can be used to determine motion metrics, such as gait parameters including stride width and foot placement, which are difficult or even impossible to measure accurately with inertial measurement unit (IMU) sensors. In some embodiments, measurements from the TOF sensors may be combined with measurements from inertial sensors to improve the accuracy of the motion metric determination.
As used herein, a “motion metric” means one or more numerical values indicative of the motion of a subject over one or more time segments (which may be of variable duration). For example, a motion metric may be a gait metric such as step time, step length, step width, stride time, stride length, stride velocity, cadence, swing time, or swing length; or another parameter, such as arm swing, elbow extension, neck rotation, knee extension, or postural sway. A motion metric may also be a summary value characteristic of the one or more numerical values, such as a mean or standard deviation (or other measure of location or variability).
In certain embodiments, each TOF sensor measures the distances to two sensors on the other foot, allowing an accurate assessment of foot placement relative to the other foot. Unlike systems such as GAITRite, this placement can be calculated throughout the stride. Advantageously, embodiments of the present invention combine the spatial accuracy benefits of instrumented walking mats with the portability benefits of IMU-based wearable sensors.
Embodiments of the invention provide one or more of the following benefits:
In the following discussion, and for ease of direct comparison with existing systems such as the GAITRite walking mat, the following definitions for some important gait metrics are adopted (see
These metrics, and their variability, are all useful to clinicians for diagnosis of neurological conditions or in evaluating general health.
In certain embodiments, with reference to
The sensor units u1 to u4 are attachable at respective attachment points of a subject. In the particular example shown in
In the particular example shown in
In the embodiment illustrated in
Each of the first u1, second u2, third u3 and fourth u4 sensor units includes a time-of-flight (TOF) ranging sensor, such as a UWB ranging sensor. Each TOF ranging sensor is in communication with at least one processor. For example, each sensor unit may include at least one on-board processor that communicates with its TOF ranging sensor via a bus.
The at least one processor is configured to cause the sensor units u1, u2, u3, u4 to execute a two-way ranging protocol at a succession of times. The two-way ranging protocol includes transmission of one or more signals from, and reception of one or more signals at, the TOF ranging sensors, to determine TOF distance data indicative of respective distances between the sensor units at respective times. An exemplary two-way ranging protocol is described in more detail below.
The at least one processor is also configured to determine, from at least the TOF distance data, one or more motion metrics, such as one or more gait metrics.
The system 10 may include at least one processor external to the sensor units, such as a processor of an external computing device (e.g. a mobile computing device 12) with which the sensor units communicate, e.g. via Bluetooth or another wireless communications protocol. As such, operations performed by the components of the sensor units, including computation of distances and motion metrics, may be carried out or instructed by on-board processors of the sensor units themselves, and/or by processors of external computing devices with which the sensor units communicate. For example, the sensor units may collectively execute the ranging protocol, compute the relative distances between the sensor units, and store the computed distances in on-board memory for later transmission to an external computing device, a processor of which may then use the computed distances to determine the one or more motion metrics.
An example sensor unit u1 is shown in
Sensor unit u1 may include an on-board processor 20 that is in communication with a memory that stores computer-readable instructions executable by the on-board processor, and that may also store data recorded by one or more sensors of the sensor unit u1. In one example, the processor is part of a system-on-a-chip (SoC) such as a core nrf51822-based assembly of Nordic Semiconductor, with a 32-bit ARM Cortex M0 at 16 MHz, with 24 kB of RAM, and 128 Kb of flash memory. An SoC, in the context of a sensor unit, may be referred to as a “processor” in the discussion below.
In addition, sensor unit u1 includes an inertial measurement unit (IMU) 22, such as a 6-axis IMU MPU6050 providing three channels from an accelerometer (ax, ay, az) and 3 channels from a gyroscope (gx, gy, gz). The IMU 22 and an EEPROM 24 are in communication with processor 20 via an I2C bus 30.
The sensor unit u1 also has a TOF ranging sensor, for example a UWB sensor 24 having an antenna 26 and being in communication with processor 20 via a serial peripheral interface (SPI) bus 32. The UWB sensor 24 may be a real-time location module such as the DWM1000 of Decawave Limited. UWB sensor 24 can be used for absolute range measurements. The ranging sensor 24 may be configured in a low-power mode, with a transmission rate of 6800 Kbps, and a pulse repetition frequency of 64 MHz, for example.
Sensor unit u1 may communicate with external computing devices, such as mobile device 12, via one or more interfaces such as a Bluetooth 4.2 (BLE) interface 34 and a USB interface 40 (that is connected to processor 20 via serial bus 44). The USB interface 40 may also be used to charge a rechargeable battery (such as a 110 mAh LiPo battery) 52. To this end, sensor unit u1 includes battery management circuitry (including charger 50 and low-dropout regulator 54) to support ultra-low power use cases, and for measuring and charging the battery 52.
In certain embodiments, the sensor unit u1 may have its electronic components mounted to a single-sided 20.4 mm×24.1 mm PCB, which as mentioned above, may be housed in a case for mounting on a shoe or another suitable attachment point of the subject (e.g. a belt, article of clothing, etc.).
The sensors u1, u2, u3, u4 can be used to measure distances as well as motion. The configuration of the sensors and their locations on the body may determine what measurements can be extracted.
For example, as will be appreciated by those skilled in the art, by appropriate sensor placement it is possible to measure any movement of the extremities, such as arm swing, elbow extension, neck rotation, knee extension, and postural sway. In one example, arm movement and elbow extension may be measured by placing one sensor on the shoulder, one on the elbow, and one on the wrist (on each side). In another example, leg movement and knee extension may be measured by placing one sensor on the ankle, one on the knee, and one on the hip (on each side).
The following discussion will focus on gait analysis, with two sets of paired sensors employed on the feet of the subject. However, it will be appreciated that the invention is not restricted to gait analysis or to the particular configuration of sensors shown in
In the discussion below, u1 and u2 are on the right shoe 14 and u3 and u4 are on the left shoe 16. However, it will be appreciated that left and right can be interchanged, with consequential changes to the labelling of the sensor units. The first sensor unit (u1 or u3) may be positioned flat on the front toe area and the other (either u2 or u4) vertically oriented on the heel of the shoe. Therefore, the distance between the front of the two shoes (u1 and u3), is labelled as
Sensors on either foot 14, 16 are a fixed distance away from each other (usually L the length of the shoe), and as a result these distances are not measured during gait analysis. These four measurement distances
The sensor units may individually or collectively transmit the following data to an external computing device, such as mobile device 12, at a sampling rate of 100 Hz:
The mobile device 12 may execute a collator application 618 (
For best line of sight, the UWB aerials 26 of each sensor may be pointed inwards towards the other shoe. As the back of the heel has been found to be an optimum place to position an IMU for gait measurement, acceleration and angular speed measurements may be limited to the IMU sensors 22 on the back of the heels (sensor units u2 and u4). The orientation of the rear IMU sensor and its channels are illustrated in
It has been found that the system 10 can run for up to 2.5 hours under continuous operation, as can be seen in
As shown, the mobile computer device 12 includes the following components in electronic communication via a bus 606:
Although the components depicted in
The display 602 generally operates to provide a presentation of content to a user, and may be realised by any of a variety of displays (e.g., CRT, LCD, HDMI, micro-projector and OLED displays).
In general, the non-volatile data storage 604 (also referred to as non-volatile memory) functions to store (e.g., persistently store) data and executable code.
In some embodiments for example, the non-volatile memory 604 includes bootloader code, modem software, operating system code, file system code, and code to facilitate the implementation components, known to those of ordinary skill in the art, which are not depicted nor described for simplicity. For example, the non-volatile memory 604 may contain a collator application 618.
In many implementations, the non-volatile memory 604 is realised by flash memory (e.g., NAND or ONENAND memory), but it is certainly contemplated that other memory types may be utilised as well. Although it may be possible to execute the code from the non-volatile memory 604, the executable code in the non-volatile memory 604 is typically loaded into RAM 608 and executed by one or more of the N processing components 610.
The N processing components 610 in connection with RAM 608 generally operate to execute the instructions stored in non-volatile memory 604. As one of ordinarily skill in the art will appreciate, the N processing components 610 may include a video processor, modem processor, DSP, graphics processing unit (GPU), and other processing components.
The transceiver component 612 includes N transceiver chains, which may be used for communicating with external devices via wireless networks. Each of the N transceiver chains may represent a transceiver associated with a particular communication scheme. For example, each transceiver may correspond to protocols that are specific to local area networks, cellular networks (e.g., a CDMA network, a GPRS network, a UMTS network), and other types of communication networks.
The mobile computer device 12 can execute mobile applications, such as the collator application 618. The collator application 618 could be a mobile application, web page application, or computer application. The collator application 618 may be accessed by a computing device such as mobile computer device 12, or a wearable device such as a smartwatch.
It should be recognised that
To describe the motion of the subject's feet during use of the system 10, a high sampling rate is advantageous to increase accuracy. Embodiments of the system 10 may record IMU and UWB measurements on all four sensors at 100 Hz, time-locked to within a few hundred μs. However, this high sampling rate needs to be balanced with the power efficiency concerns of any wearable technology. To achieve better power efficiency, it is advantageous for the four sensors to know precisely when they should turn on their UWB radios 26 for any communication required.
In view of the above, the system 10 may implement a synchronisation process. In one example, each UWB sensor 24 may be configured to send an interrupt at regular intervals (e.g., every 10 ms for a sampling rate of 100 Hz) to corresponding processor 20. Alternatively, the interrupt may be initiated at the processor 20. The processor 20 of only one of the sensor units, such as sensor unit u1, may be configured to transmit a synchronisation beacon message to each of the other sensors u2, u3 and u4.
The designation of a sensor unit as the synchronisation beacon unit may be controlled by mobile device 12. In other embodiments, the designation of a sensor unit as the beacon unit may be negotiated among the sensor units. For example, a sensor synchronisation process may include each sensor unit waiting for a random length of time after start-up, and then transmitting a first signal from its UWB sensor 24. The first sensor unit to transmit becomes the beacon, the second to transmit becomes the non-beacon initiator, and third and fourth are non-initiators. In case of a conflict where any two sensor units transmit at the same time, an exponential backoff approach may be implemented, in which all units may give up their designations, and then wait a longer random amount of time than before to start the synchronisation protocol again.
The synchronisation beacon message may be transmitted after a fixed delay after the interrupt. The synchronisation beacon message can be used by the other sensor units u2, u3, u4 to move their interrupt timings in-line with the beacon sent by sensor unit u1. Over a few hundred milliseconds, it has been found that all devices become locked to this beacon pulse to within μs. Therefore, the timings of any potential ranging protocol are known to all of the devices, meaning that the UWB radios 26 are turned on or off as required. This allows the system 10 to reduce its power consumption and improve efficiency by only turning on the UWB radios 26 approximately 20% of the time.
With reference to
In general, a single-sided two-way ranging protocol 1000 may include:
The timing differences reported by the non-initiator sensor units allow the initiator sensor unit to determine the relative motion between it and each non-initiator sensor unit.
In the example described below, the sensors on the right shoe (u1 and u2) behave as initiators and the other two (u3 and u4) behave as non-initiators. It will be appreciated that the roles of initiators and non-initiators can be switched as desired, e.g. under control of mobile device 12, or can be negotiated between the sensor units at start-up, as discussed above.
Each sensor unit samples its onboard IMU 22 and transmits a Bluetooth packet within each interrupt interval of 10 ms. Accordingly, there is a very limited time budget of 2 ms within each interrupt interval to implement the entire UWB ranging protocol 1000. Were it not for these time constraints, the ranging protocol could be run at 200-500 Hz, albeit with a much higher power consumption.
Conventionally, UWB ranging uses a symmetric double-sided two-way ranging protocol, where the protocol is structured to remove the errors caused by the different relative speeds between device oscillators/clocks. However, this approach requires more messages and a much larger time budget. Accordingly, embodiments of the present invention use a custom single-sided two-way ranging protocol with poll and response messages. In certain embodiments, only the initiators compute a distance measurement. This enables further speedup of the protocol.
With reference to
In a first step 1010, the first sensor unit u1 (the beacon) transmits a first poll signal, denoted as Poll 1 in
In a second step 1020, the second sensor unit u2 transmits a second poll signal, denoted as Poll 2 in
In a third step 1030, the third sensor unit u3 transmits a first response message, denoted as Response 1 in
In a fourth step 1040, the fourth (non-initiator) sensor unit u4 transmits a second response message, denoted as Response 2 in
The ordering of these transmission steps can be seen in
After receiving a response, at step 1050, the initiators u1 and u2 calculate the duration from sending a poll message to receiving the response message (tR
and the distance between sensor ux and uy is therefore,
u
x
u
y
where c is the speed of light. Whilst the speed of a UWB transmission through air is a little slower than c, it is only slower by approximately 0.03%, and this difference is negligible.
Advantageously, the distances between the sensors may be computed only by the initiator sensor units. This reduces the time required to execute the ranging protocol 1000.
These time differences are made with respect to the different oscillators on each device and as a consequence they may not be exactly in sync. Additionally, there may be errors associated with antenna delay and manufacturing differences in the DWM1000 chip, and as such the UWB ranging sensor may need to be calibrated.
For example, a UWB calibration process may be implemented to correct for sources of error in ranging estimation that arise from temperature variation, including antenna delay and differences in oscillator drift. Antenna delay is the internal delay of the chip, and it is determined by the differences in the shape of the aerial and the device temperature. The ranging error can be as much as 2.15 mm per degree centigrade. If a single-sided two-way protocol 1000 is used, oscillator drift can be problematic. The oscillator has a warm up time and is also affected by device temperature.
Calibration is performed by comparing known distances with UWB measurements. A linear model is fitted to the calibration data to compensate for any error associated with the geometry of the sensor arrangement, the antenna delay, and oscillator differences. The calibrated measurement between device x and y may be expressed as:
u
x
u
y
where Tx is the temperature of device x, Txmax is the maximum temperature device x reaches at steady state and ρ0, ρ1, ρ2, and ρ3 are model parameters. UWB walking data corrected using this fitted model can be seen in comparison with the direct measurements from the GAITRite in
Inertial sensor calibration may also be performed. For example, an MPU6050 IMU uses MEMS (Microelectromechanical systems) for the accelerometers and gyroscopes. As these are physical systems, they have slight manufacturing differences, and therefore these MEMS units vary from one another, and thus require individual calibration, primarily to correct the “zero points” for each axis. A factory calibration is done which sets trim values, but each unit may be recalibrated as this factory calibration is not always reliable.
To calibrate each unit 22, they may be held in a particular orientation such that the accelerometer directions for two channels are perpendicular to, and the other channel is co-linear with, the gravitational field of the earth. The units are operated for a sufficient length of time (e.g. 10 minutes) to achieve a constant temperature, and then tens of thousands of readings are made using MPU Offset Finder code (www.fenichel.net). This program resets a window of trim offsets until each axis moves to the correct values for this orientation. For example, with the Z axis (perpendicular to the IC) pointing down, it should record exactly 1 g. Trim offsets are changed until they read (ax=0, ay=0, az=1, gx=0, gy=0, gz=0). The final trim offset values are preloaded into the device each time it is used.
An embodiment of a motion metric determination method 1600 will now be described (
In general, the method 1600 may include determining (e.g., by a peak detection process) one or more stationary points, such as local maxima, local minima, or points of inflection, of a curve defined at least partly by the TOF ranging data and/or the inertial sensor data, and computing at least one motion metric based on the one or more stationary points.
Firstly, in order to interpret the signals coming from the UWB sensors 24, we consider the geometry of the arrangement of the sensors u1, u2, u3, u4, and how they change over time.
During the double support time (both feet on the ground), some assumptions can be made about the meanings of the UWB measured distances. In
The maximum Toe-Heel distance (Toe-Heel Max) in this example is given by
Now, consider the change in these measurements in motion. Unlike the GAITRite, the system 10 has the potential to measure the step width whilst the foot is in the air. In
Turning now to
Next, at step 1620, the signal may be filtered, for example using a Savitzky-Golay filter. This filter is advantageous as it does not greatly distort the shape of the signal, but still smooths out some of the noise. A continuous wavelet transformed-based peak detection algorithm may be used to find the peaks in all four signals. The four signals are the respective estimated distances
At step 1630, the internal angles of the irregular quadrilateral present between the two feet (
Having determined the inter-sensor distances and the internal angles of the quadrilateral, it is possible to calculate some important gait metrics, at step 1640.
First, the step time (Stpt) is defined as the difference of two consecutive alternating Heel-Toe maximums, and the stride time (Strt) is the sum of two consecutive step times. Stance time can be calculated based on the proportion of time that the UWB signal spends above an empirically defined threshold (time spent at the top of the Heel-Toe peak), and swing time is just the rest of that proportion. Cadence can be calculated by counting the number of Heel-Toe maximums in a fixed duration. The step length is defined as the component of
Stpl=
for the right and left steps respectively, where the angles β2 and α1 are defined as
The stride length Strl is defined as two consecutive step lengths. The step width is defined as the distance between the two mid points of the feet which by geometry is,
Furthermore, we can calculate the stride velocity as
Additionally, with these angles it is possible to calculate the positioning of the feet (relative to each other).
The foot placement determined using system 10 and methods 1000, 1600 is compared with the foot placement of the GAITRite mat in
Gait Metrics from IMU Data
Optionally, as part of step 1640, one or more metrics can be determined from the inertial sensor data.
For example, the raw IMU data may be linearly interpolated, re-sampled at 1000 Hz, and then low-pass filtered with a cutoff of 10 Hz (to remove noise), as is implemented in some known IMU-based studies. With this cleaned and interpolated data, we now turn to the problem of estimating stride length. As system 10 does not include a magnetometer, it is very difficult to orientate the sensors with respect to each other, and therefore does not consider the estimation of step length using only IMUs. We therefore use a simple (and low computational cost) zero-velocity update double integration method, based on using the gyroscope to compensate for the change in orientation of the sensor during walking. These methods can be run on embedded hardware.
As the IMU sensors 22 are oriented such that all three accelerometers are approximately in line with the three planes of the body, we can use the following general definitions: ax is the acceleration up-and-down, ay is the acceleration left-to-right, and az is the acceleration back-to-front.
The first stage of the zero-velocity update double integration method involves finding the peaks and troughs in az. These peaks are analogous to the toe-off and heel-strike events that occur during walking. The stride time can therefore be defined as the distance between two consecutive peaks. The stride length is defined as the double integral of the acceleration in the forward direction. However, due to the rotation of the sensor, the channels of acceleration cannot be used directly.
The first model involved using the gyroscope gy, to compensate for the rotation of the ankle. Using this method, the acceleration in ax and az is combined into a vector based on the angle of rotation. The method only uses 3 axes of the IMU. Another approach is to use all 6 axes of the gyroscope and accelerometers to compensate for the 3D motion of the foot. As before these IMU readings are transformed from the IMU reference frame, into a global reference frame, this time using the method based on the Direction Cosine Matrix (a full description of this methodology can be found in W. Premerlani and P. Bizard, “Direction Cosine Matrix IMU: Theory”, Technical Report, 2009). Once these transformed values are found, the signal is integrated twice between the consecutive peak and trough, this being the stride length.
Walking data from twenty one healthy adults (between the ages of 21 and 35), were recorded concurrently with a GAITRite walking mat and with system 10. An overview of the dataset is shown in Table 1.
The GAITRite walking mat is capable of measuring stride time, step time, stride length, step length, stride width, and step width amongst others and is therefore a good choice to serve as a ground truth measurement and as a comparison to system 10. GAITRite claims a spatial resolution accuracy of ±1.27 cm.
Each subject walked on a walking track for more than 80 steps, split up into 15 “sessions”, defined as one walk over the mat. All data was collected with Institutional Review Board of [BLINDED] approval. This data was collected to mimic a standard gait assessment. Subjects were asked to walk a comfortable pace over the walking mat and after each session the subject could choose to rest. The GAITRite was synchronised with system 10 using NTP to a local NTP server. This data was collected over a two week period at [BLINDED].
First we will look at the UWB-only methods for measuring gait metrics. Whilst there are undoubtedly some errors introduced due the simplification of the 3-dimensional nature of the physical system, this model performs well. Table 2 shows the root mean square error (RMSE), mean absolute error (MAE) and mean absolute percentage error (MAPE) of UWB measurements in comparison to the GAITRite. We can see across most metrics we are getting within 4-5% of the ground truth value. Additionally, we are measuring step width which is not a metric calculated by standard wearables. Despite the limitations of UWB measurement ranging technologies we are able to get accurate gait metrics.
The simple IMU methods used herein do not perform as well as the UWB metrics. This is expected as these methods are low time-complexity, and relatively simplistic. Table 3 shows the root mean square error (RMSE), mean absolute error (MAE), and mean absolute percentage error (MAPE) of IMU measurements in comparison to the GAITRite. We can see the temporal measurements are very similar to the UWB methods, however the spatial metrics perform worse. These results are consistent with those from other researchers using foot-mounted 6-axes IMU methods. These IMU measurements though are not affected by line of sight as UWB measurements are and therefore we will now look at a simple fusion of the two methods.
Although it performs worse overall, the IMU can be more accurate in measuring the stride length in a subset of our dataset. This is likely due to the UWB sensors temporarily losing line of sight during a narrow step (recall the spike in
Strl=v0StrlUWB+v1StrlIMU.
The coefficients v0 and v1 may be found using standard mathematical optimisation techniques, such as least squares regression, for example. In one example, v0=0.82 and v1=0.18.
We also try compensating for the slight difference in UWB stride length error between measuring the left and right strides by fitting this same model for the left and right strides independently. An approximate 20% improvement in accuracy by combining the two with these methods can be seen in Table 4.
In summary, the system 10 can measure gait metrics that are not possible on such IMU-based wearables, and stable spatial readings of steps is also possible. It is apparent that a combination of IMU and UWB can give an increase in accuracy. Embodiments of the system 10 therefore combine these two technologies to provide the benefits of both IMU systems and walking mats at a fraction of the cost. The GAITRite walking mat costs in the order of tens of thousands of dollars, whereas a set of four sensors such as the one shown in
In some embodiments of the motion analysis system and method, the TOF ranging sensor (such as UWB sensor) data and IMU data may be combined via a sensor fusion process. Accordingly, the inter-sensor distances and/or the one or more motion metrics may be determined based on a combination of the UWB data and IMU data.
In a first example of a sensor fusion process, the UWB data and IMU data may be combined via an extended Kalman filter.
The use of traditional filtering methods can both time shift and change the shape of the raw signal as can be seen in
Kalman Filtering is an algorithm to combine noisy measurements from multiple sensors to estimate system states more accurately. It is typically used in positioning or localisation systems such as those in commercial aircraft or drones. The EKF is the non-linear version of the Kalman Filter. In order to use EKF, the kinematic behaviour of the system is modelled.
To motivate the present use of EKF, consider the physical system that is being measured. In system 10 there are four sensor units moving relative to each other. Initially, considering that if two sensors ux and uy are moving apart with a velocity of ΔV, after a small amount of time (Δt) they will be ΔV Δt further apart as can be seen in
u
x
u
y
t+Δt=
However, the velocity cannot be measured directly as only an IMU is being used, therefore we define the velocity of ux as the cumulative acceleration:
{right arrow over (v)}
x,t+Δt
={right arrow over (v)}
x,t
+{right arrow over (a)}
x,t
Δt,
and assuming over this short amount of time that the acceleration remains constant, the acceleration after Δt must be
{right arrow over (a)}
x,t+Δt
={right arrow over (a)}
x,t.
Accordingly, there are two ways to estimate distances in the system 10. The following rules can be defined for all four UWB measurements that we have in the system:
u
1
u
3
t+Δt=
u
1
u
4
t+Δt={right arrow over (u1u4)}t+({right arrow over (v)}1−{right arrow over (v)}4)Δt
{right arrow over (u2u3)}t+Δt=
u
2
u
4
t+Δt=
With these equations in place, an EKF model can be formulated. In some embodiments, only one of the acceleration axes may be used, specifically the direction that is collinear with the direction of walking. The presently described embodiment of the system 10 has three measurements it can make at every iteration. These are the ranging estimate between ux and uy, the acceleration of ux, and the acceleration of uy, as defined below.
There are five internal states of the model: the distance (dxy,k) between ux and uy, and the velocities and accelerations of the two sensors.
Assuming constant acceleration, a transition matrix can be defined as
To implement this model, the python library FilterPy (https://github.com/rlabbe/Kalman-and-Bayesian-Filters-in-Python/) can be used. The EKF parameters such as Q and R matrices were found through experimentation. For each distance (
This method gives an interpretable model, as the measurements made in between peaks are preserved in the filtering process, as well as the expected plateau at the top of each peak. This filter can also be compared with the method that does not make use of sensor fusion, as can be seen in
In a second example of a sensor fusion process, the UWB data and IMU data may be combined via Support Vector Regression (SVR). In some embodiments, three different models may be used to calculate three different spatial gait metrics.
Before using SVR, we preprocessed and organised the raw IMU and UWB data. Specifically,
(1) the UWB measurements were calibrated as discussed above, and filtered using a Savitsky-Golay filter (though it will be appreciated that other smoothing filters, such as a Kalman filter or Butterworth filter may also be used);
(2) the IMU measurements were calibrated as discussed above;
(3) the step peaks and stride peaks in the UWB measurements were identified; and
(4) all IMU and UWB measurements were truncated to ±300 ms around each step peak, or either side of the stride peaks.
Then for each step and stride, we extracted a total of 113 features from the IMU data and UWB data of all four sensors. These features included the min, max, mean and standard deviation of all 24 channels of IMU data (6 channels for each sensor) and 4 channels of UWB data. We also use as a feature the baseline estimate of our metrics (i.e., the estimates obtained in step 1640 of
To find the optimum SVR kernel function, we used 10-fold cross validation and the steps dataset is divided into ten partitions such that a similar percentage of the amount of steps from each participant is in each partition. Through experimentation we found that, for step width and length, a SVR using the sigmoid kernel performed the best. For stride length, we found that a model with a linear kernel outperforms the sigmoid. The results of the SVR model estimations are shown in Table 6 and in
In a third example of a sensor fusion process, the UWB data and IMU data may be combined via a Multilayer Perceptron (MLP).
A regression MLP model was built using the Sequential API from Keras. The same 113 extracted features as the SVR model may be used, with the same preprocessing. 10-fold cross validation may also be used to select the best performing MLP model. Through experimentation it was found that for step length, width, and stride length, the best performing model was a single layer MLP with two nodes. The activation function was the Relu function.
The hyper parameters for MLP were the number of layers, number of nodes, and the activation functions used. Again, 10-fold cross validation was used and the steps dataset was divided into ten partitions such that a similar percentage of the amount of steps from each participant was in each partition. To make sure this result was stable we trained 100 different MLPs, and the results can be seen in Table 7 and in
Importantly, the MLP model achieves MAPE of 2.26% in estimating step width, 2.24% in estimating step length, and 2.49% in estimating stride length when comparing to the GAITRite. Note that compared to all previous models the MLP model has narrowest measurement error histograms, with the vast majority of measurements falling within ±0.03m.
In view of the above, it can be seen that by using sensor fusion, it is possible to measure important gait metrics not previously measurable in traditional IMU-based sensors, such as step width. We compared three approaches to sensor fusion EKF, SVR, and MLP with MLP performing the best for spatial metrics. Indeed, these MLP derived metrics are close to the GAITRite reported accuracy of ±1.27 cm. Importantly, embodiments of the present invention are able to estimate step width which is predictive of fall risk and is thus of great clinical significance. The best methods for calculating the gait metrics detailed herein can be seen in Table 8.
Whilst the EKF method is not as accurate as the MLP and SVR methods, it is more interpretable. Specifically, EKF filtering can be used to estimate foot movement while in the air as the shape of the UWB signal is better preserved than by other filtering methods. Additionally, the EKF can be improved by the use of quaternions, and integrating the other accelerometer axes into the model. Another possible improvement is combining all four device pairs into one EKF model, with constraints based on the fixed positioning of the devices on the shoe. Further experimentation and simulation could allow a more correct model of the system noise Q.
An important benefit of the above approach is that every single algorithm used herein could feasibly run on the embedded hardware available in the sensor units (such as sensor unit u1 shown in
This system 10 allows the user to walk in any direction during measurement, unlike the GAITRite which only allows for straight line walking. It requires no room to be set up unlike motion capture systems which require dedicated space for use. The system 10 is inexpensive compared to other devices and due to its form factor is very convenient to use. Embodiments of the present invention may have use in many applications, for example, in tracking motion in sports medicine, gait-based neurological diagnostics for conditions such as Parkinson's disease, fall risk and frailty assessment, and the monitoring of the elderly.
Embodiments of the sensor system 10 are capable of measuring important gait metrics not previously measurable in traditional IMU-based sensors. Step width variability in particular is predictive of fall risk and thus of great importance. Furthermore, the sensors of system 10 can measure foot positions on step placement. This could be used to detect step abnormality.
It will be appreciated that many further modifications and permutations of various aspects of the described embodiments are possible. Accordingly, the described aspects are intended to embrace all such alterations, modifications, and variations that fall within the spirit and scope of the appended claims.
Embodiments of the invention may, for example, comprise features in accordance with the following numbered statements:
Throughout this specification and the claims which follow, unless the context requires otherwise, the word “comprise”, and variations such as “comprises” and “comprising”, will be understood to imply the inclusion of a stated integer or step or group of integers or steps but not the exclusion of any other integer or step or group of integers or steps.
The reference in this specification to any prior publication (or information derived from it), or to any matter which is known, is not, and should not be taken as an acknowledgment or admission or any form of suggestion that that prior publication (or information derived from it) or known matter forms part of the common general knowledge in the field of endeavour to which this specification relates.
Number | Date | Country | Kind |
---|---|---|---|
10201906276U | Jul 2019 | SG | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/SG2020/050360 | 6/25/2020 | WO |