-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtrasp_lw.f
76 lines (63 loc) · 2.46 KB
/
trasp_lw.f
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
program laxwendroff
C=====================================================================================
C Code to solve the transport equation: du/dt + v*du/dx = 0. Where v is
C the speed of the propagation and is constant. Using the lax wendroff method:
C a first half step with lax and then leap frog between lax and previous solution
C
C u^{n+1/2}_{j+1/2} = (u^n_{j+1} + u^n_{j-1})/2 - (alpha/2)(u^n_{j+1} - u^n_j)
C u^{n+1}_j = u^n_j - alpha(u^{n+1/2}_{j+1/2} - u^{n+1/2}_{j+1/2})
C
C Where alpha = v*dt/dx
C The parameters are written to a file so that they are readable by both
C the simulation code and the plot code (written in python)
c=====================================================================================
implicit real*8 (a-h,p-z)
real*8, dimension(:), allocatable :: sol_v, sol_n, sol_m
open(1, file='input_trasp.txt', status='old') !parameter file
open(2, file='tra_lxw.dat', status='unknown') !results file
read(1,*) N !Number of ponits on spatial axis
read(1,*) i_T !Number of ponits on temporal axis
read(1,*) v !Speed of the propagation
read(1,*) dt !Temporal step
read(1,*) dx !Spatial step
read(1,*) i_P !How often to save the solution
allocate(sol_v(0:N), sol_n(0:N), sol_m(0:N))
alpha = v*dt/dx
print*, alpha
!Initial condition
q = 2.d0 * 4.d0 * datan(1.d0) !2 pi
do i = 0, N
x = i*dx
sol_v(i) = 15.d0*dsin(q*2.d0*x)*dexp(-(x-5)**2)
enddo
!Save the initial condition
do i = 0, N
write(2,*) sol_v(i)
enddo
do i_time = 1, i_T
do i_tpass = 1, i_P
!solution with lax
do i = 0, N - 1
sol_m(i) = 0.5*(sol_v(i+1) + sol_v(i)) +
& 0.5*alpha*(sol_v(i+1) - sol_v(i))
enddo
!Solution with leap frog
do i = 1, N - 1
sol_n(i) = sol_v(i)+alpha*(sol_m(i) - sol_m(i-1))
enddo
!Periodic boundary conditions
sol_n(0) = sol_n(N - 1)
sol_n(N) = sol_n(1)
!Update solutions
sol_v = sol_n
enddo
!save the solution on file
do i = 0, N
write(2,*) sol_v(i)
enddo
enddo
deallocate(sol_v, sol_n, sol_m)
close(1)
close(2)
stop
end program