-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinit.asv
154 lines (131 loc) · 4.35 KB
/
init.asv
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
function [] = init()
% Purpose: To initilise all parameters.
% constants
global NPI NPJ LARGE U_IN XMAX YMAX P_ATM
% variables
global x x_u y y_v u v pc p T rho mu mut mueff Gamma Cp k eps delta E E2 yplus yplus1 ...
yplus2 uplus tw b SP Su d_u d_v omega SMAX SAVG m_in m_out relax_u relax_v ...
relax_pc relax_T aP aE aW aN aS F_u F_v u_old v_old pc_old T_old k_old ...
eps_old dudx dudy dvdx dvdy
% begin: memalloc()========================================================
% allocate memory for variables
x = zeros(1,NPI+2);
x_u = zeros(1,NPI+2);
y = zeros(1,NPJ+2);
y_v = zeros(1,NPJ+2);
u = zeros(NPI+2,NPJ+2);
v = zeros(NPI+2,NPJ+2);
pc = zeros(NPI+2,NPJ+2);
p = zeros(NPI+2,NPJ+2);
T = zeros(NPI+2,NPJ+2);
rho = zeros(NPI+2,NPJ+2);
mu = zeros(NPI+2,NPJ+2);
mut = zeros(NPI+2,NPJ+2);
mueff = zeros(NPI+2,NPJ+2);
Gamma = zeros(NPI+2,NPJ+2);
Cp = zeros(NPI+2,NPJ+2);
k = zeros(NPI+2,NPJ+2);
eps = zeros(NPI+2,NPJ+2);
delta = zeros(NPI+2,NPJ+2);
E = zeros(NPI+2,NPJ+2);
E2 = zeros(NPI+2,NPJ+2);
yplus = zeros(NPI+2,NPJ+2);
yplus1 = zeros(NPI+2,NPJ+2);
yplus2 = zeros(NPI+2,NPJ+2);
uplus = zeros(NPI+2,NPJ+2);
tw = zeros(NPI+2,NPJ+2);
u_old = zeros(NPI+2,NPJ+2);
v_old = zeros(NPI+2,NPJ+2);
pc_old = zeros(NPI+2,NPJ+2);
T_old = zeros(NPI+2,NPJ+2);
k_old = zeros(NPI+2,NPJ+2);
eps_old = zeros(NPI+2,NPJ+2);
dudx = zeros(NPI+2,NPJ+2);
dudy = zeros(NPI+2,NPJ+2);
dvdx = zeros(NPI+2,NPJ+2);
dvdy = zeros(NPI+2,NPJ+2);
aP = zeros(NPI+2,NPJ+2);
aE = zeros(NPI+2,NPJ+2);
aW = zeros(NPI+2,NPJ+2);
aN = zeros(NPI+2,NPJ+2);
aS = zeros(NPI+2,NPJ+2);
b = zeros(NPI+2,NPJ+2);
SP = zeros(NPI+2,NPJ+2);
Su = zeros(NPI+2,NPJ+2);
F_u = zeros(NPI+2,NPJ+2);
F_v = zeros(NPI+2,NPJ+2);
d_u = zeros(NPI+2,NPJ+2);
d_v = zeros(NPI+2,NPJ+2);
% end of memory allocation=================================================
% begin: grid()===========================================================
% Purpose: Defining the geometrical variables See fig. 6.2-6.4 in ref. 1
% Length of volume element
Dx = XMAX/NPI;
Dy = YMAX/NPJ;
% Length variable for the scalar points in the x direction
x(1) = 0.;
x(2) = 0.5*Dx;
for I = 3:NPI+1
x(I) = x(I-1) + Dx;
end
x(NPI+2) = x(NPI+1) + 0.5*Dx;
% Length variable for the scalar points T(i,j) in the y direction
y(1) = 0.;
y(2) = 0.5*Dy;
for J = 3:NPJ+1
y(J) = y(J-1) + Dy;
end
y(NPJ+2) = y(NPJ+1) + 0.5*Dy;
% Length variable for the velocity components u(i,j) in the x direction
x_u(1) = 0.;
x_u(2) = 0.;
for i = 3:NPI+2
x_u(i) = x_u(i-1) + Dx;
end
% Length variable for the velocity components v(i,j) in the y direction
y_v(1) = 0.;
y_v(2) = 0.;
for j = 3:NPJ+2
y_v(j) = y_v(j-1) + Dy;
end
% end of grid setting======================================================
% begin: init()===========================================================
% Initialising all other variables
omega = 1.0; % Over-relaxation factor for SOR solver
% Initialize convergence parameters at large values
SMAX = LARGE;
SAVG = LARGE;
m_in = 0.; %1.;
m_out = 0.; %1.;
for i = 1:NPI+2
for J = 1:NPJ+2
u(i,J) = U_IN*1.5*(1.0-(2.0*(y(J)-YMAX/2)/YMAX)^2); % Velocity in x-direction
end
end
v(:,:) = 0.; % Velocity in y-direction
p(:,:) = 0; % Relative pressure
T(:,:) = 283.; % Temperature
rho(:,:) = 1.29; % Density
mu(:,:) = 1.8E-5; % Viscosity
Cp(:,:) = 710; % J/(K*kg) Heat capacity - assumed constant for this problem
Gamma = 0.024./Cp;% Thermal conductivity divided by heat capacity
k(:,:) = 1e-3; % k
eps(:,:) = 1e-4; % epsilon
uplus(:,:) = 1.; % uplus
yplus1(:,:)= sqrt(rho .* u ./ mu) * (y(2) - y(1)); % yplus1
yplus2(:,:)= sqrt(rho .* u ./ mu) * (y(NPJ+2) - y(NPJ+1)); % yplus2
yplus(:,:) = 1.; % yplus
tw(:,:) = 5.; % tw
u_old = u; % Velocity in x-direction old timestep
v_old = v; % Velocity in y-direction old timestep
pc_old = pc; % Pressure correction old timestep
T_old = T; % Temperature old timestep
eps_old = eps; % epsilon old timestep
k_old = k; % k old timestep
% Setting the relaxation parameters
relax_u = 0.8; % 0.8 See eq. 6.36
relax_v = relax_u; % See eq. 6.37
relax_pc = 1.1 - relax_u; % See eq. 6.33
relax_T = 1.0; % Relaxation factor for temperature
% end of initilization=====================================================
end