-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathasync-hello.f90
66 lines (55 loc) · 1.93 KB
/
async-hello.f90
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
program main
!! Demonstrate asynchronous communication of greetings created on multiple images
use iso_fortran_env, only : event_type
implicit none
type(event_type), allocatable :: greeting_ready(:)[:]
integer, parameter :: max_greeting_length=64
character(len=max_greeting_length) :: greeting[*]
integer alloc_stat
associate(me=>this_image(),ni=>num_images())
allocate(greeting_ready(2:ni)[*],stat=alloc_stat)
if (me/=1) then
write(greeting,*) "Hello from image",me,"of",ni
call random_init(repeatable=.false., image_distinct=.true.)
call random_delay
event post( greeting_ready(me)[1] )
else
write(greeting,*) "Hello from image",me,"of",ni
print *,greeting
block
logical greeting_not_printed(2:ni)
integer image, counter
greeting_not_printed = .true. ! set all array elements
do while(any(greeting_not_printed))
query_wait_print: &
do image = 2, ni
call event_query(greeting_ready(image), counter)
select case(counter)
case(0) !! nothing to do
case(1)
event wait(greeting_ready(image))
if (greeting_not_printed(image)) print *,greeting[image]
greeting_not_printed(image) = .false.
case default
error stop "invalid event count"
end select
end do query_wait_print
end do
end block
end if
end associate
contains
subroutine random_delay()
integer, parameter :: delay_magnitude=200
integer initial_count, current_count
real harvest
call system_clock(count=initial_count)
current_count = initial_count
call random_number(harvest)
associate(delay => delay_magnitude*harvest)
do while(current_count - initial_count < delay)
call system_clock(count=current_count)
end do
end associate
end subroutine
end program main