MODULE W3PARALL
  !/
  !/                  +-----------------------------------+
  !/                  | WAVEWATCH III           NOAA/NCEP |
  !/                  |                                   |
  !/                  | Aron Roland (BGS IT&E GmbH)       |
  !/                  | Mathieu Dutour-Sikiric (IRB)      |
  !/                  |                                   |
  !/                  |                        FORTRAN 90 |
  !/                  | Last update :        01-June-2018 |
  !/                  +-----------------------------------+
  !/
  !/   01-June-2018 : Origination.                        ( version 6.04 )
  !/
  !  1. Purpose : Parallel routines for implicit solver
  !  2. Method :
  !  3. Parameters :
  !
  !     Parameter list
  !     ----------------------------------------------------------------
  !     ----------------------------------------------------------------
  !
  !  4. Subroutines used :
  !
  !      Name      Type  Module   Description
  !     ----------------------------------------------------------------
  !      STRACE    Subr. W3SERVMD Subroutine tracing.
  !     ----------------------------------------------------------------
  !
  !  5. Called by :
  !
  !      Name      Type  Module   Description
  !     ----------------------------------------------------------------
  !     ----------------------------------------------------------------
  !
  !  6. Error messages :
  !  7. Remarks
  !  8. Structure :
  !  9. Switches :
  !
  !     !/S  Enable subroutine tracing.
  !
  ! 10. Source code :
  !
  !/ ------------------------------------------------------------------- /
#ifdef W3_S
  USE W3SERVMD, ONLY: STRACE
#endif
  !/
  !/ ------------------------------------------------------------------- /
  !/ Parameter list
  !/
  !/ ------------------------------------------------------------------- /
  !/ Local parameters
  !/
#ifdef W3_S
  INTEGER, SAVE           :: IENT = 0
#endif
  !
#ifdef W3_PDLIB
  INTEGER :: PDLIB_NSEAL, PDLIB_NSEALM
  INTEGER, ALLOCATABLE :: JX_TO_JSEA(:), ISEA_TO_JSEA(:)
#endif

  INTEGER, ALLOCATABLE :: ListISPnextDir(:), ListISPprevDir(:)
  INTEGER, ALLOCATABLE :: ListISPnextFreq(:), ListISPprevFreq(:)

  LOGICAL, PARAMETER   :: LSLOC = .true.
  INTEGER, PARAMETER   :: IMEM = 1

  REAL,  PARAMETER     :: ONESIXTH  = 1.0d0/6.0d0
  REAL,  PARAMETER     :: ONETHIRD  = 1.0d0/3.0d0
  REAL,  PARAMETER     :: ZERO      = 0.0d0

  REAL*8,  PARAMETER     :: THR8      = TINY(1.d0)
  REAL,  PARAMETER     :: THR       = TINY(1.0)
CONTAINS
  !/ ------------------------------------------------------------------- /
  SUBROUTINE WAV_MY_WTIME(eTime)
    !/ ------------------------------------------------------------------- /
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose :
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    !/
    !/ ------------------------------------------------------------------- /
    !/ Parameter list
    !/
    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
    IMPLICIT NONE
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    INTEGER mpimode
    REAL(8), intent(out) :: eTime
#ifdef W3_MPI
    REAL(8) mpi_wtime
#endif
    mpimode=0
#ifdef W3_MPI
    mpimode=1
    eTime=mpi_wtime()
#endif
#ifdef W3_S
    CALL STRACE (IENT, 'WAV_MY_WTIME')
#endif
    IF (mpimode .eq. 0) THEN
      CALL CPU_TIME(eTime)
    END IF
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE WAV_MY_WTIME
  !/ ------------------------------------------------------------------- /
  SUBROUTINE PRINT_MY_TIME(string)
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Print timings
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    USE W3ODATMD, ONLY : IAPROC
    IMPLICIT NONE
    !/
    !/ ------------------------------------------------------------------- /
    !/ Parameter list
    !/
    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    !/
    !/ ------------------------------------------------------------------- /
    !
    character(*), intent(in) :: string
    REAL(8) :: eTime
#ifdef W3_S
    CALL STRACE (IENT, 'PRINT_MY_TIME')
#endif
    CALL WAV_MY_WTIME(eTime)
    WRITE(740+IAPROC,*) 'TIMING time=', eTime, ' at step ', string
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE PRINT_MY_TIME
  !/ ------------------------------------------------------------------- /
  SUBROUTINE PROP_REFRACTION_PR1(ISEA,DTG, CAD)
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Compute refraction part in matrix
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    USE W3GDATMD, ONLY: NK, NK2, NTH, NSPEC, SIG, DSIP, ECOS, ESIN, &
         EC2, ESC, ES2, FACHFA, MAPWN, FLCTH, FLCK,  &
         CTMAX, DMIN, DTH, CTHG0S, MAPSF
    USE W3ADATMD, ONLY: CG, WN, DCXDX, DCXDY, DCYDX, DCYDY, DDDX,   &
         DDDY, DW
#ifdef W3_REFRX
    USE W3ADATMD, ONLY: DCDX, DCDY
#endif
    USE W3IDATMD, ONLY: FLCUR
    USE W3ODATMD, only : IAPROC
    IMPLICIT NONE
    !/
    !/ ------------------------------------------------------------------- /
    !/ Parameter list
    !/
    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    !/
    !/ ------------------------------------------------------------------- /
    !/
    !/
    REAL, intent(out) :: CAD(NSPEC)
    INTEGER, intent(in) :: ISEA
    REAL, intent(in) :: DTG
    INTEGER :: ISP, IK, ITH, IX, IY
    REAL :: FRK(NK), FRG(NK), DSDD(0:NK+1)
    REAL :: FACTH, DCXY, DCYX, DCXXYY, DTTST
    REAL :: eDCXDX, eDCXDY, eDCYDX, eDCYDY, eDDDX, eDDDY, eCTHG0
    REAL :: VCFLT(NSPEC), DEPTH, FDG
    REAL :: FDDMAX
#ifdef W3_S
    CALL STRACE (IENT, 'PROP_REFRACTION_PR1')
#endif
    IX=MAPSF(ISEA,1)
    IY=MAPSF(ISEA,2)
    eDDDX=DDDX(IY,IX)
    eDDDY=DDDY(IY,IX)
    eCTHG0 = CTHG0S(ISEA)
    FACTH  = DTG / DTH
    !
    FDG    = FACTH * eCTHG0
    DEPTH  = MAX ( DMIN , DW(ISEA) )
    DO IK=0, NK+1
      IF ( DEPTH*WN(IK,ISEA) .LT. 5. ) THEN
        DSDD(IK) = MAX ( 0. , CG(IK,ISEA)*WN(IK,ISEA)-0.5*SIG(IK) ) / DEPTH
      ELSE
        DSDD(IK) = 0.
      END IF
    END DO
    FDDMAX=0
    DO ITH=1, NTH
      FDDMAX = MAX ( FDDMAX , ABS(ESIN(ITH)*eDDDX - ECOS(ITH)*eDDDY ) )
    END DO
    DO IK=1, NK
      FRK(IK) = FACTH * DSDD(IK) / WN(IK,ISEA)
      !FRK(IK) = FRK(IK) / MAX ( 1. , FRK(IK)*FDDMAX/CTMAX )
      FRG(IK) = FDG * CG(IK,ISEA)
    END DO
    DO ISP=1, NSPEC
      VCFLT(ISP) = FRG(MAPWN(ISP)) * ECOS(ISP) +                     &
           FRK(MAPWN(ISP)) * ( ESIN(ISP)*eDDDX - ECOS(ISP)*eDDDY )
    END DO
    !
#ifdef W3_REFRX
    ! 3.c @C/@x refraction and great-circle propagation
    VCFLT  = 0.
    FRK    = 0.
    DO IK=1, NK
      FRK(IK) = FACTH * CG(IK,ISEA) * WN(IK,ISEA) / SIG(IK)
    END DO
    DO ISP=1, NSPEC
      VCFLT(ISP) = FRG(MAPWN(ISP)) * ECOS(ISP)           &
           + FRK(MAPWN(ISP)) * ( ESIN(ISP)*DCDX(ISP,1,MAPWN(ISP)) &
           - ECOS(ISP)*DCDY(ISP,1,MAPWN(ISP)) )
    END DO
#endif
    !
    IF ( FLCUR ) THEN
      eDCXDX=DCXDX(IY,IX)
      eDCXDY=DCXDY(IY,IX)
      eDCYDX=DCYDX(IY,IX)
      eDCYDY=DCYDY(IY,IX)
      DCYX   = FACTH *   eDCYDX
      DCXXYY = FACTH * ( eDCXDX - eDCYDY )
      DCXY   = FACTH *   eDCXDY
      DO ISP=1, NSPEC
        VCFLT(ISP) = VCFLT(ISP) + ES2(ISP)*DCYX  + ESC(ISP)*DCXXYY - EC2(ISP)*DCXY
      END DO
    END IF
    DO ISP=1,NSPEC
      CAD(ISP)=DBLE(VCFLT(ISP))
    END DO
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE PROP_REFRACTION_PR1
  !/ ------------------------------------------------------------------- /
  !
  SUBROUTINE PROP_REFRACTION_PR3(IP, ISEA, DTG, CAD, DoLimiter)
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Compute refraction part in matrix alternative approach
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    USE CONSTANTS, ONLY : LPDLIB
    USE W3GDATMD, ONLY: NK, NK2, NTH, NSPEC, SIG, DSIP, ECOS, ESIN, &
         EC2, ESC, ES2, FACHFA, MAPWN, FLCTH, FLCK,  &
         CTMAX, DMIN, DTH, CTHG0S, MAPSF, SIG
    USE W3ADATMD, ONLY: CG, WN, DCXDX, DCXDY, DCYDX, DCYDY, DDDX,   &
         DDDY, DW
    USE W3IDATMD, ONLY: FLCUR
    USE W3ODATMD, only : IAPROC
    IMPLICIT NONE
    !/
    !/ ------------------------------------------------------------------- /
    !/ Parameter list
    !/
    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    REAL, intent(out) :: CAD(NSPEC)
    INTEGER, intent(in) :: ISEA, IP
    REAL, intent(in) :: DTG
    logical, intent(in) :: DoLimiter
    INTEGER :: ISP, IK, ITH, IX, IY
    REAL :: FRK(NK), FRG(NK), DSDD(0:NK+1)
    REAL :: FACTH, DCXY, DCYX, DCXXYY, DTTST
    REAL :: eDCXDX, eDCXDY, eDCYDX, eDCYDY, eDDDX, eDDDY, eCTHG0
    REAL :: VCFLT(NSPEC), DEPTH, FDG, CG1(0:NK+1), WN1(0:NK+1)
    REAL :: FDDMAX, CFLTHMAX, VELNOFILT, CTMAX_eff
#ifdef W3_S
    CALL STRACE (IENT, 'PROP_REFRACTION_PR3')
#endif

    IX = MAPSF(ISEA,1)
    IY = MAPSF(ISEA,2)
    eDDDX=DDDX(1,IP)
    eDDDY=DDDY(1,IP)
    eCTHG0 = CTHG0S(ISEA)
    FACTH  = 1.0 / DTH
    !
    FDG    = FACTH * eCTHG0
    DEPTH  = MAX ( DMIN , DW(ISEA) )
    DO IK=0, NK+1
      IF ( DEPTH*WN(IK,ISEA) .LT. 5. ) THEN
        DSDD(IK) = MAX ( 0. , CG(IK,ISEA)*WN(IK,ISEA)-0.5*SIG(IK) ) / DEPTH
      ELSE
        DSDD(IK) = 0.
      END IF
    END DO
    DO IK=1, NK
      FRK(IK) = FACTH * DSDD(IK) / WN(IK,ISEA)
      FRG(IK) = FDG * CG(IK,ISEA)
    END DO
    IF (FLCUR) THEN
      eDCXDX = DCXDX(1,IP)
      eDCXDY = DCXDY(1,IP)
      eDCYDX = DCYDX(1,IP)
      eDCYDY = DCYDY(1,IP)
      DCYX   = FACTH *   eDCYDX
      DCXXYY = FACTH * ( eDCXDX - eDCYDY )
      DCXY   = FACTH *   eDCXDY
      DO ISP=1, NSPEC
        VCFLT(ISP) = ES2(ISP)*DCYX  + ESC(ISP)*DCXXYY - EC2(ISP)*DCXY
      END DO
    ELSE
      VCFLT=0
    END IF
    !
#ifdef W3_REFRX
    ! 3.c @C/@x refraction and great-circle propagation
    DO IK=1, NK
      FRK(IK) = FACTH * CG(IK,ISEA) * WN(IK,ISEA) / SIG(IK)
    END DO
#endif
    !
    CTMAX_eff=CTMAX/DTG
    DO ISP=1, NSPEC
      VELNOFILT = VCFLT(ISP)                                       &
           + FRG(MAPWN(ISP)) * ECOS(ISP)                             &
           + FRK(MAPWN(ISP)) * (ESIN(ISP)*eDDDX - ECOS(ISP)*eDDDY)
      !
      ! Puts filtering on total velocity (including currents and great circle effects)
      ! the filtering limits VCFLT to be less than CTMAX
      ! this modification was proposed by F. Ardhuin 2011/03/06
      !
      IF (DoLimiter) THEN
        VCFLT(ISP)=SIGN(MIN(ABS(VELNOFILT),CTMAX_eff),VELNOFILT)
      ELSE
        VCFLT(ISP)=VELNOFILT
      END IF
    END DO
    DO ISP=1,NSPEC
      CAD(ISP)=DBLE(VCFLT(ISP))
    END DO
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE PROP_REFRACTION_PR3
  !/ ------------------------------------------------------------------- /
  SUBROUTINE PROP_FREQ_SHIFT(IP, ISEA, CAS, DMM, DTG)
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Compute freq. shift in matrix
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    USE CONSTANTS, ONLY : LPDLIB
    USE W3GDATMD, ONLY: NK, NK2, NTH, NSPEC, SIG, DSIP, ECOS, ESIN, &
         EC2, ESC, ES2, FACHFA, MAPWN, FLCTH, FLCK,  &
         CTMAX, DMIN, DTH, MAPSF
    USE W3ADATMD, ONLY: CG, WN, DCXDX, DCXDY, DCYDX, DCYDY, CX, CY, DDDX, DDDY, DW
    USE W3ODATMD, only : IAPROC
    IMPLICIT NONE
    !/ Parameter list
    !/
    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    INTEGER, intent(in) :: ISEA, IP
    REAL, intent(out) :: DMM(0:NK2)
    REAL, intent(in) :: DTG
    REAL, intent(out) :: CAS(NSPEC)
    REAL :: DB(NK2), DSDD(0:NK+1)
    REAL :: eDCXDX, eDCXDY, eDCYDX, eDCYDY, eCX, eCY, eDDDX, EDDDY
    REAL :: DCXX, DCXYYX, DCYY, FKD, FACK
    REAL :: VELNOFILT, VELFAC, DEPTH
    REAL :: CFLK(NK2,NTH), FKC(NTH), FKD0
    INTEGER :: IK, ITH, ISP, IY, IX
#ifdef W3_S
    CALL STRACE (IENT, 'PROP_FREQ_SHIFT')
#endif
    !
    IF (LPDLIB) THEN
      eDCXDX = DCXDX(1,IP)
      eDCXDY = DCXDY(1,IP)
      eDCYDX = DCYDX(1,IP)
      eDCYDY = DCYDY(1,IP)
      eDDDX  = DDDX(1,IP)
      eDDDY  = DDDY(1,IP)
    ELSE
      IX=MAPSF(ISEA,1)
      IY=MAPSF(ISEA,2)
      eDCXDX=DCXDX(IY,IX)
      eDCXDY=DCXDY(IY,IX)
      eDCYDX=DCYDX(IY,IX)
      eDCYDY=DCYDY(IY,IX)
      eDDDX=DDDX(IY,IX)
      eDDDY=DDDY(IY,IX)
    ENDIF
    eCX=CX(ISEA)
    eCY=CY(ISEA)
    DCXX   =  -   eDCXDX
    DCXYYX =  - ( eDCXDY + eDCYDX )
    DCYY   =  -   eDCYDY
    FKD    =    ( eCX*eDDDX + eCY*eDDDY )
    FACK = DTG
    DO ITH=1, NTH
      FKC(ITH) = EC2(ITH)*DCXX + ESC(ITH)*DCXYYX + ES2(ITH)*DCYY
    END DO
    DO IK=0, NK
      DB(IK+1) = DSIP(IK) / CG(IK,ISEA)
      DMM(IK+1) = DBLE(WN(IK+1,ISEA) - WN(IK,ISEA))
    END DO
    DB(NK+2) = DSIP(NK+1) / CG(NK+1,ISEA)
    DMM(NK+2) = ZERO
    DMM(0)=DMM(1)
    !
    DEPTH  = MAX ( DMIN , DW(ISEA) )
    DO IK=0, NK+1
      IF ( DEPTH*WN(IK,ISEA) .LT. 5. ) THEN
        DSDD(IK) = MAX ( 0. , CG(IK,ISEA)*WN(IK,ISEA)-0.5*SIG(IK) ) / DEPTH
      ELSE
        DSDD(IK) = 0.
      END IF
    END DO
    DO IK=0, NK+1
      FKD0   = FKD / CG(IK,ISEA) * DSDD(IK)
      VELFAC =  FACK/DB(IK+1)
      DO ITH=1, NTH
        VELNOFILT = ( FKD0 + WN(IK,ISEA)*FKC(ITH) ) * VELFAC
        CFLK(IK+1,ITH) = VELNOFILT/VELFAC
      END DO
    END DO
    DO IK=1,NK
      DO ITH=1,NTH
        ISP=ITH + (IK-1)*NTH
        CAS(ISP)=DBLE(CFLK(IK,ITH))
      END DO
    END DO
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE PROP_FREQ_SHIFT
  !/ ------------------------------------------------------------------- /
  SUBROUTINE PROP_FREQ_SHIFT_M2(IP, ISEA, CWNB_M2, DWNI_M2, DTG)
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Compute freq. shift alternative approach
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
    !
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    USE CONSTANTS, ONLY : LPDLIB
    USE W3GDATMD, ONLY: NK, NK2, NTH, NSPEC, SIG, DSIP, ECOS, ESIN, &
         EC2, ESC, ES2, FACHFA, MAPWN, FLCTH, FLCK,  &
         CTMAX, DMIN, DTH, MAPSF
    USE W3ADATMD, ONLY: CG, WN, DCXDX, DCXDY, DCYDX, DCYDY, CX, CY, DDDX, DDDY, DW
    USE W3ODATMD, only : IAPROC

    IMPLICIT NONE

    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif

    INTEGER, intent(in) :: ISEA, IP
    REAL, intent(out) :: CWNB_M2(1-NTH:NSPEC)
    REAL, intent(out) :: DWNI_M2(NK)
    REAL, intent(in) :: DTG
    !
    REAL :: eDCXDX, eDCXDY, eDCYDX, eDCYDY, eCX, eCY, eDDDX, EDDDY
    REAL :: DCXX, DCXYYX, DCYY, FKD, FACK
    REAL :: DEPTH
    REAL :: FKC(NTH), FKD0
    REAL :: VCWN(1-NTH:NSPEC+NTH)
    REAL :: DSDD(0:NK+1)
    REAL :: sumDiff, sumDiff1, sumDiff2, sumDiff3
    REAL :: sumDiff0, sumDiff4, sumDiff5
    INTEGER :: IK, ITH, ISP, IY, IX

    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    CALL STRACE (IENT, 'PROP_FREQ_SHIFT_M2')
#endif

    IF (LPDLIB) THEN
      eDCXDX = DCXDX(1,IP)
      eDCXDY = DCXDY(1,IP)
      eDCYDX = DCYDX(1,IP)
      eDCYDY = DCYDY(1,IP)
      eDDDX  = DDDX(1,IP)
      eDDDY  = DDDY(1,IP)
    ELSE
      IX=MAPSF(ISEA,1)
      IY=MAPSF(ISEA,2)
      eDCXDX=DCXDX(IY,IX)
      eDCXDY=DCXDY(IY,IX)
      eDCYDX=DCYDX(IY,IX)
      eDCYDY=DCYDY(IY,IX)
      eDDDX=DDDX(IY,IX)
      eDDDY=DDDY(IY,IX)
    ENDIF

    eCX = CX(ISEA)
    eCY = CY(ISEA)
    FACK = DTG
    DCXX   =  - FACK *   eDCXDX
    DCXYYX =  - FACK * ( eDCXDY + eDCYDX )
    DCYY   =  - FACK *   eDCYDY
    FKD    =    FACK * ( eCX*eDDDX + eCY*eDDDY )

    DO ITH=1, NTH
      FKC(ITH) = EC2(ITH)*DCXX + ESC(ITH)*DCXYYX + ES2(ITH)*DCYY
    END DO
    !
    DEPTH  = MAX ( DMIN , DW(ISEA) )
    DO IK=0, NK+1
      IF ( DEPTH*WN(IK,ISEA) .LT. 5. ) THEN
        DSDD(IK) = MAX ( 0. , CG(IK,ISEA)*WN(IK,ISEA)-0.5*SIG(IK) ) / DEPTH
      ELSE
        DSDD(IK) = 0.
      END IF
    END DO
    ISP = -NTH
    DO IK=0, NK+1
      FKD0   = FKD / CG(IK,ISEA) * DSDD(IK)
      DO ITH=1, NTH
        ISP = ISP + 1
        VCWN(ISP) = FKD0 + WN(IK,ISEA)*FKC(ITH)
      END DO
    END DO

    sumDiff=0
    DO ISP=1-NTH,NSPEC
      CWNB_M2(ISP) = DBLE(0.5 * ( VCWN(ISP) + VCWN(ISP+NTH) ))
      sumDiff = sumDiff + MAX(CWNB_M2(ISP), ZERO)
    END DO
    DO IK=1,NK
      DWNI_M2(IK) = DBLE( CG(IK,ISEA) / DSIP(IK) )
    END DO
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE PROP_FREQ_SHIFT_M2
  !/ ------------------------------------------------------------------- /
  SUBROUTINE SYNCHRONIZE_IPGL_ETC_ARRAY(IMOD, IsMulti)
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Sync global local arrays
    !  2. Method :
    ! 		All the process need to have IPGL_tot and IPGL_TO_PROC
    ! 		This is especially the case for the output process.
    ! 		So we need some painful exportation business
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
#ifdef W3_PDLIB
    USE yowDatapool, only: istatus
    USE yowNodepool, only: np_global
    USE W3ODATMD, ONLY: NTPROC, NAPROC, IAPROC
    USE W3GDATMD, ONLY: MAPSF, NSEA
    USE W3ADATMD, ONLY: MPI_COMM_WAVE, MPI_COMM_WCMP
    USE yowRankModule, only : IPGL_TO_PROC, IPGL_tot
    USE WMMDATMD, ONLY: MDATAS
#endif
    IMPLICIT NONE
#ifdef W3_PDLIB
    INCLUDE "mpif.h"
#endif
    INTEGER, intent(in) :: IMOD
    logical, intent(in) :: IsMulti
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
#ifdef W3_PDLIB
    INTEGER :: Iarr(1)
    INTEGER :: ISEA, IP_glob
    INTEGER :: IPROC, IERR_MPI, istat
#endif

#ifdef W3_S
    CALL STRACE (IENT, 'SYNCHRONIZE_IPGL_ETC_ARRAY')
#endif

#ifdef W3_PDLIB
    IF (IAPROC .le. NAPROC) THEN
      IF (IAPROC .eq. 1) THEN
        Iarr(1)=np_global
        DO IPROC=NAPROC+1,NTPROC
          CALL MPI_SEND(Iarr,1,MPI_INT, IPROC-1, 37, MPI_COMM_WAVE, IERR_MPI)
        END DO
        DO IPROC=NAPROC+1,NTPROC
          CALL MPI_SEND(ipgl_tot,np_global,MPI_INT, IPROC-1, 43, MPI_COMM_WAVE, IERR_MPI)
          CALL MPI_SEND(ipgl_to_proc,np_global,MPI_INT, IPROC-1, 91, MPI_COMM_WAVE, IERR_MPI)
        END DO
      END IF
    ELSE
      CALL MPI_RECV(Iarr,1,MPI_INT, 0, 37, MPI_COMM_WAVE, istatus, IERR_MPI)
      np_global=Iarr(1)
      allocate(IPGL_tot(np_global), IPGL_TO_PROC(np_global), stat=istat)
      CALL MPI_RECV(ipgl_tot,np_global,MPI_INT, 0, 43, MPI_COMM_WAVE, istatus, IERR_MPI)
      CALL MPI_RECV(ipgl_to_proc,np_global,MPI_INT, 0, 91, MPI_COMM_WAVE, istatus, IERR_MPI)
    END IF
    IF (IsMulti) THEN
      WRITE(*,*) ' Before allocation of MDATAS % SEA_IPGL, SEA_IPGL_TO_PROC : IMOD=', IMOD, ' NSEA=', NSEA
      ALLOCATE(MDATAS(IMOD)%SEA_IPGL(NSEA), MDATAS(IMOD)%SEA_IPGL_TO_PROC(NSEA), STAT=ISTAT)
      !CHECK_ALLOC_STATUS ( ISTAT )
      DO ISEA=1,NSEA
        IP_glob = MAPSF(ISEA, 1)
        MDATAS(IMOD)%SEA_IPGL(ISEA) = IPGL_tot(IP_glob)
        MDATAS(IMOD)%SEA_IPGL_TO_PROC(ISEA) = IPGL_TO_PROC(IP_glob)
      END DO
    END IF
#endif
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE SYNCHRONIZE_IPGL_ETC_ARRAY
  !/ ....................----------------------------------------------- /
  SUBROUTINE SET_UP_NSEAL_NSEALM(NSEALout, NSEALMout)
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Setup nseal, nsealm in contect of pdlib
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    !/
    !/ ------------------------------------------------------------------- /
#ifdef W3_PDLIB
    use yowDatapool, only: istatus
    use yowNodepool, only: npa
    use yowRankModule, only : rank
    USE W3GDATMD, ONLY: GTYPE, UNGTYPE
#endif
#ifdef W3_MPI
    USE W3ADATMD, ONLY: MPI_COMM_WAVE, MPI_COMM_WCMP
#endif
    USE CONSTANTS, ONLY : LPDLIB
    USE W3GDATMD, ONLY: NSEA
    USE W3ODATMD, ONLY: NTPROC, NAPROC, IAPROC
    IMPLICIT NONE
    INTEGER, intent(out) :: NSEALout, NSEALMout
    !/ Local parameters
    !/
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    !/
    !/ ------------------------------------------------------------------- /
    !/
#ifdef W3_S
    CALL STRACE (IENT, 'SET_UP_NSEAL_NSEALM')
#endif

#ifdef W3_SHRD
    NSEALout  = NSEA
    NSEALMout = NSEA
#endif
    !
#ifdef W3_DIST
    IF (.NOT. LPDLIB ) THEN
      IF ( IAPROC .LE. NAPROC ) THEN
        NSEALout  = 1 + (NSEA-IAPROC)/NAPROC
      ELSE
        NSEALout  = 0
      END IF
      NSEALMout = 1 + (NSEA-1)/NAPROC
    ELSE
#endif
#ifdef W3_PDLIB
      IF (GTYPE .eq. UNGTYPE) THEN
        NSEALout  = PDLIB_NSEAL
        NSEALMout = PDLIB_NSEALM
      ELSE
        IF ( IAPROC .LE. NAPROC ) THEN
          NSEALout  = 1 + (NSEA-IAPROC)/NAPROC
        ELSE
          NSEALout  = 0
        END IF
        NSEALMout = 1 + (NSEA-1)/NAPROC
      ENDIF
#endif
#ifdef W3_DIST
    ENDIF
#endif
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE SET_UP_NSEAL_NSEALM
  !/ ------------------------------------------------------------------- /
  SUBROUTINE INIT_GET_JSEA_ISPROC(ISEA, JSEA, ISPROC)
    !/ ------------------------------------------------------------------- /
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Set Jsea for all schemes
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    !/
    USE W3ODATMD, ONLY: OUTPTS, IAPROC, NAPROC
    USE W3GDATMD, ONLY: GTYPE, UNGTYPE, MAPSF
    USE CONSTANTS, ONLY : LPDLIB
#ifdef W3_PDLIB
    USE yowRankModule, only : IPGL_TO_PROC, IPGL_tot
    use yowNodepool, only: ipgl, iplg
#endif
    IMPLICIT NONE
    !/ ------------------------------------------------------------------- /
    !/ Parameter list
    !/
    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    !/
    !/ ------------------------------------------------------------------- /
    INTEGER, intent(in) :: ISEA
    INTEGER, intent(out) :: JSEA, ISPROC
    INTEGER IP_glob
#ifdef W3_S
    CALL STRACE (IENT, 'INIT_GET_JSEA_ISPROC')
#endif

#ifdef W3_PDLIB
    IF (.NOT. LPDLIB) THEN
#endif
      JSEA   = 1 + (ISEA-1)/NAPROC
      ISPROC = ISEA - (JSEA-1)*NAPROC
#ifdef W3_PDLIB
    ELSE
      IP_glob = MAPSF(ISEA,1)
      IF (IAPROC .le. NAPROC) THEN
        JSEA   = ISEA_TO_JSEA(ISEA)
      ELSE
        JSEA   = -1
      END IF
      ISPROC = IPGL_TO_PROC(IP_glob)
    ENDIF
#endif
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE INIT_GET_JSEA_ISPROC
  !/ ------------------------------------------------------------------- /
  SUBROUTINE GET_JSEA_IBELONG(ISEA, JSEA, IBELONG)
    !/ ------------------------------------------------------------------- /
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Set belongings of jsea in context of pdlib
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    !/
    USE W3ODATMD, ONLY: OUTPTS, IAPROC, NAPROC
    USE W3GDATMD, ONLY: GTYPE, UNGTYPE, MAPSF
    USE CONSTANTS, ONLY : LPDLIB
#ifdef W3_PDLIB
    USE yowRankModule, only : IPGL_TO_PROC, IPGL_tot, IPGL_npa
    use yowNodepool, only: ipgl, iplg
#endif
    IMPLICIT NONE
    !/ ------------------------------------------------------------------- /
    !/ Parameter list
    !/
    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    !/
    !/ ------------------------------------------------------------------- /
    !/
    INTEGER, intent(in) :: ISEA
    INTEGER, intent(out) :: JSEA, IBELONG
    INTEGER ISPROC, IX, JX
#ifdef W3_S
    CALL STRACE (IENT, 'GET_JSEA_IBELONG')
#endif
    IF (.NOT. LPDLIB) THEN
      JSEA   = 1 + (ISEA-1)/NAPROC
      ISPROC = ISEA - (JSEA-1)*NAPROC
      IF (ISPROC .eq. IAPROC) THEN
        IBELONG=1
      ELSE
        IBELONG=0
      END IF
    ELSE
#ifdef W3_PDLIB
      IF (GTYPE .ne. UNGTYPE) THEN
        JSEA   = 1 + (ISEA-1)/NAPROC
        ISPROC = ISEA - (JSEA-1)*NAPROC
        IF (ISPROC .eq. IAPROC) THEN
          IBELONG=1
        ELSE
          IBELONG=0
        END IF
      ELSE
        IF (IAPROC .le. NAPROC) THEN
          IX     = MAPSF(ISEA,1)
          JX     = IPGL_npa(IX)
          IF (JX .eq. 0) THEN
            IBELONG=0
            JSEA=-1
          ELSE
            IBELONG=1
            JSEA = JX_TO_JSEA(JX)
          END IF
        ELSE
          IBELONG=0
          JSEA=-1
        END IF
      ENDIF
#endif
    ENDIF
    !/
    !/ End of INIT_GET_ISEA ---------------------------------------------- /
    !/
  END SUBROUTINE GET_JSEA_IBELONG
  !/ ------------------------------------------------------------------- /
  SUBROUTINE INIT_GET_ISEA(ISEA, JSEA)
    !/ ------------------------------------------------------------------- /
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Set Isea for all schemes
    !  2. Method :
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    !/
    USE W3ODATMD, ONLY: OUTPTS, IAPROC, NAPROC
    USE W3GDATMD, ONLY: GTYPE, UNGTYPE
    USE CONSTANTS, ONLY : LPDLIB
#ifdef W3_PDLIB
    USE YOWNODEPOOL, ONLY: iplg
#endif
    !/ ------------------------------------------------------------------- /
    !/ Parameter list
    !/
    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
    !/ ------------------------------------------------------------------- /
    !/
    !/
    !/ ------------------------------------------------------------------- /
    !/
    !/ ------------------------------------------------------------------- /
    !
    USE W3ODATMD, ONLY: OUTPTS, IAPROC, NAPROC
    USE W3GDATMD, ONLY: GTYPE, UNGTYPE
    USE CONSTANTS, ONLY : LPDLIB
#ifdef W3_PDLIB
    USE YOWNODEPOOL, ONLY: iplg
#endif
    IMPLICIT NONE
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    INTEGER, intent(in) :: JSEA
    INTEGER, intent(out) :: ISEA
#ifdef W3_S
    CALL STRACE (IENT, 'INIT_GET_ISEA')
#endif
#ifdef W3_SHRD
    ISEA         = JSEA
#endif
#ifdef W3_DIST
    IF (.NOT. LPDLIB) THEN
      ISEA         = IAPROC + (JSEA-1)*NAPROC
    ELSE
#endif
#ifdef W3_PDLIB
      IF (GTYPE .eq. UNGTYPE) THEN
        ISEA         = iplg(JSEA)
      ELSE
        ISEA         = IAPROC + (JSEA-1)*NAPROC
      ENDIF
#endif
#ifdef W3_DIST
    ENDIF
#endif
    !/
    !/ End of INIT_GET_ISEA ------------------------------------------------ /
    !/
  END SUBROUTINE INIT_GET_ISEA
  !**********************************************************************
  !*  An array of size (NSEA) is send but only the (1:NSEAL) values     *
  !*  are correct. The program synchonizes everything on all nodes.     *
  !**********************************************************************
  SUBROUTINE SYNCHRONIZE_GLOBAL_ARRAY(TheVar)
    !/ ------------------------------------------------------------------- /
    !/
    !/                  +-----------------------------------+
    !/                  | WAVEWATCH III           NOAA/NCEP |
    !/                  |                                   |
    !/                  | Aron Roland (BGS IT&E GmbH)       |
    !/                  | Mathieu Dutour-Sikiric (IRB)      |
    !/                  |                                   |
    !/                  |                        FORTRAN 90 |
    !/                  | Last update :        01-June-2018 |
    !/                  +-----------------------------------+
    !/
    !/   01-June-2018 : Origination.                        ( version 6.04 )
    !/
    !  1. Purpose : Sync global array in context of pdlib
    !  2. Method :
    !			An array of size (NSEA) is send but only the (1:NSEAL) values
    ! 			are correct. The program synchonizes everything on all nodes.
    !  3. Parameters :
    !
    !     Parameter list
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  4. Subroutines used :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !      STRACE    Subr. W3SERVMD Subroutine tracing.
    !     ----------------------------------------------------------------
    !
    !  5. Called by :
    !
    !      Name      Type  Module   Description
    !     ----------------------------------------------------------------
    !     ----------------------------------------------------------------
    !
    !  6. Error messages :
    !  7. Remarks
    !  8. Structure :
    !  9. Switches :
    !
    !     !/S  Enable subroutine tracing.
    !
    ! 10. Source code :
    !
    !/ ------------------------------------------------------------------- /
#ifdef W3_S
    USE W3SERVMD, ONLY: STRACE
#endif
    !
    USE W3GDATMD, ONLY: NSEAL, NSEA, NX
#ifdef W3_PDLIB
    USE W3ODATMD, only : IAPROC, NAPROC, NTPROC
    USE W3ADATMD, ONLY: MPI_COMM_WCMP
    use yowDatapool, only: rtype, istatus
    USE yowNodepool, only: npa
    use yowNodepool, only: iplg
    use yowDatapool, only: rkind
#endif
    IMPLICIT NONE
    !/ ------------------------------------------------------------------- /
    !/ Parameter list
    !/
    !/ ------------------------------------------------------------------- /
    !/ Local parameters
    !/
#ifdef W3_S
    INTEGER, SAVE           :: IENT = 0
#endif
    !/
    !/ ------------------------------------------------------------------- /
    !/
#ifdef W3_MPI
    INCLUDE "mpif.h"
#endif
    INTEGER ISEA, JSEA, Status(NX), rStatus(NX)
    INTEGER IPROC, I, ierr, IP, IX, IP_glob
#ifdef W3_PDLIB
    REAL(rkind), intent(inout) :: TheVar(NX)
    REAL(rkind) ::  rVect(NX)
#else
    DOUBLE PRECISION, intent(inout) :: TheVar(NX)
    DOUBLE PRECISION                ::  rVect(NX)
#endif
    Status=0
#ifdef W3_S
    CALL STRACE (IENT, 'SYNCHRONIZE_GLOBAL_ARRAY')
#endif
#ifdef W3_PDLIB
    DO IP=1,npa
      IP_glob=iplg(IP)
      Status(IP_glob)=1
    END DO
    IF (IAPROC .eq. 1) THEN
      DO iProc=2,NAPROC
        CALL MPI_RECV(rVect,NX,rtype, iProc-1, 19, MPI_COMM_WCMP, istatus, ierr)
        CALL MPI_RECV(rStatus,NX,MPI_INTEGER, iProc-1, 23, MPI_COMM_WCMP, istatus, ierr)
        DO I=1,NX
          IF (rStatus(I) .eq. 1) THEN
            TheVar(I)=rVect(I)
            Status(I)=1
          END IF
        END DO
      END DO
      DO IPROC=2,NAPROC
        CALL MPI_SEND(TheVar,NX,rtype, iProc-1, 29, MPI_COMM_WCMP, ierr)
      END DO
    ELSE
      CALL MPI_SEND(TheVar,NX,rtype, 0, 19, MPI_COMM_WCMP, ierr)
      CALL MPI_SEND(Status,NX,MPI_INTEGER, 0, 23, MPI_COMM_WCMP, ierr)
      CALL MPI_RECV(TheVar,NX,rtype, 0, 29, MPI_COMM_WCMP, istatus, ierr)
    END IF
#endif
    !/
    !/ End of JACOBI_INIT ------------------------------------------------ /
    !/
  END SUBROUTINE SYNCHRONIZE_GLOBAL_ARRAY
  !/ ------------------------------------------------------------------- /
END MODULE W3PARALL
!/ ------------------------------------------------------------------- /