-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCodeSnippets_MatlabIntro.txt
65 lines (55 loc) · 2.09 KB
/
CodeSnippets_MatlabIntro.txt
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
S1:
imax = 800; % total number of spatial grid points
% Light source
c = 3e8; % speed of light in air [m/s]
cw = c / 1.33; % speed of light in water [m/s]
f0 = 8e9; % freq. of source [Hz]
amp = 0.8; % source amplitude
ibd = round(imax / 3.5); % location of material boundary
% Sound source
c = 343; % speed of sound in water [m/s]
cw = 1498; % speed of sound in air [m/s]
f0 = 10000; % freq. of source [Hz]
amp = 0.4; % source amplitude
ibd = round(imax / 4); % location of material boundary
% Display error message
error('You entered an invalid input.')
S2:
% FD parameters
lambda0 = min(c, cw) / f0; % wavelength of source wave [m]
dx = lambda0 / 20; % space grid step
dt = dx / max(c, cw); % time grid step
nmax = round(0.5 * (imax * dx) / min(c, cw) / dt); % number of time steps
w = 2 * pi * f0; % angular frequency
tau = nmax * dt / 10; % half width of source [s]
t0 = 3 * tau; % time delay at source [s]
s1 = c * dt / dx; % update coeff. for left half space
s2 = cw * dt / dx; % update coeff. for right half space
S3:
% Define the source
source(n) = amp * sin(w * (dt * n - t0)) ...
.* exp(-((dt * n - t0).^2) / tau^2);
S4:
% Plotting results
plot(u(n + 1, 1:imax))
hold on
plot([ibd, ibd], [-1, 1], '--k');
hold off
axis([1, imax, -1, 1]);
xlabel('x'), ylabel('u');
T = ['Air ','Time step = ', num2str(n + 1), ...
' of ', num2str(nmax), ' Water'];
title(T);
pause(0.01);
S5:
% alternate way to update in space without for loop
u(n+1, 2 : ibd) = s1^2 * (u(n, 3 : ibd + 1) - ...
(2 * u(n, 2 : ibd)) + ...
u(n, 1 : ibd - 1))...
+ (2 * u(n, 2 : ibd)) ...
- u(n-1, 2 : ibd);
u(n+1, ibd + 1 : imax - 1) = s2^2 * (u(n, ibd + 2 : imax) - ...
(2 * u(n, ibd + 1 : imax - 1)) + ...
u(n, ibd : imax - 2))...
+ (2 * u(n, ibd + 1 : imax - 1)) ...
- u(n-1, ibd + 1 : imax - 1);