Interrupt-Based Step-Counting to Extend Battery Life in an Activity Monitor

Most activity monitors use an accelerometer and gyroscope sensors to characterize the wearer’s physical activity. The monitor measures the motion by polling an accelerometer or gyroscope sensor or both every 20–30ms and frequent polling affects the battery life of a wearable device. One of the key features of a commercial daily-activity monitoring device is longer battery life so that the user can keep track of his or her activity for a week or so without recharging the battery of the monitoring device. Many low-power approaches for a step-counting system use either a polling-based algorithm or an interrupt-based algorithm. In this paper, we propose a novel approach that uses the tap interrupt of an accelerometer to count steps while consuming low power. We compared the accuracy of step counting and measured system-level power consumption to a periodic sensor-reading algorithm. Our tap interrupt approach shows a battery lifetime that is 175% longer than that of a 30ms polling method without gyroscope. The battery lifetime can be extended up to 863% with a gyroscope by putting both the processor and the gyroscope into sleep state during the majority of operation time.


Introduction
The growing interest in health has motivated the development of smart accessories that monitor the wearers' physical activities, including walking, running, sitting down, and lying in bed.Recently there has been a lot of research on method of counting steps using a three-axis accelerometer in association with different algorithms, including these found in commercially produced pedometers [1].
An activity monitor or digital pedometer typically reads an accelerometer sensor periodically, at a frequency of 30-50 Hz to measure the number of steps taken in walking or running.In a polling algorithm of this sort, the monitoring processor wakes up from its sleep state every 20-30 ms, reads the sensor data, and then runs the step-counting algorithm.This approach is 99.5% accurate for walking speeds over 90 m/min, which is usually considered satisfactory.However, polling consumes more power than the alternative eventbased interrupt approach [1], in which the system only wakes from its sleep state when the acceleration crosses some threshold.Research shows the acceleration change in human walking is between 0.4 and 0.8 g along the vertical axis [2].
Because an activity monitor or pedometer is usually worn on the wrist, on ankle, or on a belt around the waist, the system needs to have a form factor similar to that of a watch.Nevertheless, users expect a battery life of a week at least.For example, the electrical specification of the Misfit Shine, which is a highly optimized commercial activity monitor, indicates that a 3 V CR2032 battery, with a capacity of approximately 200 mAh, lasts three months.To obtain this kind of battery life, a system needs to stay in its sleep state for as long as possible, and the all electrical components have to be lowpower types.For instance, the MSP430 or STM32L MCUS only draws a few nA in sleep mode [3].
In this paper, we propose a low-power approach to stepcounting which uses the tap interrupt which is provided by several accelerometer chips, including the most popular Analog Devices ADXL345 and Freescale MMA8451.This interrupt is triggered by an acceleration exceeding a preprogramed value.To the best of our knowledge, a tap interrupt function has not previously been used for step-counting.We have compared the power consumption of a system running our algorithm and running a polling algorithm.We measured average power usage with and without gyroscope, which can draw a lot of power.The accuracy of our tap interrupt algorithm ranges between 83.5% and 90.25%, depending on the weight of the users, but the battery life is extended by factors ranging up to 8.6 when compared with polling.Comparing these figures with the performance of commercial pedometers suggests that our algorithm is suitable for devices in which battery life is paramount.

2.1.
Step-Counting by Polling an Accelerometer.A polling algorithm uses a timer-based routine to wake the accelerometer sensor to read accelerations and then return it to sleep state to save power [4].We experimented with a polling algorithm running on 20 Hz and measured the system power consumption.As shown in Figure 1, the system wakes at every 50 ms and reads the sensor which produces a peak in power consumption; then it processes the sensor data for about 20 ms which also uses significant power consumption.The number of steps is displayed on an LCD every 100 ms.The power consumption in sleep state   is 1.91 mW(  ); the power   used for reading accelerometer is 6.04 mW; and the processor running the polling algorithm uses a power   of 3.95 mW when it wakes up at a polling frequency of .The power consumption of the system  system can be expressed as follows: where   is power consumption during reading of the accelerometer,   is power consumption running the stepcounting algorithm,   is power consumption in sleep state,   is processing time required to read the reading accelerometer,   is processing time required by the polling algorithm,  is frequency of polling, and  is supply voltage.Table 1 shows the average power consumption of system for 1 second.
It is clear from (1) that actually energy can be saved by running the frequency at which the step-counting algorithm is waken up.But accuracy declined at frequency below 20 Hz [5], even though a human cannot walk or run at over 5 Hz.This motivates the development of an interrupt-based algorithm.

2.2.
Step-Counting Using a Tap Interrupt.The tap interrupt provided by the ADXL345 accelerometer chip can reduce the processing time required for counting steps, hence saving power.
Figure 2 shows our step-counting algorithm which uses this interrupt.An interrupt is triggered by acceleration along one of the accelerometer three fixed axes which exceed a specific threshold.To avoid unexpected interrupt, our algorithm finds the gravity axis among three axes by averaging the acceleration along each axis over 1 second and selects the axis whose average is around −1.0 g for interrupt source axis to trigger the tap interrupt.The interrupt service routine (ISR) handling the tap interrupt checks both the tap interrupt flag and the data-available flag before it decides to count a step.And this interrupt can be triggered by accelerometer even in its sleep mode and we can put processor also in its sleep to save system power.
Figure 3 shows the power consumption of the system over 1 second using the tap interrupt technique: one step is taken and one power peak occurs.During the resulting wake-up period the system consumes 5.92 mW for 12.6 ms and most of the time the system stays in sleep state to save the power.We will present results showing that the tap interrupt algorithm does save system-level power and assess its accuracy in Section 3.

System Implementation.
We implemented our stepcounting algorithm in a pedometer, shown in Figure 4, constructed from a Texas Instruments MSP430F4618 experimenter's board, populated with an ADXL345 and a ITG3200 gyroscope.Both sensors are connected to the I2C bus on MSP430F4618, and this I2C bus was configured to run at 100 kHz to save power.All unnecessary components were removed from the board to avoid spurious power consumption.
The ADXL345 was configured to run at a sampling rate of 200 Hz, at which frequency it drew 145 A [6].The ITG3200 was put into its sleep state immediately after initialization, where it draws just 6 A; when operating normally it draws 6.5 mA [7], and this power consumption is too great for a 200 mAh battery-powered system.The ADXL345 needs to be operating normally so that it can wake the MCU up by means of an interrupt.The MCU is put into LPM4 mode, in which it typically draws 0.3 A, against 400 A in active mode at room temperature [8].To compare the power consumed by a polling algorithm and our tap interrupt algorithm, both algorithms were implemented in the single source code file, and one algorithm was selected at compilation time.
The step count is displayed by an LCD driven by the LCD controller built into the MSP430F4618.Figure 5 shows the block diagram of this system.

3.1.
Step-Counting Accuracy.The threshold value of acceleration that triggers a tap interrupt needs to be carefully selected to balance accuracy against the powers saved by the MCU in its sleep state.We searched for an optimal acceleration threshold by measuring the error in step-counting using thresholds between 0.0625 g and 0.25 g (Figure 6).The procedure involved 10 trials of 40 steps by 65 kg adult.The smallest error corresponds to an acceleration threshold of 0.187 g, and this threshold uses further experiments.All experiments were approved by the Inha University Ethics Committee.
The accuracy of our algorithm was compared with that of an Omron HJ303 pedometer (which uses triaxis technology), the Runtastic (the most downloaded Android pedometer app), and Pedometer (implemented by Levente Bagi based on a public step-counting algorithm).These tests were  conducted at walking speed of 80 m/min, because many commercial pedometers are accurate at this speed [9].Each test involved 10 trials of 40 steps by each of two adults, weighing 65 kg and 72 kg.Because accuracy can be affected by the position in which a pedometer is worn, all the devices were attached to the wear's belt above their right hip.
The result for the 65 kg walks is shown as a "box and whiskers" plot in Figure 7 of the 10 time trials.
The mean step counts (and standard deviations) for our device, the HJ303, the Runtastic, and the Android pedometer app were 41.8 (4.46), 39.8 (0.92), 40.0 (1.63), and 33.8 (3.90), respectively.Our pedometer is less accurate than the commercial pedometers but performs considerably better than the Android app.
We conducted a further experiment on our devices, involving walkers with a wider range of weights, again involving 10 trials of 40 steps.The accuracy of the results varied between 83.5% and 90.25% as shown in Table 2. Schneider et al. [10] suggested an error of up to 10% is acceptable when a pedometer is used to measure the wearer's activity over long periods.This is exactly the sort of application in which a long battery life is essential.

Energy Consumption.
To measure the system power consumption, we connected our pedometer to a Monson Solutions Power Monitor, connected in turn to a PC running Power Tool 4.0.4.The output voltage of the monitor was set to 3.0 V, and the current across a 0.56 Ω resistor was measured every 200 s [11].We performed tests with the tap interrupt algorithm and the polling algorithm, with the frequency of polling set to 20, 32, and 100 Hz.  Figure 8 shows the patterns of current consumption over 500 ms for the tap interrupt algorithm and the polling algorithm running at 32 Hz.The tap interrupt produces peak of 1.98 mA while the polling algorithm has 16 reads of 1.732 mA.

Gyroscope Power Consumption.
The accelerometer alone is sufficient to count steps, but the monitoring of other activities requires a gyroscope to be used in addition.Brajdic and Harle evaluated several more algorithms for waking detection and step-counting using accelerometer, gyroscope, and both [12].This increases power consumption by a factor of about 5 times.Figure 9 shows the pattern of current consumption when running the tap interrupt algorithm with and without the gyroscope.The gyroscope is only waken from sleep state when an interrupt is received from the accelerometer.The ETHOS system [3] draws 7.4 mA where the gyroscope is enabled, and the estimated battery life of the 4.2 V 200 mAh Li-ion battery is 27 hours.Table 3 compares the battery life for the polling and the interrupt algorithm with and without gyroscope.Our tap interrupt algorithm battery life by 175%, compared with polling without a gyroscope.With the gyroscope, the battery life can be extended by up to 863% by putting both the processor and gyroscope into sleep state for most of the time.

Discussion
This paper proposes a new approach for a low-power stepcounting algorithm by using a tap interrupt algorithm and we conducted power profiling to analyze power consumption of popular polling algorithm.By reducing wake-up frequency from the sleep state and shortening process time at every wake-up, we can reduce the average power consumption.By using the threshold interrupt of the accelerometer, the tap interrupt algorithm can contribute to a longer battery life for activity monitoring devices.A minimum of 30 minutes of daily physical activity, such as walking, is now considered necessary to maintain fitness [13].Patients with conditions such as obstructive pulmonary disease may require long-term activity monitoring, but this does not need to be very accurate.In future work, we plan to investigate whether the tap interrupt can be used to detect unexpected fall for elders or to recognize posture in humans and animals in long-term application in which frequent battery recharging is inconvenient [14].

Figure 1 :
Figure 1: System current when polling at 20 Hz.

Figure 2 :
Figure 2: Algorithm for counting steps using the tap interrupt facility of the ADXL345 accelerometer. 0

Figure 3 :
Figure 3: Current consumption of the system running the tap interrupt algorithm for 1 second.

Figure 4 :
Figure 4: Experimental pedometer and battery worn on a belt.

Figure 5 :Figure 6 :
Figure 5: Block diagram of an experimental pedometer implemented on an MSP430F4618 experimenter's board, with an accelerometer and a gyroscope.

Figure 7 :
Figure 7: "Box and whiskers" plot showing the mean, standard deviation, and quartile of results from four pedometers.

Figure 8 :
Figure8: Power drawn by the system over 500 ms, running tap interrupt and polling algorithms.The results at 100 ms intervals correspond to LCD refresh, and the wide peak in the upper chart is the tap interrupt service routine.

Table 1 :
Averages value of power consumption and processing times.

Table 2 :
Accuracy of our pedometers with walkers of different weights.

Table 3 :
Power consumptions and expected battery life using the polling and tap interrupt algorithms.