-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathfreeze_fluid.c
86 lines (71 loc) · 2.68 KB
/
freeze_fluid.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
#include"pluto.h"
#include "freeze_fluid.h"
/* ********************************************************************* */
void ZeroHypFlux (const State_1D *state, int beg, int end,
double *cmax, Grid *grid)
{
/*!
* This function is a replacement for a Riemann solver in case one wants
* to keep the fluid evolution frozen (no advection at all).
* I created this function modifying the hll Riemann solver.
*
* \param[in,out] state pointer to State_1D structure
* \param[in] beg initial grid index
* \param[out] end final grid index
* \param[out] cmax 1D array of maximum characteristic speeds
* \param[in] grid pointer to array of Grid structures.
*
*********************************************************************** */
int nv, i;
double scrh;
double *SR, *SL;
static double **VL, **VR, **UL, **UR;
static double *a2L, *a2R;
double **bgf;
/* **fL is useless, but it is used as check to know whehter
other variables have to be allocate.
Since I do not want to loose time debugging, I keep it.
*/
static double **fL;
// static double **fL, **fR;
// static double *pL, *pR;
// static double **Uhll;
if (fL == NULL){
fL = ARRAY_2D(NMAX_POINT, NFLX, double);
// fR = ARRAY_2D(NMAX_POINT, NFLX, double);
//pL = ARRAY_1D(NMAX_POINT, double);
//pR = ARRAY_1D(NMAX_POINT, double);
a2L = ARRAY_1D(NMAX_POINT, double);
a2R = ARRAY_1D(NMAX_POINT, double);
// Uhll = ARRAY_2D(NMAX_POINT, NFLX, double);
}
/* ------------------------------------------------
Solve 2x2 Riemann problem with GLM Cleaning
------------------------------------------------ */
VL = state->vL; UL = state->uL;
VR = state->vR; UR = state->uR;
/* ----------------------------------------------------
compute sound speed & fluxes at zone interfaces
---------------------------------------------------- */
SoundSpeed2 (VL, a2L, NULL, beg, end, FACE_CENTER, grid);
SoundSpeed2 (VR, a2R, NULL, beg, end, FACE_CENTER, grid);
// Next two lines to be deleted
//Flux (UL, VL, a2L, bgf, fL, pL, beg, end);
//Flux (UR, VR, a2R, bgf, fR, pR, beg, end);
/* ----------------------------------------
get max and min signal velocities
---------------------------------------- */
SL = state->SL; SR = state->SR;
HLL_Speed (VL, VR, a2L, a2R, bgf, SL, SR, beg, end);
/* ----------------------------------------
compute HLL flux
---------------------------------------- */
for (i = beg; i <= end; i++) {
scrh = MAX(fabs(SL[i]), fabs(SR[i]));
cmax[i] = scrh;
for (nv = 0; nv < NFLX; nv++) {
state->flux[i][nv] = 0.0;
}
state->press[i] = 0.0;
}
}