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カウンター
カテゴリ
ユーザータグ

LTspiceAkaiKKRmachikaneyamaScilabKKRPSoCOPアンプPICCPA強磁性常微分方程式モンテカルロ解析odeトランジスタ状態密度インターフェーススイッチング回路ecaljPDS5022DOS定電流半導体シェルスクリプト乱数レベルシフトHP6632Aブレッドボード分散関係温度解析R6452Aトランジスタ技術I2C可変抵抗反強磁性セミナー数値積分確率論偏微分方程式バンド構造非線形方程式ソルババンドギャップ絶縁熱設計シュミットトリガLEDA/Dコンバータ三端子レギュレータLM358ISO-I2CGW近似カオスフォトカプラマフィンティン半径TL431数値微分PC817Cアナログスイッチ直流動作点解析発振回路USBサーボカレントミラー74HC4053パラメトリック解析LDAbzqltyチョッパアンプ量子力学FFT2ちゃんねるアセンブラBSch開発環境電子負荷ブラべ格子イジング模型補間基本並進ベクトル標準ロジック単振り子キュリー温度繰り返しMaxima状態方程式失敗談相対論スピン軌道相互作用FETランダムウォーク熱伝導六方最密充填構造コバルトewidthTLP621GGAQSGW不規則合金位相図抵抗SMPcygwinラプラス方程式スレーターポーリング曲線gfortranスイッチト・キャパシタ詰め回路TLP552三角波格子比熱TLP521条件分岐LM555MCUNE555QNAPマントルテスタ過渡解析FXA-7020ZRダイヤモンドデータロガーガイガー管自動計測Writer509UPSシュレディンガー方程式ブラウン運動awk差し込みグラフ熱力学平均場近似仮想結晶近似VCAfsolve井戸型ポテンシャルVESTA起電力スーパーセルOpenMP第一原理計算ubuntu固有値問題L10構造OPA2277interp12SC1815fccウィグナーザイツ胞面心立方構造フィルタジバニャン方程式ヒストグラム確率論マテリアルデザインspecx.f等高線正規分布PGAフェルミ面非線型方程式ソルバ初期値固定スピンモーメントスワップ領域ルチル構造リジッドバンド模型edeltquantumESPRESSO岩塩構造BaOSIC二相共存ZnOウルツ鉱構造フォノンデバイ模型c/aノコギリ波全エネルギーFSMTeXgnuplotmultiplotハーフメタルCapSense半金属合金結晶磁気異方性Ubuntu文字列入出力TS-110TS-112疎行列Excel直流解析ヒストグラム円周率不規則局所モーメントトラックボールPC等価回路モデルパラメータ・モデルキーボードRealforce三次元マンデルブロ集合フラクタル化学反応重積分縮退日本語最小二乗法関数フィッティングGimpMAS830LHiLAPW熱拡散方程式両対数グラフナイキスト線図負帰還安定性陰解法Crank-Nicolson法P-10クーロン散乱境界条件連立一次方程式片対数グラフEAGLEPIC16F785LMC662トランスシンボルCK1026線種凡例MBEAACircuitグラフの分割軸ラベルifort

最新コメント
リンク

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