電源・省電力

低消費電力設計

電力を抑えるための設計手法全般。

概要

低消費電力設計(Low-Power Design)とは、電子システムが消費する電力(電流)を最小化するための設計手法・アプローチの総称である。バッテリー駆動のIoT機器や組み込みデバイスの設計において、電池寿命の延長・発熱の低減・電源回路の小型化を目的として体系的に取り組む設計領域である。

低消費電力設計はハードウェア層(電源回路、MCU選定、部品選定)からソフトウェア層(スリープモード制御、クロック管理、タスクスケジューリング)まで横断的に取り組む必要があり、設計の初期段階から考慮することが効果的である。

低消費電力設計の4つの基本レイヤー

レイヤー対象主な施策
アーキテクチャシステム全体の構成処理の集約・非同期化、クラウドオフロードの削減
ハードウェアMCU、電源回路、部品低消費MCU選定、DC-DC採用、未使用回路の電源遮断
ソフトウェアファームウェアスリープ活用、クロック動的変更、DMA活用
システム運用通信・センシング頻度デューティサイクルの最適化、エッジ処理の活用

歴史・背景

低消費電力設計の重要性は、携帯電子機器の登場とともに高まった。1980〜1990年代のポケベル・電卓・携帯音楽プレーヤーの時代に、MCUの低消費電力化とスリープモード活用技術が発展した。Microchip PICやAtmel AVRなどのMCUはこの時代から電力管理機能を重視していた。

2000年代のモバイルインターネット時代(スマートフォン前夜)には、ノートPCやPDAのバッテリー駆動時間の競争が活発化し、CPU・チップセット・ディスプレイなどあらゆる部品の低消費電力化が進んだ。Intelの「SpeedStep」(動的クロック変更技術)やARMの「big.LITTLE」アーキテクチャはこの流れの延長線上にある。

2010年代のIoTブームとともに、「単三電池2本で10年間動作するセンサー」というコンセプトが現実のニーズとなり、nA(ナノアンペア)オーダーの超低消費電力MCUとLPWA(Low Power Wide Area)通信の組み合わせが普及した。現在では「電力収支ゼロ(エナジーニュートラル)」を目指すエナジーハーベスティングシステムの研究・実用化も進んでいる。

技術仕様

CMOSの消費電力モデルと低電力化の理論的根拠

現代のデジタル回路(CMOS)の消費電力は以下のモデルで表される。

P_total = P_dynamic + P_static

動的消費電力(スイッチング時):
P_dynamic = α × C_L × V_DD² × f_clk

α: スイッチング活性化係数(0〜1)
C_L: 負荷容量(配線容量 + トランジスタ容量)
V_DD: 電源電圧
f_clk: クロック周波数

静的消費電力(常に流れるリーク電流):
P_static = I_leak × V_DD

この式から、消費電力低減のアプローチが直接導かれる。

パラメータ低減方法効果の大きさ
α(活性化係数)クロックゲーティング、未使用ブロック停止
C_L(負荷容量)細線化プロセス(設計者が制御困難)
V_DD²(電源電圧の二乗)電源電圧低減最大(二乗効果)
f_clk(クロック周波数)クロック分周、動的クロック変更大(線形)
I_leak(リーク電流)電源ゲーティング、低リーク素子選択大(スリープ時)

消費電流の測定と分析

低消費電力設計の開発プロセスでは、各フェーズの消費電流を実測・分析することが不可欠である。

# 消費電流プロファイルの分析スクリプト例(Nordic PPK2のCSVデータ処理)
import pandas as pd
import numpy as np

def analyze_power_profile(csv_file, threshold_ma=1.0):
    """
    PPK2のCSVデータを解析してアクティブ期間とスリープ期間を識別
    """
    df = pd.read_csv(csv_file, names=['time_us', 'current_ua'])
    df['current_ma'] = df['current_ua'] / 1000.0

    # アクティブ状態の識別(閾値以上の電流)
    df['is_active'] = df['current_ma'] > threshold_ma

    # アクティブ期間の統計
    active_data = df[df['is_active']]
    sleep_data = df[~df['is_active']]

    active_avg_ma = active_data['current_ma'].mean()
    sleep_avg_ua = sleep_data['current_ua'].mean()
    active_ratio = len(active_data) / len(df)

    # 平均消費電流
    avg_current_ma = (active_avg_ma * active_ratio +
                      sleep_avg_ua / 1000 * (1 - active_ratio))

    print(f"アクティブ時平均電流: {active_avg_ma:.2f} mA")
    print(f"スリープ時平均電流:   {sleep_avg_ua:.2f} µA")
    print(f"アクティブ率:         {active_ratio*100:.2f}%")
    print(f"全体平均消費電流:     {avg_current_ma*1000:.2f} µA")

    return avg_current_ma

主要なMCUの消費電流比較

MCUアクティブ(mA/MHz)ディープスリープ(µA)メーカー
STM32L40.056 mA/MHz0.5µASTMicro
nRF528400.44 mA/MHz(Run mode)1.5µANordic
MSP430FR0.10 mA/MHz0.1µATI
EFM32 (Gecko)0.019 mA/MHz0.02µASilicon Labs
ESP32-S310µA(ディープスリープ)Espressif
ATSAML210.070 mA/MHz0.2µAMicrochip

動作原理

デューティサイクルモデルによる電池寿命計算

低消費電力設計の核心は、システムの動作時間比率(デューティサイクル)を最小化し、スリープ時間を最大化することにある。

デューティサイクル D = t_active / T_cycle

平均消費電流:
I_avg = I_active × D + I_sleep × (1 - D)

電池寿命:
T_life = Q_battery / I_avg

例:
T_cycle = 60秒, t_active = 2秒
D = 2/60 = 0.033 (3.3%)
I_active = 20mA, I_sleep = 5µA

I_avg = 20 × 0.033 + 0.005 × 0.967
      = 0.66 + 0.0048
      ≈ 0.665mA

電池容量 2000mAh(単3×2本)の場合:
T_life = 2000 / 0.665 ≈ 3,008時間 ≈ 125日

アクティブ時間を1秒に短縮(処理高速化)した場合:
D = 1/60 = 0.0167, I_avg = 0.333mA
T_life = 2000 / 0.333 ≈ 6,006時間 ≈ 250日 → 2倍の改善!

クロック周波数と電源電圧の動的制御(DVFS)

処理負荷に応じてクロック周波数と電源電圧を動的に変更するDVFS(Dynamic Voltage and Frequency Scaling)は、スマートフォンのSoCでは標準的に実装されている手法で、組み込みMCUでも応用できる。

#include "stm32l4xx_hal.h"

// 処理強度に応じたクロック設定
typedef enum {
    PERF_LEVEL_LOW = 0,    // 4MHz, VCore = 1.0V(省電力)
    PERF_LEVEL_MEDIUM,     // 16MHz, VCore = 1.0V
    PERF_LEVEL_HIGH,       // 80MHz, VCore = 1.2V(最高性能)
} perf_level_t;

void set_performance_level(perf_level_t level) {
    switch (level) {
        case PERF_LEVEL_LOW:
            // MSI 4MHz へ切り替え
            RCC_OscInitTypeDef osc = {0};
            osc.OscillatorType = RCC_OSCILLATORTYPE_MSI;
            osc.MSIState = RCC_MSI_ON;
            osc.MSIClockRange = RCC_MSIRANGE_6;  // 4MHz
            HAL_RCC_OscConfig(&osc);
            // コア電圧を1.0Vに(Range 2)
            HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE2);
            break;

        case PERF_LEVEL_HIGH:
            // PLL 80MHz へ切り替え
            HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1);
            // ... PLL設定
            break;
    }
}

// 使用例: センサーデータ処理時のみ高性能モード
void task_process_sensor_data(void) {
    set_performance_level(PERF_LEVEL_HIGH);
    heavy_signal_processing();
    set_performance_level(PERF_LEVEL_LOW);
}

DMAを活用したCPUスリープの延長

DMA(Direct Memory Access)を使うことで、データ転送中にCPUをスリープさせ、消費電力を削減できる。

// DMAを使った UART 送信(CPUを解放してスリープ可能にする)
void uart_send_dma(const uint8_t *data, uint16_t len) {
    HAL_UART_Transmit_DMA(&huart1, (uint8_t*)data, len);

    // DMA転送完了まで CPU をスリープ
    ulTaskNotifyTake(pdTRUE, pdMS_TO_TICKS(1000));
    // DMA完了割り込み → FreeRTOS タスク通知で起床
}

// DMA完了コールバック(割り込みから呼ばれる)
void HAL_UART_TxCpltCallback(UART_HandleTypeDef *huart) {
    if (huart->Instance == USART1) {
        BaseType_t xHigherPriorityTaskWoken = pdFALSE;
        vTaskNotifyGiveFromISR(uart_task_handle, &xHigherPriorityTaskWoken);
        portYIELD_FROM_ISR(xHigherPriorityTaskWoken);
    }
}

用途・ユースケース

IoTエッジセンサーネットワーク

温湿度センサー、CO2センサー、粒子計数器などを大量展開するIoTセンサーネットワークでは、全センサーの電池寿命を5年以上にする設計目標が設定されることが多い。電池交換コスト(作業員の人件費、登攀作業など)が設備コストより高くなる場合があるため、経済的観点でも重要な設計課題となる。

スマートメータ

電気・ガス・水道のスマートメータは、設置後10〜15年の電池寿命が要求される。電池容量(D型リチウム電池: 17Ah)、通信周期(15分〜1時間)、通信プロトコル(920MHz特定小電力無線、LTE-M)などを最適化した低消費電力設計が施される。

医療用ウェアラブル

植込み型心臓デバイス(ペースメーカー、ICD)は電池交換に手術が必要なため、5〜10年の電池寿命が要求される。不整脈検出時のみ完全動作し、通常時は超低消費で心電図監視を継続する設計が必要である。

スマートファクトリー・予知保全センサー

工場設備の振動・温度監視センサーは、電池交換のための設備停止を避けるため、長い電池寿命が求められる。異常検知時のみアラートを送信するエッジAI処理との組み合わせも有効である。

実装・開発のポイント

1. 電力バジェットの設定(設計初期段階)

プロジェクト開始時に目標とする電池寿命から逆算し、許容できる平均消費電流を求める。これが全設計の制約条件となる。

目標: 単3電池2本(2000mAh)で3年間動作
許容平均消費電流 = 2000mAh / (3年 × 8760時間/年) = 0.076mA = 76µA

このバジェットを各コンポーネント(MCU、センサー、通信)に割り当てる:
- MCUスリープ: 5µA
- センサー電源(ON時平均): 20µA
- 通信モジュール(ON時平均): 50µA
- 電源回路静止電流: 1µA
合計: 76µA → ギリギリOK(余裕なし)

2. 低消費電力設計のチェックリスト

ハードウェア:
□ MCU選定: ディープスリープ消費電流 < 5µA
□ LDO/DC-DC: 静止電流 < 10µA
□ 未使用ペリフェラルの電源遮断回路
□ フローティングGPIOピンの固定(リーク電流対策)
□ プルアップ/プルダウン抵抗値の最適化

ソフトウェア:
□ アイドル時のディープスリープ実装
□ 未使用ペリフェラルのクロック停止
□ アクティブ時間の最小化(処理の高速化)
□ DMAの活用(CPUスリープ時間の確保)
□ センシング周期・通信周期の最適化
□ バッテリー電圧監視とフェールセーフ

検証:
□ 各動作モードでの消費電流実測
□ 電力プロファイリングツールによる解析
□ 電池寿命の計算値と実測値の照合
□ 最悪温度条件(低温)での電池寿命確認

3. ソフトウェアレベルの消費電流最適化

// FreeRTOS: ティックレス(Tickless)アイドルモードの活用
// FreeRTOS のコンフィグで有効化
#define configUSE_TICKLESS_IDLE  1

// アイドルフックでスリープモードに移行
void vApplicationIdleHook(void) {
    // 全タスクが待機中のときここが呼ばれる
    // TicklessアイドルはFreeRTOS内部で次のタスク起床時刻まで
    // MCUのスリープ命令を自動的に発行する
    __WFI();  // Wait For Interrupt
}

// 長時間待機のタスク: スリープを活用した実装
void sensor_task(void *pvParameters) {
    while (1) {
        // センサー電源ON
        gpio_set_level(SENSOR_PWR_PIN, 1);
        vTaskDelay(pdMS_TO_TICKS(50));  // センサー起動待ち(FreeRTOSがスリープ)

        // センサー読み取り
        float value = read_sensor();
        send_to_queue(value);

        // センサー電源OFF
        gpio_set_level(SENSOR_PWR_PIN, 0);

        // 次の計測まで待機(FreeRTOSがディープスリープに移行)
        vTaskDelay(pdMS_TO_TICKS(60000));  // 1分待機
    }
}

4. 通信プロトコルの選択

消費電流に最も大きな影響を与えるのは無線通信であることが多い。用途・通信距離・データ量に応じた最適プロトコルを選択する。

プロトコル平均電流(通信時)到達距離適用場面
BLE5〜15mA(送信時)〜100m近距離、スマホ連携
ZigBee30〜50mA〜100m近距離メッシュ
LoRaWAN40〜80mA(送信時のみ)〜数km長距離、低頻度送信
LTE-M100〜200mA(送信時のみ)セルラー中距離、移動体
Sigfox40〜60mA(送信時のみ)〜50km超低頻度送信

他技術との比較・まとめ

低消費電力設計は単一の技術ではなく、以下の施策を組み合わせた総合的なアプローチである。

消費電力削減の優先順位(効果の大きい順):

1. アーキテクチャレベル:
   - 通信・処理の周期最適化(最大効果)
   - エッジ処理でクラウド通信を削減

2. スリープモードの活用:
   - ディープスリープの活用(数mA → 数µA)
   - RTOSのティックレスアイドル活用

3. 電源回路の最適化:
   - 効率の高いDC-DCコンバータ選定
   - 低静止電流のLDO選定
   - 未使用回路の電源遮断

4. MCU・クロックの最適化:
   - 処理量に応じたクロック周波数の動的変更
   - 使用しないペリフェラルのクロック停止

5. アナログ・センサー回路:
   - センサーの使用時のみ電源供給
   - 低消費電力のセンサーICの選定

低消費電力設計の全体観点では、スリープモードディープスリープの活用がソフトウェアレベルの最重要施策であり、LDODC-DCコンバータPMICの選定がハードウェアレベルの中心課題となる。消費電流の実測・分析とバッテリー駆動設計の電力収支管理を繰り返し行うことで、目標の電池寿命を達成することができる。

関連用語

参考リンク