-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdustcakepressuredrop_withdebug.c
352 lines (311 loc) · 11.1 KB
/
dustcakepressuredrop_withdebug.c
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
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
#include "udf.h"
#define Ax 55e-13 /*permeability in x direction */
#define Ay 55e-13 /*permeability in y direction */
#define PAR_DEN 2700 /*particle real density*/
#define CELL_POROUSITY 0.524 /*porousity of dust cake*/
#define DEPOSIT_FACE_ID 32 /*dust deposit face thread id*/
#define AIR_VISOCOSITY 1.83e-5
#define FACE_VELOCITY 0.02
#define ADJUST_DYNAMIC_SHAPE_FACTOR 1.25
#define MOLE_FREE_PATH 6.9e-8
#define FLAG_USE_FACE_VELOCITY 1
#define GEOMETRIC_STANDARD_DEVIATION 1.6
#define GEOMETRIC_MEAN_DIAMETER 2.5e-6
/*for data output*/
real source_x = 0;
real source_y = 0;
/*count the cunningham correction factor in a certain cell*/
real CUNNINGHAN_CORRECTION(real particle_diam, real molecular_free_path);
/*count the adjust dynamic shape factor factor in a certain cell*/
real ADJUST_DYN_SHA_FAC(real vm_diam, real vm_cunn, real sm_diam, real sm_cunn);
/*count the total dust loading mass for a certain cell*/
real TOTAL_MASS_C(cell_t cp, Thread *tp, real timestepp);
/*count the total dust loading face area for a certain cell*/
int FACE_AREA_C(real area_f[], real face_load[],cell_t cp, Thread *tp, int deposit_face_ID);
/*function to count the dustcake in xyz direction at a certain cell, not used now*/
/*real DUSTCAKE_THICKNESS(real c_porousity, real p_real_density, int deposit_face_ID, cell_t cp, Thread *tp);*/
/*count the total dust loading mass for a certain cell*/
int FACE_DUST_LOAD_C(real face_dust_load[], cell_t cp, Thread *tp);
/*count the total porousity for a certain cell*/
real TOTALL_POROUSITY(real face_velocity, real face_dust_load);
/*count the total pressure drop on the dintust cake for a certain cell
theroy detail showed on paper "Compression properties of dust cake of fine fly ashes from a fluidized bed coal combustor on a ceramic filter" */
real PRESSURE_DROP_SOURCE(real c_porousity, real vcsity,
real ad_dynamic_shape_fac, real particle_density,
real geometric_mean_diameter, real geometric_standard_deviation,
real face_velocity, real face_dust_load);
DEFINE_SOURCE(xmom_source, c, t, dS, eqn) {
/*reserved for a classic use*/
/* real mu_coeiff;
real thickness[ND_ND];
real x[ND_ND];
real con, source;
real effu;
thickness = dustcake_thickness(Cell_porosity, PAR_DEN, DE_FACE_ID, c, t);
effu = C_MU_EFF(c, t);
con = effu / Ax*thickness[0];*/
real porous;
real air_vc;/*Viscosity*/
real adsf;/*adjust_dynamic_shape_factor*/
real pd;/*particle density*/
real gmd;/*geometric_mean_diameter*/
real gsd;/*geometric_standard_deviation*/
real fvx;/*face_velocity*/
real flx;/*face_dust_load*/
real source; /*momentum source on x direction*/
real face_load_xy[ND_ND];
real x[ND_ND];
real face_deposit_area[ND_ND];
real face_deposit_area_x;
real delt_P_x;
/* real t_mass;*/
if (FLAG_USE_FACE_VELOCITY && fabs(C_U(c,t))> 0.02)
/* fvx = fabs(C_U(c,t)/sqrt(C_V(c,t)*C_V(c,t)+C_U(c,t)*C_U(c,t))*FACE_VELOCITY);*/
fvx=FACE_VELOCITY;
else
fvx = fabs(C_U(c, t));
C_CENTROID(x, c, t);
/*the area you want to apply the source*/
/*if (sqrt(x[0] * x[0] + x[1] * x[1]) > 0.03) {*/
FACE_DUST_LOAD_C(face_load_xy,face_deposit_area, c, t);
flx = face_load_xy[0];
face_deposit_area_x=face_deposit_area[0];
/*if (face_load_xy[0] != 0) {
Message("your face_load in x now is %g \n", face_load_xy[0]);
}*/
porous = TOTALL_POROUSITY(fvx, flx);
air_vc = AIR_VISOCOSITY;
adsf = ADJUST_DYNAMIC_SHAPE_FACTOR;
gmd = GEOMETRIC_MEAN_DIAMETER;
gsd = GEOMETRIC_STANDARD_DEVIATION;
pd = PAR_DEN;
delt_P_x = -PRESSURE_DROP_SOURCE(porous, air_vc, adsf, pd, gmd, gsd, fvx,
flx)*C_U(c,t)/fabs(C_U(c,t));
source = delt_P_x*face_deposit_area_x/C_VOLUME(c, t);
/*Message(
"your porous air_vc adsf pd gmd gsd fvx flx source is %g %g %g %g %g %g %g %g %g \n",
porous, air_vc, adsf, pd, gmd, gsd, fvx, flx, source);*/
source_x = source;
C_UDMI(c,t,0) = source;
/*Message("your x pressure now is %g\n", source);*/
/*
if (c>=100 && c<=120)
{
printf('the x face thickness is %g\n ', thickness[0]);
}*/
dS[eqn] = source / fvx;
return source;
/* } else {
dS[eqn] = 0;
C_UDMI(c,t,0) = 0;
return source = 0;
}*/
}
DEFINE_SOURCE(ymom_source, c, t, dS, eqn) {
real porous;
real air_vc;
real adsf;
real pd;
real gmd;
real gsd;
real fvy;
real fly;
real source;
real face_load_xyy[ND_ND];
real face_deposit_area[ND_ND];
real y[ND_ND];
real face_deposit_areay[ND_ND];
real face_deposit_area_y;
real delt_P_y;
if (FLAG_USE_FACE_VELOCITY && fabs(C_V(c,t))>0.02)
/*fvy = fabs(C_V(c,t)/sqrt(C_V(c,t)*C_V(c,t)+C_U(c,t)*C_U(c,t))*FACE_VELOCITY);*/
fvy = FACE_VELOCITY;
else
fvy = fabs(C_V(c, t));
C_CENTROID(y, c, t);
/*if (sqrt(y[0] * y[0] + y[1] * y[1]) > 0.03) {*/
FACE_DUST_LOAD_C(face_load_xyy,face_deposit_areay,c, t);
fly = face_load_xyy[1];
/*if (face_load_xyy[1] != 0) {
Message("your face load in y now is %g \n", face_load_xyy[1]);
}*/
face_deposit_area_y=face_deposit_areay[1];
porous = TOTALL_POROUSITY(fvy, fly);
air_vc = AIR_VISOCOSITY;
adsf = ADJUST_DYNAMIC_SHAPE_FACTOR;
gmd = GEOMETRIC_MEAN_DIAMETER;
gsd = GEOMETRIC_STANDARD_DEVIATION;
pd = PAR_DEN;
delt_P_y=-PRESSURE_DROP_SOURCE(porous, air_vc, adsf, pd, gmd, gsd, fvy,
fly)*C_V(c,t)/fabs(C_V(c,t));
source = delt_P_y*face_deposit_area_y/C_VOLUME(c, t);
/*Message(
"your porous air_vc adsf pd gmd gsd fvy fly source is %g %g %g %g %g %g %g %g %g \n",
porous, air_vc, adsf, pd, gmd, gsd, fvy, fly, source);*/
source_y = source;
/*Message("your y pressure now is %g\n", source);*/
/*
if (c >= 100 && c <= 120)
{
printf('the y face thickness is %g\n ', thickneseal FACE_AREA_C(real *area_f, cell_t cp,Thread *tp,int deposit_face_ID)s[1]);
}
source = -con*C_V(c, t);*/
C_UDMI(c,t,1) = source;
dS[eqn] = source / fvy;
return source;
/* } else {
C_UDMI(c,t,1) = 0;
dS[eqn] = 0;
return source = 0;
}*/
}
DEFINE_OUTPUT_PARAMETER(pressure_x,n,parlist) {
real prex = source_x;
return prex;
}
DEFINE_OUTPUT_PARAMETER(pressure_y,n,parlist) {
real prey = source_y;
return prey;
}
real CUNNINGHAN_CORRECTION(real particle_diam, real molecular_free_path) {
if (particle_diam > 2 * molecular_free_path) {
return 1 + 2.468 * molecular_free_path / particle_diam;
} else {
return 1 + 3.294 * molecular_free_path / particle_diam;
}
}
real ADJUST_DYN_SHA_FAC(real vm_diam, real vm_cunn, real sm_diam, real sm_cunn) {
return CUNNINGHAN_CORRECTION(vm_diam, MOLE_FREE_PATH)
/ CUNNINGHAN_CORRECTION(sm_diam, MOLE_FREE_PATH)
* (vm_diam / sm_diam) * (vm_diam / sm_diam);
}
/*real DUSTCAKE_THICKNESS(real c_porousity, real p_real_density,int deposit_face_ID,cell_t cp, Thread *tp)
{int
real total_mass_c;
real real_v_c;
real v_dustcake_c;
real deposit_face_area_c;
real dust_cake_height_c[ND_ND]; C_CENTROID(y, c, t);
real A[ND_ND]; } else {
C_UDMI(c,t,1) = 0;
dS[eqn] = 0;
return source = 0;
}
int n;
total_mass_c = C_DPMS_CONCENTRATION(cp, tp)*C_VOLUME(cp, tp)*CURRENT_TIMESTEP;
real_v_c = total_mass_c / p_real_density;
v_dustcake_c = real_v_c / c_porousity;
c_face_loop(cp, tp, n)
{
if (THREAD_ID(C_FACE_THREAD(cp, tp, n)) == deposit_face_ID)
{
F_AREA(A, C_FACE(cp, tp, n), C_FACE_THREAD(cp, tp, n));
}
}
dust_cake_height_c[0] = v_dustcake_c / A[0];
dust_cake_height_c[1] = v_dustcake_c / A[1];
dust_cake_height_c[2] = 0;
return dust_cake_height_c;
}*/
real TOTAL_MASS_C(cell_t cp, Thread *tp, real timestepp) {
/*if (C_DPMS_CONCENTRATION(cp,tp) != 0)*/
/*Message("your pcon C_V times step is %g %g %g \n",
C_DPMS_CONCENTRATION(cp, tp), C_VOLUME(cp, tp),
CURRENT_TIMESTEP);*/
/*Message("your dust contentration is %g \n", C_DPMS_CONCENTRATION(cp,tp));*/
/*C_UDMI(cp,tp,2)=C_DPMS_CONCENTRATION(cp,tp);*/
return C_DPMS_CONCENTRATION(cp, tp) * C_VOLUME(cp, tp);
}
int FACE_AREA_C(real area_f[], cell_t cp, Thread *tp, int deposit_face_ID) {
int flag_flowdirection;
int n;
real x[ND_ND];
flag_flowdirection = -1; /*flow flag*/
/*#if RP_NODE*/
if (flag_flowdirection == -1) {
c_face_loop(cp, tp, n)
{
if (THREAD_ID(C_FACE_THREAD(cp, tp, n)) == deposit_face_ID) {
F_AREA(area_f, C_FACE(cp, tp, n), C_FACE_THREAD(cp, tp, n));
/*Message("your face area is %g %g %g\n",area_f[0],area_f[1],area_f[2]);*/
}
}
}
/*#endif*/
return 0;
}
/*count the face dust load in a cell mainly in x y direction*/
int FACE_DUST_LOAD_C(real face_dust_load[], real face_load[],cell_t cp, Thread *tp) {
int ii;
real face_of_area[ND_ND];
real total_mass_c;
/* real face_load[ND_ND];*/
real f_area_t;
total_mass_c = TOTAL_MASS_C(cp, tp, CURRENT_TIMESTEP);
/*if (total_mass_c != 0)*/
/* Message("your total mass is %g\n", total_mass_c);*/
FACE_AREA_C(face_of_area, cp, tp, DEPOSIT_FACE_ID);
f_area_t = NV_MAG(face_of_area);
face_load[0] = fabs(face_of_area[0])
/ sqrt(
face_of_area[0] * face_of_area[0]
+ face_of_area[1] * face_of_area[1]) * f_area_t;
face_load[1] = fabs(face_of_area[1])
/ sqrt(
face_of_area[0] * face_of_area[0]
+ face_of_area[1] * face_of_area[1]) * f_area_t;
/* Message("your face_dust_load x y z t is %g %g %g %g\n", face_of_area[0],
face_of_area[1], face_of_area[2], f_area_t);*/
/* if your case is 2D please change your dimension*/
/*#if RP_NODE*/
#if RP_3D
for (ii=0; ii<2; ii++)
{
/*Message("you face area is %g\n",fabs(face_of_area[ii]));*/
if(fabs(face_load[ii])>1e-20) {
face_dust_load[ii]= total_mass_c / face_load[ii];
/*Message("you face load is %g\n",face_dust_load[ii]);*/
}
else
{
/*Message("please keep your face_area have a non-zero value \n");*/
}
/* Message("you enter here\n");
Message("your face load is %g \n", face_dust_load[ii]);*/
}
#endif
/*#endif*/
return 0;
}
/*
(theroy detail showed on paper "Compression properties of dust cake of fine fly ashes from a
fluidized bed coal combustor on a ceramic filter")*/
real TOTALL_POROUSITY(real face_velocity, real face_dust_load) {
return 1
- (0.88
- 0.37 * pow(fabs(face_velocity), 0.36)
* pow(fabs(face_dust_load), 0.25))
* pow(fabs(face_velocity), 0.36) * pow(fabs(face_dust_load), 0.25);
}
/*your pressure drop function*/
real PRESSURE_DROP_SOURCE(real c_porousity, real vcsity,
real ad_dynamic_shape_fac, real particle_density,
real geometric_mean_diameter, real geometric_standard_deviation,
real face_velocity, real face_dust_load) {
real acoef;
real bcoef;
real ccoef;
real tpc_drop;
ccoef = 4 * log(geometric_standard_deviation)
* log(geometric_standard_deviation);
/*Message("your ccoef is %g\n", ccoef);*/
acoef = (2970 * vcsity * ad_dynamic_shape_fac * (1 - c_porousity))
/ pow(c_porousity, 4);
/*Message("your acoef is %g\n", acoef);*/
bcoef = particle_density * geometric_mean_diameter * geometric_mean_diameter
* exp(ccoef);
/*Message("your bcoef is %g\n", bcoef);*/
tpc_drop = acoef * pow(bcoef, -1) * fabs(face_velocity) * fabs(face_dust_load);
/*Message("your drop is %g\n", tpc_drop);*/
return tpc_drop;
}