260 likes | 483 Views
A Run-Time Feedback Based Energy Estimation Model for Embedded Systems. Selim Gürün Chandra Krintz Department of Computer Science U.C. Santa Barbara. International Conference on Hardware/Software Codesign and System Synthesis (CODES-ISSS) Seoul, Korea October 22-25, 2006.
 
                
                E N D
A Run-Time Feedback Based Energy Estimation Model for Embedded Systems Selim Gürün Chandra Krintz Department of Computer Science U.C. Santa Barbara International Conference on Hardware/Software Codesign and System Synthesis (CODES-ISSS) Seoul, Korea October 22-25, 2006
Power-Aware Execution: Big Picture • Power-aware methods divide task execution into operations, and prepare an execution plan for each • Operation: smallest user-visible unit of execution • Typical operation: Rendering a scene, translating a sentence, calculating a shortest path in a map • Need to know energy cost of each plan Knowing future energy cost of operations requires profiling them at run-time Identify Operations Profile at Runtime Predict Future Costs Develop Power-Aware Execution Strategy CODES-ISSS’06
Outline • Extant run-time power profiling techniques • Power profiling methodologies for embedded computers • Proposed model • Overview • Model construction • Capturing system dynamics • Evaluation • Summary and Conclusion CODES-ISSS’06
Run-Time Energy Profiling: Overview OS Interfaces like ACPI: + Provides simple API to battery voltage sensors + Ok for different hw. power levels - Very coarse - Not precise Execution Time: + Simple to measure + Fast and precise - Not correlated to power - Not suitable when hw. power levels change: DVS, sleep HPMs: + Fast access + Quite accurate - Architecture dependent - Not designed for power estimation --many events missing CODES-ISSS’06
Run Time Energy Profiling: HPMs • CPU counters provide unparalleled insight into program behavior • Cache, TLB misses • Instructions executed per cycle (IPC) • How can we accurately gather program energy consumption by monitoring key parameters? • Use HPMs as pseudo CPU component access counters: • Energy Consumption = I Cache * a0 + D Cache * a1 + ALU * a2 +… CODES-ISSS’06
Run Time Energy Profiling: HPMs • CPU counters provide unparalleled insight into program behavior • Cache, TLB misses • Instructions executed per cycle (IPC) • How can we accurately gather program energy consumption by monitoring key parameters? • Use HPMs as pseudo CPU component access counters: • Energy Consumption = I Cache * a0 + D Cache * a1 + ALU * a2 +… • Useful but not enough: • CPU consumes a portion of total energy; power-aware strategies need to know full picture. • Fails when hardware changes its behavior: DVS, sleep states • A different strategy needed! CODES-ISSS’06
Offline Analysis Fine-Grain Energy Estimation Continuous model improvement at run-time Proposed Energy Profiling Model CODES-ISSS’06
Case Study: Intel XScale on Stargate • 32 bit XScale – 400MHz • 64 MB RAM • Runs Familiar Linux • No Display • Wireless 802.11 • Compact Flash XScale Major HPM Events Inst/Data cache misses Data dependency stalls Inst/Data TLB misses Brach mispredicted Instruction executed SCL CODES-ISSS’06
Constructing Model • Are there any correlations between HPM values and full system power consumption? • Absolutely! --but some challenges exist. • Good correlation in memory/CPU subsystem • High IPC -> CPU intensive application • High cache misses/hits -> memory intensive application • But I/O is the problem! • Some heuristics possible, e.g. Low memory activity and low IPC -> possible I/O wait state • Better to use software counters embedded into drivers CODES-ISSS’06
Model Coefficients E = X1 a1 + X2 a2 + X3 a3 +… XI : Independent Variables aI : Coefficients LSQ Model: Which variables? • Estimate coefficients using least squares linear regression (LSQ) • Stable and simple • Linearity assumption Only Major All related • Efficient, clear • Easier to understand • Less accurate • More accurate • Run-time overhead • Modeling difficulties due to variable dependencies CODES-ISSS’06
grams pounds Parameter Selection & Dependencies • Hard to include all variables: Too many parameters clutter model • Parameter dependencies  unstable parameter estimations • E.g. Volume = a0 + a1 * pounds + a2 * grams Multicollinearity! • Work-around is non-trivial; HPM characteristics e.g.: • TLB miss more CPU cycles & cache miss • Memory Stall  Fewer instruction executed CODES-ISSS’06
Run-Time Energy Estimation CODES-ISSS’06
Global Coefficients Measure Power Update with RLS Run-Time Model Improvement • Global coefficients • Compute using off-line model • Continuously update coefficients • Improve using most recent data • Gradually phase out previous measurements • Recursive least squares with exponential decay • Smaller decay factor-> more agile • Model Parameters: • Decay factor • Update period • Measurement error CODES-ISSS’06
Feedback Source: DS 2760 • Measures current flow in and out of battery • Internally: A small A/D converter attached to a high precision internal resistor Pros/Cons: + Highly Available e.g. iPAQs, sensor network gateways, cell phones - Not precise enough for monitoring task energy consumption 0.25 mAh error in each reading - Slow, one-wire serial interface CODES-ISSS’06
VPerfmon VPMon SCL Stargate and Our Evaluation Bench PowerTool Programmable Power Supply High-precision Data Acquisition Device CODES-ISSS’06
Methodology • Collect energy consumption every so often • Every 10 million instructions ( a so-called interval) • Validate model accuracy on imprecise measurement data • Inject uniformly distributed random error • Evaluate various precision (error) levels: 1X – 8X • Predict energy consumption of each interval • Continuously improve model parameters every 10M * K intervals • Use a large group of workload • Computational benchmarks • Computational + communication oriented benchmarks CODES-ISSS’06
Static vs. Adaptive Models CODES-ISSS’06
Average Error Rates Measurement Precision Present Hardware Error rates and Interval sizes –Simple Model CODES-ISSS’06
Average Error Rates-Complex Model Simple Model Measurement imprecisionreducecomplex model quality more than the simple one! CODES-ISSS’06
Related Work • High-End CPU Power Models • Define CPU component access rate using HPM access heuristics • OS calls power consumption as a function of IPC • Embedded CPU Power Models • Five HPM counters for XScale • Also evaluated memory model • Memory models • UltraSparc memory subsystem • All above are static models • Power profiling setups • Powerscope CODES-ISSS’06
Summary & Conclusions • Our Goal: An accurate, efficient run-time power profiling system • Hardware counters are key • Define software counters for I/O • Smart battery monitors expose dynamics in power behavior • We propose a hybrid system that combine both • Lessons learned • Dynamic models are much better than static ones in power modeling • Models should decay old measurements conservatively when measurement errors are present • Measurement errors in the presence of multicollinearity can be deadly CODES-ISSS’06
Backup Slides CODES-ISSS’06
Decay Factor vs. Accuracy CODES-ISSS’06
Execution Cost CODES-ISSS’06
Benefit from an Offline Profiler CODES-ISSS’06
Power-Aware Execution: Case Study Speech Recognition Execution Plans src: Flinn’01 Baseline Local Reduced Remote Reduced Requires run-time power prediction of different execution plans! CODES-ISSS’06