17 type (hecmwST_local_mesh) :: hecMESH
19 integer(kind=kint):: ierr
20 call mpi_barrier (hecmesh%MPI_COMM, ierr)
27 integer(kind=kint) :: sc
28 double precision :: sbuf(sc)
29 integer(kind=kint) :: disp
30 integer(kind=kint) :: rc
31 double precision :: rbuf(rc)
32 integer(kind=kint) :: root
33 integer(kind=kint) :: comm
35 integer(kind=kint) :: ierr
36 call mpi_scatterv( sbuf, sc, disp, mpi_double_precision, &
37 rbuf, rc, mpi_double_precision, &
49 integer(kind=kint) :: operation
66 integer(kind=kint) :: sbuf(*)
67 integer(kind=kint) :: rval
68 integer(kind=kint) :: root
69 integer(kind=kint) :: comm
71 integer(kind=kint) :: ierr
72 call mpi_scatter( sbuf, 1, mpi_integer, &
73 & rval, 1, mpi_integer, root, comm, ierr )
82 integer(kind=kint) :: sval
83 integer(kind=kint) :: rbuf(*)
84 integer(kind=kint) :: root
85 integer(kind=kint) :: comm
87 integer(kind=kint) :: ierr
88 call mpi_gather( sval, 1, mpi_integer, &
89 & rbuf, 1, mpi_integer, root, comm, ierr )
98 integer(kind=kint) :: sval
99 integer(kind=kint) :: rbuf(*)
100 integer(kind=kint) :: comm
102 integer(kind=kint) :: ierr
103 call mpi_allgather( sval, 1, mpi_integer, &
104 & rbuf, 1, mpi_integer, comm, ierr )
111 & rbuf, rc, root, comm)
114 real(kind=
kreal) :: sbuf(*)
115 integer(kind=kint) :: scs(*)
116 integer(kind=kint) :: disp(*)
117 real(kind=
kreal) :: rbuf(*)
118 integer(kind=kint) :: rc
119 integer(kind=kint) :: root
120 integer(kind=kint) :: comm
122 integer(kind=kint) :: ierr
123 call mpi_scatterv( sbuf, scs, disp, mpi_real8, &
124 & rbuf, rc, mpi_real8, root, comm, ierr )
126 rbuf(1:rc)=sbuf(1:rc)
131 & rbuf, rcs, disp, root, comm)
134 real(kind=
kreal) :: sbuf(*)
135 integer(kind=kint) :: sc
136 real(kind=
kreal) :: rbuf(*)
137 integer(kind=kint) :: rcs(*)
138 integer(kind=kint) :: disp(*)
139 integer(kind=kint) :: root
140 integer(kind=kint) :: comm
142 integer(kind=kint) :: ierr
143 call mpi_gatherv( sbuf, sc, mpi_real8, &
144 & rbuf, rcs, disp, mpi_real8, root, comm, ierr )
146 rbuf(1:sc)=sbuf(1:sc)
151 & rbuf, rcs, disp, root, comm)
154 integer(kind=kint) :: sbuf(*)
155 integer(kind=kint) :: sc
156 integer(kind=kint) :: rbuf(*)
157 integer(kind=kint) :: rcs(*)
158 integer(kind=kint) :: disp(*)
159 integer(kind=kint) :: root
160 integer(kind=kint) :: comm
162 integer(kind=kint) :: ierr
163 call mpi_gatherv( sbuf, sc, mpi_integer, &
164 & rbuf, rcs, disp, mpi_integer, root, comm, ierr )
166 rbuf(1:sc)=sbuf(1:sc)
173 integer(kind=kint) :: sval
174 integer(kind=kint) :: rval
175 integer(kind=kint):: op, comm, ierr
177 call mpi_allreduce(sval, rval, 1, mpi_integer, &
187 integer(kind=kint) :: sbuf(*)
188 integer(kind=kint) :: sc
189 integer(kind=kint) :: rbuf(*)
190 integer(kind=kint) :: rc
191 integer(kind=kint) :: comm
193 integer(kind=kint) :: ierr
194 call mpi_alltoall( sbuf, sc, mpi_integer, &
195 & rbuf, rc, mpi_integer, comm, ierr )
197 rbuf(1:sc)=sbuf(1:sc)
205 integer(kind=kint) :: sbuf(*)
206 integer(kind=kint) :: sc
207 integer(kind=kint) :: dest
208 integer(kind=kint) :: tag
209 integer(kind=kint) :: comm
210 integer(kind=kint) :: req
212 integer(kind=kint) :: ierr
213 call mpi_isend(sbuf, sc, mpi_integer, &
214 & dest, tag, comm, req, ierr)
222 integer(kind=kint) :: sc
223 double precision,
dimension(sc) :: sbuf
224 integer(kind=kint) :: dest
225 integer(kind=kint) :: tag
226 integer(kind=kint) :: comm
227 integer(kind=kint) :: req
229 integer(kind=kint) :: ierr
230 call mpi_isend(sbuf, sc, mpi_double_precision, &
231 & dest, tag, comm, req, ierr)
239 integer(kind=kint) :: rbuf(*)
240 integer(kind=kint) :: rc
241 integer(kind=kint) :: source
242 integer(kind=kint) :: tag
243 integer(kind=kint) :: comm
244 integer(kind=kint) :: req
246 integer(kind=kint) :: ierr
247 call mpi_irecv(rbuf, rc, mpi_integer, &
248 & source, tag, comm, req, ierr)
256 integer(kind=kint) :: rc
257 double precision,
dimension(rc) :: rbuf
258 integer(kind=kint) :: source
259 integer(kind=kint) :: tag
260 integer(kind=kint) :: comm
261 integer(kind=kint) :: req
263 integer(kind=kint) :: ierr
264 call mpi_irecv(rbuf, rc, mpi_double_precision, &
265 & source, tag, comm, req, ierr)
272 integer(kind=kint) :: cnt
273 integer(kind=kint) :: reqs(*)
274 integer(kind=kint) :: stats(HECMW_STATUS_SIZE,*)
276 integer(kind=kint) :: ierr
277 call mpi_waitall(cnt, reqs, stats, ierr)
285 integer(kind=kint) :: rbuf(*)
286 integer(kind=kint) :: rc
287 integer(kind=kint) :: source
288 integer(kind=kint) :: tag
289 integer(kind=kint) :: comm
290 integer(kind=kint) :: stat(HECMW_STATUS_SIZE)
292 integer(kind=kint) :: ierr
293 call mpi_recv(rbuf, rc, mpi_integer, &
294 & source, tag, comm, stat, ierr)
302 integer(kind=kint) :: rc
303 double precision,
dimension(rc) :: rbuf
304 integer(kind=kint) :: source
305 integer(kind=kint) :: tag
306 integer(kind=kint) :: comm
307 integer(kind=kint) :: stat(HECMW_STATUS_SIZE)
309 integer(kind=kint) :: ierr
310 call mpi_recv(rbuf, rc, mpi_double_precision, &
311 & source, tag, comm, stat, ierr)
322 integer(kind=kint) :: n, hec_op,op, comm, ierr
323 double precision,
dimension(n) :: val
324 double precision,
dimension(n) :: VALM
326 select case( hec_op )
336 call mpi_allreduce(val,valm,n,mpi_double_precision,op,comm,ierr)
338 integer(kind=kint) :: i
348 integer(kind=kint) :: hec_op, comm
349 double precision :: s1, s2
350 double precision,
dimension(1) :: val
351 double precision,
dimension(1) :: VALM
370 integer(kind=kint):: n, ntag
371 real(kind=
kreal),
dimension(n) :: val
372 type (hecmwST_local_mesh) :: hecMESH
374 integer(kind=kint):: ierr
375 real(kind=
kreal),
dimension(:),
allocatable :: valm
381 & (val, valm, n, mpi_double_precision, mpi_sum, &
382 & hecmesh%MPI_COMM, ierr)
387 & (val, valm, n, mpi_double_precision, mpi_max, &
388 & hecmesh%MPI_COMM, ierr)
393 & (val, valm, n, mpi_double_precision, mpi_min, &
394 & hecmesh%MPI_COMM, ierr)
405 integer(kind=kint):: ntag
406 real(kind=
kreal) :: s
407 type (hecmwST_local_mesh) :: hecMESH
409 real(kind=
kreal),
dimension(1) :: val
424 integer(kind=kint):: n, ntag
425 integer(kind=kint),
dimension(n) :: val
426 type (hecmwST_local_mesh) :: hecMESH
428 integer(kind=kint):: ierr
429 integer(kind=kint),
dimension(:),
allocatable :: VALM
435 & (val, valm, n, mpi_integer, mpi_sum, &
436 & hecmesh%MPI_COMM, ierr)
441 & (val, valm, n, mpi_integer, mpi_max, &
442 & hecmesh%MPI_COMM, ierr)
447 & (val, valm, n, mpi_integer, mpi_min, &
448 & hecmesh%MPI_COMM, ierr)
460 integer(kind=kint):: ntag, s
461 type (hecmwST_local_mesh) :: hecMESH
463 integer(kind=kint),
dimension(1) :: val
479 integer(kind=kint):: n, nbase
480 real(kind=
kreal),
dimension(n) :: val
481 type (hecmwST_local_mesh) :: hecMESH
483 integer(kind=kint):: ierr
484 call mpi_bcast (val, n, mpi_double_precision, nbase, hecmesh%MPI_COMM, ierr)
491 integer(kind=kint):: n, nbase
492 real(kind=
kreal),
dimension(n) :: val
493 integer(kind=kint):: comm
495 integer(kind=kint):: ierr
496 call mpi_bcast (val, n, mpi_double_precision, nbase, comm, ierr)
503 integer(kind=kint):: nbase, ierr
504 real(kind=
kreal) :: s
505 type (hecmwST_local_mesh) :: hecMESH
507 real(kind=
kreal),
dimension(1) :: val
509 call mpi_bcast (val, 1, mpi_double_precision, nbase, hecmesh%MPI_COMM, ierr)
517 integer(kind=kint):: nbase
518 real(kind=
kreal) :: s
519 integer(kind=kint):: comm
521 integer(kind=kint):: ierr
522 real(kind=
kreal),
dimension(1) :: val
524 call mpi_bcast (val, 1, mpi_double_precision, nbase, comm, ierr)
536 integer(kind=kint):: n, nbase
537 integer(kind=kint),
dimension(n) :: val
538 type (hecmwST_local_mesh) :: hecMESH
540 integer(kind=kint):: ierr
541 call mpi_bcast (val, n, mpi_integer, nbase, hecmesh%MPI_COMM, ierr)
548 integer(kind=kint):: n, nbase
549 integer(kind=kint),
dimension(n) :: val
550 integer(kind=kint):: comm
552 integer(kind=kint):: ierr
553 call mpi_bcast (val, n, mpi_integer, nbase, comm, ierr)
560 integer(kind=kint):: nbase, s
561 type (hecmwST_local_mesh) :: hecMESH
563 integer(kind=kint):: ierr
564 integer(kind=kint),
dimension(1) :: val
566 call mpi_bcast (val, 1, mpi_integer, nbase, hecmesh%MPI_COMM, ierr)
574 integer(kind=kint):: nbase, s
575 integer(kind=kint):: comm
577 integer(kind=kint):: ierr
578 integer(kind=kint),
dimension(1) :: val
580 call mpi_bcast (val, 1, mpi_integer, nbase, comm, ierr)
592 integer(kind=kint):: n, nn, nbase
593 character(len=n) :: val(nn)
594 type (hecmwST_local_mesh) :: hecMESH
596 integer(kind=kint):: ierr
597 call mpi_bcast (val, n*nn, mpi_character, nbase, hecmesh%MPI_COMM,&
605 integer(kind=kint):: n, nn, nbase
606 character(len=n) :: val(nn)
607 integer(kind=kint):: comm
609 integer(kind=kint):: ierr
610 call mpi_bcast (val, n*nn, mpi_character, nbase, comm,&
624 integer(kind=kint):: n, m
625 real(kind=
kreal),
dimension(m*n) :: val
626 type (hecmwST_local_mesh) :: hecMESH
628 integer(kind=kint):: ns, nr
629 real(kind=
kreal),
dimension(:),
allocatable :: ws, wr
631 if( hecmesh%n_neighbor_pe == 0 )
return
633 ns = hecmesh%import_index(hecmesh%n_neighbor_pe)
634 nr = hecmesh%export_index(hecmesh%n_neighbor_pe)
636 allocate (ws(m*ns), wr(m*nr))
638 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
639 & hecmesh%import_index, hecmesh%import_item, &
640 & hecmesh%export_index, hecmesh%export_item, &
641 & ws, wr, val , hecmesh%MPI_COMM, hecmesh%my_rank)
655 integer(kind=kint):: n, m
656 integer(kind=kint),
dimension(m*n) :: val
657 type (hecmwST_local_mesh) :: hecMESH
659 integer(kind=kint):: ns, nr
660 integer(kind=kint),
dimension(:),
allocatable :: WS, WR
662 if( hecmesh%n_neighbor_pe == 0 )
return
664 ns = hecmesh%import_index(hecmesh%n_neighbor_pe)
665 nr = hecmesh%export_index(hecmesh%n_neighbor_pe)
667 allocate (ws(m*ns), wr(m*nr))
669 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
670 & hecmesh%import_index, hecmesh%import_item, &
671 & hecmesh%export_index, hecmesh%export_item, &
672 & ws, wr, val , hecmesh%MPI_COMM, hecmesh%my_rank)
687 integer(kind=kint):: n, m
688 real(kind=
kreal),
dimension(m*n) :: val
689 type (hecmwST_local_mesh) :: hecMESH
691 integer(kind=kint):: ns, nr
692 real(kind=
kreal),
dimension(:),
allocatable :: ws, wr
694 if( hecmesh%n_neighbor_pe == 0 )
return
696 ns = hecmesh%export_index(hecmesh%n_neighbor_pe)
697 nr = hecmesh%import_index(hecmesh%n_neighbor_pe)
699 allocate (ws(m*ns), wr(m*nr))
701 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
702 & hecmesh%import_index, hecmesh%import_item, &
703 & hecmesh%export_index, hecmesh%export_item, &
704 & ws, wr, val , hecmesh%MPI_COMM, hecmesh%my_rank)
720 integer(kind=kint):: n, m, ireq
721 real(kind=
kreal),
dimension(m*n) :: val
722 type (hecmwST_local_mesh) :: hecMESH
724 if( hecmesh%n_neighbor_pe == 0 )
return
727 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
728 & hecmesh%import_index, hecmesh%import_item, &
729 & hecmesh%export_index, hecmesh%export_item, &
730 & val , hecmesh%MPI_COMM, hecmesh%my_rank, ireq)
745 integer(kind=kint):: ireq
746 type (hecmwST_local_mesh) :: hecMESH
748 if( hecmesh%n_neighbor_pe == 0 )
return
765 integer(kind=kint):: n, m
766 integer(kind=kint),
dimension(m*n) :: val
767 type (hecmwST_local_mesh) :: hecMESH
769 integer(kind=kint):: ns, nr
770 integer(kind=kint),
dimension(:),
allocatable :: WS, WR
772 if( hecmesh%n_neighbor_pe == 0 )
return
774 ns = hecmesh%export_index(hecmesh%n_neighbor_pe)
775 nr = hecmesh%import_index(hecmesh%n_neighbor_pe)
777 allocate (ws(m*ns), wr(m*nr))
779 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
780 & hecmesh%import_index, hecmesh%import_item, &
781 & hecmesh%export_index, hecmesh%export_item, &
782 & ws, wr, val , hecmesh%MPI_COMM, hecmesh%my_rank)