当前位置: 首页 > news >正文

做名宿比较好的网站百度如何购买关键词

做名宿比较好的网站,百度如何购买关键词,河池网站制作,dt高端网站设计今天有幸参加了一个XSEDE OpenMP的workshop讲座,真是受益匪浅啊。简单来说OpenMP就是一个多线程程序的框架。和MPI相比,MPI每一个Node都有独立的内存空间,但是OpenMP所有的线程共享一个内存空间。显而易见,OpenMP的硬件制约要比MP…

今天有幸参加了一个XSEDE OpenMP的workshop讲座,真是受益匪浅啊。简单来说OpenMP就是一个多线程程序的框架。和MPI相比,MPI每一个Node都有独立的内存空间,但是OpenMP所有的线程共享一个内存空间。显而易见,OpenMP的硬件制约要比MPI大,但是只要硬件跟得上就会比MPI要快。OpenMP一般都会部署再超级计算机中心,但是几年之前它就成为了一个通用标准。基本上所有的主流C/C++语言编译器都支持OpenMP(当然除了C之外,OpenMP还支持Fortran,不过这里我主要介绍一下C),这意味着只要你的计算机上安装了C的编译器你就可以直接使用OpenMP不需要额外部署任何东西。(这太方便了,想想Hadoop,当年为了部署它,我被折磨的那个叫一个销魂啊。)

##编写OpenMP程序

编写OpenMP的程序并不需要额外的学习很多东西,其实就是普通的C代码加上一些Directives。用Hello World为例:

#include

int main(int argc,char** argv){

printf("Hello World!\n");

return 0;

}

这是一个最简单的程序,编译执行后的输出是。

Hello World!

然后我们给他加上OpenMP的directive,他就变成了。

#include

int main(int argc,char** argv){

#pragma omp parallel

printf("Hello World!\n");

return 0;

}

看到没?就是简单的加了一句话#pragma omp parallel,若是正常编译的话,这句话会被忽略一点都不影响你的程序,只有调用OpenMP的lib编译的时候才会编译成OpenMP的版本。以GCC为例,OpenMP的编译方法是:

gcc -o hello hello.c -fopenmp

仅仅多了一个-fopenmp的flag,太简单了。现在我们试试效果,这个hello world的输出结果变成了:

Hello World!

Hello World!

Hello World!

Hello World!

Hello World!

Hello World!

Hello World!

Hello World!

输出了8次Hello World!。这是为什么呢?原因是那个directive之后的代码被多线程操作了,默认情况下GCC的-fopenmpflag会调用和你CPU内核数相同数量的线程来执行程序。这个线程数量是可以控制,只需要修改环境变量中OMP_NUM_THREADS参数,例如:

export OMP_NUM_THREADS=2

之后也不需要重新编译,直接执行之前的程序,就会发现Hello World!的数量变成了两个了。

###for循环

大多数情况下,我们主要会将多线程技术应用在循环中而不是全部代码。OpenMP主要被应用于for循环的多线程处理,这主要还是因为for循环比较容易控制。当然如果你非要用在while循环上也不是不可以,只不过要大量修改你的代码然后用一个block来圈在while之外,总之是一个比较另类的操作了。我在此就不多说了。用一个最简单的例子,找寻1到10000中最大的数字。当然这个例子很白痴,但是代码简洁比较好理解。

#include

int main(int argc, char** argv){

int i;

int max = 0;

#pragma omp parallel for

for(i=0;i<=10000;i++){

if(i>max)max=i;

}

printf("%d\n",max);

}

结果是:

10000

我们在directive里面加了一个for,变成了#pragma omp parallel for,这样的话OpenMP就只会把下面的for循环进行多线程处理,所以我们只看到了一个输出而不是好几个。

这里有一点一定要主要,将要进行多线程处理的for循环一定是独立的(independent),也就是说下面这种情况是不可以的。

for(i=0;i<10000;i++){

a[i] = a[i-1]+1;

}

每一次循环都需要之前的结果,这种循环没有办法进行多线程处理,因为每一次都要等待之前的输出,强行处理还会出错。

####private参数

细心的话,也许你会有一个问题。那就是循环只有一个迭代器(通常是变量i),但进行多线程处理的时候,这个迭代器会不会被各个线程互相扯皮?这却是是一个问题,如果这个迭代器仅仅用作计数的话可能还不是什么大问题,但是如果这个变量也参与运算,这就麻烦了,所有OpenMP引入了private参数,用来告诉编译器那些变量需要有一个本地的实例。这个参数用于迭代器的话就变成了下面的例子。

#pragma omp parallel for private(i)

for(i=0;i<10000;i++){

...

}

这样的话每个线程都有自己的i拷贝,就不会冲突了。当然这个参数的用途很广,这仅仅是一个简单的例子。但事实上基本上每次对循环进行多线程处理的时候都需要拷贝迭代器,因此可以把for private()这样连起来记忆,不容易忘。

####reduction参数

我们回到之前的那个10000以内最大整数的例子。之前我提到了循环一定不能互相关联,否则不是效率低下(还不如单线程),就是出错误。这个例子其实就是一个反面典型,就是因为max这个变量。循环的每一步都会读取之前的结果来参与计算。可是针对max变量的这个例子,我们还是有解决办法的。

如果我们环境变量设置线程数为2,这个循环的前5000项和后5000项将分别在两个不同的线程中处理,也就是一份为二。我们需要的是所有数值中的最大值,换一个角度想。我们可以在前5000项和后5000项分别算出最大值,然后在对这两个结果进行比较取最大值,这样的话我们同样完成了寻找最大值的目的同时还可以多线程处理。

那么怎样做到呢?这个时候我们就需要reduction这个参数。reduction就是让某些变量先在各自的线程中独自计算,然后在循环结束时在合并。那么我们用这个参数来修改之前的例子:

#include

int main(int argc, char** argv){

int i;

int max = 0;

#pragma omp parallel for private(i) reduction(max:max)

for(i=0;i<=10000;i++){

if(i>max)max=i;

}

printf("%d\n",max);

}

这下就变成了完整版。reduction这个函数格式是reduction(operation:variable),冒号前面的是操作类型,冒号后面的是变量名。目前reduction这个函数只支持如下几个操作:

+(初始值是0)

-(初始值是0)

max(初始值是最小值)

min(初始值是最大值)

Bit(&,|,^,iand,ior)(初始值是~0,0)

Logical(&&,||,.and.,.or.)(初始值是0,1,.true.,.false.)

##编译与执行

其实之前已经提到了如何编译和执行。今天有幸在超计算机中心的服务器上面测试了几次,然后回到本地计算机试了一下,发现本地执行简单的多。因为本地执行就是简单的./program。Windows下的话你可以试试双击。在服务器上面跑还要考虑调度多少node和多少core,但是在本地不需要提供任何额外的参数就和执行普通程序一样。所以说OpenMP真是多线程计算一大神器啊,主要还是操作简单。

之前提到了现在主流的C/C++编译器都已经支持OpenMP了,那么都有那些编译器呢?我在这里给出一个列表。

编译器参数不设置环境变量时的初始值

GNU (gcc, g++, gfortran)

-fopenmp

与CPU内核数相同数量的线程

Intel (icc ifort)

-openmp

与CPU内核数相同数量的线程

Portland Group (pgcc,pgCC,pgf77,pgf90)

-mp

只使用一个线程

顺便在提一下,环境变量是控制线程数的环境变量是OMP_NUM_THREADS。

###参考文献

http://www.lbrq.cn/news/2664559.html

相关文章:

  • ps快速做网站竞价账户托管
  • wix做的网站微信引流主动被加软件
  • 成都网站建设的公司免费个人网站怎么建立
  • 推荐几个色情图片网站游戏推广话术技巧
  • 西安城乡建设委员会的网站百度平台商家我的订单查询
  • 免费设计图片素材网站seo短视频入口引流
  • 千海网站建设 小程序网站优化排名易下拉软件
  • 电器网站建设目的有没有可以代理推广的平台
  • 专业的上海网站建设游戏广告联盟平台
  • 烟台建设协会网站十大销售管理软件排行榜
  • wordpress图片缓冲windows优化大师值得买吗
  • 上海网页设计培训机构seo页面链接优化
  • 郑州大学现代远程教育 《网页设计与网站建设》个人主页今日头条号官网
  • 做网站上海网络营销的优势
  • 网站开发 后端服务国际时事新闻最新消息
  • 网站网页优化怎么做怎样进行关键词推广
  • 做网站需要服务器吗可以直接进入的舆情网站
  • 如何利用服务器做网站免费的网站推广软件下载
  • 破解织梦做的网站关键词代发包收录
  • 长春网站制作费用网站优化建议
  • 深圳腾网站建设百度指数查询手机版app
  • 淘宝代运营费用多少钱360优化大师下载官网
  • 南京g3云推广seo需要什么技术
  • 郑州做营销型网站公司管理人员需要培训哪些课程
  • 有哪些教育网站做的比较好网络营销工具与方法
  • 企业网站设计期末考试百度号码认证平台官网首页
  • 慕课网站建设开题报告搜索引擎营销的简称
  • 做网站,就上凡科建站百度手机助手网页
  • 中山手机网站建设报价推广普通话手抄报句子
  • 给别人做网站别人经营违法百度免费网站制作
  • MATLAB绘制水的蒸汽压曲线(Antoine方程)
  • Rust 实战四 | Traui2+Vue3+Rspack 开发桌面应用:通配符掩码计算器
  • Java数据结构——LinkedList
  • 从MySQL到大数据平台:基于Spark的离线分析实战指南
  • 时序分解 | MATLAB实现SAO-VMD雪消融算法优化变分模态分解
  • 八、Linux Shell 脚本:变量与字符串