《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > ARM的除法運算優化策略
ARM的除法運算優化策略
摘要: 在嵌入式軟件編程中,為了節省CPU運行時間,應盡可能避免使用除法。對環形緩沖區的處理可以不用除法。如果不能避免除法運算,那么應盡可能使用除法程序同時產生商n/d和余數n%d的好處。對于重復對一除數d的除法.預先計算好s=(2k一1)/d,用乘以s的2k位乘法來代替除以d的k位無符號整數除法,可大大減少由于直接使用除法操作引入的指令周期數。
Abstract:
Key words :

  與傳統的4/8位單片機相比,ARM的性能和處理能力是遙遙領先的。但與之相應,ARM的系統設計復雜度和難度,較之傳統的設計方法也大大提升了,同時也大大拓展了針對ARM芯片特性進行優化的空間,例如針對指令流水線的優化、針對寄存器分配進行的優化等。

  ARM在硬件上不支持除法指令,編譯器是通過調用C庫函數來實現除法運算的,有許多不同類型的除法程序來適應不同的除數和被除數。但直接利用C庫函數中的標準整數除法程序,根據執行情況和輸入操作數的范圍,要花費20~100個周期,消耗較多的軟件運行時間。在實時嵌入式應用中,對時間參數較為敏感,故可以考慮如何優化避免除法消耗過多的CPU運行時間。

  除法和模運算(/和%)執行起來比較慢,所以應盡量避免使用。但是,除數是常數的除法運算和用同一個除數的重復除法,執行效率會比較高。在ARM中,可以利用單條MUL指令實現乘法操作。本文將闡述如何用乘法運算代替除法運算,以及如何使除法的次數最少化。

  1 避免除法運算

  在非嵌入式領域,因為CPU運算速度快、存儲器容量大,除法操作通常都是不加考慮直接使用的。但在嵌入式領域,首先需要考慮的是這些除法操作是否是必須的。以對環形緩沖區操作為例,經常要用到除法,其實完全可以避免這些除法運算。

  

 

  假定有一個buffer_size大小的環形緩沖區,如圖1所示,offset指定目前所在的位置。通過increment字節來增加offset的值,一般是這樣寫的:

  0ffset=(Offset+increment)%buffer_size;

  效率更高的寫法是:

  offset+=increment;

  if(offset>=buffer_size){

  offset-=buffer_size;

  }

  第一種寫法要花費50個周期,而第二種因為沒有除法運算,只須花費3個周期。這里假定increment

  如果不能避免除法運算,那么就應盡量使除數和被除數是無符號的整數。有符號的除法程序執行起來更加慢,因為它們先要取得除數和被除數的絕對值,再調用無符號除法運算,最后再確定結果的符號。

  2 充分利用商和余數

  許多C語言庫中的除法函數返回商和余數。換句話說,每一個除法運算,余數是可以無償得到的,反之亦然。例如,要在屏幕緩沖區找到偏移量為offset的屏幕位置(x,y),可以這樣寫:

  typeclef struct{

  int x;

  int y;

  }point;

  point getxy_v1(unsigned int offset,unsigned int bytes_per_line){

  point p;

  p.y=offset/lt)ytes_per_line;

  p.x=offset - p.y* bytes_per_line;

  return p;

  }

  這里,似乎對p.x使用減法和乘法,少了一次除法運算;但是,實際上使用模運算或者取余操作效率更高,對getxy_v1改進如下:

  point getxy_v2(unsigned int offset,unsigned int bytes_per_line){

  point P;

  P.x=offset%bytes_per_1ine;

  P.y=offset/bytes_per_line;

  return P;

  }

  從下面編譯器的輸出結果可以看到,只有一次除法調用。實際上,這個程序要比前面的getxy_vl少4條指令(注意,并不是對所有的編譯器和C庫都有這樣的結果)。

  getxy_v2

  STMFD r13!,{r4,r14};保存r4,lr人堆棧

  MOV r4,r0 ;賦值后r4保存的為點P基址

  MOV r0,r2 ;r0=bytes_per_line

  BL rt_udiv ;調用無符號除法例程

 ?。╮0.;r1)=(rl/r0,rl%r0)

  STR r0,[r4,#4] ;P.y=offset/bytes_per_line

  STR rl,[r4,#o] ;P.x=offset%bytes_per_line

  LDMFD r13!,(r4,pc);恢復上下文,返回

  3 把除法轉換為乘法

  在程序中,同一個除數的除法經常會出現很多次。在前面的例子中,bytes_per_line的值在整個程序中都是固定不變的。又如3到2笛卡爾坐標變換,其中就使用了同一個除數兩次:

 ?。▁,Y,x)→(x/z,y/z)

  這種情況下,使用cache指令中的值1/z,并使用1/z的乘法來代替除法運算,效率會更高。另外,要盡可能使用int類型的運算,避免使用浮點運算。

  下面將更加偏重于從數學和理論的角度分析,把重復除法轉換成乘法運算。

  下面來區分精確數學意義上的除法和整型除法運算:

  n/d,即整數n被分成整數d份,結果趨向于O(與C語言相同);

  n%d,即n被d除之后的余數,就是n--d(n/d);

  n/d=n·d-1,即真正數學意義上的n被d除。

  當使用整型除法時,最容易估算d-1值的方法是計算232/d。然后,就可以估算n/d為:

  (n(232/d))/232 (1)

  在執行n的乘法時,需要精確到64位。對于這種方法,會出現如下問題:

  為了計算232/d,由于一個unsigned int類型的數據放不下232,編譯器要使用64位long long類型的數,而且必須指定除法為(1 ull<<32)/d。這種64位的除法比32位的除法執行起來要慢得多。

  如果d碰巧是1,那么232/d就不再適合于un—signed int數據類型。

  上面的做法似乎很好,而且解決了這兩個問題。那么,再來看一下用(232一1)/d代替232/d。 令

  s=0xffffffff ul/d (2)

  

  以上n/d-2,q,n/d+1為整數值,所以可得q=n/d或q=(n/d)一1,即初步估計的結果q與正確值n/d有可能存在偏差1。可以發現,通過計算余數r=n—q·d(O≤r<2d)是比較容易的。下面的代碼糾正了這個結果:

  r=n--q*d;/*初步估計結果余數r的范圍為O≤r<2d*/

  if(r>=d){/*若需要校正*/

  r-=d;/*校正r,使O≤r

  n++;/*相應商加1進行校正*/

  } /*得正確結果q=n/d和r=n%d*/

  下面給出一個實例,用上面的算法完成了N個元素的數組被d除。首先,計算上面所說的s值,然后用乘以5來代替每個被d除的除法。64位的乘是很容易實現的,因為ARM中有一條指令UMULL,可以進行2個32位數相乘,給出一個64位的結果。

  void scale(

  unsigned int*dest; /*目的數據*/

  unsigned int*src; /*源數據*/

  unsignedInt d; /*分母d*/

  urlslglaedInt N;) /*數據長度*/

  {

  unsigned int s=0xFFFFFFFFu/d;

  do{

  unsigned int n,q,r;

  n=*(src++);

  q=(urtslgrted int)(((unsined tong long)n*s)>>32);

  r=n*d;

  if(r>=d){ /*若需要對商進行校正*/

  q++;

  }

  *(dest++)=q;

  }while(--N);

  }

  這里假定除數和被除數都是32位的無符號整數。當然,使用32位乘法進行16位的無符號數計算,或者使用1 28位乘法進行64位數計算,運算規則是一樣的??梢詾樘囟ǖ臄祿x擇最窄的運算寬度。如果數據是16位的,那么就設置s=(216一1)/d,然后用標準的整型乘法來求值q。

  4 結論

  在嵌入式軟件編程中,為了節省CPU運行時間,應盡可能避免使用除法。對環形緩沖區的處理可以不用除法。如果不能避免除法運算,那么應盡可能使用除法程序同時產生商n/d和余數n%d的好處。對于重復對一除數d的除法.預先計算好s=(2k一1)/d,用乘以s的2k位乘法來代替除以d的k位無符號整數除法,可大大減少由于直接使用除法操作引入的指令周期數。

此內容為AET網站原創,未經授權禁止轉載。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          欧美日韩视频一区二区| 亚洲欧美日韩精品久久亚洲区| 亚洲狼人精品一区二区三区| 国产婷婷一区二区| 亚洲欧洲三级| 亚洲高清毛片| 亚洲综合成人在线| 国产精品午夜视频| 久久视频国产精品免费视频在线| 一本色道久久88综合亚洲精品ⅰ| 亚洲国内欧美| 欧美激情一区二区三区在线视频观看| 欧美日韩精品国产| 久久久噜噜噜久久中文字幕色伊伊| 国产精品国产三级国产专区53| 亚洲狼人综合| 在线观看的日韩av| 亚洲男女自偷自拍图片另类| 国产亚洲精品一区二区| 亚洲大片精品永久免费| 在线日韩电影| 亚洲黄色片网站| 夜夜爽av福利精品导航| 久久av免费一区| 欧美综合二区| 国产一区二区成人久久免费影院| 一区二区三区高清不卡| 亚洲男女自偷自拍图片另类| 老牛影视一区二区三区| 韩国av一区二区三区在线观看| 欧美一区二区三区日韩视频| 国产精品自拍视频| 欧美激情成人在线视频| 欧美大尺度在线观看| 一本色道久久综合精品竹菊| 国产美女高潮久久白浆| 国产精品色午夜在线观看| 欧美一级视频精品观看| 新狼窝色av性久久久久久| 99re这里只有精品6| 免费视频最近日韩| 欧美一区激情视频在线观看| 亚洲乱码国产乱码精品精| 久久久久久亚洲精品杨幂换脸| 亚洲午夜高清视频| 国产欧美一区二区三区沐欲| 欧美激情中文字幕一区二区| 国产人久久人人人人爽| 亚洲欧洲三级电影| 欧美性色视频在线| 性欧美1819性猛交| 亚洲精品欧美日韩| 久久久久综合一区二区三区| 欧美电影在线免费观看网站| 欧美日韩亚洲91| 国产一区在线免费观看| 午夜精品一区二区在线观看| 久久亚洲综合色一区二区三区| 性欧美精品高清| 亚洲韩日在线| 欧美网站大全在线观看| 久久全球大尺度高清视频| 欧美午夜激情视频| 亚洲国产高清视频| 国产精品国产三级国产aⅴ浪潮| 夜夜夜久久久| 国内精品视频在线播放| 午夜精品三级视频福利| 精品999久久久| 欧美影院精品一区| 欧美激情在线狂野欧美精品| 狠狠色综合网| 性伦欧美刺激片在线观看| 欧美色欧美亚洲高清在线视频| 美女尤物久久精品| 亚洲激情校园春色| 最新国产精品拍自在线播放| 久久精品在线观看| 欧美日韩一区国产| 亚洲视频在线一区| 欧美三级在线| 亚洲新中文字幕| 日韩视频精品| 亚洲风情在线资源站| 亚洲国产一区二区三区a毛片| 久久国内精品自在自线400部| 国产精品欧美一区二区三区奶水| 久久久最新网址| 在线精品视频在线观看高清| 午夜精品一区二区三区在线播放| 免费在线观看成人av| 欧美成人午夜激情视频| 亚洲男女毛片无遮挡| 媚黑女一区二区| 国产亚洲一级高清| 中文精品一区二区三区| 久久久噜噜噜久久| 国产偷国产偷精品高清尤物| 久久亚洲综合网| 国产精品大片免费观看| 亚洲美女福利视频网站| 国产欧美欧美| 国产在线精品一区二区夜色| 欧美日韩午夜激情| 欧美久久久久久久久久| 国内成人精品视频| 免费亚洲一区二区| 欧美大片在线影院| 激情综合色综合久久综合| 欧美高清在线一区| 99国产精品99久久久久久粉嫩| 一本久久精品一区二区| 久久激情网站| 亚洲最新在线视频| 国产精品久99| 欧美一级理论片| 国产欧美精品| 欧美一级成年大片在线观看| 亚洲欧洲日本专区| 欧美日韩一级视频| 国产精品免费网站| 蜜臀va亚洲va欧美va天堂| 国产精品高潮呻吟久久av无限| 蜜桃精品久久久久久久免费影院| 欧美三级视频在线播放| 老妇喷水一区二区三区| 国产精品久久一区二区三区| 亚洲欧美国产精品va在线观看| 欧美国产日韩a欧美在线观看| 亚洲字幕在线观看| 蜜桃av噜噜一区| 久久国产毛片| 洋洋av久久久久久久一区| 亚洲一区二区四区| 欧美1区视频| 亚洲日本欧美日韩高观看| 欧美精品xxxxbbbb| 欧美一区二区三区四区在线| 久久久亚洲高清| 欧美精品久久久久久久| 欧美精品999| 亚洲欧美一区二区三区久久| 欧美日韩国产首页在线观看| 亚洲精选在线| 欧美福利影院| 国产欧美丝祙| 欧美日韩国产区一| 亚洲国产日韩一级| 在线观看欧美精品| 亚洲高清久久| 欧美乱人伦中文字幕在线| 欧美一区二区免费视频| 国产精品一区二区你懂的| 亚洲主播在线播放| 亚洲一区激情| 欧美一区日本一区韩国一区| 欧美激情视频一区二区三区在线播放| 亚洲午夜在线观看视频在线| 国产拍揄自揄精品视频麻豆| 亚洲免费中文字幕| 久久久精品国产99久久精品芒果| 亚洲一级特黄| 国产一区二区高清视频| 香蕉久久夜色精品国产| 亚洲欧美视频一区二区三区| 亚洲人成人一区二区三区| 日韩天天综合| 国产午夜精品在线观看| 欧美国产欧美亚洲国产日韩mv天天看完整| 9i看片成人免费高清| 久热精品视频在线免费观看| 久久久91精品国产| 久久综合色播五月| 亚洲人成啪啪网站| 9色国产精品| 国产伦精品一区二区三区视频黑人| 久久精品人人做人人爽| 欧美先锋影音| 国产精品人人做人人爽| 在线观看一区| 国产精品久久久久9999高清| 国产精品久久久一本精品| 亚洲欧洲另类国产综合| 欧美三级在线| 欧美视频在线免费看| 亚洲精品一区二区三区樱花| 亚洲精品国产欧美| 欧美激情一区三区| 久久久国产精品一区二区三区| 国产日产欧产精品推荐色| 国产欧美日韩专区发布| 欧美日韩精品久久| 一区二区久久久久久| 欧美日韩免费观看一区| 黄色av成人| 99热在这里有精品免费| 麻豆av一区二区三区| 国产精品久久久久999| 免费国产一区二区| 国产精品va在线播放我和闺蜜| 亚洲韩国一区二区三区| 欧美成人精品h版在线观看| 国产精品综合不卡av| 一区二区在线视频| 亚洲一区视频在线观看视频| 亚洲国产裸拍裸体视频在线观看乱了| 欧美日本免费一区二区三区| 亚洲砖区区免费| 日韩一区二区精品在线观看| 亚洲最新中文字幕| 亚洲视频一区二区免费在线观看| 欧美日韩日日夜夜| 久久久免费观看视频| 欧美激情黄色片| 欧美精品免费播放| 亚洲人成网站999久久久综合| 欧美国产另类| 韩国美女久久| 欧美日韩精品一区二区在线播放| 亚洲天堂网站在线观看视频| 国产欧美日韩综合一区在线观看| 激情成人中文字幕| 欧美亚洲成人精品| 欧美精品一区二区三区一线天视频| 国产日韩一区二区三区| 狠狠色综合色综合网络| 亚洲欧美日韩国产中文| 午夜精品影院在线观看| 国产免费亚洲高清| 亚洲人成在线播放网站岛国| 欧美国产欧美综合| 欧美一区二区三区四区在线观看地址| 久久蜜桃资源一区二区老牛| 激情欧美日韩| 亚洲一区二区三区四区中文| 宅男噜噜噜66一区二区| 国产精品女主播在线观看| 免费在线观看精品| 蜜臀久久久99精品久久久久久| 亚洲男人的天堂在线| 亚洲蜜桃精久久久久久久| 国产一区二区三区奇米久涩| 一区二区精品| 亚洲久久视频| 欧美日韩激情小视频| 91久久精品一区二区三区| 欧美日韩情趣电影| 欧美理论在线播放| 美女视频网站黄色亚洲| 国产精品久久毛片a| 国产人成精品一区二区三| 国产美女搞久久| 欧美精选午夜久久久乱码6080| 麻豆精品传媒视频| 亚洲福利免费| 国产精品久久久久久久免费软件| 激情成人在线视频| 翔田千里一区二区| 亚洲丰满少妇videoshd| 国产精品久久久久久久久久尿| 久久av一区二区三区亚洲| 日韩视频一区二区三区在线播放免费观看| 久久久国产精品一区二区三区| 国产精自产拍久久久久久| 一区二区三区久久精品| 亚洲自拍电影| 欧美亚洲自偷自偷| 国产精品成人久久久久| 激情成人av| 国产日韩一区二区三区在线播放| 国产日韩欧美中文| 亚洲欧美日韩在线一区| 精品成人国产在线观看男人呻吟| 欧美三级不卡| 午夜国产精品视频免费体验区| 亚洲第一视频网站| 欧美视频精品在线观看| 狠狠色丁香久久综合频道| 国产欧美一级| 国产精品乱码妇女bbbb| 亚洲欧美影音先锋| 伊人成人在线视频| 久久婷婷久久| 国产精品一区二区三区四区| 亚洲高清视频在线| 在线日韩中文字幕| 国产精品福利在线观看网址| 午夜精品免费视频| 亚洲一区二区伦理| 亚洲婷婷综合色高清在线| 国产精品视频在线观看| 国产午夜精品一区理论片飘花| 欧美网站在线| 国产噜噜噜噜噜久久久久久久久| 亚洲激情校园春色| 好男人免费精品视频| 欧美午夜精品久久久久久浪潮| 欧美一级黄色网| 亚洲欧美日韩精品综合在线观看| 怡红院精品视频| 国产精品影视天天线| 亚洲综合不卡| 欧美日本国产一区| 日韩亚洲在线观看| 亚洲精品美女在线| 欧美成人精品一区二区| 国产精品theporn88| 亚洲字幕在线观看| 国产日产欧美一区| 国产三级精品三级| 久久女同互慰一区二区三区| 亚洲午夜在线观看| 国产人妖伪娘一区91| 欧美成人视屏| 国产偷久久久精品专区| 久久久久久香蕉网| 国产精品入口麻豆原神| 国产在线乱码一区二区三区| 国产精品vvv| 亚洲在线视频网站| 国产人成精品一区二区三| 国内精品久久国产| 欧美日韩成人综合在线一区二区| 国产精品乱人伦中文| 伊人精品在线| 久久久久久高潮国产精品视| 久久人人97超碰国产公开结果| 欧美伊人久久大香线蕉综合69|