OpenMP for Fortran
OpenMP for Fortran
- OpenMP Directive
- Syntax of OpenMP compiler directive for Fortran:
!$OMP DirectiveName Optional_CLAUSES...
...
... Program statements between the !$OMP lines
... are executed in parallel by all threads
...
!$OMP END DirectiveName - Program statements between the 2 red lines are executed by multiple threads
- Setting the level of parallellism in OpenMP programs
- The number of threads that will be created to execute parallel sections in an OpenMP program is controlled by the environment variable OMP_NUM_THREADS
- To set this environment variable use:
export OMP_NUM_THREADS=... Example: export OMP_NUM_THREADS=8
- Compiling OpenMP programs
- Fortran
- Compile:
f90 -O -c -xopenmp -stackvar Prog.f90
- Link:
f90 -O -o Executable \
-xopenmp -stackvar \
Prog1.o Prog2.o ....
- Compile:
- Fortran
- Introductory Example
- Parallel "Hello World" OpenMP program:
PROGRAM Main !$OMP PARALLEL print *, "Hello World !" !$OMP END PARALLEL END
- Example Program: (Demo above code)
- Prog file (OpenMP Hello World): click here
- Compile with:
- f90 -O
-xopenmp -stackvar
- openMP01.f90
- Run with:
- export OMP_NUM_THREADS=8
- a.out
Make sure you do it on compute.
You will see "Hello World !!!" printed EIGHT times !!! (Remove the #pragma line and you get ONE line)....
- Parallel "Hello World" OpenMP program:
- Defining shared and private (non-shared) variables in parallel section
- Recall:
- There is no scopes in Fortran
Fortran uses option keywords to define private (non-shared) (and shared) variables....
- Defining shared and private variables in a PARALLEL section
- A variable is by default shared among all threads
- A private variable in a PARALLE section must be specified using the option PRIVATE
- Fortran example of SHARED variable:
PROGRAM Main
IMPLICIT NONE integer :: N ! Shared N = 1001
print *, "Before parallel section: N = ", N !$OMP PARALLEL
N = N + 1
print *, "Inside parallel section: N = ", N
!$OMP END PARALLEL print *, "After parallel section: N = ", N
END - Example Program: (Demo above code)
- Prog file: (Shared variable in OpenMP) --- click here
- Compile with:
- f90 -O
-xopenmp -stackvar
- openMP02a.f90
- Run a few times with:
- export OMP_NUM_THREADS=8
- a.out
You should see the value for N at the end is not always 1009, it could be less. This is evidence of asynchronous update.
- Fortran example of NON-SHARED (private) variable:
PROGRAM Main
IMPLICIT NONE integer :: N ! Shared N = 1001
print *, "Before parallel section: N = ", N !$OMP PARALLEL PRIVATE(N)
N = N + 1
print *, "Inside parallel section: N = ", N
!$OMP END PARALLEL print *, "After parallel section: N = ", N
END - Example Program: (Demo above code)
- Prog file: (Private variable in OpenMP) --- click here
- Compile with:
- f90 -O
-xopenmp -stackvar
- openMP02b.f90
- Run a few times with:
- export OMP_NUM_THREADS=8
- a.out
- Output:
Before parallel section: N = 1001
Inside parallel section: N = 1
Inside parallel section: N = 1
Inside parallel section: N = 1
Inside parallel section: N = 1
Inside parallel section: N = 1
Inside parallel section: N = 1
Inside parallel section: N = 1
Inside parallel section: N = 1
After parallel section: N = 1001Each thread has its own variable N
This variable N is different from the "program" variable defined in the main program !!!
- OpenMP Support function
- Most useful support functions in OpenMP:
Function Name Effect omp_set_num_threads(int nthread) Set size of thread team INTEGER omp_get_num_threads() return size of thread team INTEGER omp_get_max_threads() return max size of thread team (typically equal to the number of processors INTEGER omp_get_thread_num() return thread ID of the thread that calls this function INTEGER omp_get_num_procs() return number of processors LOGICAL omp_in_parallel() return TRUE if currently in a PARALLEL segment - Here is a simple OMP program in Fortran:
PROGRAM Main
IMPLICIT NONE INTEGER :: nthreads, myid
INTEGER, EXTERNAL :: OMP_GET_THREAD_NUM, OMP_GET_NUM_THREADS !$OMP PARALLEL private(nthreads, myid) myid = OMP_GET_THREAD_NUM() print *, "Hello I am thread ", myid if (myid == 0) then
nthreads = OMP_GET_NUM_THREADS()
print *, "Number of threads = ", nthreads
end if !$OMP END PARALLEL END - Example Program: (OpenMP Fortran program) --- click here

- Compile using the following command:
- f90 -O
-xopenmp -stackvar
- hello.f90
- Run with:
- export OMP_NUM_THREADS=8
- a.out
- Output:
Hello I am thread 7
Hello I am thread 5
Hello I am thread 1
Hello I am thread 0
Hello I am thread 2
Number of threads = 8
Hello I am thread 4
Hello I am thread 3
Hello I am thread 6
- Caveat with Fortran
- Recall:
- Array indices in Fortran by default start with 1 (ONE)
- Observed from "Hello" program:
- Thread IDs start with 0 (ZERO)
- Caveat:
- Use ThreadID+1 as index to an array in Fortran !!!
- Recall:
- Example OpenMP Program: Find minimum in an array
- A sequential program in C++ can be found here: (click here)
- We will write this program using OpenMP in Fortran
- Parallel Find Min program in Fortran:
PROGRAM Min
IMPLICIT NONE INTEGER, PARAMETER :: MAX = 10000000 DOUBLE PRECISION, DIMENSION(MAX) :: x
DOUBLE PRECISION, DIMENSION(10) :: my_min
DOUBLE PRECISION :: rmin INTEGER :: num_threads
INTEGER :: i, n
INTEGER :: id, start, stop ! ===========================================================
! Declare the OpenMP functions
! ===========================================================
INTEGER, EXTERNAL :: OMP_GET_THREAD_NUM, OMP_GET_NUM_THREADS ! ===================================
! Parallel section: Find local minima
! ===================================
!$OMP PARALLEL PRIVATE(i, id, start, stop, num_threads, n) num_threads = omp_get_num_threads()
n = MAX/num_threads id = omp_get_thread_num() ! ----------------------------------
! Find my own starting index
! ----------------------------------
start = id * n + 1 !! Array start at 1 ! ----------------------------------
! Find my own stopping index
! ----------------------------------
if ( id <> (num_threads-1) ) then
stop = start + n
else
stop = MAX
end if ! ----------------------------------
! Find my own min
! ----------------------------------
my_min(id+1) = x(start) DO i = start+1, stop
IF ( x(i) < my_min(id+1) ) THEN
my_min(id+1) = x(i)
END IF
END DO !$OMP END PARALLEL ! ===================================
! Find min over the local minima
! ===================================
rmin = my_min() DO i = 2, num_threads
IF ( rmin < my_min(i) ) THEN
rmin = my_min(i)
END IF
END DO print *, "min = ", rmin
END PROGRAM - Example Program: (Demo above code)
- Prog file: click here
- f90 -O
-xopenmp -stackvar
- min-mt1.f90
- Run with:
- export OMP_NUM_THREADS=8
- a.out
- Mutual exclusion synchronization Primitives
- This mutual exclusion effect in Fortran is achieved in OpenMP using the following pragma:
!$OMP CRITICAL ... statements are guaranteed to be executed
,,, by ONE thread at any one time !$OMP END CRITICAL
- Example OpenMP program with synchronization: compute Pi
- Example:
PROGRAM Compute_PI
IMPLICIT NONE INTEGER, EXTERNAL :: OMP_GET_THREAD_NUM, OMP_GET_NUM_THREADS INTEGER N, i
INTEGER id, num_threads
DOUBLE PRECISION w, x, sum
DOUBLE PRECISION pi, mypi N = 50000000 !! Number of intervals
w = 1.0d0/N !! width of each interval sum = 0.0d0 !$OMP PARALLEL PRIVATE(i, id, num_threads, x, mypi) num_threads = omp_get_num_threads()
id = omp_get_thread_num() mypi = 0.0d0; DO i = id, N-1, num_threads
x = w * (i + 0.5d0)
mypi = mypi + w*f(x)
END DO !$OMP CRITICAL
pi = pi + mypi
!$OMP END CRITICAL !$OMP END PARALLEL PRINT *, "Pi = ", pi END PROGRAM - Example Program: (OpenMP compute Pi) --- click here

- Compile with:
- f90 -O
-xopenmp -stackvar
- openMP_compute_pi2.f90
- Run a few times with:
- export OMP_NUM_THREADS=8
- a.out
- Parallel For Loop in OpenMP
The division of labor (splitting the work of a for-loop) of a for-loop can be done in OpenMP through a special Parallel LOOP construct.
- A Parallel Loop construct MUST appear within a Parallel region of the program !
- The syntax of a Parallel LOOP construct in Fortran is:
!$OMP DO DO index = ....
.... ! Division of labor is taken care of
! by the Fortran compiler
END DO !$OMP END DO - The meaning of this Parallel LOOP construct is to distribute the iterations in the for-loop (or do-loop) among the threads.
Each iteration of the for-loop is executed exactly once by each thread.
The loop variable used in the Parallel LOOP construct is by default PRIVATE (other variables are still by default SHARED)
- Example: compute Pi with parallel DO loop
PROGRAM Compute_PI
IMPLICIT NONE INTEGER N, i, num_threads
DOUBLE PRECISION w, x, sum
DOUBLE PRECISION pi, mypi N = 50000000 !! Number of intervals
w = 1.0d0/N !! width of each interval sum = 0.0d0 !$OMP PARALLEL PRIVATE(x, mypi) mypi = 0.0d0; !$OMP DO
DO i = 0, N-1 !! Parallel Loop
x = w * (i + 0.5d0)
mypi = mypi + w*f(x)
END DO
!$OMP END DO !$OMP CRITICAL
pi = pi + mypi
!$OMP END CRITICAL !$OMP END PARALLEL PRINT *, "Pi = ", pi END PROGRAM - Example Program: (OpenMP compute Pi) --- click here

- Compile with:
- f90 -O
-xopenmp -stackvar
- openMP_compute_pi3.f90
- Run with:
- export OMP_NUM_THREADS=8
- a.out
- Final Notes
- The stack size of each thread can be controlled by setting another environment variable:
setenv STACKSIZE nBytes
- For more information on OpenMP, see: http://www.openmp.org
OpenMP for Fortran的更多相关文章
- 在fortran下进行openmp并行计算编程
最近写水动力的程序,体系太大,必须用并行才能算的动,无奈只好找了并行编程的资料学习了.我想我没有必要在博客里开一个什么并行编程的教程之类,因为网上到处都是,我就随手记点重要的笔记吧.这里主要是open ...
- Fortran+ OpenMP实现实例
PROGRAM parallel_01 USE omp_lib IMPLICIT NONE INTEGER :: i,j INTEGER() :: time_begin, time_end, time ...
- OpenMP并行构造的schedule子句详解 (转载)
原文:http://blog.csdn.net/gengshenghong/article/details/7000979 schedule的语法为: schedule(kind, [chunk_si ...
- openMP的一点使用经验【非原创】
按照百科上说的,针对于openmp的编程,最简单的就是在开头加个#include<omp.h>,然后在后面的for上加一行#pragma omp parallel for即可,下面的是较为 ...
- Call Paralution Solver from Fortran
Abstract: Paralution is an open source library for sparse iterative methods with special focus on mu ...
- OpenMP初步(英文)
Beginning OpenMP OpenMP provides a straight-forward interface to write software that can use multipl ...
- Fortran并行计算的一些例子
以下例子来自https://computing.llnl.gov/tutorials/openMP/exercise.html网站 一.打印线程(Hello world) C************* ...
- OpenMP并行编程
什么是OpenMP?“OpenMP (Open Multi-Processing) is an application programming interface (API) that support ...
- 学习OpenCV——OpenMP
转自:http://www.cnblogs.com/yangyangcv/archive/2012/03/23/2413335.html openMP的一点使用经验 最近在看多核编程.简单来说,由 ...
随机推荐
- C#学习笔记——Show()与ShowDialog()的区别
用Show()调用的窗体不会返回任何值,在使用form.Show()显示form以后,会马上继续执行form.Show()后面的语句.而用ShowDialog()调用的窗体会返回一个DialogRes ...
- 三种方法实现js跨域访问
转自:http://narutolby.iteye.com/blog/1464436 javascript跨域访问是web开发者经常遇到的问题,什么是跨域,一个域上加载的脚本获取或操作另一个域上的文档 ...
- RTP/RTCP/RTSP/SIP/SDP 关系(直接看总结)
RTP/RTCP/RTSP/SIP/SDP 关系 RTP(实时传输协议,传输层) Real-time Transport Protocol)是用于Internet上针对多媒体数据流的一种传输层协议 ...
- c# 作业2
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- jQuery插件AjaxFileUpload实现ajax文件上传
转自:http://www.cnblogs.com/linjiqin/p/3530848.html jQuery插件AjaxFileUpload用来实现ajax文件上传,该插件使用非常简单,接下来写个 ...
- Android 启动APP时黑屏白屏的三个解决方案
你会很奇怪,为什么有些app启动时,会出现一会儿的黑屏或者白屏才进入Activity的界面显示,但是有些app却不会如QQ手机端,的确这里要做处理一下.这里先了解一下为什么会出现这样的现象,其实很简单 ...
- 启动mysql出现了error the server quit without updating pid file (/var/lib/mysql/localhost.localdomain.pid)
原来是我的mysql日志太多,所以去/data/log/mysql目录(这个目录是从/etc/my.cnf中的log-error确定的)下删除了 rm -rf mysql_binary_log.*的日 ...
- SU sufdmod2命令学习
- RectAnimation用于在DrawingVisual画进度条
使用Visual来画图,可以使用其派生类,UIElement.Viewport3DVisual用于呈现3D内容,其他可以用来画图的为DrawingVisual,使用DrawingVisual可以使用编 ...
- 博客搬到blog.csgrandeur.com
博客已搬到blog.csgrandeur.com. cnblogs停止更新. wordpress太臃肿,难刷. hexo对windows似乎不太友好,迁移的时候建了十几层文件夹,导致目录过深无法移动无 ...