《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 設計應用 > 源碼級和算法級的功耗測試與優化
源碼級和算法級的功耗測試與優化
中電網
廖海艷 范明明
摘要: 軟件設計中,代碼優化是一件非常有意義的事情。優化的本質是對代碼進行等價變換,使變換前后的代碼運行結果相同,但變換后的代碼比變換前的代碼具有更多優越性能。傳統的觀點要求變換后的代碼運行速度較快或占用較少運行資源,或二者兼備。隨著嵌人式系統的快速發展,軟件功耗問題顯得越來越重要,應該將“省電”作為軟件優化的一項技術指標,這樣對軟件優化的評價體系才算完整。值得注意的是,大多數情況下性能和功耗并不矛盾,減少程序執行時間同樣會使程序功耗減少。
關鍵詞: 源碼級 算法 測試
Abstract:
Key words :

軟件設計中,代碼優化是一件非常有意義的事情。優化的本質是對代碼進行等價變換,使變換前后的代碼運行結果相同,但變換后的代碼比變換前的代碼具有更多優越性能。傳統的觀點要求變換后的代碼運行速度較快或占用較少運行資源,或二者兼備。隨著嵌人式系統的快速發展,軟件功耗問題顯得越來越重要,應該將“省電”作為軟件優化的一項技術指標,這樣對軟件優化的評價體系才算完整。值得注意的是,大多數情況下性能和功耗并不矛盾,減少程序執行時間同樣會使程序功耗減少。

在功耗優化這個問題上,研究者普遍比較關注硬件功耗優化,應用各種技術想方設法改進硬件的功耗,比如在芯片制造工藝上采用更精細的納米技術,不斷降低芯片驅動電壓,不斷改變片內系統結構等。事實上,整個系統的運行管理是由軟件體現的。在硬件基礎一定的情況下,只有將軟件系統對能量的損耗降至最小,才能使整個系統工作于最佳狀態。面向功耗的軟件優化方法是當前嵌入式系統低功耗研究領域的熱點。掌握軟件運行時的能量消耗特征、準確獲取能量消耗數據信息,是面向低功耗的軟件優化研究的前提。經過多年的努力,許多學者也提出了關于如何減少軟件功耗的方法。研究表明,軟件優化對降低功耗會有數量級的貢獻。針對同一任務,所選擇的算法不同或采用不同的實現方式,不僅性能有差別,能耗也大不一樣。因此在進行系統優化設計時,除了代碼的規模和執行性能之外,功耗也是一個需要認真考慮的問題。

1軟件功耗優化方法

常用的軟件功耗優化方法大致可分為以下4類:

(1)軟件體系結構級

不存在沒有體系結構的軟件。通常考慮軟件體系結構都是注重軟件的可修改性、可重用性和可靠性等問題,軟件體系結構的好壞直接關系到軟件性能的好壞。而且前,關于軟件體系結構對軟件功耗影響這方面的研究較少,用不同軟件體系結構開發出的軟件功耗會有差異,怎樣選擇合適的軟件體系結構使軟件功耗最小化,將成為軟件低功耗優化的重要研究方向。

(2)源程序級

C語言的源程序級功耗優化指的是實現同一功能的不同語句間的選擇。比如,同樣實現循環功能,有多種選擇(for、while、goto等)。這些語句的功耗會有差異,為了實現低功耗的軟件,應采用功耗最低的語句來完成相同的功能。這就需要對所有語句的功耗進行測試與研究。同時,對C語言不同數據類型操作的功耗進行分析。比如,同樣表示數目,可以用8位int型、16位int型和32位int型。再者,對不同變量的存儲類型功耗也要進行分析,如寄存器變量、靜態變量、自動變量等。總之,在源碼級對軟件功耗進行優化是一個重要的研究方向。

(3)算法級

算法是為解決某個特定問題而定義的無二義性的操作序列,算法復雜性分析就是對算法運行時所消耗的計算機資源作量化的分析和預測。以往,程序設計者關心的資源主要是運行時間和存儲空間。由于能量消耗已成為軟件設計中的關鍵約束條件,因此本文將能耗作為一項重要資源,對算法運行時所消耗的能量進行分析和比較。

(4)編譯級

對于某個硬件來說,執行程序所產生的功耗取決于它的機器代碼,而機器代碼是從源代碼編譯而來的,這就說明編譯過程也影響了硬件的功耗。既然編譯器可以很大程度上控制硬件的運行軌跡,除了性能這一傳統的優化目標之外,編譯器也可以通過適當的調度優化,使得硬件執行某一個程序時的功耗變小。國際上對于低功耗編譯的歷史并不長,是從20世紀90年代初才開始研究的,這方面的文章最早出現于文獻[4-5],Tiwari等人在這些文章中提出了對軟件進行功耗分析的一些基本概念,建立了基本的指令級功耗模型,以486DX為例初步探討了低功耗編譯技術。

本文主要從源程序級和算法級這兩個方面對軟件功耗特征進行測試與分析,并根據分析結果對μC/OS-II進行源碼級的功耗優化。

2源碼級和算法級的功耗測試

測試環境是T.K.Tan等人研發的EMSIM,它是一個基于指令級的嵌入式軟件功耗模擬器,其主要的功耗估算思想是累計函數中所有單條指令的功耗作為該函數的總功耗。嵌入式硬件平臺是ARM公司的StrongARM110。EMSIM測試功耗的單位為函數,即它只能測試某個函數的功耗。在本文的測試中,將要測試的語句放入函數中,測得整個函數的功耗,記為E1,然后測試同樣參數及返回值的空語句函數的功耗,記為E2,最后計算得到語句的功耗為:E=E1-E2。

2.1源碼級的功耗測試

本小節對C語言的源碼級功耗進行測試,測試過程分為以下幾步:

①對每種數據類型的不同操作的功耗進行測試。要測試8位整型、16位整型、32位整型以及32位浮點型和64位浮點型的基本操作功耗。基本操作有:加、減、乘、除、取余、賦值、移位、與、或、非。此處測試的結果與處理器的位數有關,StrongARM110為32位精簡指令集系統,在此基礎上測試的結果如表1所列。

 

從表1可知,對于相同數據類型,加、減、乘、除和取余操作的功耗一樣,與、或、非操作的功耗一樣,而移位功耗最低。對于不同數據類型來說,32位數比16位數的操作功耗低,16位數比8位數的操作功耗低。32位浮點數與32位整形數的操作功耗一樣。在所有數據類型中64位浮點數的操作功耗最高。

測試環境的處理器StrongARM110為32位處理器,對8位數和16位數的處理要考慮字節對齊問題,而對32位就不用考慮該問題。

②對函數、內聯函數和宏定義的功耗進行測試。如表2所列,內聯函數和宏定義的功耗比一般函數的功耗低,CPU周期數及指令數也小。

 

③對相同功能不同實現語句的功耗進行測試。主要針對循環語句、選擇語句(二元和多元)、乘法、移位、除法、移位進行測試,測試結果如表3所列。


 

從表3可知,同樣實現循環功能,for循環的功耗比while、goto的要大,goto語句的功耗明顯最低;二元選擇運算中三目運算比if語句的功耗低,但是只能在單條賦值語句中使用三目運算,在復雜的多條語句的情況下,兩者功耗一樣;多元選擇運算中,switch語句比if…elseif…語句功耗低;寄存器變量的操作比自動變量的操作功耗低近50%,因為處理器從寄存器里直接讀取變量省去了反復從內存讀取變量的過程,從而達到降低功耗的目的。

2.2算法級功耗測試

算法級功耗測試是比源碼級功耗測試更高一層次的測試,不同的算法針對同一問題的考慮方面不同,如可靠性、易用性、時間復雜度、空間復雜度、功耗等。以往對軟件算法的研究著重在性能上面,本文把功耗作為主要考慮對象,研究算法對功耗的影響。為了便于討論,本文提出一具體問題,針對該問題提出5種不同的算法,然后分析這些算法對軟件功耗的影響。

問題描述:對于1字節的變量v,求其二進制表示中1的個數。

算法1:用除法和取余實現。對于二進制操作,除以2,原來的數將會減少1個0,如果在除的過程中有余,就表示當前位置為1。

算法2:使用與&(即移位>>)操作。&操作,把8位數字v與00000001進行與操作,如果結果為1,表示當前8位的最后1位為1,否則為0,然后再將v右移1位,循環進行。

算法3:使用與&操作,僅考慮v中1的個數。

算法4:使用分支操作,直接把0~255的情況都羅列出來,使用switch…case…,即可得到答案。

算法5:使用查表法,將0~255中1的個數直接存儲在數組Array中,v作為數組的下標,則Array[v]就是v中1的個數。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲精品综合| 久久精品国产亚洲5555| 欧美一区国产一区| 亚洲在线一区| 亚洲一区二区三区在线播放| 99国内精品| 日韩视频永久免费观看| 亚洲精品日韩一| 亚洲欧洲在线播放| 91久久久亚洲精品| 亚洲黑丝一区二区| 亚洲激精日韩激精欧美精品| 亚洲电影视频在线| 亚洲国产天堂网精品网站| 亚洲第一天堂av| 亚洲国产视频一区| 亚洲精品国产精品国自产在线| 亚洲激情专区| 99精品视频一区| av成人黄色| 亚洲一二三级电影| 亚洲欧美日韩在线| 欧美一区2区视频在线观看 | 亚洲国产精品一区二区第一页 | 亚洲欧美日韩第一区| 亚洲欧美日本视频在线观看| 欧美在线高清| 亚洲欧洲一区二区三区| 亚洲伦理在线免费看| 一区二区三区色| 欧美一区二区视频97| 久久久一区二区三区| 欧美高清在线一区| 欧美午夜一区| 国产日韩欧美黄色| 亚洲成人在线网| 日韩亚洲欧美成人一区| 午夜精品久久久久久久蜜桃app| 性欧美暴力猛交69hd| 欧美在线视屏| 亚洲美女中文字幕| 亚洲女女做受ⅹxx高潮| 久久精品夜色噜噜亚洲a∨ | 国产亚洲精品aa| 亚洲成色777777女色窝| 亚洲日本黄色| 亚洲欧美国产不卡| 亚洲国产一区在线| 亚洲视频日本| 久久全国免费视频| 欧美日韩综合不卡| 国产在线观看91精品一区| 亚洲激精日韩激精欧美精品| 亚洲一区免费视频| 亚洲精品久久久久久久久久久久久 | 国产精品99久久久久久人| 久久er精品视频| 欧美猛交免费看| 国产视频自拍一区| 亚洲精品免费一区二区三区| 亚洲免费影院| 亚洲免费播放| 久久精品国产一区二区三区| 欧美激情一级片一区二区| 国产精品网站视频| 亚洲激情网站| 欧美专区第一页| 亚洲一区二区三区视频| 久久久久久国产精品mv| 欧美日韩情趣电影| 国户精品久久久久久久久久久不卡| 亚洲精品久久视频| 久久精品国产一区二区电影| 亚洲性图久久| 欧美成人综合在线| 国产日产高清欧美一区二区三区| 亚洲日韩中文字幕在线播放| 欧美中日韩免费视频| 亚洲一区二区三区在线看| 毛片一区二区三区| 国产欧美一区二区精品仙草咪| 亚洲精品久久久久久一区二区| 亚洲电影在线观看| 欧美一区二区三区在线观看视频 | 国产精品乱码一区二区三区| 亚洲高清一二三区| 欧美一区二区三区免费视频| 亚洲一区二区成人在线观看| 免费毛片一区二区三区久久久| 国产婷婷色一区二区三区| 亚洲小少妇裸体bbw| 这里只有精品电影| 欧美风情在线| 在线观看精品视频| 亚洲成在人线av| 久久精品毛片| 国产精品视频大全| 亚洲欧洲在线视频| 亚洲欧洲日本一区二区三区| 久久精品伊人| 国产欧美 在线欧美| 亚洲视频 欧洲视频| 一区二区三区精品视频| 欧美精品 国产精品| 在线精品高清中文字幕| 久久9热精品视频| 久久精品欧洲| 国产主播在线一区| 欧美亚洲视频在线看网址| 午夜精品成人在线视频| 国产精品久久久久久福利一牛影视 | 欧美大片国产精品| 雨宫琴音一区二区在线| 亚洲第一福利在线观看| 久久嫩草精品久久久精品| 国内久久精品| 亚洲国产黄色片| 美脚丝袜一区二区三区在线观看 | 最新国产成人在线观看| 亚洲久久视频| 欧美精品免费看| 日韩视频国产视频| 中日韩美女免费视频网站在线观看| 欧美日韩国产免费| 99re8这里有精品热视频免费| 正在播放亚洲一区| 国产精品久久久久久久9999| 亚洲一区二区在线播放| 午夜精品久久久久久久蜜桃app| 国产精品国产三级国产a| 亚洲午夜国产一区99re久久| 午夜国产精品视频| 国产亚洲精品激情久久| 久久精品亚洲一区| 欧美风情在线| 一区二区三区视频在线观看| 亚洲欧美三级在线| 国产午夜精品一区二区三区欧美| 久久激情网站| 欧美成人免费全部| 日韩视频在线观看| 午夜精品在线观看| 国产一区二区观看| 亚洲欧洲中文日韩久久av乱码| 欧美日韩国产色综合一二三四| 99视频在线精品国自产拍免费观看| 亚洲专区一区二区三区| 国产麻豆一精品一av一免费| 久久se精品一区精品二区| 免费看av成人| 中国成人黄色视屏| 久久国产视频网站| 1024国产精品| 亚洲制服av| 黄色成人av网| 一区二区三区精密机械公司| 国产美女诱惑一区二区| 亚洲国产电影| 欧美日韩一区二区三区四区五区| 亚洲免费在线看| 免费短视频成人日韩| 亚洲免费av电影| 久久久久国产精品一区三寸| 亚洲第一在线| 亚洲欧美日韩一区二区三区在线| 国产一区二区按摩在线观看| 亚洲精品视频免费在线观看| 欧美色123| 久久国产欧美日韩精品| 欧美绝品在线观看成人午夜影视| 亚洲专区国产精品| 欧美电影打屁股sp| 亚洲欧美日韩网| 欧美日本亚洲韩国国产| 午夜国产欧美理论在线播放| 欧美高清视频在线播放| 亚洲综合首页| 欧美激情综合五月色丁香小说| 亚洲专区免费| 欧美精品乱码久久久久久按摩| 午夜天堂精品久久久久| 欧美激情综合网| 欧美一区二区私人影院日本| 欧美日韩高清区| 久久精品亚洲精品| 国产精品私房写真福利视频| 亚洲精品视频在线看| 国产酒店精品激情| 一区二区三区精品视频在线观看 | 国产日韩综合一区二区性色av| 久久精品网址| 国产精品白丝av嫩草影院| 午夜宅男久久久| 欧美日韩午夜剧场| 久久精品亚洲精品国产欧美kt∨| 欧美午夜精品伦理| 亚洲精品久久久蜜桃| 国产视频一区二区在线观看| 亚洲图片在线观看| 亚洲国产精品一区二区三区|