C $Header: /u/gcmpack/MITgcm/pkg/exf/exf_set_obcs.F,v 1.16 2009/09/01 19:37:46 jmc Exp $
C $Name:  $

#include "EXF_OPTIONS.h"

C--  File exf_set_obcs.F:
C--   Contents
C--   o EXF_SET_OBCS_XZ
C--   o EXF_SET_OBCS_YZ
C--   o EXF_SET_OBCS_X
C--   o EXF_SET_OBCS_Y

C---+----1----+----2----+----3----+----4----+----5----+----6----+----7-|--+----|

      SUBROUTINE EXF_SET_OBCS_XZ (
     U       obcs_fld_xz, obcs_xz_0, obcs_xz_1,
     I       obcs_file, obcsmask,
     I       fac, first, changed, useYearlyFields, obcs_period,
     I       count0, count1, year0, year1,
     I       myTime, myIter, myThid )

c     ==================================================================
c     SUBROUTINE EXF_SET_OBCS_XZ
c     ==================================================================
c
c     o set open boundary conditions
c
c     started: heimbach@mit.edu 01-May-2001
c     mods for pkg/seaice: menemenlis@jpl.nasa.gov 20-Dec-2002

c     ==================================================================
c     SUBROUTINE EXF_SET_OBCS_XZ
c     ==================================================================

      IMPLICIT NONE

c     == global variables ==

#include "EEPARAMS.h"
#include "SIZE.h"
#include "GRID.h"
#include "EXF_PARAM.h"
#include "EXF_CONSTANTS.h"

c     == routine arguments ==

      _RL obcs_fld_xz(1-OLx:sNx+OLx,Nr,nSx,nSy)
      _RL obcs_xz_0(1-OLx:sNx+OLx,Nr,nSx,nSy)
      _RL obcs_xz_1(1-OLx:sNx+OLx,Nr,nSx,nSy)

      CHARACTER*(128) obcs_file
      CHARACTER*1 obcsmask
      LOGICAL first, changed
      LOGICAL useYearlyFields
      _RL     obcs_period
      INTEGER count0, count1, year0, year1
      _RL     fac
      _RL     myTime
      INTEGER myIter
      INTEGER myThid

#ifdef ALLOW_OBCS

c     == local variables ==

      CHARACTER*(128) obcs_file0, obcs_file1
      INTEGER bi, bj
      INTEGER i, k

c     == end of interface ==

      IF ( obcs_file .NE. ' ' ) THEN

         IF ( first ) THEN

            CALL EXF_GETYEARLYFIELDNAME(
     I         useYearlyFields, twoDigitYear, obcs_period, year0,
     I         obcs_file,
     O         obcs_file0,
     I         myTime, myIter, myThid )

            CALL READ_REC_XZ_RL( obcs_file0, exf_iprec_obcs, Nr,
     &                           obcs_xz_1, count0, myIter, myThid )
         ENDIF

         IF (( first ) .OR. ( changed )) THEN
            CALL EXF_SWAPFFIELDS_XZ( obcs_xz_0, obcs_xz_1, myThid )

            CALL EXF_GETYEARLYFIELDNAME(
     I         useYearlyFields, twoDigitYear, obcs_period, year1,
     I         obcs_file,
     O         obcs_file1,
     I         myTime, myIter, myThid )

            CALL READ_REC_XZ_RL( obcs_file1, exf_iprec_obcs, Nr,
     &                           obcs_xz_1, count1, myIter, myThid )
         ENDIF

         DO bj = myByLo(myThid),myByHi(myThid)
            DO bi = myBxLo(myThid),myBxHi(myThid)
               DO k = 1,Nr
                  DO i = 1,sNx
                     obcs_fld_xz(i,k,bi,bj) =
     &                    fac * obcs_xz_0(i,k,bi,bj) +
     &                    (exf_one - fac) * obcs_xz_1(i,k,bi,bj)
                  ENDDO
               ENDDO
            ENDDO
         ENDDO

      ENDIF

#endif /* ALLOW_OBCS */

      RETURN
      END


C---+----1----+----2----+----3----+----4----+----5----+----6----+----7-|--+----| SUBROUTINE EXF_SET_OBCS_YZ ( U obcs_fld_yz, obcs_yz_0, obcs_yz_1, I obcs_file, obcsmask, I fac, first, changed, useYearlyFields, obcs_period, I count0, count1, year0, year1, I myTime, myIter, myThid) c ================================================================== c SUBROUTINE EXF_SET_OBCS_YZ c ================================================================== c c o set open boundary conditions c c started: heimbach@mit.edu 01-May-2001 c ================================================================== c SUBROUTINE EXF_SET_OBCS_YZ c ================================================================== IMPLICIT NONE c == global variables == #include "EEPARAMS.h" #include "SIZE.h" #include "GRID.h" #include "EXF_PARAM.h" #include "EXF_CONSTANTS.h" c == routine arguments == _RL obcs_fld_yz(1-OLy:sNy+OLy,Nr,nSx,nSy) _RL obcs_yz_0(1-OLy:sNy+OLy,Nr,nSx,nSy) _RL obcs_yz_1(1-OLy:sNy+OLy,Nr,nSx,nSy) CHARACTER*(MAX_LEN_FNAM) obcs_file CHARACTER*1 obcsmask LOGICAL first, changed LOGICAL useYearlyFields _RL obcs_period INTEGER count0, count1, year0, year1 _RL fac _RL myTime INTEGER myIter INTEGER myThid #ifdef ALLOW_OBCS c == local variables == CHARACTER*(128) obcs_file0, obcs_file1 INTEGER bi, bj INTEGER j, k c == end of interface == IF ( obcs_file .NE. ' ' ) THEN IF ( first ) THEN CALL EXF_GETYEARLYFIELDNAME( I useYearlyFields, twoDigitYear, obcs_period, year0, I obcs_file, O obcs_file0, I myTime, myIter, myThid ) CALL READ_REC_YZ_RL( obcs_file0, exf_iprec_obcs, Nr, & obcs_yz_1, count0, myIter, myThid ) ENDIF IF (( first ) .OR. ( changed )) THEN CALL EXF_SWAPFFIELDS_YZ( obcs_yz_0, obcs_yz_1, myThid ) CALL EXF_GETYEARLYFIELDNAME( I useYearlyFields, twoDigitYear, obcs_period, year1, I obcs_file, O obcs_file1, I myTime, myIter, myThid ) CALL READ_REC_YZ_RL( obcs_file1, exf_iprec_obcs, Nr, & obcs_yz_1, count1, myIter, myThid ) ENDIF DO bj = myByLo(myThid),myByHi(myThid) DO bi = myBxLo(myThid),myBxHi(myThid) DO k = 1,Nr DO j = 1,sNy obcs_fld_yz(j,k,bi,bj) = & fac *obcs_yz_0(j,k,bi,bj) + & (exf_one - fac) *obcs_yz_1(j,k,bi,bj) ENDDO ENDDO ENDDO ENDDO ENDIF #endif /* ALLOW_OBCS */ RETURN END


C---+----1----+----2----+----3----+----4----+----5----+----6----+----7-|--+----| SUBROUTINE EXF_SET_OBCS_X ( U obcs_fld_x, obcs_x_0, obcs_x_1, I obcs_file, obcsmask, I fac, first, changed, useYearlyFields, obcs_period, I count0, count1, year0, year1, I myTime, myIter, myThid ) c ================================================================== c SUBROUTINE EXF_SET_OBCS_X c ================================================================== c c o set open boundary conditions c same as EXF_SET_OBCS_XZ but for Nr=1 c c ================================================================== c SUBROUTINE EXF_SET_OBCS_X c ================================================================== IMPLICIT NONE c == global variables == #include "EEPARAMS.h" #include "SIZE.h" #include "GRID.h" #include "EXF_PARAM.h" #include "EXF_CONSTANTS.h" c == routine arguments == _RL obcs_fld_x(1-OLx:sNx+OLx,nSx,nSy) _RL obcs_x_0(1-OLx:sNx+OLx,nSx,nSy) _RL obcs_x_1(1-OLx:sNx+OLx,nSx,nSy) CHARACTER*(128) obcs_file CHARACTER*1 obcsmask LOGICAL first, changed LOGICAL useYearlyFields _RL obcs_period INTEGER count0, count1, year0, year1 _RL fac _RL myTime INTEGER myIter INTEGER myThid #ifdef ALLOW_OBCS c == local variables == CHARACTER*(128) obcs_file0, obcs_file1 INTEGER bi, bj, i c == end of interface == IF ( obcs_file .NE. ' ' ) THEN IF ( first ) THEN CALL EXF_GETYEARLYFIELDNAME( I useYearlyFields, twoDigitYear, obcs_period, year0, I obcs_file, O obcs_file0, I myTime, myIter, myThid ) CALL READ_REC_XZ_RL( obcs_file0, exf_iprec_obcs, 1, & obcs_x_1, count0, myIter, myThid ) ENDIF IF (( first ) .OR. ( changed )) THEN CALL EXF_SWAPFFIELDS_X( obcs_x_0, obcs_x_1, myThid ) CALL EXF_GETYEARLYFIELDNAME( I useYearlyFields, twoDigitYear, obcs_period, year1, I obcs_file, O obcs_file1, I myTime, myIter, myThid ) CALL READ_REC_XZ_RL( obcs_file1, exf_iprec_obcs, 1, & obcs_x_1, count1, myIter, myThid ) ENDIF DO bj = myByLo(myThid),myByHi(myThid) DO bi = myBxLo(myThid),myBxHi(myThid) DO i = 1,sNx obcs_fld_x(i,bi,bj) = & fac * obcs_x_0(i,bi,bj) + & (exf_one - fac) * obcs_x_1(i,bi,bj) ENDDO ENDDO ENDDO ENDIF #endif /* ALLOW_OBCS */ RETURN END


C---+----1----+----2----+----3----+----4----+----5----+----6----+----7-|--+----| SUBROUTINE EXF_SET_OBCS_Y ( U obcs_fld_y, obcs_y_0, obcs_y_1, I obcs_file, obcsmask, I fac, first, changed, useYearlyFields, obcs_period, I count0, count1, year0, year1, I myTime, myIter, myThid ) c ================================================================== c SUBROUTINE EXF_SET_OBCS_Y c ================================================================== c c o set open boundary conditions c same as EXF_SET_OBCS_YZ but for Nr=1 c c ================================================================== c SUBROUTINE EXF_SET_OBCS_Y c ================================================================== IMPLICIT NONE c == global variables == #include "EEPARAMS.h" #include "SIZE.h" #include "GRID.h" #include "EXF_PARAM.h" #include "EXF_CONSTANTS.h" c == routine arguments == _RL obcs_fld_y(1-OLy:sNy+OLy,nSx,nSy) _RL obcs_y_0(1-OLy:sNy+OLy,nSx,nSy) _RL obcs_y_1(1-OLy:sNy+OLy,nSx,nSy) CHARACTER*(MAX_LEN_FNAM) obcs_file CHARACTER*1 obcsmask LOGICAL first, changed LOGICAL useYearlyFields _RL obcs_period INTEGER count0, count1, year0, year1 _RL fac _RL myTime INTEGER myIter INTEGER myThid #ifdef ALLOW_OBCS c == local variables == CHARACTER*(128) obcs_file0, obcs_file1 INTEGER bi, bj, j c == end of interface == IF ( obcs_file .NE. ' ' ) THEN IF ( first ) THEN CALL EXF_GETYEARLYFIELDNAME( I useYearlyFields, twoDigitYear, obcs_period, year0, I obcs_file, O obcs_file0, I myTime, myIter, myThid ) CALL READ_REC_YZ_RL( obcs_file0, exf_iprec_obcs, 1, & obcs_y_1, count0, myIter, myThid ) ENDIF IF (( first ) .OR. ( changed )) THEN CALL EXF_SWAPFFIELDS_Y( obcs_y_0, obcs_y_1, myThid ) CALL EXF_GETYEARLYFIELDNAME( I useYearlyFields, twoDigitYear, obcs_period, year1, I obcs_file, O obcs_file1, I myTime, myIter, myThid ) CALL READ_REC_YZ_RL( obcs_file1, exf_iprec_obcs, 1, & obcs_y_1, count1, myIter, myThid ) ENDIF DO bj = myByLo(myThid),myByHi(myThid) DO bi = myBxLo(myThid),myBxHi(myThid) DO j = 1,sNy obcs_fld_y(j,bi,bj) = & fac *obcs_y_0(j,bi,bj) + & (exf_one - fac) *obcs_y_1(j,bi,bj) ENDDO ENDDO ENDDO ENDIF #endif /* ALLOW_OBCS */ RETURN END