基于多核的多線程算法并行優(yōu)化.pdf_第1頁
已閱讀1頁,還剩57頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、在多核處理器不斷普及的今天,并行軟件開發(fā)技術(shù)的加速發(fā)展已成為關(guān)鍵。多核處理器既促進了并行軟件開發(fā)技術(shù)的發(fā)展,也依賴于并行軟件開發(fā)技術(shù)。但是軟件并行化的發(fā)展需要克服重重困難。當今在使用的很大部分軟件還是串行思想開發(fā)的產(chǎn)物,我們需要從根本軟件開發(fā)理念上改變,進行軟件并行化。目前已經(jīng)出現(xiàn)了多種并行編程模型,主要有共享存儲編程模型、消息傳遞模型和分布式存儲模型。多線程并行編程就基于共享存儲的編程模型。
   矩陣相乘算法的重要性不言而喻

2、,在很多科學計算和工程方面應(yīng)用極廣。因此,對矩陣相乘算法做了實驗,分別采用了Win32多線程API、OpenMP及C#多線程對其進行實現(xiàn)。在此過程中,歸結(jié)了這幾種多線程編程方法的特性和優(yōu)缺點。Win32多線程API具有性能優(yōu),可以顯性操作線程的優(yōu)點,但是實現(xiàn)相對復雜,對軟件開發(fā)人員要求高。OpenMP實現(xiàn)簡單,適合于優(yōu)化循環(huán)。但是性能相對Win32多線程API稍微遜色。而C#在語言級提供了對多線程的支持,但是由于其基于虛擬機的機制導致其

3、性能還不如前兩者,實現(xiàn)難度介于兩者之間,也可顯性操作線程。本實驗結(jié)果有助于在開發(fā)時對編程方法的選擇。
   排序算法是常用而且對其本身性能要求很高的算法。在前面實驗研究的基礎(chǔ)上,提出了一種排序組合算法,并且對后半部分的歸并排序進行了改進。改進的方法采用了多線程的思想,將原來單線程執(zhí)行的歸并過程進化成可以同時執(zhí)行的兩個線程。兩個線程分別從已經(jīng)有序的兩個序列的最大值端和最小值端同時進行比較,將相應(yīng)的結(jié)果放在新序列的相應(yīng)端。兩個線程都

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論