diff --git a/Software/MOHIDBase1/ModuleFunctions.F90 b/Software/MOHIDBase1/ModuleFunctions.F90 index f5e1639c6..31a20d96c 100644 --- a/Software/MOHIDBase1/ModuleFunctions.F90 +++ b/Software/MOHIDBase1/ModuleFunctions.F90 @@ -5194,7 +5194,7 @@ subroutine FillMatrix3D (ILB, IUB, JLB, JUB, KLB, KUB, ComputePoints3D, OutValue real, dimension(:,: ), pointer :: Value2D integer, dimension(:,: ), pointer :: Map2D - integer :: k, kfirst, klast + integer :: k, kfirst, klast, i, j !Begin----------------------------------------------------------------- @@ -5218,10 +5218,14 @@ subroutine FillMatrix3D (ILB, IUB, JLB, JUB, KLB, KUB, ComputePoints3D, OutValue !Search for the first layer with data d2: do k = KLB, KUB - if (OutValues3D(ILB, JLB, k) > FillValueReal/1e4) then + do j = JLB, JUB + do i = ILB, IUB + if (OutValues3D(i, j, k) > FillValueReal/1e4) then kfirst = k - exit + exit d2 endif + enddo + enddo enddo d2 !Extrapolate for the bottom layers @@ -5231,10 +5235,14 @@ subroutine FillMatrix3D (ILB, IUB, JLB, JUB, KLB, KUB, ComputePoints3D, OutValue !Search for the last layer with data d4: do k = KUB, KLB,-1 + do j = JLB, JUB + do i = ILB, IUB if (OutValues3D(ILB, JLB, k) > FillValueReal/1e4) then klast = k - exit + exit d4 endif + enddo + enddo enddo d4 !Extrapolate for the surface layers diff --git a/Software/MOHIDWater/ModuleSediment.F90 b/Software/MOHIDWater/ModuleSediment.F90 index 0a76bf9e4..bac943a54 100644 --- a/Software/MOHIDWater/ModuleSediment.F90 +++ b/Software/MOHIDWater/ModuleSediment.F90 @@ -5335,15 +5335,13 @@ subroutine ComputeBedSlopeEffects dhdy = 0. if (SandClass%FluxU(i, j) < 0.) then - !if (Me%ExternalVar%ComputeFacesU2D(i, j) == Covered ) then - if (Me%ExternalVar%WaterPoints2D(i, j-1) == WaterPoint) then + if (Me%ExternalVar%ComputeFacesU2D(i, j) == Covered ) then dhdx = (Me%ExternalVar%Bathymetry(i, j) - Me%ExternalVar%Bathymetry(i, j-1)) / & Me%ExternalVar%DZX(i,j-1) endif else - !if (Me%ExternalVar%ComputeFacesU2D(i,j+1) == Covered) then - if (Me%ExternalVar%WaterPoints2D(i, j+1) == WaterPoint) then + if (Me%ExternalVar%ComputeFacesU2D(i,j+1) == Covered) then dhdx = (Me%ExternalVar%Bathymetry(i, j+1) - Me%ExternalVar%Bathymetry(i, j)) / & Me%ExternalVar%DZX(i,j) @@ -5351,15 +5349,13 @@ subroutine ComputeBedSlopeEffects endif if (SandClass%FluxV(i, j) < 0.) then - !if (Me%ExternalVar%ComputeFacesV2D(i, j) == Covered) then - if (Me%ExternalVar%WaterPoints2D(i-1, j) == WaterPoint) then + if (Me%ExternalVar%ComputeFacesV2D(i, j) == Covered) then dhdy = (Me%ExternalVar%Bathymetry(i, j) - Me%ExternalVar%Bathymetry(i-1, j)) / & Me%ExternalVar%DZY(i-1,j) endif else - !if (Me%ExternalVar%ComputeFacesV2D(i+1, j) == Covered) then - if (Me%ExternalVar%WaterPoints2D(i+1, j) == WaterPoint) then + if (Me%ExternalVar%ComputeFacesV2D(i+1, j) == Covered) then dhdy = (Me%ExternalVar%Bathymetry(i+1, j) - Me%ExternalVar%Bathymetry(i, j)) / & Me%ExternalVar%DZY(i,j) @@ -5708,8 +5704,7 @@ subroutine ComputeEvolution do i=WILB, WIUB if (SandClass%FluxU(i, j) < 0.) then - !if (Me%ExternalVar%ComputeFacesU2D(i, j) == Covered ) then - if (Me%ExternalVar%WaterPoints2D(i, j-1) == WaterPoint) then + if (Me%ExternalVar%ComputeFacesU2D(i, j) == Covered ) then SandClass%DM(i, j-1) = SandClass%DM(i, j-1) - Me%Evolution%SedimentDT * SandClass%FluxU(i, j) SandClass%DM(i, j ) = SandClass%DM(i, j ) + Me%Evolution%SedimentDT * SandClass%FluxU(i, j) @@ -5721,8 +5716,7 @@ subroutine ComputeEvolution endif elseif (SandClass%FluxU(i, j) > 0.) then - !if (Me%ExternalVar%ComputeFacesU2D(i,j+1) == Covered) then - if (Me%ExternalVar%WaterPoints2D(i, j+1) == WaterPoint) then + if (Me%ExternalVar%ComputeFacesU2D(i,j+1) == Covered) then SandClass%DM(i, j+1) = SandClass%DM(i, j+1) + Me%Evolution%SedimentDT * SandClass%FluxU(i, j) SandClass%DM(i, j ) = SandClass%DM(i, j ) - Me%Evolution%SedimentDT * SandClass%FluxU(i, j) @@ -8113,7 +8107,7 @@ subroutine ReadLockExternalVar call GetComputeFaces2D(Me%ObjHorizontalMap, & ComputeFaces2DU = Me%ExternalVar%ComputeFacesU2D, & ComputeFaces2DV = Me%ExternalVar%ComputeFacesV2D, & - ActualTime = Me%ExternalVar%Now, & + !ActualTime = Me%ExternalVar%Now, & STAT = STAT_CALL) if (STAT_CALL /= SUCCESS_) stop 'ReadLockExternalVar - ModuleSediment - ERR06'