第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

MATLAB parfor慢于 - 出了什么問題?

MATLAB parfor慢于 - 出了什么問題?

繁星淼淼 2019-08-28 10:32:01
MATLAB parfor慢于 - 出了什么問題?我正在處理的代碼有如下循環(huán):bistar = zeros(numdims,numcases); parfor hh=1:nt          bistar = bistar +  A(:,:,hh)*data(:,:,hh+1)' ;end小nt(10)。計時后,它實際上比使用常規(guī)循環(huán)慢100倍!我知道parfor可以做并行總和,所以我不確定為什么這不起作用。我跑matlabpool在運行我的代碼之前使用開箱即用的配置。我對matlab比較陌生,剛開始使用并行功能,所以請不要認為我沒有做一些愚蠢的事情。謝謝!PS:我在四核上運行代碼,所以我希望看到一些改進。
查看完整描述

3 回答

?
茅侃侃

TA貢獻1842條經(jīng)驗 獲得超21個贊

對小的值進行分區(qū)和分組結果(分割工作和從多個線程/核心收集結果的開銷)很高nt。這是正常的,您不會為可以在簡單循環(huán)中快速執(zhí)行的簡單任務分區(qū)數(shù)據(jù)。

始終在循環(huán)內執(zhí)行一些具有挑戰(zhàn)性的東西,這值得分區(qū)開銷。這是對并行編程的一個很好的介紹。

線程來自線程池,因此創(chuàng)建線程的開銷不應該存在。但是為了創(chuàng)建部分結果必須創(chuàng)建大小的n矩陣,bistar計算所有部分結果,然后必須添加所有這些部分結果(重新組合)。在直接循環(huán)中,這很有可能就地完成,不進行分配。

幫助中的完整聲明(感謝您的鏈接):

如果計算f,g和h的時間很長,則parfor將明顯快于相應的for語句,即使n相對較小。

所以你看他們的意思與我的意思完全相同,如果你在循環(huán)中做的事情足夠復雜/耗時,那么小n值的開銷只值得努力。


查看完整回答
反對 回復 2019-08-28
?
largeQ

TA貢獻2039條經(jīng)驗 獲得超8個贊

除了由于通信開銷導致的性能不佳(參見其他答案)之外,還有另一個原因是parfor在這種情況下不使用。parfor在這種情況下完成的所有內容都使用內置多線程。假設所有工作人員都在同一臺PC上運行,那么沒有任何優(yōu)勢,因為單個呼叫已經(jīng)使用了處理器的所有核心。


查看完整回答
反對 回復 2019-08-28
  • 3 回答
  • 0 關注
  • 1755 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號