Abstract-Transient computing systems do not have energy storage, and operate directly from energy harvesting. These systems are often faced with the inherent challenge of lowcurrent or transient power supply. In this paper, we propose "power-neutral" operation, a new paradigm for such systems, whereby the instantaneous power consumption of the system must match the instantaneous harvested power. Power neutrality is achieved using a control algorithm for dynamic frequency scaling, modulating system performance gracefully in response to the incoming power. Detailed system model is used to determine design parameters for selecting the system voltage thresholds where the operating frequency will be raised or lowered, or the system will be hibernated. The proposed control algorithm for power-neutral operation is experimentally validated using a microcontroller incorporating voltage threshold-based interrupts for frequency scaling. The microcontroller is powered directly from real energy harvesters; results demonstrate that a powerneutral system sustains operation for 4%-88% longer with up to 21% speedup in application execution.
Graceful Performance Modulation for Power-Neutral Transient Computing Systems physical phenomena such as light, heat, pressure etc.; microcontrollers, CPUs, DSPs, etc., to process data; memory for data storage; and finally, radio-frequency transceivers for communication. Rapid technological advances are driving the widespread deployment of IoT devices for numerous application areas, including environmental, medical, military, transportation, crisis management, homeland defense, and smart spaces [3] .
Scaling of CMOS device geometry has far outpaced the scaling of energy densities in batteries, meaning that the power supply is often the largest and most expensive part of IoT sensor nodes. This determines the operating life, defined as the lifetime of an IoT sensor node [4] . The high cost and disruption associated with replacing the batteries of IoT nodes is limiting their large scale deployment. For several years, researchers have tried to reduce the power consumption of sensor nodes using various design techniques [5] . An alternative approach which addresses the finite lifetime of battery-operated sensor nodes is energy harvesting [6] , which is defined as the process of harnessing electrical energy from alternative sources such as light, wind, heat, vibration, and movement, and using it to power sensor nodes. However, energy harvesting sources can be volatile, meaning that a steady power supply cannot be relied upon [7] . A conventional sensor node will turn off when its supply voltage falls below the minimum operating voltage. To mitigate this, several approaches may be used (Section II).
The conventional solution is to equip energy-harvesting autonomous devices with an energy buffer in the form of a supercapacitor or rechargeable battery [8] . The design objective is to match in the long-term the energy consumption with the available energy, achieving longer lifetimes. These approaches are known as energy-neutral solutions, as they attempt to balance the long-term energy consumed with the stored energy [9] [10] [11] . Techniques for adjusting the activity levels of battery-powered systems include sleeping or powering-down parts of the system, or modifying the supply voltage and/or frequency of the processor [12] . Dynamic voltage scaling (DVS) is where the supply voltage of the system is adjusted to the minimum to maintain the required performance level; dynamic frequency scaling (DFS) is where the clock frequency of the system is modulated for the required performance; or a combination of dynamic voltage and frequency scaling involves both parameters (voltage and frequency) being adjusted to maximize efficiency. Conventionally, these parameters are modulated to minimize the power drawn by the system 0278-0070 c 2016 IEEE. Personal use is permitted, but republication/redistribution requires IEEE permission.
See http://www.ieee.org/publications_standards/publications/rights/index.html for more information.
while still meeting the required deadlines or other performance demands.
Even though storing energy is convenient for compensating temporary deficiencies in harvested power with the energy stored in periods of abundance, energy storage in the form of batteries pose pollution and sustainability issues, while supercapacitor-based solutions increase sensor node dimensions. As an illustration, two AA-sized batteries on a Crossbow Telos mote occupy over half of its overall volume [13] . In systems with constrained dimensions, such as implantable bio-sensors for medical applications and wearable consumer devices [14] , assisted living and health-care [15] , home and building automation [16] , and radio-frequency identification applications [17] , the inherent lack of storage may limit their effectiveness. It is desirable to reduce the size of the energy harvester (EH) and the storage as far as possible, to limit the cost and dimensions of sensor systems.
An alternative approach is to operate a sensor node directly from an energy harvesting source without dedicated energy storage. However, the drawback of this approach is that, the power supply is typically varying (transient), computation will frequently be interrupted and reset. This recently proposed computing paradigm is termed transiently-powered computing [18] , and systems supporting transient computations are termed as transient computing systems. To deal with the unstable output from EHs, the system state is saved and hibernated as the supply voltage falls below the minimum operating voltage, and resumes operation from that point when the power supply recovers [19] . Other approaches include checkpointing at regular intervals [20] , [21] , and optimal energy allocation for data communication using information about existing and future power availability [22] . However, for some application scenarios, continuous operation, even with performance degradation, is desirable over a fail-stop approach where operation suspends on power failure. It could also avoid some of the overheads of the other approaches.
In this paper, we propose power-neutral operation, a new paradigm for low-current and transiently-powered IoT devices: instead of using additional energy storage or suspending operation on power failure, power-neutral IoT devices aim to operate uninterruptedly through DFS, matching their instantaneous power consumption to that of their energy harvesting supply. Fig. 1 shows the envisaged power-neutral behavior of a system (shown in red) in response to a rectified sinusoidal signal (shown in blue). An existing system [19] responds to this input signal by hibernating and restoring every time the input voltage passes a threshold (2.2 V). This response is shown in the figure in green. As seen in the figure, power neutral behavior offers advantages over the existing system by continuing operation in a dynamic scenario without multiple hibernation and restore events. Power neutrality is achieved using a control algorithm which scales the microcontroller frequency adaptively in response to changes in the supply voltage. Specifically, the algorithm gradually increases the operating frequency when the input voltage increases, thereby improving system performance. On the other hand, when the input voltage decreases, the algorithm gradually reduces the operating frequency, modulating the performance. Only when the input power is too low to sustain computation even at the lowest operating condition, a snapshot of the system is stored in the ferroelectric RAM (FRAM), and the microcontroller is hibernated. Thus, through power-neutral operation, we achieve the following.
1) For a scenario where the supply is insufficient to start operation at the highest performance level, powerneutrality allows a microcontroller to start with reduced performance and gracefully modulate it in response to changes in the input power source. 2) For a dynamic scenario where the input power is transient, power-neutrality allows continuous operation without frequent hibernation and restore operations (as in existing systems), thus saving energy and improving performance.
Contributions:
The key contributions of this paper are as follows.
1) A methodology for power-neutral operation through DFS, responding to changes in the power supply (Section III). 2) Mathematical formulation of power-neutral system behavior for determining design parameters of the control algorithm (Section IV). 3) Validation of the methodology with real EHs on a low-power microcontroller (Section V), demonstrating lifetime and performance improvement. Experiments conducted on a Texas Instrument's microcontroller with a real photovoltaic cell and wind EH demonstrate that the power-neutral system sustains operation for an additional 4%-88% of the time (as compared to existing systems) with up to 21% speedup in application execution.
The remainder of this paper is organized as follows. Related works on transient computing techniques is provided in Section II. The control strategy leading to power-neutral operation is described in Section III. This is followed by mathematical modeling of the system in order to determine design parameters for experiments in Section IV. Results using synthetic and real EHs are presented in Section V. This paper is concluded in Section VI.
II. RELATED WORKS
Wireless distributed sensor networks have gained importance in recent years due to the widespread deployment of IoT devices for numerous application areas, including environmental, medical, military, transportation, crisis management, homeland defense, and smart spaces [3] , [23] . To maximize a sensor node's active lifetime post deployment, power management techniques are typically used to match the functionality of a system and its peripherals to the demands of its workload [12] while consuming the least power. Cho et al. [24] proposed a new supply voltage scaling technique termed passive voltage scaling that eliminates the need for dc-dc converters. The idea behind this approach is to extend the lifetime of a wireless sensor node by scaling the frequency of operation as a function of battery voltage. There are two major limitations of this paper. First, this technique implements an open loop control system, which results in stability concerns when applied to transient supplies associated with EHs. Second, this technique is not able to adapt the voltage level in response to the workload, independent of the battery state.
A dc-dc converter aware optimal power management technique is proposed in [25] which aims to achieve optimal system performance under energy harvesting constraints through DVS. A system-wide power management approach is proposed in [26] that maximizes the energy reserve for all nodes by modulating frequency of operation, ensuring highly resilient performance under emergency and fault-driven situations. These approaches generally assume that power is provided by a battery, and that energy should be conserved where possible while meeting the objectives of the application. However, this is complicated by systems which can generate electrical power from their environment through energy harvesting [6] .
Traditionally, sensor nodes powered directly by energy harvesting lose their state upon power loss, restarting computation from the beginning on power recovery. To address this, a number of approaches have been recently proposed. Checkpointing can be used [20] to periodically store system state in nonvolatile memory (e.g., flash); when power recovers, the system will restore the most recent checkpoint and continue operation. Disadvantages of this approach include the fact that many checkpoints will be taken (most of which will be redundant), and that space must be reserved in nonvolatile memory for two complete checkpoints in case a power interruption occurs whilst one is being taken. To overcome this, a new technique, known as Hibernus [19] , was recently reported which delivers stable operation for intermittently powered systems, saving state to nonvolatile memory as the supply fails. The technique monitors the external supply using a voltage comparator; when the external voltage drops below a predefined threshold, a snapshot of the system's volatile memory (RAM and processor registers) is stored in the nonvolatile memory. Upon recovering power, the microcontroller restores these data, allowing the system to resume operation. The major benefit of Hibernus is that only one checkpoint is saved per power interruption, so the overheads of the scheme are much lower than for other reported works. A similar approach is recently proposed in [27] that shuts down or hibernates the microcontroller in response to the external power availability.
This paper differs from the existing work [19] by exploiting the DFS capabilities of the microcontroller to gracefully 
Fig. 3. Behavior with a transient input (in blue)
. The response to this input for existing system [19] and power-neutral system is shown in green and red, respectively.
scale its operating frequency up or down in response to its power status. An additional safeguard is that it can hibernate when the supply voltage falls below a predefined threshold, enabling our proposed approach to be used alongside the existing checkpointing techniques [19] , [20] , [27] . The main benefit of the proposed approach is that, by avoiding the overheads of hibernation (as in the case of [19] ) by gracefully scaling the operating frequency, we can achieve power-neutral operation while maximizing the system's active time and throughput.
III. POWER-NEUTRAL OPERATION

A. Control Strategy
For an explanation of the power-neutral concept, we consider an example system architecture ( Fig. 2) , where the output from an EH is half-wave rectified and used to power an autonomous device. In this scenario, the input EH is first applied and then discontinued, demonstrating how the microcontroller responds to this transient source. This behavior is shown in Fig. 3 , which plots the input voltage (in blue), the typical microcontroller response (in green), and the ideal response under our proposed power-neutral control scheme (in red), where the system gracefully modulates the system's performance dependent on its power status. Additionally, the system is assumed to have the capability to hibernate when the voltage falls to a critical level (as with Hibernus [19] ), i.e., as soon as the decoupling capacitor's voltage crosses the hibernation threshold (V H ), the microcontroller saves its state and suspends operation. Two additional thresholds: 1) frequency up-scaling threshold V inc and 2) frequency down-scaling threshold V dec are defined. 
B. Power-Neutral Dynamic Frequency Scaling
The flowchart in Fig. 4 describes the behavior of the proposed approach, from when the microcontroller is powered on. The microcontroller remains in low power mode until the supply voltage reaches the restore threshold V R . At this time, the microcontroller is set at the highest frequency 1 ( f N f ). A check is performed to determine whether a snapshot of the system state has previously been saved (i.e., whether the system has been active and successfully hibernated). If there is a saved snapshot, it is restored; otherwise the system is initialized. Following this, the DFS control algorithm is started simultaneously with the application. As long as the supply voltage is above the hibernate threshold V H , the application execution is triggered along with the DFS control algorithm to scale the operating frequency dynamically. When the supply voltage drops to V H , an interrupt is generated which stops the DFS algorithm. The frequency is set to its maximum value in order to save the snapshot. The application execution is terminated and microcontroller settles to a low power mode and waits for the supply voltage to raise again to V R . It is to be noted that if the supply system stays in low-power mode for a fixed amount of time, the system shuts down.
The DFS control algorithm is shown as a flowchart in Fig. 5 . The algorithm waits for the supply voltage to be equal to V inc or V dec . If the supply voltage is equal to V dec , a voltage interrupt is generated which sets a timer to count N wait number of cycles. When this timer expires, another interrupt is generated and the frequency is decremented. A check is performed to determine if the supply voltage is lower than V dec . If true, the timer is set again and process is repeated. If, however, the frequency is above V dec (the check evaluates to false), the control is initialized to the beginning of the flow, to be interrupted when the supply voltage is equal to V dec or V inc . A similar 1 In this paper, we used the highest frequency to hibernate and restore, as this is the most energy efficient frequency (Section V) but opposite control strategy is implemented when the supply voltage equals V inc .
IV. SYSTEM MODELING
A. Control Analysis
As shown in Fig. 3 , an example microcontroller (response shown in green) suspends at time t 5 . The time duration for which the microcontroller is active is (t 5 −t 1 ). Mathematically, this duration is determined as follows. During the duration (t 2 − t 1 ), the on-board capacitance charges to the peak voltage V max using the input source and this time is dependent on the input source (shown in blue). During the time duration (t 5 − t 2 ), the capacitor discharges due to the application execution, which can be represented using a constant current sink I 4 . It is to be noted that this current I 1 is dependent on the operating frequency of the microcontroller. For Hibernus, this is the highest frequency f N f . Using this, the current-voltage relation of a capacitor can be solved to determine the time duration as
In the considered scenario (Fig. 3) , the microcontroller is powered by an EH and the current it draws is dependent on the application and the operating frequency. The capacitance, C, is the on-board capacitance, which is mainly comprised of decoupling capacitors. In the following sections, we analyze the power-neutral behavior of the microcontroller to determine the design parameters for the proposed control algorithm.
B. Threshold-Based Control
In the proposed approach, a power-neutral system needs to change its frequency adaptively in response to the input source. To achieve this, we define two voltage thresholds: 1) V inc and 2) V dec . In its simplest form (discussed in details in the previous section), the frequency is increased if the input voltage (the voltage at the output of the Schottky diode) increases above V inc ; and the microcontroller decreases the frequency of operation if the input voltage is lower than V dec . As discussed before, the system's power-neutral behavior is demonstrated only for the decreasing voltage scenario and is plotted in red in the figure. As can be seen, the discharge characteristics of the decoupling capacitor change over time and the overall duration for which the microcontroller operates is (t 7 −t 1 ). The improvement in the operating lifetime of the microcontroller as compared to the typical behavior is (t 7 −t 5 ). The time duration (t 7 −t 1 ) can be determined as follows. As before, the time (t 2 − t 1 ) is the time of charging the capacitance to the peak voltage V max . Following this, the microcontroller operates at the highest frequency until the input voltage reaches V dec . This time is
Next we determine the time interval (t 7 − t 3 ) for a general case with N f frequency points. 2 There are two choices for selecting the interval for successive frequency scaling.
At each of these intervals, the frequency of the microcontroller is scaled down progressively.
. However, the lengths of these intervals are not equal. As before, the frequency of the microcontroller is scaled down progressively at these intervals. In this paper, we use variable voltage intervals determined using a fixed number of clock cycles. In other words, the microcontroller scales its operating frequency and waits for a fixed number of clock cycles, before checking the voltage and scaling the frequency again. Fig. 6 shows one of the nonuniform voltage intervals. The frequency (scaled down from the highest frequency f N f ) for this interval is shown in the figure. Assuming that the microcontroller waits for N wait clock cycles before scaling the frequency further, the time interval (t wait ) for these N wait cycles is
We are interested in finding the bounds on this time t wait in order to determine the optimum value of N wait . The minimum wait time is given by the highest operating frequency N f , i.e., t min wait = (N wait /f N f ) . The lower bound on t min wait is determined by the frequency switching overhead t so , i.e., t min wait > t so . The upper bound is determined by the time interval (t 5 − t 2 ) which 2 In Fig. 3 only four frequency points are shown for demonstrations, i.e., N f = 4. is the time taken by a microcontroller to hibernate, after supply is cut-off that is
In other words, if the time t min wait is greater than the time (t 5 − t 2 ), there remains no scope for frequency scaling and the power-neutral system behaves like a traditional one, offering no lifetime improvement. To summarize, the minimum wait time is bounded by
Using (4), the above equation can be rewritten as
The value of the frequency switching overhead t so is justified in Section V-F.
We introduce a design parameter L such that
where L ≥ 1.
Having defined the wait time, the time interval (t 7 − t 2 ) can be written as
where I 4 is written as I N f for the general case and t so is the frequency switching overhead. Typically, the frequency switching overhead depends on the frequency levels between which the switching takes place. However, as a first-order approximation to the problem formulation, t so is the maximum overhead of switching between any pair of frequencies.
Using (4) and (8), the improvement in microcontroller lifetime is
To verify the validity of the simplified microcontroller representation (Fig. 2) , we need to look at the dynamics of microcontroller's power demands. To this end, we conducted a set of experiments on the experimental platform executing the three example applications at frequencies ranging from 1 to 8 MHz. Fig. 7 plots the results for the fast Fourier transform (FFT), cyclic redundancy check (CRC), and RSA Current consumed by the experimental platform at different frequencies and executing different applications. applications. As can be seen, at a given frequency the current drawn by these applications are similar (within 0.1%). Additionally, the current drawn by the microcontroller appears to be linearly dependent on its frequency of operation; this is consistent with the datasheet. Although the current values reported in this figure are averaged across the execution of these applications, the variation within execution is insignificant. To illustrate this, Fig. 8 plots the current drawn by the microcontroller during FFT execution at 5.33 MHz. The maximum current variation is 20 μA which is less than 3% of the mean current of 0.715 mA during the FFT execution at this frequency. For all our analysis in Section IV, this variation is ignored and the microcontroller is represented using a constant current load for a given application at a particular frequency, as shown in Fig. 2 .
As seen from Fig. 7 , the frequency of operation and the current drawn by a microcontroller can be represented using a linear equation of the form
Substituting this in (9), the lifetime improvement is determined by
C. Threshold and Interval Definition
Referring back to Fig. 6 , the boundary conditions for the voltage levels are V 0 = V dec and V N f −1 = V H . The intermediate voltage values (V i ) can be determined using the capacitor voltage current relation using a constant current sink model (Fig. 2) as Using the boundary conditions, the interval V dec − V H can be represented as
The minimum value of V dec can thus be determined. To determine V inc , we consider an EH source with an oscillating nature as shown in Fig. 9 . As discussed previously, every time the input voltage increases above V inc , the frequency is incremented one step, whereas if the voltage decreases below V dec , the frequency is decremented to the next lower level. Assuming that the frequency of the microcontroller is incremented to f i at point A in the figure when the input voltage crosses V inc , the time taken by the microcontroller voltage to drop to V dec in response to the EH source is
where I i is the current drawn by the microcontroller at frequency f i . The least time taken t min is
For stable operation, this minimum time has to be greater than the worst-case frequency switching overhead t so . We choose this to be a few orders of magnitude higher. The lower bound for V inc is t so . To determine the upper bound of V inc , we need to consider the scenario with increasing supply voltage. Using similar reasoning as before, it can be shown that the upper bound of
D. Performance Analysis
The performance of a microcontroller is measured in terms of the number of instructions executed in the time interval between restoring a snapshot and hibernating. To estimate this, we let IPC denote the instructions executed by the microcontroller per clock cycle and f source denote the frequency of a sinusoidal signal powering the microcontroller. For the existing system [19] , the time for which the microcontroller is active is the sum of the time to charge the decoupling capacitor to its peak value and the time to discharge. The charging time is approximately (17) where the first term in the above equation is the rise time of the input source to its peak value V max . The second term, which represents the time the input signal takes to reach the threshold voltage V H , is discounted from the first term to highlight the fact the microcontroller starts its operation when the supply voltage reaches the threshold V H . The microcontroller always operates at the highest frequency f N f and therefore the discharge time is given by (1)
The number of instructions executed in the duration for which the microcontroller is on, is given by
On the other hand, the power-neutral system scales its frequency adaptively. As before, t wait (i) denotes the time a power-neutral system spends before scaling up/down the frequency. We determine the average throughput obtained by this microcontroller when the supply voltage is suddenly cut off. As discussed in the previous section, when the supply is cut off, the microcontroller uses the highest frequency until the voltage drops to V dec . This time interval (t 3 − t 2 ) is given by (2) . Thereafter, frequency is scaled every t wait (i) interval. It is to be noted that once scaled down to the lowest frequency f 1 , the microcontroller continues to operate at this frequency until the frequency drops to V H . We therefore have to determine the time interval with lowest frequency of operation separately. To determine this interval, we determine the voltage drop until the point when the frequency is scaled to the lowest value f 1 . This is given by
The above equation is determined using (12) and (13) . The voltage interval for which the lowest frequency is active is V N f −2 − V H . The time taken for this voltage drop across the decoupling capacitor using the constant current sink of I 1 (Fig. 2) corresponding to the lowest frequency of f 1 , is given by
The number of instructions executed by the microcontroller in the time for which the decoupling capacitor discharges from V max to V H is given by Due to symmetrical operation of the power neutral microcontroller during charging and discharging, the number of instructions executed during charging is given by
The total number of instructions executed by a powerneutral system is given by
The comparison of the performance C EN and C PN depends on the input source used. In Section V, we provide a comparison of these for a range of input frequencies.
V. RESULTS AND DISCUSSION
In this section, we present a thorough validation of our approach starting with a description of the test setup, the EHs, and applications. Fig. 10 shows the test setup for all our experiments. The microcontroller is a TI MSP430FR5739, which incorporates FRAM nonvolatile memory and a 16-bit reduced instruction set computer CPU. The microcontroller is operative from 2.0 V; an external low drop-out regulator (LDO) restricts the supply voltage to a maximum of 3.6 V. An external comparator circuit is used to detect two separate thresholds simultaneously and assert digital inputs when the supply exceeds them. This is used to detect when V H , V inc , or V dec are crossed.
A. Experimental Setup
To demonstrate the power-neutral behavior with transientlypowered energy-harvesting sources, all external peripherals are disabled. The frequency of the CPU clock MCLK is adjusted using the digitally controlled oscillator (DCO). Two registers DCOCTL and BCSCTL1 are programmed to set any frequency in the range of 0.167-24 MHz. To demonstrate the operation of the proposed control algorithm, four frequencies are selected: 1) 1 MHz; 2) 3 MHz; 3) 5.33 MHz; and 4) 8 MHz. It is to be noted that below 1 MHz, the quiescent component dominates the current consumption and there would be little benefit in extending the operating frequency below 1 MHz. Similarly, the maximum frequency of FRAM operation is 8 MHz. To avoid having wait states while accessing FRAM, the maximum frequency of the CPU is also limited to 8 MHz.
For validation of the proposed control scheme, we have used three sources: a sinusoidal voltage from a bench signal generator, and two real energy-harvesting sources [a photovoltaic cell (PV) and a micro wind-turbine]. Example dynamics of the EHs are shown in Fig. 11 .
It is important to note that the microcontroller's CPU is ultralow power 3 but less powerful than their application processor counterparts. For this reason, the range of executable applications is limited. We therefore demonstrate power-neutral behavior using three standard microcontroller applications: 1) FFT; 2) CRC; and 3) RSA, which are the applications used in [19] [20] [21] and are representative workloads for low-power resource-constrained systems. The FFT application analyzes three arrays, each holding 128 8-bit samples of tri-axial accelerometer data. The CRC application calculates a 16-bit CRC of a message using polynomials. The RSA application performs 64-bit encryption on 128 characters. In a recent study [18] , the technique of [19] is compared with two previously proposed transient computing approaches [20] , [21] ; results demonstrate that [19] outperforms the other two techniques. In this paper, we have therefore, compared our work with [19] . Fig. 12 plots the value of the external capacitor required to sustain continuous operation if a buffered "energy neutral" system is used, as the frequency of the input sinusoid is increased from 1 to 20 Hz. This is the frequency range of a typical wind turbine EH. As seen from this figure, the peak capacitance requirement of the system is 360 μF. It is to be noted that if the capacitor is not sufficient to sustain continuous operation at a particular input frequency, the microcontroller resets and restarts computation every time the voltage value drops below the minimum working voltage of the microcontroller. On the other side, a transient computing system does not require any external capacitance and operates directly from an EH source using the parasitic and on-board decoupling capacitance (approximately 19 μF for our experimental platform). For transient computing systems, execution is restored from the point of suspension using hibernate and restore through FRAM [19] ; and lifetime is extended through dynamic frequency control (our approach). Fig. 13 plots the improvement in lifetime of a power-neutral system as compared to existing one [19] , as the design parameter L (7) is varied from 5 to 50 for the FFT application. Also plotted in the same graph, the difference V inc − V dec as a function of L. As can be seen, the microcontroller lifetime increases with an increase in L, signifying that higher L is better. On the other hand, with increasing L, the difference between the two voltage levels decreases. From (15) , it can be concluded that the lower the design parameter L, the higher the difference between V inc and V dec and therefore, better it is for system stability. Results for the CRC and the RSA application are similar to the FFT application. We therefore select the cross-over point with L = 20 and the remaining design parameters are selected using (2)- (15), such that the system's lifetime is maximized. Results are summarized in Table I .
B. Capacitance Requirement of Energy-Neutral Systems
C. Selection of Design Parameters
To determine the impact of the parameter L on different design aspects, we have conducted an experiment with the FFT application and the results are summarized in Table II. As seen from this table, the difference between V dec − V H increases with an increase in the parameter L as expected according to (13) . This voltage difference determines the time spent by the system in the lowest frequency as reported in column 4. This time is expressed as a percentage of the hibernation time and input signal period as reported in columns 5 and 6, respectively. As can be seen, the fraction of the time for the system to hibernate reduces with an increase in the time spent in the lowest frequency. However, the percentage of time of the input period increases. This effectively means that as the system spends more time at the lowest frequency, there is much less scope for graceful performance modulation.
D. Hibernate and Restore
An important aspect of the proposed algorithm (Fig. 4) is that the microcontroller's operating frequency is set to its maximum (i.e., 8 MHz in this case) when hibernating and restoring. This is because this operating condition is the most energy-efficient of all the four frequencies. To explore this, Table III reports the time overhead, the power and the energy consumption for storing and restoring a snapshot from FRAM. As can be seen, the energy overhead for a snapshot restore is 3.56 μJ at 8 MHz, which is 3× lower than the energy overhead for restoring a snapshot at 1 MHz. Similarly, the energy overhead for hibernation at 8 MHz is 2.9× lower than that at 1 MHz. Clearly, it is most energy efficient to use 8 MHz, and is therefore selected as the frequency for restore and hibernate in our control algorithm.
E. DFS Overhead
To quantify the DFS switching overhead, Fig. 14 shows the overhead of switching from 1 to 8 MHz and 8 to 1 MHz (channel FREQ). To set a particular frequency, the corresponding clock divider register is first unlocked; the setting is written into the register; and the register is locked again (channels 0 and 1, respectively, for switching from 1 to 8 MHz and vice versa). Specifically, channel 0 is set when the clock divider register is unlocked (indicated by marker with letter a) and is reset when the clock divider register is locked again (indicated by marker with letter b). The clock frequency changes within this interval. As shown in the figure, time from unlocking the register to that when the clock frequency changes, with the change propagated to the output, measuring the overhead of switching from 1 to 8 MHz and is close to the time between marker a and b, which is 58.6 μs. For practical reasons, this is used as the switching overhead. A similar trend can be observed for switching from 8 to 1 MHz, where the time between markers c and d is 20 μs. Table IV reports the time taken for switching between the four selected frequency levels, both during up-scaling and down-scaling. As can be seen, the time taken for switching depends on the frequency levels between which the switching takes place. For deriving the voltage levels for our design, we have used the worst-case frequency switching overhead of 58.6 μs. This choice addresses two objectives: 1) the worstcase overhead gives an upper bound on the energy overhead of the proposed approach and 2) the worst-case frequency switching overhead also guarantees graceful system performance operating at the highest frequency. Fig. 15 shows the response of a power-neutral system to a sinusoidal source of 0.5 Hz. The input to the microcontroller is shown in blue. This is the voltage applied to the input of the Schottky diode in Fig. 10 . The voltage at the input of the decoupling capacitor of the microcontroller (i.e., at output of the Schottky diode) is shown in red in the figure. Channel F0:F1:F2 represents the frequency of the microcontroller (e.g., F0:F1:F2 = "101" implies that the frequency is set to 5 MHz); channel RESTORE is set when a snapshot is restored; channel MAIN is the main clock (MCLK) to the microcontroller; channel HIBERN is set when the hibernate routine is invoked; and finally channel MCU_ON is the set when the microcontroller is in operation. As seen from the figure, when the supply is applied to the microcontroller, the voltage across the Schottky diode starts to increase. When the voltage crosses the restore threshold (2.2 V), the frequency is ramped up gradually to the highest frequency of 8 MHz. This can be observed from the changes to the frequency selection channels F0-F2. The microcontroller continues to operate at the highest frequency, until the voltage drops to V dec , when the microcontroller starts decreasing the frequency until it reaches the hibernate threshold, at which point the microcontroller saves its state to FRAM. The lifetime of the microcontroller is the time interval between the restore and the hibernate.
F. System Response 1) Sinusoidal Input Source:
2) Photovoltaic Cell and Wind Harvester: To verify the system operation using real EHs, experiments are conducted on the platform by using a photovoltaic cell and micro wind turbine. Fig. 16 plots the response of the microcontroller to a PVEH which generates a current of approximately 450 μA. As seen from the figure, the microcontroller switches between the four frequencies in response to the input source. This demonstrates the power-neutral behavior of the microcontroller, scaling frequency and modulating performance in response to the dynamics of the input source. A similar trend is observed in the wind EH; the response is shown in Fig. 17 . It is important to note that the system operates continuously, without hibernate and restore, in response to photovoltaic cell and micro wind turbine EHs.
G. Performance Improvements
Table V reports the number of instructions executed by the existing system [19] and the power-neutral one, for an input sinusoidal signal. Results are reported for five frequencies-1-20 Hz, encompassing the frequency range for most commonly used EHs. As can be seen, for input frequencies of 1 and 2 Hz, the existing system executes an average 4% more instructions than the power-neutral system. However, for all other frequencies, the power-neutral system outperforms the existing system by executing 13%-82% (mean 50%) more instructions per clock cycle.
To compare the execution time of the chosen applications, an experiment is conducted on a microcontroller powered with a constant low current source. The number of times the microcontroller hibernated during the execution and the total time taken to execute the application are recorded and are reported in Table VI for the existing system [19] and the proposed power-neutral system. The current values used for this experiment are reported in column 2 for the application in column 1. As can be seen, the existing system takes 1960 ms to execute the FFT application with a current source of 200 μA. In doing so, the system hibernates 18 times. For the same input current, the power-neutral system takes 1551 ms (improvement of 21%) to complete FFT executions, hibernating only 12 times. This demonstrates the performance improvement of the powerneutral system over [19] . A power-neutral system also reduces the energy overhead associated with hibernate and restore by reducing the number of hibernates. It is interesting to note that with larger current source, the existing system sustains its operation for a longer duration due to higher charge stored in the decoupling capacitor and thus, requiring fewer hibernate and restore operations. For same current values current values, the power-neutral system does not need to hibernate (and restore) and therefore, the corresponding entries are marked as 0. Beyond 800 μA, the existing system also sustains its operation for the entire duration, requiring no hibernate (or restore) and are therefore not included in the table.
A similar trend is observed for the other applications. To summarize, the power-neutral system can provide a speedup of up to 21%, by sustaining operation with reduced frequency, avoiding the need for multiple hibernate and restore operation.
H. Improvement of IoT Device Lifetime
Table VII reports the lifetime (measured as the absolute time from the end of the restore routine to the start of the hibernate routine) of the microcontroller in response to a sinusoidal source for one period of operation. For demonstration, five frequencies are selected from 1 to 20 Hz. The result using the proposed power-neutral DFS approach is compared with the existing system [19] . The results are reported both as the absolute operating time (in ms) and as a percentage of the period of the sinusoidal source. As can be seen for both systems, the lifetime decreases with an increase in frequency. This is because the increasing frequency has a shorter period; the lifetime which represents a part of this time period also reduces. In comparison to the existing system, the powerneutral system increases the lifetime by 4% at 1 Hz (241.5 versus 232.3 ms). However, at higher frequencies (20 Hz) , the lifetime improvement is up to 88%. It is to be noted that with an increase in the frequency of operation, the fraction of time for which the microcontroller is active within a clock period increases, both for the existing system and the power-neutral system. However, the improvement for the power-neutral system is higher; because the power-neutral system adaptively modulates the frequency, thereby modulating the discharge TABLE VII MICROCONTROLLER LIFETIME AT DIFFERENT FREQUENCIES characteristics of the on-board decoupling capacitance. Since the time spent at each frequency step is independent of the input frequency, the improvement of active time of the powerneutral system increases with frequency. This demonstrates that the power-neutral approach significantly improves the operational lifetime of systems.
VI. CONCLUSION
We have proposed a new paradigm for transiently-powered computing, called power-neutral operation, in which a microcontroller's frequency is dynamically adapted in response to the input power source. Power neutrality was achieved using a control strategy which scales the microcontroller frequency adaptively in response to changes in the supply voltage. Specifically, the control strategy gradually increases the operating frequency when the input voltage increases, thereby improving system performance. An analytical model was developed for the power-neutral system to determine the voltage thresholds for experiments. A detailed experimental validation was performed to demonstrate the power-neutral behavior in response to a sinusoidal voltage from a bench signal generator, and two real energy-harvesting sources (PV cell and micro wind-turbine). Results using standard applications demonstrated that a power-neutral system can extend its lifetime by 4%-88% at different frequencies, with up to a 21% speedup in application execution, by sustaining operation with reduced frequency.
