硬件強(qiáng)悍,算法是否已經(jīng)不再重要?

作者:樂購科技 來源: 2013-10-13 18:28:02 閱讀 我要評(píng)論 直達(dá)商品

本文翻譯自程序員的問答社區(qū) stackexchange.com 上的一個(gè)提問:追求算法(特別是普遍高效的)已經(jīng)不再重要。因?yàn)楝F(xiàn)在計(jì)算機(jī)硬件的成本,比起以前已經(jīng)很便宜,是否意味著算法和改進(jìn)算法的技能已經(jīng)不那么重要了?大部分時(shí)候,只要?jiǎng)e寫出一個(gè)死循環(huán)就行了。但當(dāng)你擁有了強(qiáng)悍的硬件,是不是意味著爛代碼也不是什么大問題?

Pavel Zaichenkov 11 票

我特別喜歡《算法導(dǎo)論(Introduction to Algorithms)》一書中的一個(gè)例子,以摧枯拉朽地方法說明了算法性能的重要性:

我們來比較兩種排序算法:「插入排序」和 「歸并排序」。他們的算法復(fù)雜度分別是 O(n2)=c1n2 和 O(nlogn)=c2n lg n。一般情況下,歸并排序算法有一個(gè)更大的常數(shù)因子,所以我們假設(shè) c1 < c 2。

為了回答你的問題,我們在一臺(tái)時(shí)髦的高速電腦 A 上跑「插入排序」算法,和一臺(tái)跑「歸并排序」算法的老土電腦 B 做對比。

我們假設(shè):

- 輸入的問題數(shù)據(jù)量為 1,000萬個(gè)數(shù)字:n=107;

- 電腦 A 一秒鐘可以執(zhí)行 1010 次運(yùn)算指令 ( ~ 10GHz );

- 電腦 B 一秒鐘只能執(zhí)行 107 次運(yùn)算指令 ( ~ 10MHz );

- 常數(shù)系數(shù) C1 = 2 (有點(diǎn)夸張),C2 = 50 (比現(xiàn)實(shí)中稍微小了一點(diǎn))

于是在以上假設(shè)下,我們得到如下結(jié)果:

牛X電腦A:

2·(107)2 次運(yùn)算1010 次運(yùn)算/秒=2·104 秒

IE爪機(jī)用戶:

硬件強(qiáng)悍,算法是否已經(jīng)不再重要

土鱉電腦 B :

50·107lg107 次運(yùn)算107 次運(yùn)算/秒≈1163 秒

IE爪機(jī)蛋友:

硬件強(qiáng)悍,算法是否已經(jīng)不再重要

所以你看,那部慢了1000倍的電腦,干活速度是快的那臺(tái)的17倍。而且在現(xiàn)實(shí)中,歸并算法有更高的效率,特別是隨計(jì)算量增加的而更加明顯。我希望這個(gè)答案能回答你的問題。

然而,這還不光是算法復(fù)雜程度的問題。在今天,單單想通過提高CPU主頻來獲得很明顯的性能提升是不可能的。我們需要改良算法在多核CPU架構(gòu)下的表現(xiàn)。而且這是個(gè)不太好對付的問題,因?yàn)殡S著內(nèi)核數(shù)量的增加,其他方面的開銷正在成為性能的障礙(比如內(nèi)存訪問調(diào)度控制)。所以,堆硬件很難獲得線性的性能增長。

總而言之,當(dāng)下對于算法的改進(jìn)和以前一樣重要,因?yàn)樵俣嗟腃PU內(nèi)核和再高的主頻都無法給你帶來和算法改進(jìn)一樣的回報(bào)。

Yuval Filmus 11票

正相反,隨著硬件越來越便宜,新的運(yùn)算需求正在增加。

首先,我們現(xiàn)在所需要面對和處理的數(shù)據(jù)正海量增加。這就要談到「準(zhǔn)線性算法(quasilinear time algorithms)」和大數(shù)據(jù)研究的話題。比如想想搜索引擎的算法設(shè)計(jì) —— 它們必須要處理巨量的請求,在茫茫數(shù)據(jù)中,快速地找到,返回結(jié)果,算法的效率比以前更加重要。

其次,「機(jī)器學(xué)習(xí)(machine learning)」的勢頭正猛,這就是一個(gè)算法的世界(可能和你大學(xué)本科學(xué)的不太一樣)。這個(gè)領(lǐng)域充滿荊棘,但也正是新的算法誕生的地方。

再者,「分布式計(jì)算」已經(jīng)變得非常重要,現(xiàn)在我們在CPU主頻提升上已經(jīng)遇到了瓶頸。如今計(jì)算機(jī)性能只能通過并行計(jì)算來獲得提升,這也是算法發(fā)揮力量的地方。

最后,為了平衡 CPU/GPU 性能的突飛猛進(jìn),大量虛擬機(jī)技術(shù)被用來抵御安全漏洞的威脅,操作系統(tǒng)花費(fèi)更多的時(shí)間和精力來處理安全威脅和警報(bào),余下的CPU時(shí)間才能真正用來做正經(jīng)事,這讓你的程序性能表現(xiàn)有所下降。特別是還有很耗費(fèi)CPU資源的視頻壓縮/解壓縮計(jì)算,雖然計(jì)算機(jī)硬件性能與日俱增,但使用效率并沒有同樣提高。

總結(jié)一下,對于大數(shù)據(jù)處理、人工智能領(lǐng)域、分布式計(jì)算來說,算法的改進(jìn)是不可或缺的;CPU 的運(yùn)算能力在脫韁野馬一般增長的需求面前,因?yàn)楦鞣N原因沒有得到有效的利用,算法的重要性離死還遠(yuǎn)著呢。

[via stackexchange]


  推薦閱讀

  諾基亞Lumia 620獲Mobile Choice雜志年度最具價(jià)值手機(jī)稱號(hào)

《Mobile Choice》是英國最權(quán)威的一本手機(jī)雜志,每年這本雜志都會(huì)評(píng)選>>>詳細(xì)閱讀


本文標(biāo)題:硬件強(qiáng)悍,算法是否已經(jīng)不再重要?

地址:http://m.sdlzkt.com/a/05/20131013/290454.html

樂購科技部分新聞及文章轉(zhuǎn)載自互聯(lián)網(wǎng),供讀者交流和學(xué)習(xí),若有涉及作者版權(quán)等問題請及時(shí)與我們聯(lián)系,以便更正、刪除或按規(guī)定辦理。感謝所有提供資訊的網(wǎng)站,歡迎各類媒體與樂購科技進(jìn)行文章共享合作。

網(wǎng)友點(diǎn)評(píng)
我的評(píng)論: 人參與評(píng)論
驗(yàn)證碼: 匿名回答
網(wǎng)友評(píng)論(點(diǎn)擊查看更多條評(píng)論)
友情提示: 登錄后發(fā)表評(píng)論,可以直接從評(píng)論中的用戶名進(jìn)入您的個(gè)人空間,讓更多網(wǎng)友認(rèn)識(shí)您。
自媒體專欄

評(píng)論

熱度

主站蜘蛛池模板: 亚洲国产精品成人精品软件| 国产成人精品午夜福利在线播放| 97成人碰碰久久人人超级碰OO | 四虎www成人影院| 免费看一级淫片成人| 日韩国产欧美成人一区二区影院 | 成人欧美一区二区三区小说| 国产成人精品综合| 亚洲av成人综合网| 国产精品成人va| 日韩成人无码一区二区三区| 国产成人免费网站| 成人毛片一区二区| 亚洲国产成人va在线观看网址 | 欧美国产成人在线| 亚洲国产成人精品无码区在线观看 | 精品无码成人片一区二区98| 国产91成人精品亚洲精品| 成人国产在线24小时播放视频| 国产亚洲欧美成人久久片| 成人午夜亚洲精品无码网站| 无码国产成人午夜电影在线观看| 亚洲成人动漫在线观看| 国产成人爱片免费观看视频| 成人亚洲欧美日韩在线| 日韩精品成人一区二区三区| 色综合天天综合网国产成人网 | 国产成人精品久久免费动漫| 成人免费看吃奶视频网站| 欧美成人四级剧情在线播放| 亚洲国产成人久久一区www| 亚洲精品成人a在线观看| 国产乱色精品成人免费视频| 午夜亚洲国产成人不卡在线| 国产成人无码AⅤ片在线观看 | 国产成人亚洲精品大帝| 国产成人无码av在线播放不卡 | 亚洲成人www| 亚洲精品亚洲人成人网| 午夜电影成人福利| 亚洲欧美成人网|