《OpenACC并行编程实战》—— 3.2 导语格式

简介: OpenACC的绝大部分功能都是以导语的形式实现,导语有一个基本格式,这个格式简单易学。本书中关于OpenACC语法的描述,都会引用官方标准《The OpenACC Application Programming Interface Version 2.5》,不易懂的地方会追加解释。

本节书摘来自华章出版社《OpenACC并行编程实战》一 书中的第3章,第3.2节,作者何沧平,更多章节内容可以访问云栖社区“华章计算机”公众号查看。

3.2 导语格式

OpenACC的绝大部分功能都是以导语的形式实现,导语有一个基本格式,这个格式简单易学。本书中关于OpenACC语法的描述,都会引用官方标准《The OpenACC Application Programming Interface Version 2.5》,不易懂的地方会追加解释。
在C/C++中,使用#pragma预处理机制指定OpenACC导语,语法是:
#pragma acc 导语名字 [子语列表] 换行
每个导语都以#pragma acc开始。导语的其他部分都遵守C/C++中pragma的使用规范。空格和跳格统称为空白字符。#的前后都可以使用空白字符;导语中使用空白字符来分隔各字段。#pragma后面的预处理标记使用宏替换。导语区分大小写。一个OpenACC导语作用于紧接着的语句、结构块和循环。子语列表是一串用逗号分隔的子语。这里的“换行”意为每个导语要独占一行,不要在一行上写多个导语。

3cdfab57632740ef0a845d00302a43e4ca277364

例3.3给出了几个格式正确的导语例子,里面的导语、子语的具体含义先不必理会,后文会详述。符号代表空白字符(强调说明可以使用空白字符)。在这几行导语中,private(i)和independent这两个子语既可以使用空白字符分隔,又可以使用逗号分隔。最后两行组成一个导语,续行符“”将长导语分写在多行,便于阅读。去掉所有的续行符和换行符,其他不做任何改变,多行导语就成为仅占一行的长导语。
Fortran自由格式源文件中,用下列格式指定OpenACC导语:
!$acc 导语名字 [子语列表]
第一个注释字符(!)可以放在任意列,但它前面只能是空白字符(空格和跳格的统称)。前导符!$acc必须以一个整体出现,中间不能有空白字符。Fortran语言的每行长度、空白字符、续行符规则同样适用于导语行。导语起始行的前导符后面必须接有空白字符。待续行中导语部分的最后一个非空白字符必须是连字符(&),连字符后面仍然可以写注释;接续行中导语必须以前导符开始(前面允许有空白字符),前导符后面的第一个非空白字符可以是续行符。导语行上也可以放注释,注释以感叹号开始,直至行尾。如果前导符后面的第一个非空白字符是一个感叹号,那么该行被忽略。子语列表是一串用逗号分隔的子语。
ede9f1950dc8716a5030ff813408388dd4506521 cf93e1c30aa09dca1c0b4db90c1eb09c6bf7d072

例3.4中给出几个Fortran版本的导语示范。空白字符的使用规则与C版本相同,不同的是续行规则。第3~5行是分写成3行的一个导语,每行都需要以前导符!$acc开始,而C版则不需要以#pragma开始。
在固定格式Fortran源代码文件中,OpenACC导语可以采取下列形式中的一个:
    !$acc 导语名字 [ 子语列表 ]
    c$acc 导语名字 [ 子语列表 ]
    *$acc 导语名字 [ 子语列表 ]

前导符(!$acc、c$acc或*$acc)必须写在1~5列。固定格式的每行长度、空白字符、续行、列的规则同样适用于导语行。导语起始行第6列必须是空格或0,接续行导语在第6列不能是空格或零。导语行也可以添加注释,注释可以从第7列(包含)之后的任意列以感叹号开始,至行尾结束。
在Fortran中,导语不区分大小写。分写在多行的单个程序语句中间不能混入导语,同样,分写在多行的单个导语中间也不能混入程序语句。本文档中所有Fortran版导语例子都采用自由格式,建议读者也尽量避免新开发Fortran 77代码。
每个导语中只能有一个导语名字,一个例外是组合导语,它被视为单个导语名字。如无特别规定,多个子语出现的顺序无关紧要,子语可以重复出现多次。有些子语的参数会包含一个列表。列表是用逗号分隔的一串子语或参数。
相关文章
|
8月前
|
Python
解释Python中的并发编程和并行编程之间的区别。
解释Python中的并发编程和并行编程之间的区别。
55 0
|
6月前
|
存储 大数据 数据处理
逆天改命!生成器表达式让Python数据处理效率飙升,你还在等什么?
【7月更文挑战第2天】Python的生成器表达式是高效处理大数据的关键。它们惰性计算,按需生成值,节省内存,提升性能,尤其适合大规模数据集。通过简洁的语法,生成器表达式能轻松筛选、处理文件中的偶数等任务,避免内存溢出。掌握这一体现Python精髓的工具,将使你的代码更高效、更具可读性。立即开始使用生成器表达式,解锁数据处理新效能!**
54 0
|
编译器 程序员 C语言
C语言中的小知识点(程序环境和预处理篇(1))
C语言中的小知识点(程序环境和预处理篇(1))
76 0
|
并行计算 C语言 C++
《OpenACC并行编程实战》—— 第2章 OpenACC概览 2.1 OpenACC规范的内容
2007年出现的CUDA C/C++语言引爆了GPU通用计算热潮,但编程比较麻烦,挖掘硬件性能需要很多高超的优化技巧。为了降低编程门槛,2011年11月,Cray、PGI、CAPS和英伟达4家公司联合推出OpenACC 1.0编程标准,2012年3月PGI率先推出支持OpenACC的编译器PGI Accelerator with OpenACC。
3209 0
|
Python 程序员 Shell
带你读《Python 程序设计与问题求解(原书第2版)》之二:软件开发、数据类型和表达式
本书是为计算机科学专业程序设计课程编写的教材,选用流行且易于教学的Python语言,主要涵盖五个方面的内容:编程基础,包括数据类型、控制结构、 算法设计等;面向对象编程,包括基础原则和应用方法;数据和信息处理,包括字符串、数组、文件、列表等;软件开发生命周期,包括大量案例研究;编程实践,包括数字和文本处理、事件驱动编程、图形图像处理、网络通信等。书中的每个新概念只在解决问题时才被引入,重视培养良好的编程习惯,适合所有程序设计初学者阅读。
|
并行计算 异构计算
《OpenACC并行程序设计:性能优化实践指南》一 3.10 使用Score-P和Vampir记录OpenACC运行时事件
本节书摘来自华章出版社《OpenACC并行程序设计:性能优化实践指南》一 书中的第3章,第3.10节,作者:[美] 罗布·法伯(Rob Farber),更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1531 0
|
并行计算 异构计算
《OpenACC并行程序设计:性能优化实践指南》一 3.6 第一个并行PIConGPU实现
本节书摘来自华章出版社《OpenACC并行程序设计:性能优化实践指南》一 书中的第3章,第3.6节,作者:[美] 罗布·法伯(Rob Farber),更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1570 0
|
程序员 C++
《OpenACC并行程序设计:性能优化实践指南》一 1.2 简单的任务并行示例
本节书摘来自华章出版社《OpenACC并行程序设计:性能优化实践指南》一 书中的第1章,第1.2节,作者:[美] 罗布·法伯(Rob Farber),更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1496 0
|
并行计算 安全 程序员
《OpenACC并行程序设计:性能优化实践指南》一 1.1 简单的数据并行循环
本节书摘来自华章出版社《OpenACC并行程序设计:性能优化实践指南》一 书中的第1章,第1.1节,作者:[美] 罗布·法伯(Rob Farber),更多章节内容可以访问云栖社区“华章计算机”公众号查看。
3206 0
《OpenACC并行编程实战》—— 2.2 OpenACC 2.5规范
本节列出OpenACC的主要构件、导语,读完本书后可以在此处快速查阅语法,不必到正文中寻找零星的介绍。初次阅读请跳过。
1637 0