OpenMP 共享內(nèi)存編程

梯形積分法

菜包的總結(jié)

首次擼OpenMP示例程序,==關(guān)鍵問(wèn)題在于C語(yǔ)言的語(yǔ)法及基礎(chǔ)知識(shí)的不足;
其次對(duì)于OpenMP編程模型的掌握還不熟練;

知識(shí)點(diǎn)

  1. scanf()輸入%lf-->double;%f-->float;%d-->int; …
    其中后半部分是&a校哎,不能寫(xiě)變量名稱(chēng);
  2. openMP 基本塊:
    -并行部分: # pragma omp parallel ...;
    -互斥部分: # pragma omp critical...;
源碼:
#include <stdio.h>
#include <stdlib.h>
#include <omp.h>

void Trap(double a,double b,int n,double* res);
double f(double d);

int main(int argc,char* argv[]){
  int thread_count = strtol(argv[1],NULL,10);
  int n;
  double a,b;
  double res=0.0;

  printf("Please input a, b and n\n");
  scanf("%lf,%lf,%d",&a,&b,&n);
  printf("a is: %f, b is: %f, n is %d \n ", a,b,n); 

# pragma omp parallel num_threads(thread_count)
  Trap(a,b,n,&res);

  printf("Result is %lf !\n",res);
  return 0;
}

void Trap(double a,double b,int n,double* res){
  double h,x,my_res;
  double local_a,local_b;
  int i,local_n;
  int rank = omp_get_thread_num();
  int thread_count = omp_get_num_threads();

  h=(b-a)/n;
  local_n = n/thread_count;
  local_a = a+h*rank*local_n;
  local_b = local_a+local_n*h;
  my_res = (f(local_a)+f(local_b))/2.0;

  for(i=1;i<local_n;i++){
    x = local_a+i*h;
    my_res+=f(x);
  }
  my_res = my_res*h;

# pragma omp critical
  *res+=my_res;
}

double f(double d){
  return d*d;
}
運(yùn)行及結(jié)果
> gcc -g -Wall -fopenmp -o Tixing Tixing.c  
> ./Tixing 5 
Please input a, b and n
0.0,10.0,1000
a is: 0.000000, b is: 10.000000, n is 1000 
 Result is 333.333500 !
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末酷宵,一起剝皮案震驚了整個(gè)濱河市岸浑,隨后出現(xiàn)的幾起案子贱迟,更是在濱河造成了極大的恐慌奠支,老刑警劉巖拳缠,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異马澈,居然都是意外死亡瓢省,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)痊班,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)勤婚,“玉大人,你說(shuō)我怎么就攤上這事涤伐÷ǎ” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵凝果,是天一觀的道長(zhǎng)祝迂。 經(jīng)常有香客問(wèn)我,道長(zhǎng)器净,這世上最難降的妖魔是什么型雳? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮掌动,結(jié)果婚禮上四啰,老公的妹妹穿的比我還像新娘。我一直安慰自己粗恢,他們只是感情好柑晒,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著眷射,像睡著了一般匙赞。 火紅的嫁衣襯著肌膚如雪佛掖。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,573評(píng)論 1 305
  • 那天涌庭,我揣著相機(jī)與錄音芥被,去河邊找鬼。 笑死坐榆,一個(gè)胖子當(dāng)著我的面吹牛拴魄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播席镀,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼匹中,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了豪诲?” 一聲冷哼從身側(cè)響起顶捷,我...
    開(kāi)封第一講書(shū)人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎屎篱,沒(méi)想到半個(gè)月后服赎,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡交播,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年重虑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片堪侯。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡嚎尤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出伍宦,到底是詐尸還是另有隱情,我是刑警寧澤乏梁,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布次洼,位于F島的核電站,受9級(jí)特大地震影響遇骑,放射性物質(zhì)發(fā)生泄漏卖毁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一落萎、第九天 我趴在偏房一處隱蔽的房頂上張望亥啦。 院中可真熱鬧,春花似錦练链、人聲如沸翔脱。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)届吁。三九已至错妖,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間疚沐,已是汗流浹背暂氯。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留亮蛔,地道東北人痴施。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像究流,于是被迫代替她去往敵國(guó)和親晾剖。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容