PICマイコンのNOPとGOTOの消費電力

PIC12/16Fの小技として、NOPが2回分の時間稼ぎの代わりにGOTO $を使うとプログラム領域を節約できるというものがあります。
私はソースの可読性の観点からと、PAGEの概念があるPICで不必要なGOTOを行うことに抵抗があるという理由から、こういう場面ではNOPを使ってきました。
そんな折、2ちゃんねるの【初心者】PICでBEEP音を作りたい!!2【親切に】スレッドで以下のようなやり取りを見ました。

520 名前:技術奴隷[sage] 投稿日:2008/09/04(木) 05:38:55 ID:ECgj3Ptz
>>519
>あとさ、NOP、NOPはGOTO $+1にすると、容量が半分で済みます。

容量が有り余ってる時は大して意味が無いな。
逆にNOPで時間稼ぎした方が低消費電力になるメリットがある。
馬鹿の一つ覚えで凝り固まらず状況によって使い分ければヨロシ

536 名前:774ワット発電中さん[sage] 投稿日:2008/09/14(日) 15:47:50 ID:7tJFO2EZ
本当かどうか試しに 12F683 内蔵8MHz 5V で実験

LOOP GOTO $+1 ×32
 GOTO LOOPで 851uA

LOOP NOP ×64
 GOTO LOOPで 777uA

確かに1割位電流少なかった。
ただ最初 動作確認の為にGPIOをON/OFFさせてたら2mA位食ってたから
この程度 NOP/GOTO $+1の差なんてどうでもいい差だと思うが
重箱の隅が気になる方はどうぞってかんじ

重箱の隅が気になったので、追試してみました。条件は以下のとおり。
・PIC16F88使用
・内部クロック8MHz
・電源電圧は5V、電源は手持ちの安物スイッチング電源
・回路は以下のもの




◎ GOTO版

1.841mA




MAIN
FILL (GOTO $+D'1'),D'100'
GOTO MAIN


◎ NOP版

1.728mA




MAIN
FILL (NOP),D'200'
GOTO MAIN


私の行った追試の結果は、1.841mA(GOTO)/1.728mA(NOP)=1.065と1割とまではいかないながらもNOP版のほうが低消費電力ということでした。
二つの間で実験条件はほぼ変わらないので、定性的にNOP版のほうが低消費電力といっていいと思います。また、PIC16F88のデータシートによると、私の試験条件(VDD=5V,T=室温,Fosc=8MHz)での消費電流IDDは1.7mA(typ)ということなので、妥当な結果だと思います。




分かっていたことですが、この二つの消費電流の差はプルアップ抵抗一本分ぐらいの差なのであまり気にしても仕方ないかもしれません。ボタン電池駆動などの極省電力を目指すなら、SLEEPとWDTを使うのが常套手段でしょうし。

さらに追試をしたい方がいるかもしれないので、コードの全文を載せておきます。

goto.asm

        LIST    P=PIC16F88
INCLUDE "P16F88.INC"
__CONFIG _CONFIG1, _CP_OFF & _MCLR_OFF & _PWRTE_ON & _WDT_OFF & _INTRC_IO &_LVP_OFF __CONFIG _CONFIG2, _FCMEN_OFF & _IESO_OFF

ORG H'0000'
INITIALIZE
BANKSEL(OSCCON)
MOVLW B'01110000' ;8MHz
IORWF OSCCON,F
BANKSEL(TRISA)
CLRF TRISA
CLRF TRISB
BANKSEL(ANSEL)
;A/D Converter OFF
CLRF ANSEL
BANKSEL(CMCON)
;Comparator OFF
MOVLW B'00000111'
MOVWF CMCON
BANKSEL(PORTB)

MAIN
FILL (GOTO $+D'1'),D'100'
GOTO MAIN
END


nop.asm

        LIST    P=PIC16F88
INCLUDE "P16F88.INC"
__CONFIG _CONFIG1, _CP_OFF & _MCLR_OFF & _PWRTE_ON & _WDT_OFF & _INTRC_IO &_LVP_OFF
__CONFIG _CONFIG2, _FCMEN_OFF & _IESO_OFF

ORG H'0000'
INITIALIZE
BANKSEL(OSCCON)
MOVLW B'01110000' ;8MHz
IORWF OSCCON,F
BANKSEL(TRISA)
CLRF TRISA
CLRF TRISB
BANKSEL(ANSEL) ;A/D Converter OFF
CLRF ANSEL
BANKSEL(CMCON) ;Comparator OFF
MOVLW B'00000111'
MOVWF CMCON
BANKSEL(PORTB)

MAIN
FILL (NOP),D'200'
GOTO MAIN
END


tag: PIC アセンブラ 

comment

Secret

FC2カウンター
カテゴリ
ユーザータグ

LTspiceAkaiKKRmachikaneyamaScilabKKRPSoC強磁性CPAPICOPアンプecalj常微分方程式モンテカルロ解析状態密度トランジスタodeDOSインターフェース定電流スイッチング回路PDS5022半導体シェルスクリプト分散関係レベルシフト乱数HP6632AR6452A可変抵抗トランジスタ技術温度解析ブレッドボードI2C反強磁性確率論数値積分セミナーバンドギャップバンド構造偏微分方程式非線形方程式ソルバ熱設計絶縁ISO-I2Cカオス三端子レギュレータLM358GW近似マフィンティン半径A/DコンバータフォトカプラシュミットトリガLEDPC817C発振回路数値微分直流動作点解析サーボカレントミラーTL431アナログスイッチUSB74HC4053bzqltyVESTA補間電子負荷アセンブライジング模型BSch量子力学単振り子2ちゃんねるチョッパアンプLDA開発環境基本並進ベクトルFFT標準ロジックブラべ格子パラメトリック解析抵抗SMPMaxima失敗談ラプラス方程式繰り返し位相図スイッチト・キャパシタ熱伝導状態方程式キュリー温度gfortranコバルトTLP621不規則合金Quantum_ESPRESSO六方最密充填構造ランダムウォーク相対論ewidthスピン軌道相互作用FETQSGWVCAcygwinスレーターポーリング曲線GGA仮想結晶近似PWscfシュレディンガー方程式LM555ハーフメタル固有値問題NE555最小値ガイガー管QNAPUPS自動計測ダイヤモンドマントルTLP552格子比熱最適化MCU井戸型ポテンシャル最大値xcrysdenCIF条件分岐詰め回路フェルミ面差し込みグラフスーパーセルfsolveブラウン運動awk過渡解析起電力三角波第一原理計算FXA-7020ZRWriter509Ubuntuテスタ熱力学データロガーTLP521OpenMPubuntu平均場近似MAS830LトランスCK1026PIC16F785PGA2SC1815EAGLEノコギリ波負帰還安定性ナイキスト線図MBEOPA2277P-10フィルタCapSenseAACircuitLMC662文字列固定スピンモーメントFSMTeX結晶磁気異方性全エネルギーc/a合金multiplotgnuplot非線型方程式ソルバL10構造正規分布等高線ジバニャン方程式初期値interp1fcc面心立方構造ウィグナーザイツ胞半金属デバイ模型電荷密度重積分SIC二相共存磁気モーメント不純物問題PWgui擬ポテンシャルゼーベック係数ZnOウルツ鉱構造edeltquantumESPRESSOフォノンリジッドバンド模型スワップ領域BaO岩塩構造ルチル構造ヒストグラム確率論マテリアルデザインフラクタルマンデルブロ集合キーボードRealforceクーロン散乱三次元疎行列縮退化学反応関数フィッティング最小二乗法Excel直流解析PCTS-110TS-112日本語パラメータ・モデル等価回路モデルcif2cell入出力陰解法熱拡散方程式HiLAPW両対数グラフCrank-Nicolson法連立一次方程式specx.fifort境界条件片対数グラフグラフの分割円周率ヒストグラム不規則局所モーメントGimpシンボル軸ラベル凡例線種トラックボール

最新コメント
リンク

にほんブログ村 その他趣味ブログ 電子工作へ