NVIDIA OpenACC 在线课程 (一) 学习笔记

1. pragma acc kernels[]
{
}
表示可能存在并行性,由编译器分析并行性,并根据分析结果决定是否生成GPU kernels


2. #pragma acc parallel loop 
开发者已经知道该循环可以并行化,不用编译器再来分析并行性;只并行化当前修饰的循环且该循环可以是嵌套的;


Independent clause
开发者知道循环迭代间不存在别名关系,例如 
pragma acc kernels[]
#pragma acc loop independent


3. pragma acc data  
{ }
表示所有的数据都会被保留在GPU平台上,直到到达区域外。{}里面可以是parallel loop或者多个kernels
copyin(a[0:N]) :0是起始位置,N表示元素个数
copyout(a[0:N]) copy(a[0:N]), create() 只分配内存,不拷贝数据;
present(list)已经在GPU上分配了内存,不需要分配
deviceptr:与cuda互操作,表示该指针就是在gpu上的指针


pgi社区版本 免费支持学术界使用,由NVIDIA提供支持,比gcc的支持更好;


PGI编译器指南
pgcc  -acc -Minfo=accel  -Mcuda=cc60 main.c
-ta=tesla 指定体系结构
-Mcuda=cc60 GPU的计算能力, k40的计算能力是cc35, p100计算能力是cc60
-Mcuda=keepgpu  生成kernel文件,但是可读性差;也可以保留到ptx代码
会打印编译信息
PGI_ACC_TIME=1 ./a.out




OpenACC默认是同步执行的;CUDA默认是异步执行的;


pragma acc loop gang, vector(128)  gang是指block,vector是指block内的线程数目
没有支持python的计划;
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: OpenACC是一种用于并行计算的编程模型,常用于加速CPU和GPU上的科学计算、机器学习等应用。以下是一些常用的OpenACC语句: 1. `#pragma acc parallel`:用于在CPU或GPU上创建并行区域。 2. `#pragma acc kernels`:用于在GPU上并行执行内核函数。 3. `#pragma acc loop`:用于在循环中并行化迭代。 4. `#pragma acc data`:用于在设备和主机之间传输数据。 5. `#pragma acc update`:用于在设备和主机之间更新数据。 6. `#pragma acc atomic`:用于在并行环境下对共享变量进行原子操作。 7. `#pragma acc cache`:用于指定数据在缓存中的存储方式。 这些语句可以根据具体应用的需求进行灵活地组合和使用。 ### 回答2: OpenACC是一种并行计算模型,常用于GPU加速计算。以下是一些常用的OpenACC语句: 1. `#pragma acc parallel loop`: 声明一个并行循环,将循环迭代并行化,使得循环中的迭代可以同时在GPU上执行。 2. `#pragma acc data`: 声明数据区域,用于将数据从主机内存传输到GPU内存,也可以将数据从GPU内存传输回主机内存。 3. `#pragma acc kernels`: 将下面的代码块标记为并行代码,让OpenACC将其编译为可以在GPU上并行执行的代码。 4. `#pragma acc routine`: 声明一个函数,使其能够在GPU上运行。 5. `#pragma acc loop seq`: 声明一个串行循环,即不在GPU上并行执行循环迭代。 6. `#pragma acc parallel`: 声明一个并行区域,将下面的代码块标记为可以并行执行的。 7. `#pragma acc enter data` 和 `#pragma acc exit data`: 用于手动控制数据在主机内存和GPU内存之间的传输,分别用于将数据传输到GPU和从GPU传输回主机。 8. `#pragma acc update`: 用于数据传输的指令,可以将数据从主机内存传输到GPU或从GPU传输回主机。 9. `#pragma acc atomic`: 用于确保对共享变量的原子操作,以避免多个线程同时访问造成的竞态条件。 以上是一些OpenACC常用语句的示例。根据具体的应用场景和需求,还可以使用更多的OpenACC指令来实现更复杂的并行计算任务。 ### 回答3: OpenACC是一种并行编程模型,用于在GPU上并行执行计算。在OpenACC中,常见的语句包括: 1. `#pragma acc parallel loop`:并行循环指令,用于将循环迭代分配到GPU上并行执行。 2. `#pragma acc parallel`:并行指令,用于将代码块分配到GPU上并行执行。 3. `#pragma acc loop`:循环指令,指示循环迭代可被并行执行。 4. `#pragma acc data`:数据指令,用于管理GPU内存的数据传输和复制。 5. `#pragma acc data copyin(array)`:数据指令,将数组从主机内存复制到GPU内存,并在计算结束后将结果从GPU内存复制回主机内存。 6. `#pragma acc data copy(array)`:数据指令,将数组从主机内存复制到GPU内存,并不将结果从GPU内存复制回主机内存。 7. `#pragma acc update host(array)`:数据指令,将数组从GPU内存复制回主机内存。 8. `#pragma acc update device(array)`:数据指令,将数组从主机内存复制到GPU内存。 9. `#pragma acc kernels`:指示下面的代码段在GPU上执行。 10. `#pragma acc routine(func)`:将函数标记为可在GPU上执行的设备代码。 这些是OpenACC中常见的语句,用于在GPU上实现并行计算。使用这些语句可以将代码分解成可以在不同线程上并行执行的任务,以提高计算性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值