版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
2、附件是熱傳導(dǎo)問題的串行程序示例。請根據(jù)該實(shí)例編寫pthread并行程序。serial: : atomic: :可以看出mtxserial: : atomic: : serial: : atomic: : serial: : atomic: : serial: : atomic: : serial: : atomic: : serial:found :foundatomic: :primescost=13.primescost=1.primescost=1.primesserial: : atomic: : 25—35的范圍時(shí),并行性能略有提高。計(jì)算劃分的任務(wù)粒度越小,并行程序中任NXPROB*NYPROB*ntsu2。NXPROB,NYPROB,nts,thread_num。FILE:SerialHEAT2DExample-CThisexampleisbasedonatwo-dimensionalheatequation Thetemperatureiscomputedtobehighinthemiddleofthezeroatthe Theboundariesareheldatzerothe Duringthetime-step,anarraycontainingsisused;thesesalternatebetweenolddataandnew#include<stdio.h>#include<stdlib.h>#include<time.h>#include<unistd.h>//#include<math.h>#include<stdlib.h>#include#defineNXPROB#defineNYPROB#defineCLOCK_PER_SEC((clock_t)1000)#defineMax_Thread_Num256#define struct{floatcx;floatcy;intnts;}parms={0.1,0.1,intfloatinttotalThread;intiz,it;intposX,intcolumn, mtx;{ *pMyStatus=threads;intloc_posX,loc_posY;intix,while((*pMyStatus)!=pthread_self())pMyStatus++;loc_posX=posX;loc_posY=posY+=if(posY>={posX+=row;posY=1;}{for(ix=loc_posX;ix<loc_posX+row&&ix<NXPROB-1;{for(iy=loc_posY;iy<loc_posY+column&&iy<NYPROB-1;{u[1-iz][ix][iy]=u[iz][ix][iy]+parms.cx*(u[iz][ix+1][iy]+u[iz][ix-1][iy]-2.0*+parms.cy*(u[iz][ix][iy+1]+u[iz][ix][iy-1]-2.0*}}if(it>=parms.nts)}return(void*)0;}void{intix,voidinidat(),prtdat(),inti,for(ix=0;ix<=NXPROB-1;{u[1][ix][0]=}for(iy=0;iy<=NYPROB-1;{u[1][0][iy]=}totalThread=pthread_cond_init(&cMaster,NULL);pthread_mutex_init(&mtx,NULL);posX=1;posY=if(thread_num>Max_Thread_Num)thread_num=Max_Thread_Num;if(thread_num%2==1)thread_num-=1;column=(NYPROB-2+2)/row=(NXPROB-2+thread_num/2-1)/(thread_num/for(i=0;i<thread_num;while(totalThread!=thread_num)pthread_cond_wait(&cWorker,&mtx);iz=0;for(it=1;it<=parms.nts;{totalThread=while(totalThread!=thread_num)pthread_cond_wait(&cWorker,&mtx);iz=1-iz;}printf("%dthreadnum:%d\n",totalThread,thread_num);prtdat(NXPROB,NYPROB,&u[iz][0][0],"final_p.dat");for(i=0;i<thread_num;i++)pthread_join(threads[i],NULL);}int{structtimespects,te;clock_tbegin,end;doubleserial_cost,//floatintix,iy,iz,voidinidat(),prtdat(), inidat(NXPROB,NYPROB,u);{{{v[i][j][k]=}}}prtdat(NXPROB,NYPROB,u,"initial.dat");begin=clock();doublea=//printf("a:cost=%-15.10f\n",a/CLOCK_PER_SEC);clock_gettime(CLOCK_REALTIME,&ts);for(ix=0;ix<=NXPROB-1;{u[1][ix][0]=}for(iy=0;iy<=NYPROB-1;{u[1][0][iy]=} Iterateoveralliz=0;for(it=1;it<=parms.nts;{iz=1-}end=doubleb=clock_gettime(CLOCK_REALTIME,&te);doubleserial_costs=te.tv_sec-ts.tv_sec+(double)(te.tv_nsec-ts.tv_nsec)/NANO;printf("serial:cost=%-15.10f\n",serial_costs);//doubles_cost=b-//printf("serial:cost=%-15.10f\n",serial_cost);{{{u[i][j][k]=}}}begin=a=//printf("a:cost=%-15.10f\n",a/CLOCK_PER_SEC);doublesyns_cost=te.tv_sec-ts.tv_sec+(double)(te.tv_nsec-ts.tv_nsec)/NANO;printf("syn:cost=%-15.10f\n",syns_cost);printf("speedup=%-15.10f\n",serial_costs/syns_cost);end=clock();b=//printf("b:cost=%-15.10f\n",b/CLOCK_PER_SEC);syn_cost=b-a;} update(nx,ny,u1,u2)intnx,ny;float*u1,{intix,for(ix=1;ix<=nx-2;{for(iy=1;iy<=ny-2;{*(u2+ix*ny+iy)= parms.cx*(*(u1+(ix+1)*ny+iy)+*(u1+(ix-1)*ny+iy)2.0* )parms.cy*(*(u1+ix*ny+iy+1)+*(u1+ix*ny+iy-1)2.0* }}} inidat(nx,ny,u1)intnx,ny;/*floatu1[nx][ny];*/float*u1;{intix,for(ix=0;ix<=nx-1;{for(iy=0;iy<=ny-1;{/*u1[ix][iy]=(float)(ix*(nx-ix-1)*iy*(ny-iy-1));*(u1+ix*ny+iy)=(float)(ix*(nx-ix-1)*iy*(ny-iy-}}}*subroutineprtdat(nx,ny,u1,fnam)int
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 《豬姜片吸蟲病》課件
- 地理(內(nèi)蒙古)-【八省聯(lián)考】河南、山西、陜西、內(nèi)蒙古、四川、云南、寧夏、青海八省2025年高考綜合改革適應(yīng)性演練聯(lián)考試題和答案
- 《知識大考驗(yàn)》課件
- 小學(xué)一年級10以內(nèi)連加連減口算練習(xí)題
- 出凝血疾病的實(shí)驗(yàn)診斷學(xué)思路-2019年華醫(yī)網(wǎng)繼續(xù)教育答案
- 作業(yè)姿勢的分類分析及抗疲勞方案
- 2019工程倫理慕課答案(2019秋)習(xí)題及期末答案
- 2022年合肥幼兒師范高等??茖W(xué)校單招面試題庫及答案解析
- 小學(xué)數(shù)學(xué)二年級數(shù)學(xué)加減法練習(xí)題
- 物流運(yùn)輸客服工作經(jīng)驗(yàn)
- 廣西河池市2023-2024學(xué)年七年級上學(xué)期語文期末試卷(含答案)
- 江蘇省蘇州市(2024年-2025年小學(xué)五年級語文)統(tǒng)編版期末考試((上下)學(xué)期)試卷及答案
- 供應(yīng)鏈年終總結(jié)報(bào)告
- 體育訓(xùn)練服務(wù)行業(yè)市場調(diào)研分析報(bào)告
- 肝性腦病的護(hù)理課件-
- 2024年丟失物品索償協(xié)議書模板
- 2025年八省聯(lián)考新高考 語文試卷
- 建筑物拆除場地清理垃圾外運(yùn)施工方案
- 內(nèi)部調(diào)查與舉報(bào)制度
- 《賣火柴的小女孩》公開課一等獎(jiǎng)創(chuàng)新教學(xué)設(shè)計(jì)(共兩課時(shí))
- 山東省東營市(2024年-2025年小學(xué)四年級語文)統(tǒng)編版期末考試(上學(xué)期)試卷及答案
評論
0/150
提交評論