

# Exploring the Effect of Energy Storage Sizing on Intermittent Computing System Performance

Jie Zhan, Geoff V. Merrett, *Senior Member, IEEE*, and Alex S. Weddell, *Member, IEEE*

**Abstract**—Batteryless energy-harvesting devices promise to deliver a sustainable Internet of Things. Intermittent computing is an emerging area, where forward progress of application execution is maintained by saving volatile computing state into non-volatile memory before power interruptions, and restored afterwards. Conventional intermittent computing approaches typically minimize energy storage to reduce device dimensions and interruption periods, but this can result in high state-saving and -restoring overheads and impede forward progress. In this paper, we argue that adding a small amount of energy storage can significantly improve forward progress. We develop an intermittent computing model that accurately estimates forward progress, with an experimentally validated mean error of 0.5%. Using this model, we show that sizing energy storage can improve forward progress by up to 65% with a constant current supply, and 43% with real-world photovoltaic sources. An extension to this approach, which uses a cost function to trade off the energy storage size against forward progress, can save 83% of capacitor volume and 91% of interruption periods while maintaining 93% of the maximum forward progress.

**Index Terms**—Intermittent computing, energy harvesting, energy storage, forward progress, batteryless, wireless sensor networks, internet of things.

## I. OVERVIEW

Internet of Things (IoT) devices are becoming ubiquitous, with forecasts of hundreds of billions being installed in the near future [?]. They are conventionally battery-powered, thus have constrained lifespans, necessitating inconvenient periodic battery replacement. Energy-harvesting is a potential solution. Environmentally harvested power is, however, intrinsically variable and intermittent [?]. Traditionally, large energy storage devices such as rechargeable batteries or supercapacitors are used to smooth out supply variability [?]. Unfortunately, these increase cost and device dimensions [?], raise pollution concerns [?], and still limit lifespans [?].

Recently, *intermittent computing systems* (ICSs) have been proposed as an alternative [?]. Instead of using large energy storage devices to sustain execution, they tolerate power interruptions by saving the state of the system into non-volatile memory (NVM) so that computation can continue when power is restored. They may save this state (e.g. CPU registers and RAM contents) either *statically* at pre-defined points, or *reactively* by detecting when the supply is about to fail [?].

Static approaches save state at points determined at design or compile time, either by inserting checkpoints [?], [?] or

The authors are with the School of Electronics and Computer Science, University of Southampton, Southampton, SO17 1BJ, UK (email: {j.zhan, gvm, asw}@ecs.soton.ac.uk).

This work was supported in part by the UK Engineering and Physical Sciences Research Council (EPSRC) under EP/P010164/1.

Data and software associated with this paper will be made available online on publication.



Fig. 1. The relationship between energy storage capacitance and ICS forward progress, for various supply currents.

decomposing a program into atomic tasks<sup>1</sup> [?], [?]. After a power interruption, progress rolls back and resumes from the last saved checkpoint or task boundary. This can introduce issues such as violation of data memory consistency, along with wasting energy on lost and re-executed progress.

Conversely, reactive approaches monitor the supply voltage and only save state when it falls below a threshold [?], [?], [?], which is set high enough to reliably save state even with a total and immediate drop-off in harvested energy. They then enter a low-power mode, in many cases preserving their volatile memory and avoiding re-execution. These typically make more forward progress than static approaches, e.g. a 2.5× mean computational speedup [?].

In ICSs, *forward progress* denotes the effective application progress, excluding re-executed progress, lost progress, and state-saving and -restoring operations [?]. The amount of forward progress directly determines application performance, e.g. program iteration rate or task completion time. In this paper, to allow fair comparison, we define normalized forward progress as *the ratio of the effective execution time to the total elapsed time*, without being restricted to a specific workload.

With the goal of minimizing device dimensions and interruption periods, most ICS approaches adopt a minimum amount of energy storage [?], [?], [?], [?], [?]. This is typically just sufficient for the most energy-expensive atomic operation. However, our assertion is that this can be *inherently inefficient in terms of time and energy*. We show that a system with minimum energy storage frequently goes through a cycle of: wake up; restore state; execute program; save state; halt.

<sup>1</sup>Atomic operations in ICSs denote operations that should be completed in one continuous period. If an atomic operation is interrupted by a power failure, it should be re-executed rather than resumed. Examples of atomic operations include saving and restoring volatile state, transmitting and receiving packets, and sampling sequences of data from sensors.

We propose that provisioning *slightly more* energy storage can prolong the operating cycles, reduce the frequency of interruptions, and hence improve forward progress. We show with modelled and experimental results that (Fig. ??) using efficiently-sized energy storage capacitance ( $43\ \mu\text{F}$ ) achieves up to a 55% improvement in forward progress compared against using the theoretical minimum amount of capacitance ( $6.2\ \mu\text{F}$ ). This improvement is more significant with a weaker supply. However, the relationship between ICS energy storage capacitance and forward progress has not previously been defined. Also, current tools for ICSs (Section ??) are not practical for fast estimation of forward progress in a long-term deployment, and lack a method of sizing energy storage to improve forward progress while moderating the physical size and interruption periods.

This paper presents an approach for sizing energy storage in ICSs, quantifying and trading off forward progress, capacitor volume, and interruption periods. The main contributions are:

- A reactive ICS model which accurately estimates forward progress; experimental validation shows a 0.5% mean error (Section ??).
- A model-based sizing approach that recommends appropriate energy storage capacitance in ICSs (Section ??).
- An exploration based on the model, where we analyze the energy storage sizing effect on forward progress, showing up to 65% forward progress improvement (Section ??).
- An evaluation of the impact of sizing in real-world conditions using real energy availability data (Section ??). This includes a cost function-based method for trading off parameters. In an example, this reduced capacitor volume and interruption periods by 83% and 91% respectively, while sacrificing 7% of forward progress.

The associated simulation tool, coded in C, is available open-source at (*link to be provided on publication*).

## II. RELATED WORK

To explore forward progress of ICSs, simulation tools need to represent transient operation (timescales of  $\mu\text{s-ms}$ ) as well as long-term overall performance (from days up to years).

Su *et al.* [?] modelled a dual-channel solar-powered non-volatile sensor node, and Jackson *et al.* [?] provided a model to explore battery usage in ICSs. Both were configured for long-term simulations and large energy storage (from mF-scale supercapacitors to batteries), thus cannot respond to frequent power interruptions and accurately estimate forward progress when using minimized energy storage (e.g.  $4.7\ \mu\text{F}$  [?]).

In contrast, a set of fine-grained models have been proposed to accurately simulate the frequent micro-operations in ICSs. NVPsim [?] is a gem5-based simulator for nonvolatile processors. Fused [?] is a closed-loop simulator which allows interaction between power consumption, power supply, and forward progress. EH model [?] can compare a range of ICS approaches in a single active period with the same energy budget, quantifying forward progress by the energy spent on effective execution. These fine-grained models are inefficient for processing long-term energy data, especially when iterative tests are needed for various system configurations.

TABLE I  
MODEL PARAMETERS OF REACTIVE ICS

| Input Parameters         |                                 |
|--------------------------|---------------------------------|
| $I_{harv}$               | Energy harvester current supply |
| $C$                      | Energy storage capacitance      |
| Configuration Parameters |                                 |
| $I_{exe}$                | Execution current draw          |
| $I_{lpm}$                | Low-power mode current draw     |
| $I_r$                    | Restore current draw            |
| $I_s$                    | Save current draw               |
| $I_{leak}$               | Leakage current draw            |
| $V_r$                    | Restore voltage threshold       |
| $V_s$                    | Save voltage threshold          |
| $T_r$                    | Restore time overhead           |
| $T_s$                    | Save time overhead              |
| Output Parameter         |                                 |
| $\alpha_{exe}$           | Normalized forward progress     |

Besides models and simulators, hardware emulators of energy harvesters [?], [?] can provide repeatable power profiles recorded from energy harvesters for experimental comparisons. Though they provide practical results, hardware emulations are limited by hardware options and are generally impractical for performing long-term trials.

To address the above problem, we provide a reactive ICS model to estimate forward progress, as well as a simulation tool that enables fast exploration with long-term real-world environmental conditions. Further, we provide a sizing approach which recommends appropriate energy storage capacitance for deploying ICSs.

## III. REACTIVE ICS MODELLING

To facilitate the understanding and exploration of reactive ICSs, we present a model which outputs the normalized forward progress  $\alpha_{exe}$  when powered from a constant current supply  $I_{harv}$ . Parameters of this model are listed in Table ???. The model assumes that all configuration parameters remain constant.

For brevity,  $I_{in}$  denotes the usable input current as expressed in (??). The effect of capacitor leakage current,  $I_{leak}$ , is discussed at the end of Section ??.

$$I_{in} = I_{harv} - I_{leak} \quad (1)$$

### A. Operating Modes of Reactive ICS

The behavior of reactive ICSs can be classified into three operating modes depending on the supply current, as shown in Fig. ???. These are differentiated by the relationship between input current  $I_{in}$  and the system's current draw in its low-power mode (LPM) or active modes, i.e.  $I_{lpm}$  and  $I_{exe}$ . We define the three modes as:

- *Off* mode: When  $I_{in} < I_{lpm}$ , the system stays inactive. The supply voltage  $V_{cc}$  cannot rise above the restore threshold  $V_r$  to wake the system and start execution. The LPM current  $I_{lpm}$  includes the consumption of voltage monitoring circuits and system idle current.
- *On* mode: When  $I_{in} > I_{exe}$ , the system executes constantly as the supply voltage  $V_{cc}$  never drops below  $V_s$ .



Fig. 2. Operating modes of reactive ICSs, and achieved forward progress against supply current.

$V_{cc}$  grows until  $I_{in}$  and  $I_{exe}$  are in equilibrium, which may result from  $I_{in}$  decreasing due to poor impedance matching, or  $I_{exe}$  increasing due to either greater current draw at higher voltage or dissipation through overvoltage protection circuits.

- **Intermittent mode:** When  $I_{lpm} < I_{in} < I_{exe}$ , the system executes intermittently after  $V_{cc} > V_r$  and before  $V_{cc} < V_s$ .  $V_{cc}$  can rise above  $V_r$  and the system starts execution. However, the stored energy is then consumed by the load as  $I_{in} < I_{exe}$ , causing  $V_{cc}$  to eventually drop below the save threshold  $V_s$ , where the system saves its state and enters LPM. The system stays in LPM until  $V_{cc}$  rises to  $V_r$  again and then resumes execution. In general, a higher  $I_{in}$  leads to more forward progress in this mode, but the exact relationship between  $I_{in}$  and forward progress requires further analysis.

### B. Formulating Forward Progress

Next, we derive formulations to calculate  $\alpha_{exe}$  from  $I_{in}$  and energy storage capacitance  $C$ . We then explore the effect of capacitor leakage on maximum forward progress.

In the *On* and *Off* modes, the normalized forward progress is trivial to find (simply 1 and 0 respectively). In the *Intermittent* mode, as shown in Fig. ??, the system goes through four intervals in turn, i.e. charging, restoring, executing, and saving, with current consumption of  $I_{lpm}$ ,  $I_r$ ,  $I_{exe}$ , and  $I_s$  in each interval respectively. The normalized forward progress, i.e. effective execution time ratio, is indicated as  $T_{exe}/T_{cycle}$ , where  $T_{exe}$  is the time spent on effective execution in one operating cycle and  $T_{cycle}$  is the period of operating cycles. Hence, the forward progress given all supply levels is expressed as:

$$\alpha_{exe} = \begin{cases} 0 & , \text{ Off } (I_{in} < I_{lpm}) \\ \frac{T_{exe}}{T_{cycle}} & , \text{ Intermittent } (I_{lpm} < I_{in} < I_{exe}) \\ 1 & , \text{ On } (I_{in} > I_{exe}) \end{cases} \quad (2)$$

In the following analysis, we focus on deriving  $T_{exe}/T_{cycle}$  in the *Intermittent* mode. Let  $V_{pr}$  (post-restore) and  $V_{ps}$  (post-save) denote the voltage after restoring and saving operations.  $V_{pr}$  and  $V_{ps}$  can be calculated as:

$$V_{pr} = V_r + \frac{T_r(I_{in} - I_r)}{C} \quad (3)$$



Fig. 3. Operating cycles in the *Intermittent* mode.

$$V_{ps} = V_s + \frac{T_s(I_{in} - I_s)}{C} \quad (4)$$

With (??), the time spent on effective execution  $T_{exe}$  in one operating cycle can be expressed as:

$$T_{exe} = \frac{C(V_{pr} - V_s)}{I_{exe} - I_{in}} \quad (5)$$

Analogously, with (??), the charging interval can be described as:

$$T_{charge} = \frac{C(V_r - V_{ps})}{I_{in} - I_{lpm}} \quad (6)$$

With (??) and (??), the period of an operating cycle is:

$$T_{cycle} = T_{charge} + T_r + T_{exe} + T_s \quad (7)$$

Finally, combining (??)–(??), we obtain normalized forward progress  $\alpha_{exe}$  in the *Intermittent* mode as:

$$\alpha_{exe} = \frac{T_{exe}}{T_{cycle}} = \frac{\frac{C(V_r - V_s) + T_r(I_{in} - I_r)}{I_{exe} - I_{in}}}{\frac{C(V_r - V_s) + T_s(I_{in} - I_{lpm})}{I_{in} - I_{lpm}} + \frac{C(V_r - V_s) + T_r(I_{exe} - I_r)}{I_{exe} - I_{in}}} \quad (8)$$

In the numerator  $T_{exe}$ ,  $C(V_r - V_s)$  represents the amount of charge in the capacitor available for restoring and executing.  $T_r(I_{in} - I_r)$  represents the charge used by a restore operation.  $I_{exe} - I_{in}$  is the rate of charge consumption from the energy storage during execution.

To explore the effect of energy storage on forward progress, we need to analyze  $d\alpha_{exe}/dC$ . Here, if we assume that  $I_{leak}$  remains constant,  $\alpha_{exe}$  keeps increasing and approaches  $(I_{in} - I_{lpm})/(I_{exe} - I_{lpm})$  when energy storage capacitance  $C$  increases. Defining  $(I_{in} - I_{lpm})/(I_{exe} - I_{lpm})$  as  $\alpha_{exe\_ideal}$ ,  $\alpha_{exe} = \alpha_{exe\_ideal}$  is an ideal case, where restore and save overheads are absent.

In an electrolytic capacitor, however,  $I_{leak}$  typically increases with  $C$  with the following relationship [?]:

$$I_{leak} = kCV_{cc} \quad (9)$$

where  $k$  is a constant normally in a range 0.01 to 0.03 ( $\frac{A}{F \cdot V}$ ). Combining (??) with (??),  $dI_{in}/dC$  is  $-kV_{cc}$ , meaning  $I_{in}$  decreases linearly as  $C$  increases. Thus, when  $C$  increases,  $\alpha_{exe}$  keeps approaching  $\alpha_{exe\_ideal}$  while  $\alpha_{exe\_ideal}$  decreases. Hence, we believe that there is a capacitance value that leads to the maximum  $\alpha_{exe}$  considering  $I_{leak}$  increases with  $C$ .



Fig. 4. Model validation with experimental and modelled forward progress.

### C. Model Validation

We implemented and parameterized a reactive ICS [?] on a TI MSP430FR6989 microcontroller to validate our model. The on-board decoupling capacitance was measured as  $10.0\text{ }\mu\text{F}$ , and hence was the minimum capacitance that could be tested. Further capacitance was added to provide extra energy storage. The parameters are profiled with the MCU running a Dijkstra path finding algorithm with 1696B RAM usage at 8 MHz. The supply voltage monitoring circuits use the MCU's internal comparator and an external  $3\text{ M}\Omega$  voltage divider. The restore and save voltage thresholds are set as  $V_r = 2.4\text{ V}$  and  $V_s = 2.1\text{ V}$  respectively. The MCU shutdown voltage  $V_{off}$  is  $1.8\text{ V}$ .

To validate the accuracy of our model, we powered the device with a range of supply currents ( $[0.1, 0.2, \dots, 0.8]\text{ mA}$ ) to operate the device in *Intermittent* mode, and repeated the tests with three energy storage capacities: a)  $10.0\text{ }\mu\text{F}$  decoupling capacitance; b)  $21.5\text{ }\mu\text{F}$  ( $11.5\text{ }\mu\text{F}$  added); c)  $43.0\text{ }\mu\text{F}$  ( $33.0\text{ }\mu\text{F}$  added). We compared the actual forward progress against predictions generated from our model. As shown in Fig. ??, the model-generated output matches closely with the experimental results with only 0.5% mean absolute percentage error.

The reactive ICS model presented in this section will be used to explore energy storage sizing effects in Section ???. In the next section, we extend this approach with a cost function for trading off forward progress against various design factors.

## IV. ENERGY STORAGE SIZING APPROACH

We propose a sizing approach which recommends appropriate energy storage capacitance for an ICS, trading off forward progress against capacitor volume and interruption periods. We present a system model which accepts real long-term data on environmental energy conditions. The three inputs can be swept for design exploration, but we focus on energy storage in this paper. The model outputs forward progress, capacitor volume, and interruption periods (defined in Section ??). These are subsequently traded off in a cost function to obtain the appropriate energy storage capacitance. This process is summarized in Fig. ?? with details explained as follows.



Fig. 5. Structure of the proposed system model and sizing approach.

### A. Input

A time trace of representative environmental energy conditions in the intended deployment location is provided as an input, along with the energy harvester size; for design exploration, these can optionally be changed to explore variations and scales of harvested power. A pre-defined set of energy storage capacitance values are swept through.

### B. System Model

This contains three modules:

- *Energy Harvester and Conversion Circuits*: The energy harvester module transduces environmental energy into electricity. In ICSs, conversion circuits may simply be a diode to inhibit backflow of current. The energy harvester and conversion circuits can be modelled together as a module because they are usually coupled or integrated.
- *Energy Storage*: Energy storage in ICSs is usually in the form of a  $\mu\text{F}$ - to  $\text{mF}$ -scale capacitor. It must be sufficient to complete the most energy-expensive atomic operation, and may be formed only of the decoupling capacitor(s).
- *Intermittent Load*: Includes all the power consumers in an ICS, such as a microcontroller, sensors, and a radio.

The outputs from the system model are the interruption periods, capacitor volume, and forward progress.

### C. Trade-off

The appropriate capacitance is then found through a cost function. This may trade off forward progress against capacitor volume and interruption periods.

## V. EXPLORATION OF ENERGY STORAGE SIZING

In this section, we configure the reactive ICS model presented in Section ?? to approximate a real ICS platform, and then present an exploration of the relationship between  $\alpha_{exe}$  and  $C$  with respect to  $I_{harv}$  and volatile state size.

TABLE II  
PROFILED MCU PARAMETERS

| Parameter | Value             |
|-----------|-------------------|
| $I_{exe}$ | 887 $\mu\text{A}$ |
| $I_{lpm}$ | 26 $\mu\text{A}$  |
| $I_r$     | 971 $\mu\text{A}$ |
| $I_s$     | 811 $\mu\text{A}$ |
| $T_r$     | 1.903 ms          |
| $T_s$     | 1.880 ms          |

### A. Model Configuration

1) *Energy Storage*: The energy storage is represented as an ideal capacitor with leakage current. Its terminal voltage is directly applied to the load, so is modelled as:

$$C \frac{dV_{cc}}{dt} = I_{harv} - I_{load} - I_{leak} \quad (10)$$

where  $I_{load}$  is the current consumption of the load. In this exploration, we refer to the empirical  $I_{leak}$  of AVX TAJ low-profile series tantalum capacitors, which depends on capacitance  $C$ , rated voltage  $V_{rated}$ , and terminal voltage  $V_{cc}$  [?]:

$$I_{leak} = 0.01\lambda CV_{rated} \quad (A) \quad (11)$$

where  $\lambda$  denotes the ratio of the actual current leakage at  $V_{cc}$  to the current leakage at  $V_{rated}$ , and  $\lambda$  is approximated as:

$$\lambda = 0.05 \times 20^{\frac{V_{cc}}{V_{rated}}} \quad (12)$$

We assume a typical load of  $< 4.0$  V so, to minimize leakage, we select a device with  $V_{rated} = 10$  V so as to operate between 25-40% of its rated voltage [?].

2) *Intermittent Load*: The load parameters of current draws and time overheads, as listed in Table ??, were profiled with the experimental settings explained in Section ???. The current draw was profiled with experimental measurements at a range of supply voltages. The variation of  $I_{lpm}$  between  $V_{off}$  (1.8 V) and  $V_r$  (2.4 V) is 2%, and for  $I_{exe}$  between  $V_s$  (2.1 V) and 3.3 V is 1.5%.  $I_{exe}$  also has a run-time variation of 2.8% due to a variable memory access rate. We omit these minor variations and use the mean of  $I_{exe}$  and  $I_{lpm}$  in the model.  $I_r$  and  $I_s$  are measured at  $V_r$  and  $V_s$  respectively. Given the voltage thresholds and the current consumption, the minimum energy storage capacitance is 6.2  $\mu\text{F}$ . This guarantees that a save and restore operation can complete even if the incoming supply current drops instantaneously to zero. The model parameters in Table ?? are given as an example, and can be changed for different load characteristics. For example,  $T_r$  and  $T_s$  can be tuned for different volatile state sizes.

### B. Sizing Energy Storage to Improve Forward Progress

1) *Impact of Supply Current*: Increasing energy storage capacitance above the minimum can improve forward progress by reducing the frequency of power interruptions, but this improvement may be offset by increased leakage. Fig. ?? shows the relationship between forward progress and energy storage capacitance for a range of constant supply currents. Optimal capacitance values are shown for each current value.



Fig. 6. Forward progress against energy storage capacitance at different levels of constant supply current. Error bars around optimal points denote the impact of typical  $\pm 20\%$  capacitance tolerance.



Fig. 7. Maximum forward progress improvement by sizing energy storage given a spectrum of supply current (normalized by the minimum capacitance case), with the corresponding maximum and sub-maximum (95% of maximum) capacitance.

The minimum capacitance (dashed line in Fig. ??) is calculated to deliver correct operation even if the supply current instantaneously drops to zero. If it does not drop to zero, this means that correct operation could have continued even with a smaller capacitance, though designing a system in this way would be inadvisable owing to unpredictability of the supply. This property is illustrated in Fig. ??, in the area on the left of the dashed line. It may be observed that, for each of the current values, there is a sudden drop-off towards zero forward progress. This illustrates the hazard of setting the capacitance too small: the stored energy is too low to allow a restore and save to be undertaken.

Typically, commercially-available capacitors have a  $\pm 20\%$  tolerance. The effect of this variation on maximum forward progress is shown to be negligible ( $< 0.23\%$ ) in Fig. ???. However, it must be pointed out that the effect would be much more pronounced if operating at the minimum capacitance as the variation of forward progress is larger with smaller capacitance values. Thus, it is recommended that a tolerance is considered when designing ICSs with minimum capacitance.

Fig. ?? shows that an improvement in forward progress of

TABLE III  
LINEAR SCALING RANGE OF VOLATILE STATE SIZE AND RESTORE/SAVE TIME OVERHEADS

| State Size<br>(Registers + SRAM) | Restore Time | Save Time   |
|----------------------------------|--------------|-------------|
| 64B + 160B (lower bound)         | 232 $\mu$ s  | 208 $\mu$ s |
| 64B + 2048B (upper bound)        | 2.298 ms     | 2.274 ms    |



Fig. 8. Impact of RAM usage (linear to restore/save overheads) on sizing energy storage with 0.4 mA current supply. Improvement and reduction are normalized by the minimum capacitance case.

up to 65% can be achieved when using the optimal capacitance instead of the minimum. However, it may not be desirable to set the capacitance solely for maximizing forward progress, because there are often trade-offs with other factors including increased interruption periods and dimensions. While a large improvement can be delivered with the optimal capacitance, as shown in Fig. ??, 95% of this gain can still be obtained with significantly smaller capacitances (mean 31% of the optimal value). For example, reducing from 325  $\mu$ F to 90  $\mu$ F gives 95% of the maximum improvement with a 0.5 mA supply.

2) *Impact of Volatile State Size:* The size of volatile state differs across applications with different amounts of RAM usage, and hence incurs varying time and energy overheads for restore and save operations. We measured time overheads of restore and save operations in the minimum case (64B register data and a 160B stack) and the maximum case (64B register data and a full 2048B RAM) respectively as shown in Table ???. As these time overheads are expected to be linear to the state size [?], the model can be tuned for various volatile state sizes by linearly scaling the profiled values.

An example of this is plotted in Fig. ???. The forward progress improvement by sizing energy storage increases with the volatile state size, and the optimal capacitance grows accordingly. The improvement becomes insignificant when the volatile state size is small because the restore and save overheads are already negligible. For example, when the workload uses the least volatile state (the leftmost point), the maximum progress improvement is only 3.6% although the restore and save overheads are reduced by 93%.



Fig. 9. System model of a PV-based ICS.

TABLE IV  
PV CELL PROPERTIES UNDER A 1000 W/CM<sup>2</sup>, AM-1.5 LIGHT SOURCE

| Parameter             | Value                   |
|-----------------------|-------------------------|
| Open-Circuit Voltage  | 0.89 V/cell             |
| Short-Circuit Current | 14.8 mA/cm <sup>2</sup> |
| Maximum Power Voltage | 0.65 V/cell             |
| Maximum Power Current | 12.1 mA/cm <sup>2</sup> |

### C. Validation of Sizing Effects

As previously shown in Fig. ??, the efficiently-sized energy storage capacitance (43  $\mu$ F) improves forward progress by up to 55% and 30% compared to the minimum and decoupling capacitance respectively. We notice that this improvement becomes significant when the supply current attenuates because the save and restore overheads consume a larger proportion of the available energy. Also, this achieves at least 90% of the ideal forward progress mentioned in Section ???. These results illustrate the importance of this technique, in particular for conditions where the supply current is low.

## VI. SIZING UNDER REAL-WORLD ENERGY CONDITIONS

In this section, we model an ICS with a photovoltaic (PV) energy harvester to explore the energy storage sizing effect in real-world energy conditions, and demonstrate use of the proposed sizing approach.

### A. Simulation Configuration

We integrate the validated reactive ICS model into a system model with a PV energy-harvesting supply as shown in Fig. ???. The energy storage model and the intermittent load model are as presented in Section ??.

We use a converter-less supply circuit where only a Schottky diode is connected to the energy harvester output in order to prevent current backflow. The energy source conditions are imported from NREL outdoor solar irradiance data [?] and EnHANTs indoor irradiance data [?]. Four sets of light conditions are used to encompass different energy environments. To convert irradiance into harvested power, we adopt a PV cell model [?] which uses the parameters available in common datasheets, so it can easily be reconfigured to suit various devices. We refer to Panasonic Amorton glass type solar cells [?] for PV cell properties as shown in Table ???. We set four cells in series (with  $V_{oc} = 3.56V$ ) to match the operating voltage of the MCU (maximum 3.6V), and model energy harvester sizing by scaling the cell area.

### B. Exploration with Real-World Energy Source Conditions

In real-world deployments, ambient energy source conditions are dependent on time and location. The energy harvester and storage need to be sized to achieve the desired forward progress across the range of expected conditions.

*1) Sizing the Energy Harvester:* For the purposes of this exploration, three levels of baseline mean forward progress ( $\alpha_{exe}$ ) are set as 0.1, 0.2, and 0.3. We use the system model to find the PV panel area that achieves the expected forward progress under the different energy source conditions with minimum energy storage. We scale the PV panel area to find that which achieves each baseline  $\alpha_{exe}$ . As shown in Fig. ??, the energy harvester sizes that achieve the desired  $\alpha_{exe}$  may span orders of magnitude given different energy source conditions from mm<sup>2</sup> for outdoor sources ((c) and (d)) to cm<sup>2</sup> for indoor sources ((a) and (b)).

*2) Sizing the Energy Storage:* Having obtained the energy harvester sizes for the baseline forward progress, we then use the modelling approach to size energy storage. We analyze the sizing effect of energy storage on forward progress given real-world energy conditions. Fig. ?? shows a 7.8-43.3% improvement in forward progress by sizing energy storage under the given real-world energy conditions and baseline energy harvester sizes. It can also be inferred that optimizing energy storage can either improve forward progress for a given energy harvester size, or reduce the energy harvester size that achieves the target forward progress. Given higher-power energy sources (e.g. Denver 2018 and Hawaii 2018 outdoor solar), increasing the harvester size efficiently improves forward progress with minor dimensional overheads, e.g. tens of mm<sup>2</sup>; however, given lower-power sources (e.g. EnHANTs Setup A and Setup D indoor light), optimizing energy storage capacitance can save tens of cm<sup>2</sup> of PV panel area to achieve the same forward progress.

*3) Interruption Period:* Besides forward progress, we also explore how the capacitance can change the interruption periods. When interrupted by insufficient power supply, an ICS enters an interruption period where it saves its volatile state, waits for supply voltage to recover, and restores the state to resume execution, without making any forward progress. Applications that require frequent sensing may be negatively affected by long interruption periods. We measure an interruption period as the period between two successive execution periods, e.g. a consecutive ‘SLR’ period in Fig. ?? forms an interruption period. We record all the interruption periods during a one-year simulation with 10–50 μF capacitors, the Denver 2018 dataset, and an 80 mm<sup>2</sup> PV panel. Fig. ?? presents the distribution of all the interruption periods. With increased energy storage, the interruption period is prolonged. For example, the 90th percentile of interruption periods increases from 32.2 ms at 10 μF to 123.4 ms at 50 μF at an approximate rate of 23 ms per 10 μF. Facilitated by the simulator, developers are enabled to estimate whether the distribution of interruption periods meet their application requirement.



Fig. 10. EnHANTs Setup A



Fig. 11. EnHANTs Setup D



Fig. 12. NREL Denver 2018



Fig. 13. NREL Hawaii 2018

Fig. 14. Improvement of average forward progress by sizing energy storage given different PV panel areas under real-world energy source conditions. The model is able to find the PV panel area required for achieving the target mean forward progress.

### C. Trading Forward Progress, Dimensions, and Interruption Period

Although increasing energy storage capacitance improves forward progress, larger capacitance increases both dimensions and interruption periods. We evaluate the overheads of increased capacitor dimensions and interruption periods, and then trade them off against forward progress using a cost function to suggest an optimal capacitance value.

*1) Metric of Dimensions:* The overhead of capacitor dimensions is evaluated by characteristics of off-the-shelf tantalum capacitors. We narrow down the range of sample capacitors within a set of characteristics: low-profile, 10V rated voltage, and surface-mount package, and select six series of capaci-



Fig. 15. Distribution of interruption periods.



Fig. 16. Tantalum capacitor volume against capacitance for the six series of capacitors analyzed.

tors<sup>2</sup>. The volume and capacitance of these devices are plotted in Fig. ???. We use the regression of these data to approximate a capacitance-volume relationship.

2) *Metric of Interruption Periods*: Applications may have various requirements on interruption periods. To demonstrate the usage of our sizing approach, we consider a designer requests the 90th percentile of all interruption periods as an example metric of interruption periods, denoted as  $T_{int}$ . This metric indicates 90% of interruption periods are shorter than  $T_{int}$ . This metric can be adapted for particular application requirements.

3) *Cost Function*: From the previous observations (Fig. ???) we can see that achieving the optimal progress improvement costs much more capacitance (mean  $3.2\times$ ) than to achieve 95% improvement. A trade-off is necessary to improve forward progress while restricting the overheads of increased capacitor volume and interruption periods. We use the cost function in (??) to trade off forward progress, capacitor volume, and interruption periods:

$$f = \frac{\alpha_{exe}}{k_1} - \left( \frac{v_{cap}}{k_2} \right)^2 - \left( \frac{T_{int}}{k_3} \right)^2 \quad (13)$$

where  $v_{cap}$  denotes capacitor volume and  $T_{int}$  denotes interruption periods.  $\alpha_{exe}$ ,  $v_{cap}$ ,  $T_{int}$  can be described as functions

<sup>2</sup>The series of capacitor considered were: AVX TAJ, AVX TACmicrochip, AVX F92, Vishay 572D, Vishay 591D, and Vishay 592D.



Fig. 17. The sizing approach trades off forward progress, capacitor volume, and interruption periods. The results are plotted against a range of PV panel area, given Denver 2018 energy source dataset.

of  $C$ .  $k_1$ ,  $k_2$ , and  $k_3$  are independent factors used for normalizing each metric, and they are empirically determined according to applications. In this example, the undesirable parameters are expressed as quadratics to give an increasing cost to higher values. While only three parameters are considered here, others (such as the energy harvester size) could be included for a system-wise sizing scenario. As an example, we configure the function by setting  $k_1 = 0.2$ ,  $k_2 = 200 \text{ mm}^3$ , and  $k_3 = 500 \text{ ms}$ .

The effect of the trade-off is plotted in Fig. ?? using the Denver 2018 energy source dataset. Compared to the capacitor size that solely maximizes forward progress, on average, an appropriately-sized capacitor achieves 93% of the maximum forward progress, while saving 83% of capacitor volume and 91% of interruption periods. Compared to the minimum storage case, the appropriately-sized capacitor improves forward progress by 12-124% with energy storage increased from  $6.2 \mu\text{F}$  to  $30 \mu\text{F}$ .

As shown in Fig. ??, the closest available capacitance that satisfies the  $6.2 \mu\text{F}$  minimum capacitance is  $6.8 \mu\text{F}$ , whereas the closest available capacitance to the appropriate  $30 \mu\text{F}$  is  $33 \mu\text{F}$ . The minimum volumes of  $6.8 \mu\text{F}$  and  $33 \mu\text{F}$  capacitors are both  $2.75 \text{ mm}^3$ , which means using the appropriate capacitance, instead of the minimum one, may not incur dimensional overhead. The regressed volume of the above two capacitance values are  $8.1 \text{ mm}^3$  and  $23.8 \text{ mm}^3$  respectively. However, the selection of capacitors can be dependent on factors other than physical volume, such as reliability, operation temperature, and more specific application needs. These factors can also be added into the cost function if necessary.

## VII. CONCLUSIONS

While conventional ICSs have used minimal levels of capacitance, this paper has shown that increasing the amount of energy storage can improve system performance by up to 65% with a constant current supply and 43% with real-world PV sources. The work includes a simulation tool which is available to download, enabling researchers to experiment with energy storage sizes to optimize ICS designs. A cost function can be incorporated, allowing various aspects of system performance to be traded-off. Our conclusion is that energy storage should be carefully designed, rather than minimized or indiscriminately picked, to efficiently operate ICSs.



**Jie Zhan** received the B.Eng. degree in electrical engineering from Xiamen University, China, in 2017. He is currently pursuing a Ph.D. in electronic engineering with the School of Electronics and Computer Science, University of Southampton. His research is focused on efficient intermittent computing for batteryless energy-harvesting devices



**Geoff V. Merrett** (GSM'06-M'09-SM'19) received the B.Eng. (Hons) and Ph.D. degrees from the University of Southampton, U.K., in 2004 and 2008, respectively. He currently holds a Personal Chair in Electronic and Software Systems at the School of Electronics and Computer Science, University of Southampton, U.K., where he is Head of the Centre for Internet of Things and Pervasive Systems.

Prior to becoming a Professor in 2019, he was a Lecturer and Associate Professor at Southampton from 2009 and 2014 respectively. He is Co-Director of the Arm-ECS Research Centre, an award winning collaboration between the university and Arm Research, Cambridge. His current research interests are in energy management of mobile/embedded systems and self-powered devices, and he has published over 200 journal and conference articles on these topics.



**Alex S. Weddell** (GSM'06-M'10) received the M.Eng. degree (1st class honors) and Ph.D. in electronic engineering from the University of Southampton, U.K., in 2005 and 2010. His main research focus is in the areas of energy harvesting and energy management for future Internet of Things devices. He has over 15 years' experience in energy harvesting systems, and has published over 65 papers in the area. He is now a Lecturer at the University of Southampton, involved with three projects funded by EPSRC, EU Horizon 2020 and Clean Sky 2.