• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Jarod 的學(xué)習(xí)筆記

            統(tǒng)計(jì)

            留言簿(1)

            閱讀排行榜

            評論排行榜

            又是未完成的東西

            原本打算給實(shí)驗(yàn)室的朋友們介紹一下我最新的研究結(jié)果,如何高效地實(shí)現(xiàn)矩陣運(yùn)算。結(jié)果今晚的學(xué)長打擊了我,他們編程不多。我說的這些,他們能聽懂我已經(jīng)做好的PPT的一半就不錯(cuò)了。還沒完成的部分由于有范型的東西,估計(jì)他們就完全不明白了。編程語言也講個(gè)基礎(chǔ)的,C++非一日兩日就能熟悉的。唉。嘆惜我研究半天的東西沒有人懂啊~還好,放在我的blog里,與更多的朋友共享吧。

            以下PPT講述了一般情況下,編寫矩陣運(yùn)算遇到的問題,特別是性能問題。主要舉例說明了實(shí)現(xiàn)加法運(yùn)算會(huì)產(chǎn)生的問題,如以下的代碼,實(shí)際上是非常影響性能的。詳細(xì)的請看PPT。

            Matrix?operator? + ?( const ?Matrix? & ?a,? const ?Matrix? & ?b)? {
            ???
            int ?M? = ?a.getM(),?N? = ?a.getN();
            ???Matrix?result(M,N);
            ???
            for ?( int ?i = 0 ;i < M;i ++ )? {
            ??????
            for ?( int ?j = 0 ;j < N;j ++ )? {
            ??????????result(i,j)?
            = ?A(i,j)? + ?B(i,j);
            ??????}

            ???}

            ???
            return ?result;
            }



            矩陣運(yùn)算PPT

            posted on 2007-03-27 00:14 Jarod-Yin 閱讀(956) 評論(13)  編輯 收藏 引用

            評論

            # re: 又是未完成的東西 2007-03-27 08:45 萬連文

            你不介紹一下功能 解決問題,誰知道是那方面。  回復(fù)  更多評論   

            # re: 又是未完成的東西 2007-03-27 09:47 Rocky

            如果要講究效率的話,還是用你所說的原始的方法,然后把整個(gè)算法封裝起來的好。如果打算用C++,從出發(fā)點(diǎn)上就是要放棄一定的效率的,還是用運(yùn)算符重載增加可讀性比較好一點(diǎn)。建議去讀一讀STL、boost等類庫源代碼,學(xué)習(xí)一下如何既照顧效率,又照顧封裝之后的可用性。  回復(fù)  更多評論   

            # re: 又是未完成的東西[未登錄] 2007-03-27 09:58 炙熱的太陽

            太過于古板,你給他們講個(gè)故事,做個(gè)例子,生動(dòng)一點(diǎn),肯定有人會(huì)聽得  回復(fù)  更多評論   

            # re: 又是未完成的東西 2007-03-27 10:34 王一偉

            hehe 不錯(cuò),可以做一些測試  回復(fù)  更多評論   

            # re: 又是未完成的東西 2007-03-27 10:35 沐楓_

            怎么只有個(gè)開頭。  回復(fù)  更多評論   

            # re: 又是未完成的東西 2007-03-27 10:37 沐楓_

            再說了,上面的代碼未必很影響性能,如果編譯器好的話。  回復(fù)  更多評論   

            # re: 又是未完成的東西 2007-03-27 12:15 chenger

            還是原始的辦法好
            搞科學(xué)計(jì)算的,就不要太講究什么封裝,用類都顯得多余
            其實(shí)更重要的問題可能是比較底層的,比如緩存命中等等。至于用模板技術(shù),已經(jīng)有bliz++(是不是叫這個(gè)名?)等庫在先,不如去研究研究。其實(shí)如果用模板,可讀性更差,除非對template了解很深入,否則幾乎看不懂  回復(fù)  更多評論   

            # re: 又是未完成的東西 2007-03-27 12:59 Jarod-Yin

            謝謝各位的關(guān)注。
            萬連文:根據(jù)你的建議,我多寫了一些說明
            rockey:解決方法當(dāng)然也是用了重載。
            王一偉 :我確實(shí)做過反匯編了
            沐楓_ :我不知道什么編譯器會(huì)做這些優(yōu)化,你能否介紹一下?
            chenger:就是bliz,我就是學(xué)習(xí)bliz得到的結(jié)果  回復(fù)  更多評論   

            # re: 又是未完成的東西[未登錄] 2007-03-27 13:46 cc

            [url=http://guises.eguo.com/user1/uutv8806/archives/2007/26.html]Jewelry Wholesale[/url]  回復(fù)  更多評論   

            # re: 又是未完成的東西[未登錄] 2007-03-27 13:46 cc

            <a href=http://www.chengan.cn/my/vip/422/archives/2007/743.html>Jewelry Wholesale</a>  回復(fù)  更多評論   

            # re: 又是未完成的東西[未登錄] 2007-03-27 13:46 cc

            wholesale jewelry jewelry jewelry Making Handcrafted jewelry
            wholesale silver jewelry
            Jewelry Wholesa, China Jewelry Wholesale, pearl jewelry wholesale, wholesale pearl jewelry,
            pearl jewelry
              回復(fù)  更多評論   

            # re: 又是未完成的東西 2007-03-29 14:01 skipper

            more effective c++里已經(jīng)提出了lazy evaluation的思想。作者沒有解決怎么實(shí)現(xiàn)的問題。

            而且看到作者ppt里的代碼,效率好像并不是很高啊。  回復(fù)  更多評論   

            # re: 又是未完成的東西 2007-09-15 22:49 螞蟻終結(jié)者

            看了一下ppt的代碼,如skipper所說,效率并不高,先不說lazy evaluation。看看Metrix本身的設(shè)計(jì):

            copy construct 其實(shí)沒必要2層循環(huán),也沒必要用operator()來存取元素:
            這樣寫效率肯定不一樣
            Metrix::Metrix(const Metrix& a) {
            M = a.M;
            N = a.N;
            int size = M * N;
            element = new double[size];
            for (int i = 0; i < size ; ++i)
            element[i] = a.element[i];
            }
            當(dāng)然了,上面的還可以再優(yōu)化,用memcpy會(huì)更快:
            Metrix::Metrix(const Metrix& a) {
            //...
            memcpy(element, a.element, size * sizeof(double));
            }
            copy assignment operator以及operator+也一樣可以優(yōu)化...
            不多說了呵呵  回復(fù)  更多評論   


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            日产精品久久久久久久| 成人精品一区二区久久久| 久久精品一本到99热免费| 97精品伊人久久大香线蕉| 无码国内精品久久人妻蜜桃 | 国内精品伊人久久久久777| AV无码久久久久不卡蜜桃| 国内精品久久久久久99蜜桃| 99久久夜色精品国产网站| 亚洲?V乱码久久精品蜜桃 | 国产成人精品久久亚洲| 亚洲精品国精品久久99热| 久久亚洲日韩精品一区二区三区| 久久精品国产亚洲欧美| 久久免费视频1| 嫩草影院久久99| 一本久久a久久精品vr综合| 久久99中文字幕久久| 久久久久久久91精品免费观看 | 亚洲色欲久久久综合网东京热| 99国产精品久久| 亚洲精品无码专区久久同性男| 国内精品久久久久久久97牛牛| 久久久久人妻一区精品| 国内精品伊人久久久久av一坑| 日本高清无卡码一区二区久久| 国产成人精品免费久久久久| 免费精品国产日韩热久久| 久久亚洲国产精品一区二区| 精品无码久久久久国产动漫3d| 99久久精品久久久久久清纯| 久久久久亚洲AV无码网站| 亚洲精品无码久久久| 亚洲国产精品久久久久| 久久婷婷国产综合精品| 久久婷婷午色综合夜啪| 久久国产成人| 国产高潮久久免费观看| 久久精品国产99国产电影网| 亚洲色婷婷综合久久| 久久久这里有精品|