File: FEDriver.f90

package info (click to toggle)
paraview 5.1.2%2Bdfsg1-2
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 221,108 kB
  • ctags: 236,092
  • sloc: cpp: 2,416,026; ansic: 190,891; python: 99,856; xml: 81,001; tcl: 46,915; yacc: 5,039; java: 4,413; perl: 3,108; sh: 1,974; lex: 1,926; f90: 748; asm: 471; pascal: 228; makefile: 198; objc: 83; fortran: 31
file content (56 lines) | stat: -rw-r--r-- 1,444 bytes parent folder | download | duplicates (4)
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
! A Fortran Catalyst example. Note that coproc.py
! must be in the directory where the example
! is run from.
! Thanks to Lucas Pettey for helping create the example.

PROGRAM coproc
  use tcp
  implicit none
  include 'mpif.h'
  integer,parameter :: nx=100,ny=100,nz=100,ntime=10
  integer :: i,j,k,time,nxstart,nxend
  real :: max
  complex(kind=8), allocatable :: psi01(:,:,:)
  integer :: numtasks,rank,ierr

  call mpi_init(ierr)
  call mpi_comm_size(MPI_COMM_WORLD, numtasks, ierr)
  call mpi_comm_rank(MPI_COMM_WORLD, rank, ierr)

  call coprocessorinitializewithpython("coproc.py",9)

  ! partition in the x-direction only
  nxstart=rank*nx/numtasks+1
  nxend=(rank+1)*nx/numtasks
  if(numtasks .ne. rank+1) then
     nxend=nxend+1
  endif

  allocate(psi01(nxend-nxstart+1,ny,nz))
  ! set initial values
  max=sqrt(real(nx)**2+real(ny)**2+real(nz)**2)
  do k=1,nz
     do j=1,ny
        do i=1,nxend-nxstart+1
           psi01(i,j,k)=CMPLX(max-sqrt(real(i-50)**2+real(j-50)**2+real(k-50)**2),&
                real(1+j+k))/max*100.0
        enddo
     enddo
  enddo

  do time=1,ntime
     do k=1,nz
        do j=1,ny
           do i=1,nxend-nxstart+1
              psi01(i,j,k)=CMPLX(real(0.30),0.0)+psi01(i,j,k)
           end do
        end do
     end do
     call testcoprocessor(nxstart,nxend,nx,ny,nz,time,dble(time),psi01)
  enddo
  deallocate(psi01)

  call coprocessorfinalize()
  call mpi_finalize(ierr)

end program coproc