forked from circlelq/weno5-2D
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbc.m
67 lines (59 loc) · 1.59 KB
/
bc.m
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
%
% bc.m
% code3
%
% Created by Yuan Leiqi (袁磊祺) on 2021/6/11.
%
function [W] = bc(W)
% set boundary conditions
%
global Nx Ny
d = (Nx * 0.2);
h = (Ny * 0.2);
% Entry condition
for j = 1:Ny
W(1, j, :) = [1.4, 3, 0, 1];
W(2, j, :) = [1.4, 3, 0, 1];
W(3, j, :) = [1.4, 3, 0, 1];
end
% Export condition
for j = 1:Ny
W(Nx, j, :) = W(Nx - 2, j, :);
W(Nx - 1, j, :) = W(Nx - 2, j, :);
W(Nx - 2, j, :) = W(Nx - 2, j, :);
end
% Top condition
for i = 2:Nx - 1
W(i, Ny, :) = W(i, Ny - 5, :);
W(i, Ny, 3) = -W(i, Ny - 5, 3);
W(i, Ny - 1, :) = W(i, Ny - 4, :);
W(i, Ny - 1, 3) = -W(i, Ny - 4, 3);
W(i, Ny - 2, :) = W(i, Ny - 3, :);
W(i, Ny - 2, 3) = -W(i, Ny - 3, 3);
end
% Bottom condition
for i = 2:d - 1
W(i, 1, :) = W(i, 6, :);
W(i, 1, 3) = -W(i, 6, 3);
W(i, 2, :) = W(i, 5, :);
W(i, 2, 3) = -W(i, 5, 3);
W(i, 3, :) = W(i, 4, :);
W(i, 3, 3) = -W(i, 4, 3);
end
for i = d + 1:Nx - 1
W(i, h - 2, :) = W(i, h + 3, :);
W(i, h - 2, 3) = -W(i, h + 3, 3);
W(i, h - 1, :) = W(i, h + 2, :);
W(i, h - 1, 3) = -W(i, h + 2, 3);
W(i, h, :) = W(i, h + 1, :);
W(i, h, 3) = -W(i, h + 1, 3);
end
for j = 2:h - 1
W(d + 2, j, :) = W(d - 3, j, :);
W(d + 2, j, 2) = -W(d - 3, j, 2);
W(d + 1, j, :) = W(d - 2, j, :);
W(d + 1, j, 2) = -W(d - 2, j, 2);
W(d, j, :) = W(d - 1, j, :);
W(d, j, 2) = -W(d - 1, j, 2);
end
end