-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtraspnl_lw.f
70 lines (56 loc) · 2.12 KB
/
traspnl_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
program traspnonlinearlw
C=============================================================================
C Code to solve the transport equation: du/dt + df(u)/dx = 0. Where f can be
C an arbritary function of u, so also non linear case (e.g. schok wave)
C The code use the lax wendroff method. (For plot always trasp_plot.py)
c=============================================================================
implicit real*8 (a-h,p-z)
f(u) = v*u**2 ! Non linear equation, wavefront break
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))
c = dt/dx
!Initial condition
q = 2.d0 * 4.d0 * datan(1.d0) !2 pi
do i = 0, N
x = i*dx
sol_v(i) = dsin(q*0.2d0*x)
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*c*(f(sol_v(i+1))-f(sol_v(i)))
enddo
!solution with leap frog
do i = 1, N - 1
sol_n(i) = sol_v(i)+c*(f(sol_m(i))-f(sol_m(i-1)))
enddo
!poriodic boundary conditions
sol_n(0) = sol_n(N - 1)
sol_n(N) = sol_n(1)
!Update solutions
sol_v = sol_n
enddo
!scrivo sul 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