▶ OpenMP 的任务并行 (task parallelism):显式定义一系列可执行的任务及其相互依赖关系,通过任务调度的方式多线程动态执行,支持任务的延迟执行 (deferred execution)

● 变量的数据域:并行区共享变量 → task 区也为共享;并行区私有变量 → task 区为 firstprivate;task 区其他变量 → 默认私有

● 范例代码

 #include <stdio.h>
#include <omp.h>
#include <time.h> int fib(int n)
{
int x, y;
if (n < )
return n;
#pragma omp task shared(x) // 创建关于 x 的 task
x = fib(n - );
#pragma omp task shared(y) // 创建关于 y 的 task
y = fib(n - );
#pragma omp taskwait // 等待两个 task 完成才嫩开始接下来的计算
return x + y;
} int main()
{
int res, n = ;
clock_t tick = clock();
#pragma omp parallel // task 要在并行区内调用
{
#pragma omp single // 根任务只调用 1 次
res = fib(n);
}
printf("Fib[%d] == %d, time = %f ms\n", n, res, float(clock() - tick)/);
getchar();
return ;
}

▶ 动态线程:系统动态选择并行区的线程数 (默认关闭)

● 用库函数打开 / 关闭动态线程,flag == 0 按优先级决定线程数,flag != 0 系统动态调节线程数

void omp_set_dynamic(int flag)

● 用环境变量打开 / 关闭动态线程

export OMP_DYNAMIC = true

● 检查动态线程是否打开

int omp_get_dynamic (void)

▶ 嵌套并行:并行区之内开启并行区 (默认开启)

● 用库函数打开 / 关闭嵌套并行

void omp_set_nested(int flag)

● 用环境变量打开 / 关闭嵌套并行

export OMP_NESTED = true
export OMP_NUM_THREADS = n1, n2, n3 # 每层嵌套的线程数

● 检查嵌套并行是否打开

int omp_get_nested (void)

▶ 动态线程和嵌套并行的范例代码

 #include <stdio.h>
#include <omp.h>
#include <time.h> int main()
{
omp_set_dynamic(); // 关闭动态线程
#pragma omp parallel num_threads(2)
{
#pragma omp single // 一个线程来执行,返回 2
printf("Outer: num_thds=%d\n\n", omp_get_num_threads()); omp_set_nested(); // 开启嵌套并行
#pragma omp parallel num_threads(3) // 内嵌一个 3 线程的并行块
{
#pragma omp single
printf("Inner: num_thds=%d\n", omp_get_num_threads()); // 返回 3
}
#pragma omp barrier omp_set_nested(); // 关闭嵌套并行
#pragma omp parallel num_threads(3) // 内嵌一个 3 线程的并行块
{
#pragma omp single
printf("Inner: num_thds=%d\n", omp_get_num_threads()); // 返回 1
}
#pragma omp barrier
} getchar();
return ;
}

▶ 线程私有型全局变量:将全局变量置为线程私有(对线程而言是全局变量),必须置于全局变量的声明列表之后

#pragma omp threadprivate (list)

● 范例代码

 #include <stdio.h>
#include <omp.h> int a, b, i, tid;
float x; #pragma omp threadprivate(a, x) int main(int argc, char *argv[])
{
omp_set_dynamic();
omp_set_num_threads(); printf("1st Parallel Region:\n");
#pragma omp parallel private(b, tid)
{
tid = omp_get_thread_num();
a = tid;
b = tid;
x = float(tid);
printf("Thread %d: a, b, x= %d, %d, %f\n", tid, a, b, x);
} printf("\n2nd Parallel Region:\n");
#pragma omp parallel private(tid)
{
tid = omp_get_thread_num();
printf("Thread %d: a, b, x= %d, %d, %f\n", tid, a, b, x);
} getchar();
return ;
}

● 输出结果,b 没有私有化,保持了第一并行区的结果

1st Parallel Region :
Thread : a, b, x = , , 0.000000
Thread : a, b, x = , , 1.000000
Thread : a, b, x = , , 3.000000
Thread : a, b, x = , , 2.000000 2nd Parallel Region :
Thread : a, b, x = , , 0.000000
Thread : a, b, x = , , 2.000000
Thread : a, b, x = , , 3.000000
Thread : a, b, x = , , 1.000000

▶ OpenMP 堆栈:除了主线程,每个线程的私有变量存储空间受线程堆栈大小控制,超出堆栈大小程序的行为不可控

● OpenMP 堆栈大小依赖实现:icc 默认 4 MB;gcc / gfortran 默认 2 MB;

● 可以通过环境变量修改默认堆栈大小:

export OMP_STACKSIZE=32M
export OMP_STACKSIZE=8192K

▶ 线程亲和性(affinity)和线程绑定(binding):线程亲和性决定 NUMA 架构的系统上线程在物理计算核心的映射策略;线程绑定显式确定线程与物理计算核心的对应关系,以提升性能

● OpenMP 3.1 开始提供线程绑定支持,OpenMP 4.5 开始较好支持,工具:numactl(参考http://www.glennklockwood.com/hpc-howtos/process-affinity.html)

export OMP_PROC_BIND=TRUE

● icc 可设置线程亲和性(参考https://software.intel.com/en-us/node/522691)

export KMP_AFFINITY = [<modifier>,...] <type> [,<permute>] [,<offset>]

▶ PETSc (Portable Extensible Toolkit for Sciencific Computation)讲座相关

● Advanced Sciencific Computing:

  ■ 应用上(Large and Complex)

  ■ 算法上(fully or semi implicit, multileve, nested, hierarchical, computer architure aware)

  ■ 并行化(Libraries, extensible solvers, composable)

● 部分幻灯片

● 终端中的代码

cd petsc-3.10./
module add mpich
module add petsc
cd src/vec/vec/examples/tutorials/
ls -al
make ex2
srun -c mpiexec -n ./ ex2 # 指定 核心

分布式计算课程补充笔记 part 3的更多相关文章

  1. 分布式计算课程补充笔记 part 4

    ▶ 并行通讯方式: map 映射 全局一到一 全局单元素计算操作 transpose 转置 一到一 单元素位移 gather 收集 多到一 元素搬运不计算 scatter 分散 一到多 元素搬运不计算 ...

  2. 分布式计算课程补充笔记 part 2

    ▶ 并行计算八字原则:负载均衡,通信极小 ▶ 并行计算基本形式:主从并行.流水线并行.工作池并行.功能分解.区域分解.递归分治 ▶ MPI 主要理念:进程 (process):无共享存储:显式消息传递 ...

  3. 分布式计算课程补充笔记 part 1

    ▶ 高性能计算机发展历程 真空管电子计算机,向量机(Vector Machine),并行向量处理机(Parallel Vector Processors,PVP),分布式并行机(Parallel Pr ...

  4. 分布式计算课程补充笔记 part 1.5

    ▶ 编写 SLURM 脚本 #!/bin/bash #SBATCH -J name # 任务名 #SBATCH -p gpu # 分区名,可为 cpu 或 gpu #SBATCH -N # 节点数 # ...

  5. (转载)林轩田机器学习基石课程学习笔记1 — The Learning Problem

    (转载)林轩田机器学习基石课程学习笔记1 - The Learning Problem When Can Machine Learn? Why Can Machine Learn? How Can M ...

  6. 03、同事分享课程的笔记 —《Android应用低功耗设计》

    这是安卓组的同事一个月前分享的一节课程,听课时写了一下笔记,之前是写在本子上的,感觉内容挺不错 的,就保存在博客了吧,方便回看. 他曾经在就职于英特尔公司,是与芯片设计相关的,这课程标题虽然是与安卓相 ...

  7. Coursera台大机器学习基础课程学习笔记1 -- 机器学习定义及PLA算法

    最近在跟台大的这个课程,觉得不错,想把学习笔记发出来跟大家分享下,有错误希望大家指正. 一机器学习是什么? 感觉和 Tom M. Mitchell的定义几乎一致, A computer program ...

  8. 分布式计算框架学习笔记--hadoop工作原理

    (hadoop安装方法:http://blog.csdn.net/wangjia55/article/details/53160679这里不再累述) hadoop是针对大数据设计的一个计算架构.如果你 ...

  9. [基础]斯坦福cs231n课程视频笔记(三) 训练神经网络

    目录 training Neural Network Activation function sigmoid ReLU Preprocessing Batch Normalization 权重初始化 ...

随机推荐

  1. R语言安装xlsx包,读入excel表格

    开学的时候,男神给了数据(.xlsx格式)让用R语言分析分析,作为编程小白,读了一天都没读近R,更别提如何分析了. 现在小伙伴们都喜欢读txt 和csv格式的,好多xlsx的表格读不进R,将xlsx格 ...

  2. 一十九条优雅Python编程技巧

    1.交换赋值 #不推荐 temp = a a = b b = a #推荐 a , b = b , a #先生成一个元组(tuple)对象,然后在unpack 2.Unpacking #不推荐 l = ...

  3. 读txt文件乱码

    /** * 读入TXT文件 */public static List<String> readFile(String pathName) {// 绝对路径或相对路径都可以,写入文件时演示相 ...

  4. 使用Sublime Text 3进行Markdown 编辑+实时预览

    这种做法可能会对你的磁盘IO造成一小部分性能负担,但负面影响足以忽略. 另外,由于这种频率的读写会被磁盘缓存接管,不必担心磁盘寿命的影响. 对于刚安装好的Sublime Text,我们需要安装一个软件 ...

  5. jQuery-1.样式篇---选择器

    jQuery选择器之id选择器 页面的任何操作都需要节点的支撑,开发者如何快速高效的找到指定的节点也是前端开发中的一个重点.jQuery提供了一系列的选择器帮助开发者达到这一目的,让开发者可以更少的处 ...

  6. C++学习(三十七)(C语言部分)之 链式栈(推箱子实现)

    用链表实现栈一开始在表头插入,就要一直在表头插入一开始在表尾插入,就要一直在表头插尾表头当栈底 也可以把表尾当栈底 实现的测试代码笔记如下: #include<stdio.h> #incl ...

  7. C# Restful 启用 Session

    虽然很多人说不建议启用,但我就是想启用. [ServiceContract(SessionMode=SessionMode.Allowed)] public interface IBIService ...

  8. 使用vue自定义简单的消息提示框

    <style scoped> /** 弹窗动画*/ a { text-decoration: none } .drop-enter-active { /* 动画进入过程:0.5s */ t ...

  9. jar包不能乱放【浪费了下午很多时间】

    不能放在类路径下(也即是src文件夹下),然后再buildpath 必须放在web-inf文件夹下 这样才能tomcat找打jar文件

  10. js+css jQuery实现页面后退执行 & 遮罩弹框

    JS部分 <script src="http://libs.baidu.com/jquery/2.0.0/jquery.js"></script> < ...