- 1、本文档共3页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
OpenMP程序的编译和运行
SHANGHAI UNIVERSITY
学 院 实姓学教时
验 名 号 师 间
计算机工程与科学学院 OpenMP程序的编译和运行
陈帅刘芳芳 2021.05.06
报告成绩
实验2-1. OpenMP程序的编译和运行 1. 实验目的
1) 在Linux平台上编译和运行OpenMP程序; 2) 在Windows平台上编译和运行OpenMP程序。 3) 掌握OpenMP并行编程基础。
2. 实验环境
1) 硬件环境:计算机一台;
2) 软件环境:Linux、Win2021、GCC、MPICH、VS2021或其他版本Visual Studio;
3. 实验内容
1. Linux下OpenMP程序的编译和运行。OpenMP是一个共享存储并行系统上的应用编程接口,支持C/C++和FORTRAN等语言,编译和运行简单的\程序。在Linux下编辑hellomp.c源程序,或在Windows下编辑并通过附件中的FTP工具(端口号:1021)上传,用\命令编译,用\命令运行程序。 注:在虚拟机中当使用vi编辑文件时,不是以ESC键退出插入模式,可以使用“Ctrl+c”进入命令模式,然后输入wq进行存盘退出。 代码如下:
#include #include int main() {
int nthreads,tid;
omp_set_num_threads(8);
#pragma omp parallel private(nthreads,tid) {
tid=omp_get_thread_num();
printf(\if(tid==0) {
nthreads=omp_get_num_threads();
printf(\} } }
安装gcc
检查GCC是否安装完成
编写hellomp.c
编译运行
2.控制并行执行的线程数。
根据算法的要求和硬件情况,例如CPU数量或者核数,选择适合的线程数可以加速程序的运行。请按照下列的方法进行线程数量的设置。
//设置线程数为10
[xuyc@sv168 openmp]$ OMP_NUM_THREADS=10
//将线程数添加为环境变量
[xuyc@sv168 openmp]$ export OMP_NUM_THREADS
//运行
修改hellomp.c程序,删除omp_set_num_threads(8);语句
如果不定义OMP_NUM_THREADS,默认会等于CPU数量,在8核心的机器上,会打印出8行\
omp_set_num_threads(8); 设置了子线程数为8,即是可以有8个子线程并行运行。
#pragma omp parallel private(nthreads,tid) 为编译制导语句,每个线程都自己的nthreads
和tid两个私有变量,线程对私有变量的修改不影响其它线程中的该变量。
程序的功能是对于每个线程都打印出它的id号,对于id号为0的线程打印出线程数目。
2. Windows下OpenMP程序的编译和运行。用VS2021编辑上述的hellomp.c源程序,注意在菜单“项目-属性-C/C++-语言”选中“OpenMP支持”,编译并运行程序。
打开或者新建一个c++项目,依次选择Project - 属性 - 配置属性(configuration property) - c/c++ - 语言(Language),打开OpenMP支持;
设置环境变量OMP_NUM_THREADS。
设置环境变量:我的电脑 - 属性 - 高级 - 环境变量,新建一个OMP_NUM_THREADS变量,值设为2,即为程序执行的线程数。
图3 VS2021使用界面
感谢您的阅读,祝您生活愉快。
您可能关注的文档
- “一师一优课一课一名师”先进个人事迹材料.docx
- 银行营业网点客户投诉处理办法及流程.docx
- 让我进步的《中国邮政报》.docx
- 半命题作文4篇:我的.docx
- 平川区红会学校简介2021.2.docx
- 重庆南开中学2021-2021学年(下)初三阶段测试(三)(二模) - 化学及答案.docx
- 2021-2021年高考语文学业水平测试一轮复习 专题十一 名句名篇.docx
- 公司年会主持人现场串词稿.docx
- 军事理论练习题及答案.docx
- 表示哀悼的短信.docx
- 中国国家标准 GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- 《GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计》.pdf
- 中国国家标准 GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- 《GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置》.pdf
- 中国国家标准 GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- GB/T 17889.4-2024梯子 第4部分:铰链梯.pdf
- 《GB/T 17889.4-2024梯子 第4部分:铰链梯》.pdf
文档评论(0)