File: openmp_54.f90

package info (click to toggle)
lfortran 0.58.0-4
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 54,512 kB
  • sloc: cpp: 162,179; f90: 68,251; python: 17,476; ansic: 6,278; yacc: 2,334; sh: 1,317; fortran: 892; makefile: 33; javascript: 15
file content (42 lines) | stat: -rw-r--r-- 943 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
program openmp_54
  use omp_lib
  implicit none

  integer, parameter :: N = 1000
  integer :: i, tid
  integer :: total_sum
  integer :: partial_sum


  !$omp parallel shared(total_sum) private(i, partial_sum, tid)
    tid = omp_get_thread_num()
    partial_sum = 0
    total_sum = 0
    !$omp barrier

    !$omp do
        do i = 1, N
            partial_sum = partial_sum + i
        end do
    !$omp end do

    ! Critical update to the shared total_sum
    !$omp critical
        total_sum = total_sum + partial_sum
        print *, "Thread ", tid, " added partial_sum ", partial_sum
    !$omp end critical

    !$omp barrier

    !$omp single
        if (total_sum /= N*(N+1)/2) then
            print *, "ERROR: total_sum = ", total_sum, " expected = ", N*(N+1)/2
            error stop
        else
            print *, "Success! total_sum = ", total_sum
        end if
    !$omp end single

  !$omp end parallel

end program openmp_54