-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathdtcompute.f90
62 lines (59 loc) · 2.04 KB
/
dtcompute.f90
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
subroutine decompute(dtmax)
use globalvar
implicit none
!**********************************************************************
!
! FunctionL Compute local time step
!
!**********************************************************************
! Arguments
real*8 :: dtmax
! Local variables
integer :: i,n
real*8 :: norm(ndimn),enorm,ex,ey,vari(nmet),cc,deltx,delty,deltz,celvol
dtmax=0.0D0
if( 3 .eq. ndimn) then
do i=1, ncell
call ctop(vari(:),cellinfo%cvar(:,i))
cc=dsqrt(gamma*vari(5)/vari(i))
celvol=cellinfo%vol(i)
deltx=0.0D0
delty=0.0D0
deltz=0.0D0
do n=1,ncellface
norm(:)=cellinfo%facenorm(:,n,i)
deltx =deltx+0.5D0*dabs(norm(1))
delty =delty+0.5D0*dabs(norm(2))
deltz =deltz+0.5D0*dabs(norm(3))
end do
deltx=(dabs(vari(2))+cc)*deltx
delty=(dabs(vari(3))+cc)*delty
deltz=(dabs(vari(4))+cc)*deltz
cellinfo%eigen(1,1,i)=deltx
cellinfo%eigen(2,1,i)=delty
cellinfo%eigen(3,1,i)=deltz
cellinfo%deltt(i)=cfl*celvol/(deltx+delty+deltz)
if(cellinfo%deltt(i) .gt. dtmax) dtmax=cellinfo%deltt(i)
end do
else if(2 .eq. ndimn) then
do i=1, ncell
call ctop(vari(:),cellinfo%cvar(:,i))
cc=dsqrt(gamma*vari(4)/vari(i))
celvol=cellinfo%vol(i)
deltx=0.0D0
delty=0.0D0
do n=1,ncellface
norm(:)=cellinfo%facenorm(:,n,i)
deltx =deltx+0.5D0*dabs(norm(1))
delty =delty+0.5D0*dabs(norm(2))
end do
deltx=(dabs(vari(2))+cc)*deltx
delty=(dabs(vari(3))+cc)*delty
cellinfo%eigen(1,1,i)=deltx
cellinfo%eigen(2,1,i)=delty
cellinfo%deltt(i)=cfl*celvol/(deltx+delty)
if(cellinfo%deltt(i) .gt. dtmax) dtmax=cellinfo%deltt(i)
end do
end if
return
end subroutine decompute