• <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>
            萬(wàn)星星@豌豆莢 歡迎加入我們
            一個(gè)吃軟飯的男人!!!!!我只想寫程序####
            微博:http://weibo.com/wanlianwen
            posts - 172,  comments - 1253,  trackbacks - 0
            自從失戀以來(lái),很久沒(méi)有寫隨筆,多謝大家對(duì)我鼓勵(lì),總覺(jué)得要寫一點(diǎn)什么的,苦于學(xué)校壓力和外面工作需要,時(shí)間甚少。這里先發(fā)關(guān)于上學(xué)期一門課程開發(fā)入門文章,是我自己寫的。隨后將推出一系列軟件設(shè)計(jì)的文章,因?yàn)槟壳案鷮O輝老師學(xué)技術(shù),將拿出來(lái)和大家分享,也算是技術(shù)推廣吧!

            系統(tǒng)環(huán)境配置

            Win2K Adv Svr + VC6

            MPI開發(fā)包下載

            網(wǎng)上搜索下載MPICH2地址http://www-unix.mcs.anl.gov/mpi/mpich2/

            MPI開發(fā)包安裝

            ?????? 下載完畢,開始安裝MPICH2開發(fā)包,提示需要.NET 1.1 框架。鑒于本人對(duì)VS.NET 2003愛(ài)好,直接安裝了整個(gè)開發(fā)環(huán)境,也可以只安裝.NET框架。可以到微軟官方網(wǎng)站下載安裝包(http://msdn.microsoft.com/netframework/downloads/framework1_1/)。安裝.NET框架后便可以安裝MPICH2開發(fā)包。安裝后可以看到MPICH2目錄層次:

            環(huán)境配置

            ?????? 我的電腦”path中設(shè)置MPICH2bin目錄(%MPICH2%\bin)以便運(yùn)行mpiexec程序。我的具體設(shè)置如下:

            ?????? VC6開發(fā)環(huán)境中包含MPICH2開發(fā)包的include目錄和lib目錄。具體步驟:打開VC6,選擇”Tools->Options”,在彈出的“Options”對(duì)話框中選擇Directories選項(xiàng)卡,分別設(shè)置如下圖:

            (設(shè)置Include目錄%MPICH2%/include

            (設(shè)置Lib目錄%MPICH2%/LIB

            ?????? MPICH2環(huán)境配置。運(yùn)行%MPICH2%/LIBwmpiregister,在注冊(cè)界面輸入本機(jī)器用戶名和密碼以便mpiexec運(yùn)行程序。

            開發(fā)第一個(gè)程序“Hello World

            ?????? 經(jīng)過(guò)上面的步驟,MPICH2開發(fā)環(huán)境已經(jīng)建立好,下面便可以步入MPICH2的大殿了。開始最簡(jiǎn)單也是最經(jīng)典程序“Hello World”,在過(guò)程中倒是遇到不少麻煩。

            ?????? 打開VC6,建立一個(gè)控制臺(tái)應(yīng)用程序,如下圖:

            ?????? 依照課本,包含頭文件且把代碼敲入main函數(shù)中。

            ?????? #include "mpi.h"

            #include <cstdio>

            ?

            ?

            int main(int argc, char* argv[])

            {

            ??????

            ?????? MPI_Init(&argc, &argv);

            ?????? printf("Hello World!\n");

            ?????? MPI_Finalize();

            ?????? return 0;

            }

            ?????? 編譯程序,發(fā)現(xiàn)出現(xiàn)很多編譯錯(cuò)誤,一時(shí)間不知道怎么辦好。在細(xì)看錯(cuò)誤,都是一些函數(shù)重載錯(cuò)誤。原本想修改代碼,但是沒(méi)有全部源代碼。再進(jìn)一步,發(fā)現(xiàn)全部是mpicxx.h文件導(dǎo)致的錯(cuò)誤,于是想是否MPI_Init等函數(shù)與此文件有關(guān)。通過(guò)搜索包含文字,發(fā)現(xiàn)MPI_Init等函數(shù)只在mpi.h中定義,于是想辦法不包含mpicxx.h文件以避開問(wèn)題。在mpi.h中發(fā)現(xiàn)代碼:

            #if !defined(MPICH_SKIP_MPICXX)

            #include "mpicxx.h"

            #endif

            #endif

            這下有辦法,在程序中定義宏MPICH_SKIP_MPICXX,然后重新編譯程序(注意在包含mpi.h前定義)。哈哈,果然避開了mpicxx.h文件,有出現(xiàn)幾個(gè)為定義錯(cuò)誤,包含Lib文件就OK!如下圖:

            ?????? 有個(gè)建議,既然包含頭文件必須連接庫(kù)的話,可以在頭文件中指定庫(kù)。本人在開發(fā)過(guò)程中一直這樣做,感覺(jué)很好。這樣可以避免入門者不會(huì)設(shè)定庫(kù)。

            ?????? 下面是運(yùn)行。運(yùn)行命令行,輸入:

            E:\MyProject\MPIPractice\HelloWorld\Debug>mpiexec -np 4 helloworld

            輸出結(jié)果:

            Hello World!

            Hello World!

            Hello World!

            Hello World!

            這樣便完成第一個(gè)MPI程序,下面的任務(wù)就是依據(jù)并行算法思想解決復(fù)雜問(wèn)題,留帶大家自己解決。

            總結(jié)

            ?????? 耗費(fèi)一下午重新安裝系統(tǒng)和各種軟件,大約一個(gè)小時(shí)編制及調(diào)試“Hello World”程序,盡管簡(jiǎn)單,但是畢竟對(duì)于MPI編程入門,感覺(jué)良好。耗費(fèi)一小時(shí)書寫文檔,總結(jié)問(wèn)題,以便其他同學(xué)遇到麻煩好解決,希望互相學(xué)習(xí)進(jìn)步。

            ?

            萬(wàn)連文

            2005/10/19晚于寢室

            posted on 2006-06-12 17:50 萬(wàn)連文 閱讀(19188) 評(píng)論(42)  編輯 收藏 引用 所屬分類: 亂七八糟

            FeedBack:
            # re: 并行編程--MPI開發(fā)入門
            2006-06-12 20:12 | 史傳紅
            我現(xiàn)在也在搞這方面的研究,不過(guò)是在linux系統(tǒng)下,多多向你學(xué)習(xí)。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-06-12 20:49 | 萬(wàn)連文
            學(xué)習(xí)到不敢當(dāng),只是當(dāng)時(shí)學(xué)習(xí)的時(shí)候了解了一下,為入門的朋友們方便。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-06-23 10:16 | 祝喬
            我現(xiàn)在想學(xué)習(xí)MPI,但是感覺(jué)它好難哦,我想問(wèn),MPI能在單機(jī)上運(yùn)行,并驗(yàn)證程序的正確性嗎?  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-06-23 12:17 | 萬(wàn)連文
            可以在單機(jī)運(yùn)行,我就是在單機(jī)測(cè)試的。
            其實(shí)MPI主要是想法,就是如何分配任務(wù)以并行處理。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-07-12 11:59 | 郭恒明
            你好! 我也是剛開始學(xué)MPI,我裝的是MPICH2,在vc下環(huán)境已經(jīng)配置好了,運(yùn)行c+mpi時(shí)沒(méi)有問(wèn)題,但是在運(yùn)行mpi+c++時(shí),總是出現(xiàn)下面的問(wèn)題,請(qǐng)問(wèn)一下怎么樣解決,先謝謝了!
            d:\program files\mpich2\include\mpicxx.h(1417) : error C2555: 'MPI::Nullcomm::Clone' : overriding virtual function differs from 'MPI::Comm::Clone' only by return type or calling convention
            d:\program files\mpich2\include\mpicxx.h(1051) : see declaration of 'Comm'
            d:\program files\mpich2\include\mpicxx.h(1483) : error C2555: 'MPI::Intercomm::Clone' : overriding virtual function differs from 'MPI::Comm::Clone' only by return type or calling convention
            等,內(nèi)容太長(zhǎng)了,放不下,不過(guò)都是上面顯示的這些問(wèn)題。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-07-12 12:15 | 萬(wàn)連文
            由于時(shí)間隔太長(zhǎng),不太記得,確實(shí)存在問(wèn)題,但是可以避開包含mpicxx.h文件:
            在mpi.h中發(fā)現(xiàn)代碼:

            #if !defined(MPICH_SKIP_MPICXX)

            #include "mpicxx.h"

            #endif

            #endif

            這下有辦法,在程序中定義宏MPICH_SKIP_MPICXX,然后重新編譯程序(注意在包含mpi.h前定義)。
            我寫過(guò)幾個(gè)程序都這樣避開的,要真解決我倒沒(méi)有做過(guò)。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-07-12 14:06 | 郭恒明
            謝謝了。我自己再看一下。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-08-07 15:17 |
            其實(shí)只要在#include所有頭文件前,包含mpi.h即可
            如果工程中包含stdafx.h那么就在stdafx.h的最初包含mpi.h即可  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-08-07 15:54 |
            另外這里通過(guò)#define MPICH_SKIP_MPICXX的方法雖然可以解決當(dāng)下的問(wèn)題,但是你這里使用的是mpi的C語(yǔ)言方式,如果使用MPI::Init這樣的C++方式,就行不通了。

            所以依我看,把mpi.h的包含位置提前是根本的解決之道,而且mpich2的示例程序也是這樣做的。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-08-07 16:21 | 萬(wàn)連文
            恩,謝謝拉。要是以前知道的話就可以試驗(yàn)一下,可惜放下很久了。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-08-14 09:29 | zhongyuan
            我運(yùn)行MPI程序時(shí)出現(xiàn)如下問(wèn)題(huangzhongyuan是我用wmpiregister.exe 注冊(cè)的一個(gè)用戶):
            Credentials for huangzhongyuan rejected connecting to huangzhongyuan
            Aborting: Unable to connect to huangzhongyuan
            請(qǐng)問(wèn)如何解決該問(wèn)題
            我的Email:zhongyuan2@hotmail.com  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-08-14 09:35 | zhongyuan
            我剛才已經(jīng)解決,多謝  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-09-12 17:02 | Dew
            真是太好了,我也是剛在接觸MPI,也在為上面所說(shuō)的問(wèn)題苦惱,謝謝大家!!!  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2006-11-20 11:15 | angel
            謝謝哈:)  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-03-05 18:30 | Anoba
            我使用VS2005+MPICH2 1.0.5+Winserver2003寫了一個(gè)程序,編譯沒(méi)問(wèn)題,wmpiexec運(yùn)行該程序,報(bào)錯(cuò):Aborting:unable to connect to master,smpd version mismatch
            按CTRL+C出現(xiàn)
            error encountered before initializing MPICH
            如果不選復(fù)選框"run in an seperate window"則能運(yùn)行,這是怎么回事啊?
              回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-03-05 18:33 | Anoba
            還有我運(yùn)行的服務(wù)器是4CPU,將該EXE文件復(fù)制到一臺(tái)單CPU的WINXP機(jī)器上則可以運(yùn)行,不管選不選那個(gè)復(fù)選框.  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-03-05 22:38 | 萬(wàn)連文
            不好意思,我已經(jīng)很久沒(méi)有這方面研究了,不敢誤人子弟,請(qǐng)另處尋找答案。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-03-08 20:33 | Anoba
            @zhongyuan
            你的問(wèn)題是怎么解決的啊?我的郵箱是anoba@163.com  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-03-08 20:34 | Anoba
            你的問(wèn)題是怎么解決的啊?我的郵箱是anoba@163.com@zhongyuan
              回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-03-08 21:01 | Anoba
            @萬(wàn)連文
            還是謝謝你的文章啊!這方面的材料太少了.  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-03-10 13:09 | 萬(wàn)連文
            @Anoba
            你可以通過(guò)郵件與zhongyuan 聯(lián)系  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-05-10 16:40 | angus
            為什么我用這個(gè)命令test.exe -np 4就不能輸出四次呢?求助  回復(fù)  更多評(píng)論
              
            # 請(qǐng)教MPICH2安裝失敗的原因
            2007-05-21 16:12 | wangzr
            我在windows XP操作系統(tǒng)下,按要求安裝了.NET 1.1 框架,再安裝MPICH2時(shí),提示"there is a problem with this windows installer package.A problem runs a part of the setup did not finish as expected....."的信息,請(qǐng)幫我分析一下是什么原因啊  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-05-22 09:37 | 萬(wàn)連文
            建議你安裝一個(gè)虛擬機(jī),然后多做幾次安裝試驗(yàn)。這個(gè)東西我已經(jīng)1年多沒(méi)有在玩了,所以.......  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-06-08 10:36 | jiaoyang
            did you have some books about learning how to make procedure with mpi, I mean that MPI include some API and then can be used for realizing parallel caculation.  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-06-08 13:20 | 萬(wàn)連文
            這里我再次聲明下,這個(gè)東西是一年多前學(xué)習(xí)了一段時(shí)間,后來(lái)一直沒(méi)有接觸。所以沒(méi)有什么深入研究,請(qǐng)大家原諒。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-09-17 17:12 | jiajd
            您好:我在用java做MPI開發(fā),主要是項(xiàng)目需要,看了幾天資料一時(shí)不知道怎樣入手,還忘指點(diǎn)  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-11-19 21:35 | anqiongdy
            請(qǐng)問(wèn) 有沒(méi)有人在多機(jī)環(huán)境下實(shí)現(xiàn)過(guò)啊,我在多機(jī)的配置上遇到問(wèn)題了,有高手做過(guò)的話,還望指點(diǎn)下啊。(E_mail:anqiongdy@163.com)  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-11-20 12:11 | llmwm
            我運(yùn)行MPI程序時(shí)出現(xiàn)如下問(wèn)題(huangzhongyuan是我用wmpiregister.exe 注冊(cè)的一個(gè)用戶):
            Credentials for huangzhongyuan rejected connecting to huangzhongyuan
            Aborting: Unable to connect to huangzhongyuan
            請(qǐng)問(wèn)如何解決該問(wèn)題

            這個(gè)問(wèn)題怎么解決的啊,急求!  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2007-11-20 12:18 | 萬(wàn)連文
            請(qǐng)使用administrator帳戶注冊(cè)試一下,有可能是權(quán)限問(wèn)題。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2008-03-29 21:20 | gjx
            不知道有誰(shuí)知道如何在vs2005下調(diào)試mpi程序,每次按msdn說(shuō)明還是無(wú)法進(jìn)入預(yù)設(shè)的斷點(diǎn),不知道為什么?  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2008-04-22 16:00 | cow
            呵呵,居然還有在win32平臺(tái)上做計(jì)算的?  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門[未登錄](méi)
            2009-10-19 16:25 | 攀升
            CuteFTP 8 Professional
            SSH Secure Shell Client
            SSH Secure File Transfer Client
            集群的這三個(gè)軟件怎么用啊?哪位能夠提供一個(gè)使用文檔~謝謝
            如何在集群上運(yùn)行程序啊?
            郵箱:pstrueman@163.com.QQ:493231671  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2010-03-10 09:31 | YWT
            樓主有QQ沒(méi),我也在做并行計(jì)算,想交流一下QQ:252601388  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門[未登錄](méi)
            2010-04-23 11:05 | wang
            @wangzr
            裝新版本的mpi
              回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門[未登錄](méi)
            2010-06-17 10:58 | paul
            MPI初學(xué)者,大家一起交流一下 QQ:408474219   回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2010-08-24 09:57 | Hmilyy
            可以向你學(xué)習(xí)MPI嗎?麻煩了 我的QQ是469082066  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2011-11-28 12:48 | izatgul
            hi ,我在linux系統(tǒng)下用 c++ 編一個(gè)程序, 但是總是找不到我的頭文件mpi.h這怎么會(huì)事? 明明有這個(gè)頭文件。 在makefile文件里面寫它的路徑也試過(guò)
            INCLUDE = -I/usr/locsl/mpich/include
            你們看看這個(gè)mpi程序?qū)憁akefile的時(shí)候有什么規(guī)則嗎?  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2012-08-24 23:05 | overman
            你是怎么解決的?@郭恒明
              回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2013-03-14 10:38 | hcc
            怎么從根本上解決mpicxx.h的問(wèn)題?如果我要用到這個(gè)里邊的函數(shù)的話。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2014-05-27 19:35 | wangnann
            @萬(wàn)連文
            是的。就是權(quán)限問(wèn)題。該帳號(hào)必須是系統(tǒng)當(dāng)前使用帳號(hào)并擁有管理權(quán)限。用wmpiconfig 中的scan Hosts 下面用戶顯示綠色可以,不然就出現(xiàn)Aborting: Unable to connect to。。。。  回復(fù)  更多評(píng)論
              
            # re: 并行編程--MPI開發(fā)入門
            2015-10-15 20:53 | M琨M
            我是用的vs+MPICH2,用wmpiexec運(yùn)行我的exe的時(shí)候,不能連接到主機(jī)是什么鬼啊。。求回復(fù)  回復(fù)  更多評(píng)論
              
            簡(jiǎn)歷下載
            聯(lián)系我

            <2006年1月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(66)

            隨筆分類

            隨筆檔案

            相冊(cè)

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久国产综合精品五月天| 久久亚洲AV成人无码电影| 欧美久久久久久午夜精品| 婷婷久久综合| 久久精品亚洲日本波多野结衣| 91精品国产综合久久婷婷| 国产高潮国产高潮久久久91 | 国产精品毛片久久久久久久| 久久久久国产一级毛片高清版| 久久久精品久久久久久| 久久亚洲AV无码精品色午夜| 奇米综合四色77777久久| 国产精品成人99久久久久 | 模特私拍国产精品久久| 久久亚洲私人国产精品| 国产99久久久国产精免费| 欧美亚洲国产精品久久高清| 1000部精品久久久久久久久| 欧洲国产伦久久久久久久 | 精品人妻久久久久久888| 久久亚洲国产成人影院网站| 久久精品青青草原伊人| 国产精品永久久久久久久久久| 99久久国产宗和精品1上映| 99久久精品国产一区二区三区 | 久久久久99这里有精品10| 国内精品久久久久久久97牛牛| 色婷婷久久综合中文久久一本| 精品无码久久久久国产| 一级a性色生活片久久无| 久久最近最新中文字幕大全| 国产成人久久精品一区二区三区 | 亚洲国产精品无码久久久久久曰| 97久久精品无码一区二区天美| 亚洲精品美女久久久久99小说 | 亚洲精品美女久久久久99| 久久996热精品xxxx| 国产V亚洲V天堂无码久久久| 国色天香久久久久久久小说 | 69久久精品无码一区二区| 亚洲精品无码久久久久久|