17 type (hecmwST_local_mesh) :: hecMESH
19 integer(kind=kint):: ierr
20 call mpi_barrier (hecmesh%MPI_COMM, ierr)
27 double precision :: sbuf(*)
28 integer(kind=kint) :: sc(*)
29 integer(kind=kint) :: disp(*)
30 double precision :: rbuf(*)
31 integer(kind=kint) :: 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
474 integer(kind=kint):: ntag
476 type (hecmwST_local_mesh) :: hecMESH
478 integer(kind=kint):: ierr
484 & (flag, flagm, 1, mpi_logical, mpi_lor, &
485 & hecmesh%MPI_COMM, ierr)
490 & (flag, flagm, 1, mpi_logical, mpi_land, &
491 & hecmesh%MPI_COMM, ierr)
506 integer(kind=kint):: n, nbase
507 real(kind=
kreal),
dimension(n) :: val
508 type (hecmwST_local_mesh) :: hecMESH
510 integer(kind=kint):: ierr
511 call mpi_bcast (val, n, mpi_double_precision, nbase, hecmesh%MPI_COMM, ierr)
518 integer(kind=kint):: n, nbase
519 real(kind=
kreal),
dimension(n) :: val
520 integer(kind=kint):: comm
522 integer(kind=kint):: ierr
523 call mpi_bcast (val, n, mpi_double_precision, nbase, comm, ierr)
530 integer(kind=kint):: nbase, ierr
531 real(kind=
kreal) :: s
532 type (hecmwST_local_mesh) :: hecMESH
534 real(kind=
kreal),
dimension(1) :: val
536 call mpi_bcast (val, 1, mpi_double_precision, nbase, hecmesh%MPI_COMM, ierr)
544 integer(kind=kint):: nbase
545 real(kind=
kreal) :: s
546 integer(kind=kint):: comm
548 integer(kind=kint):: ierr
549 real(kind=
kreal),
dimension(1) :: val
551 call mpi_bcast (val, 1, mpi_double_precision, nbase, comm, ierr)
563 integer(kind=kint):: n, nbase
564 integer(kind=kint),
dimension(n) :: val
565 type (hecmwST_local_mesh) :: hecMESH
567 integer(kind=kint):: ierr
568 call mpi_bcast (val, n, mpi_integer, nbase, hecmesh%MPI_COMM, ierr)
575 integer(kind=kint):: n, nbase
576 integer(kind=kint),
dimension(n) :: val
577 integer(kind=kint):: comm
579 integer(kind=kint):: ierr
580 call mpi_bcast (val, n, mpi_integer, nbase, comm, ierr)
587 integer(kind=kint):: nbase, s
588 type (hecmwST_local_mesh) :: hecMESH
590 integer(kind=kint):: ierr
591 integer(kind=kint),
dimension(1) :: val
593 call mpi_bcast (val, 1, mpi_integer, nbase, hecmesh%MPI_COMM, ierr)
601 integer(kind=kint):: nbase, s
602 integer(kind=kint):: comm
604 integer(kind=kint):: ierr
605 integer(kind=kint),
dimension(1) :: val
607 call mpi_bcast (val, 1, mpi_integer, nbase, comm, ierr)
619 integer(kind=kint):: n, nn, nbase
620 character(len=n) :: val(nn)
621 type (hecmwST_local_mesh) :: hecMESH
623 integer(kind=kint):: ierr
624 call mpi_bcast (val, n*nn, mpi_character, nbase, hecmesh%MPI_COMM,&
632 integer(kind=kint):: n, nn, nbase
633 character(len=n) :: val(nn)
634 integer(kind=kint):: comm
636 integer(kind=kint):: ierr
637 call mpi_bcast (val, n*nn, mpi_character, nbase, comm,&
651 integer(kind=kint):: n, m
652 real(kind=
kreal),
dimension(m*n) :: val
653 type (hecmwST_local_mesh) :: hecMESH
655 integer(kind=kint):: ns, nr
656 real(kind=
kreal),
dimension(:),
allocatable :: ws, wr
658 if( hecmesh%n_neighbor_pe == 0 )
return
660 ns = hecmesh%import_index(hecmesh%n_neighbor_pe)
661 nr = hecmesh%export_index(hecmesh%n_neighbor_pe)
663 allocate (ws(m*ns), wr(m*nr))
665 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
666 & hecmesh%import_index, hecmesh%import_item, &
667 & hecmesh%export_index, hecmesh%export_item, &
668 & ws, wr, val , hecmesh%MPI_COMM, hecmesh%my_rank)
682 integer(kind=kint):: n, m
683 integer(kind=kint),
dimension(m*n) :: val
684 type (hecmwST_local_mesh) :: hecMESH
686 integer(kind=kint):: ns, nr
687 integer(kind=kint),
dimension(:),
allocatable :: WS, WR
689 if( hecmesh%n_neighbor_pe == 0 )
return
691 ns = hecmesh%import_index(hecmesh%n_neighbor_pe)
692 nr = hecmesh%export_index(hecmesh%n_neighbor_pe)
694 allocate (ws(m*ns), wr(m*nr))
696 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
697 & hecmesh%import_index, hecmesh%import_item, &
698 & hecmesh%export_index, hecmesh%export_item, &
699 & ws, wr, val , hecmesh%MPI_COMM, hecmesh%my_rank)
714 integer(kind=kint):: n, m
715 real(kind=
kreal),
dimension(m*n) :: val
716 type (hecmwST_local_mesh) :: hecMESH
718 integer(kind=kint):: ns, nr
719 real(kind=
kreal),
dimension(:),
allocatable :: ws, wr
721 if( hecmesh%n_neighbor_pe == 0 )
return
723 ns = hecmesh%export_index(hecmesh%n_neighbor_pe)
724 nr = hecmesh%import_index(hecmesh%n_neighbor_pe)
726 allocate (ws(m*ns), wr(m*nr))
728 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
729 & hecmesh%import_index, hecmesh%import_item, &
730 & hecmesh%export_index, hecmesh%export_item, &
731 & ws, wr, val , hecmesh%MPI_COMM, hecmesh%my_rank)
747 integer(kind=kint):: n, m, ireq
748 real(kind=
kreal),
dimension(m*n) :: val
749 type (hecmwST_local_mesh) :: hecMESH
751 if( hecmesh%n_neighbor_pe == 0 )
return
754 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
755 & hecmesh%import_index, hecmesh%import_item, &
756 & hecmesh%export_index, hecmesh%export_item, &
757 & val , hecmesh%MPI_COMM, hecmesh%my_rank, ireq)
772 integer(kind=kint):: ireq
773 type (hecmwST_local_mesh) :: hecMESH
775 if( hecmesh%n_neighbor_pe == 0 )
return
792 integer(kind=kint):: n, m
793 integer(kind=kint),
dimension(m*n) :: val
794 type (hecmwST_local_mesh) :: hecMESH
796 integer(kind=kint):: ns, nr
797 integer(kind=kint),
dimension(:),
allocatable :: WS, WR
799 if( hecmesh%n_neighbor_pe == 0 )
return
801 ns = hecmesh%export_index(hecmesh%n_neighbor_pe)
802 nr = hecmesh%import_index(hecmesh%n_neighbor_pe)
804 allocate (ws(m*ns), wr(m*nr))
806 & ( n, m, hecmesh%n_neighbor_pe, hecmesh%neighbor_pe, &
807 & hecmesh%import_index, hecmesh%import_item, &
808 & hecmesh%export_index, hecmesh%export_item, &
809 & ws, wr, val , hecmesh%MPI_COMM, hecmesh%my_rank)
subroutine hecmw_solve_send_recv_i(N, m, NEIBPETOT, NEIBPE, STACK_IMPORT, NOD_IMPORT, STACK_EXPORT, NOD_EXPORT, WS, WR, X, SOLVER_COMM, my_rank)
subroutine hecmw_solve_rev_send_recv_i(N, M, NEIBPETOT, NEIBPE, STACK_IMPORT, NOD_IMPORT, STACK_EXPORT, NOD_EXPORT, WS, WR, X, SOLVER_COMM, my_rank)
subroutine hecmw_solve_isend_irecv_wait(m, ireq)
subroutine hecmw_solve_isend_irecv(N, M, NEIBPETOT, NEIBPE, STACK_IMPORT, NOD_IMPORT, STACK_EXPORT, NOD_EXPORT, X, SOLVER_COMM, my_rank, ireq)
subroutine hecmw_solve_send_recv(N, m, NEIBPETOT, NEIBPE, STACK_IMPORT, NOD_IMPORT, STACK_EXPORT, NOD_EXPORT, WS, WR, X, SOLVER_COMM, my_rank)
subroutine hecmw_solve_rev_send_recv(N, M, NEIBPETOT, NEIBPE, STACK_IMPORT, NOD_IMPORT, STACK_EXPORT, NOD_EXPORT, WS, WR, X, SOLVER_COMM, my_rank)
integer(kind=kint), parameter hecmw_land
integer(kind=kint), parameter hecmw_sum
integer(kind=kint), parameter hecmw_prod
integer(kind=kint), parameter hecmw_max
integer(kind=4), parameter kreal
integer(kind=kint), parameter hecmw_lor
integer(kind=kint), parameter hecmw_min
subroutine hecmw_assemble_r(hecMESH, val, n, m)
subroutine hecmw_bcast_c_comm(val, n, nn, nbase, comm)
subroutine hecmw_gatherv_real(sbuf, sc, rbuf, rcs, disp, root, comm)
subroutine hecmw_update_r(hecMESH, val, n, m)
subroutine hecmw_isend_int(sbuf, sc, dest, tag, comm, req)
subroutine hecmw_scatterv_real(sbuf, scs, disp, rbuf, rc, root, comm)
subroutine hecmw_recv_int(rbuf, rc, source, tag, comm, stat)
subroutine hecmw_bcast_r_comm(val, n, nbase, comm)
subroutine hecmw_bcast_c(hecMESH, val, n, nn, nbase)
subroutine hecmw_isend_r(sbuf, sc, dest, tag, comm, req)
subroutine hecmw_allreduce_i1(hecMESH, s, ntag)
subroutine hecmw_gather_int_1(sval, rbuf, root, comm)
subroutine hecmw_bcast_i_comm(val, n, nbase, comm)
subroutine hecmw_allreduce_i(hecMESH, val, n, ntag)
subroutine hecmw_allreduce_r(hecMESH, val, n, ntag)
subroutine hecmw_bcast_i1(hecMESH, s, nbase)
subroutine hecmw_allgather_int_1(sval, rbuf, comm)
subroutine hecmw_allreduce_dp1(s1, s2, hec_op, comm)
subroutine hecmw_waitall(cnt, reqs, stats)
subroutine hecmw_assemble_i(hecMESH, val, n, m)
subroutine hecmw_allreduce_dp(val, VALM, n, hec_op, comm)
subroutine hecmw_bcast_r(hecMESH, val, n, nbase)
subroutine hecmw_irecv_int(rbuf, rc, source, tag, comm, req)
subroutine hecmw_bcast_r1_comm(s, nbase, comm)
subroutine hecmw_scatter_int_1(sbuf, rval, root, comm)
subroutine hecmw_irecv_r(rbuf, rc, source, tag, comm, req)
subroutine hecmw_allreduce_l1(hecMESH, flag, ntag)
subroutine hecmw_bcast_i(hecMESH, val, n, nbase)
subroutine hecmw_update_r_async(hecMESH, val, n, m, ireq)
subroutine hecmw_update_i(hecMESH, val, n, m)
subroutine hecmw_recv_r(rbuf, rc, source, tag, comm, stat)
subroutine hecmw_allreduce_r1(hecMESH, s, ntag)
subroutine hecmw_alltoall_int(sbuf, sc, rbuf, rc, comm)
subroutine hecmw_update_r_wait(hecMESH, ireq)
subroutine hecmw_bcast_r1(hecMESH, s, nbase)
subroutine hecmw_scatterv_dp(sbuf, sc, disp, rbuf, rc, root, comm)
subroutine hecmw_allreduce_int_1(sval, rval, op, comm)
subroutine hecmw_gatherv_int(sbuf, sc, rbuf, rcs, disp, root, comm)
subroutine hecmw_barrier(hecMESH)
integer(kind=kint) function hecmw_operation_hec2mpi(operation)
subroutine hecmw_bcast_i1_comm(s, nbase, comm)