src1d_geo.f.html | ![]() |
Source file: src1d_geo.f | |
Directory: /home/rjl/git/rjleveque/clawpack-4.x/geoclaw/2d/lib | |
Converted: Sun May 15 2011 at 19:15:41 using clawcode2html | |
This documentation file will not reflect any later changes in the source file. |
c c c ========================================================= subroutine src1d(meqn,mbc,mx1d,q1d,maux,aux1d,t,dt) c ========================================================= use geoclaw_module implicit double precision (a-h,o-z) dimension q1d(mx1d, meqn) dimension aux1d(mx1d, maux) c c c # This routine should be a simplified version of src2 c # which applies source terms for a 1-d slice of data along the c # edge of a grid. This is called only from qad where the conservative c # fix-up is applied and is used to apply source terms over partial c # time steps to the coarse grid cell values used in solving Riemann c # problems at the interface between coarse and fine grids. c # incorporates friction using Manning coefficient g=grav coeff = coeffmanning tol = 1.d-30 !# to prevent divide by zero in gamma if (coeffmanning.gt.0.d0.and.frictiondepth.gt.0.d0) then do i=1,mx1d h=q1d(i,1) if (h.lt.frictiondepth) then c # apply friction source term only in shallower water hu=q1d(i,2) hv=q1d(i,3) if (h.lt.tol) then q1d(i,2)=0.d0 q1d(i,3)=0.d0 else gamma= dsqrt(hu**2 + hv**2)*(g*coeff**2)/(h**(7/3)) dgamma=1.d0 + dt*gamma q1d(i,2)= q1d(i,2)/dgamma q1d(i,3)= q1d(i,3)/dgamma endif endif enddo endif * ! coriolis-------------------------------------------------------- * ! coriolis-------------------------------------------------------- if (icoordsys.eq.2.and.icoriolis.eq.1) then w = 2.d0*pi/(86400.d0) !angular velocity of earth do i=1,mx1d cor = 2.d0*w*sin(aux1d(i,3)) ct = cor*dt * !integrate momentum exactly using matrix exponential * !forth order term should be sufficient since cor^3 ~= eps hu0 = q1d(i,2) hv0 = q1d(i,3) * !dq/dt = 2w*sin(latitude)*[0 1 ; -1 0] q = Aq * !e^Adt = [a11 a12; a21 a22] + I a11 = -0.5d0*ct**2 + ct**4/24.d0 a12 = ct - ct**3/6.0d0 a21 = -ct + ct**3/6.0d0 a22 = a11 * !q = e^Adt * q0 q1d(i,2) = q1d(i,2) + hu0*a11 + hv0*a12 q1d(i,3) = q1d(i,3) + hu0*a21 + hv0*a22 enddo endif * ! ---------------------------------------------------------------- c return end