gfixup.f.html | ![]() |
Source file: gfixup.f | |
Directory: /home/rjl/git/rjleveque/clawpack-4.x/amrclaw/2d/lib | |
Converted: Sun May 15 2011 at 19:16:14 using clawcode2html | |
This documentation file will not reflect any later changes in the source file. |
c c ----------------------------------------------------------- c subroutine gfixup(lbase, lfnew, nvar, naux) c implicit double precision (a-h,o-z) include "call.i" c c ::::::::::::::::::::::::: GFIXUP ::::::::::::::::::::::::::::::::; c interpolate initial values for the newly created grids. c the start of each level is located in newstl array. c since only levels greater than lbase were examined, start c looking there. c :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::; c c reclaim old storage (position 8) and list space 15 and 16 c before allocating new storage. remember, finest level grids c (if level = mxnest so that error never estimated) don't have c 2 copies of solution values at old and new times. c c call putsp(lbase,lbase,nvar,naux) level = lbase + 1 1 if (level .gt. lfine) go to 4 call putsp(lbase,level,nvar,naux) mptr = lstart(level) 2 if (mptr .eq. 0) go to 3 nx = node(ndihi,mptr) - node(ndilo,mptr) + 1 ny = node(ndjhi,mptr) - node(ndjlo,mptr) + 1 mitot = nx + 2*nghost mjtot = ny + 2*nghost nwords = mitot*mjtot*nvar if (level .lt. mxnest) . call reclam(node(store2, mptr), nwords) node(store2, mptr) = 0 mptr = node(levelptr, mptr) go to 2 3 level = level + 1 go to 1 c 4 lcheck = lbase + 1 5 if (lcheck .gt. mxnest) go to 99 hx = hxposs(lcheck) hy = hyposs(lcheck) c c interpolate level lcheck c mptr = newstl(lcheck) 10 if (mptr .eq. 0) go to 80 nx = node(ndihi,mptr) - node(ndilo,mptr) + 1 ny = node(ndjhi,mptr) - node(ndjlo,mptr) + 1 mitot = nx + 2*nghost mjtot = ny + 2*nghost corn1 = rnode(cornxlo,mptr) corn2 = rnode(cornylo,mptr) loc = igetsp(mitot * mjtot * nvar) node(store1, mptr) = loc if (naux .gt. 0) then locaux = igetsp(mitot * mjtot * naux) maxmx = mitot - 2*nghost mx = maxmx maxmy = mjtot - 2*nghost my = maxmy call setaux(maxmx,maxmy,nghost,mx,my,corn1,corn2,hx,hy, & naux,alloc(locaux)) else locaux = 1 endif node(storeaux, mptr) = locaux time = rnode(timemult, mptr) c c We now fill in the values for grid mptr using filval. It uses c piecewise linear interpolation to obtain values from the c (lcheck - 1) grid, then overwrites those with whatever (lcheck) c grids are available. We take advantage of the fact that the c (lcheck - 1) grids have already been set, and that the distance c between any point in mptr and a (lcheck - 1) and (lcheck - 2) c interface is at least one (lcheck - 1) cell wide. c c # make a coarsened patch with ghost cells so can use c # grid interpolation routines, but only set "interior". c # extra 2 cells so that can use linear interp. on c # "interior" of coarser patch to fill fine grid. mic = nx/intratx(lcheck-1) + 2 mjc = ny/intraty(lcheck-1) + 2 ivalc = igetsp(mic*mjc*(nvar+naux)) ivalaux = ivalc + nvar*mic*mjc xl = rnode(cornxlo,mptr) xr = rnode(cornxhi,mptr) yb = rnode(cornylo,mptr) yt = rnode(cornyhi,mptr) hx = hxposs(lcheck) hy = hyposs(lcheck) ilo = node(ndilo, mptr) ihi = node(ndihi, mptr) jlo = node(ndjlo, mptr) jhi = node(ndjhi, mptr) c ## need to get scratch space here, since passing ins c ## variables indexed into alloc. This is in case dynamic c ## memory would have changed the alloc location iperim = mitot+mjtot ! get max amount possible locflip = igetsp(iperim*(nvar+naux)) call filval(alloc(loc),mitot,mjtot,hx,hy,lcheck,time, 1 alloc(ivalc),alloc(ivalaux),mic,mjc, 2 xl,xr,yb,yt,nvar, 3 mptr,ilo,ihi,jlo,jhi, 4 alloc(locaux),naux,locflip) call reclam(ivalc,mic*mjc*(nvar+naux)) call reclam(locflip,iperim*(nvar+naux)) mptr = node(levelptr, mptr) go to 10 c c done filling new grids at level. move them into lstart from newstl c (so can use as source grids for filling next level). can also c get rid of loc. 7 storage for old level. c 80 mptr = lstart(lcheck) 85 if (mptr .eq. 0) go to 90 nx = node(ndihi,mptr) - node(ndilo,mptr) + 1 ny = node(ndjhi,mptr) - node(ndjlo,mptr) + 1 mitot = nx + 2*nghost mjtot = ny + 2*nghost call reclam(node(store1,mptr),mitot*mjtot*nvar) if (naux .gt. 0) then call reclam(node(storeaux,mptr),mitot*mjtot*naux) endif mold = mptr mptr = node(levelptr,mptr) call putnod(mold) go to 85 90 lstart(lcheck) = newstl(lcheck) lcheck = lcheck + 1 go to 5 c 99 lfine = lfnew c c initialize 2nd (old time) storage block for new grids not at top level c levend = min(lfine,mxnest-1) do 110 level = lbase+1, levend mptr = lstart(level) 105 if (mptr .eq. 0) go to 110 nx = node(ndihi,mptr) - node(ndilo,mptr) + 1 ny = node(ndjhi,mptr) - node(ndjlo,mptr) + 1 mitot = nx + 2*nghost mjtot = ny + 2*nghost nwords = mitot*mjtot*nvar node(store2,mptr) = igetsp(nwords) mptr = node(levelptr,mptr) go to 105 110 continue c c grid structure now complete again. safe to print, etc. assuming c things initialized to zero in nodget. c return end