update corey model in greyscale
This commit is contained in:
parent
bed008b785
commit
f55b946b8a
@ -234,12 +234,12 @@ extern "C" void ScaLBL_D3Q19_AAodd_GreyscaleColor(int *d_neighborList, int *Map,
|
|||||||
double Fx, double Fy, double Fz, int strideY, int strideZ, int start, int finish, int Np);
|
double Fx, double Fy, double Fz, int strideY, int strideZ, int start, int finish, int Np);
|
||||||
|
|
||||||
extern "C" void ScaLBL_D3Q19_AAeven_GreyscaleColor_CP(int *Map, double *dist, double *Aq, double *Bq, double *Den,
|
extern "C" void ScaLBL_D3Q19_AAeven_GreyscaleColor_CP(int *Map, double *dist, double *Aq, double *Bq, double *Den,
|
||||||
double *Phi, double *GreySolidW, double *GreySn, double *GreySw, double *GreyKn, double *GreyKw, double *Poros,double *Perm,double *Vel, double *Pressure,
|
double *Phi, double *GreySolidW, double *GreySn, double *GreySw, double *GreyKn, double *GreyKw, double *Poros,double *Perm,double *Vel, double *MobilityRatio, double *Pressure,
|
||||||
double rhoA, double rhoB, double tauA, double tauB,double tauA_eff,double tauB_eff, double alpha, double beta,
|
double rhoA, double rhoB, double tauA, double tauB,double tauA_eff,double tauB_eff, double alpha, double beta,
|
||||||
double Fx, double Fy, double Fz, bool RecoloringOff, int strideY, int strideZ, int start, int finish, int Np);
|
double Fx, double Fy, double Fz, bool RecoloringOff, int strideY, int strideZ, int start, int finish, int Np);
|
||||||
|
|
||||||
extern "C" void ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(int *d_neighborList, int *Map, double *dist, double *Aq, double *Bq, double *Den,
|
extern "C" void ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(int *d_neighborList, int *Map, double *dist, double *Aq, double *Bq, double *Den,
|
||||||
double *Phi, double *GreySolidW, double *GreySn, double *GreySw, double *GreyKn, double *GreyKw, double *Poros, double *Perm,double *Vel,double *Pressure,
|
double *Phi, double *GreySolidW, double *GreySn, double *GreySw, double *GreyKn, double *GreyKw, double *Poros, double *Perm,double *Vel, double *MobilityRatio, double *Pressure,
|
||||||
double rhoA, double rhoB, double tauA, double tauB, double tauA_eff,double tauB_eff, double alpha, double beta,
|
double rhoA, double rhoB, double tauA, double tauB, double tauA_eff,double tauB_eff, double alpha, double beta,
|
||||||
double Fx, double Fy, double Fz, bool RecoloringOff, int strideY, int strideZ, int start, int finish, int Np);
|
double Fx, double Fy, double Fz, bool RecoloringOff, int strideY, int strideZ, int start, int finish, int Np);
|
||||||
|
|
||||||
|
@ -1271,7 +1271,6 @@ extern "C" void ScaLBL_D3Q19_AAeven_GreyscaleColor(int *Map, double *dist, doubl
|
|||||||
-mrt_V6*m9-mrt_V7*m10+0.25*m14+0.125*(m18-m17);
|
-mrt_V6*m9-mrt_V7*m10+0.25*m14+0.125*(m18-m17);
|
||||||
dist[16*Np+n] = fq;
|
dist[16*Np+n] = fq;
|
||||||
|
|
||||||
|
|
||||||
// q = 17
|
// q = 17
|
||||||
fq = mrt_V1*rho+mrt_V9*m1
|
fq = mrt_V1*rho+mrt_V9*m1
|
||||||
+mrt_V10*m2+0.1*(jy-jz)+0.025*(m6-m8)
|
+mrt_V10*m2+0.1*(jy-jz)+0.025*(m6-m8)
|
||||||
@ -1341,7 +1340,8 @@ extern "C" void ScaLBL_D3Q19_AAeven_GreyscaleColor(int *Map, double *dist, doubl
|
|||||||
//CP: capillary penalty
|
//CP: capillary penalty
|
||||||
// also turn off recoloring for grey nodes
|
// also turn off recoloring for grey nodes
|
||||||
extern "C" void ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(int *neighborList, int *Map, double *dist, double *Aq, double *Bq, double *Den,
|
extern "C" void ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(int *neighborList, int *Map, double *dist, double *Aq, double *Bq, double *Den,
|
||||||
double *Phi, double *GreySolidW, double *GreySn, double *GreySw, double *GreyKn, double *GreyKw, double *Poros,double *Perm, double *Velocity, double *Pressure,
|
double *Phi, double *GreySolidW, double *GreySn, double *GreySw, double *GreyKn, double *GreyKw, double *Poros,double *Perm,
|
||||||
|
double *Velocity, double *MobilityRatio, double *Pressure,
|
||||||
double rhoA, double rhoB, double tauA, double tauB,double tauA_eff,double tauB_eff,double alpha, double beta,
|
double rhoA, double rhoB, double tauA, double tauB,double tauA_eff,double tauB_eff,double alpha, double beta,
|
||||||
double Gx, double Gy, double Gz, bool RecoloringOff, int strideY, int strideZ, int start, int finish, int Np){
|
double Gx, double Gy, double Gz, bool RecoloringOff, int strideY, int strideZ, int start, int finish, int Np){
|
||||||
|
|
||||||
@ -1423,21 +1423,33 @@ extern "C" void ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(int *neighborList, int *Map
|
|||||||
Krw_grey = 0.0;
|
Krw_grey = 0.0;
|
||||||
if (nA/(nA+nB)<Sn_grey && porosity !=1.0){
|
if (nA/(nA+nB)<Sn_grey && porosity !=1.0){
|
||||||
perm = Kw_grey;
|
perm = Kw_grey;
|
||||||
|
Krw_grey = Kw_grey;
|
||||||
Swn = 0.0;
|
Swn = 0.0;
|
||||||
}
|
}
|
||||||
else if (nA/(nA+nB)>=Sn_grey && nA/(nA+nB) <= Sw_grey && porosity !=1.0){
|
else if (nA/(nA+nB)>=Sn_grey && nA/(nA+nB) <= Sw_grey && porosity !=1.0){
|
||||||
Swn = (nA/(nA+nB) - Sn_grey) /(Sw_grey - Sn_grey);
|
Swn = (nA/(nA+nB) - Sn_grey) /(Sw_grey - Sn_grey);
|
||||||
Krn_grey = Kn_grey*Swn*Swn; // Corey model with exponent = 2, make sure that W cannot shift to zero
|
Krn_grey = Kn_grey*Swn*Swn; // Corey model with exponent = 2, make sure that W cannot shift to zero
|
||||||
Krw_grey = Kw_grey*(1.0-Swn)*(1.0-Swn); // Corey model with exponent = 2, make sure that W cannot shift to zero
|
Krw_grey = Kw_grey*(1.0-Swn)*(1.0-Swn); // Corey model with exponent = 4, make sure that W cannot shift to zero
|
||||||
// recompute the effective permeability
|
// recompute the effective permeability
|
||||||
perm = mu_eff*(Krn_grey*3.0/(tauA-0.5) + Krw_grey*3.0/(tauA-0.5));
|
perm = mu_eff*(Krn_grey*3.0/(tauA-0.5) + Krw_grey*3.0/(tauB-0.5));
|
||||||
//mobility_ratio =(nA*Krn_grey*3.0/(tauA-0.5) - nB*Krw_grey*3.0/(tauB-0.5))/(nA*Krn_grey*3.0/(tauA-0.5) + nB*Krw_grey*3.0/(tauB-0.5));
|
//mobility_ratio =(nA*Krn_grey*3.0/(tauA-0.5) - nB*Krw_grey*3.0/(tauB-0.5))/(nA*Krn_grey*3.0/(tauA-0.5) + nB*Krw_grey*3.0/(tauB-0.5));
|
||||||
}
|
}
|
||||||
else if (nA/(nA+nB)>Sw_grey && porosity !=1.0){
|
else if (nA/(nA+nB)>Sw_grey && porosity !=1.0){
|
||||||
perm = Kn_grey;
|
perm = Kn_grey;
|
||||||
|
Krn_grey = Kn_grey;
|
||||||
Swn = 1.0;
|
Swn = 1.0;
|
||||||
}
|
}
|
||||||
mobility_ratio =(nA*Krn_grey*3.0/(tauA-0.5) - nB*Krw_grey*3.0/(tauB-0.5))/(nA*Krn_grey*3.0/(tauA-0.5) + nB*Krw_grey*3.0/(tauB-0.5));
|
/* compute the mobility ratio */
|
||||||
|
if (porosity != 1.0){
|
||||||
|
mobility_ratio =(Krn_grey/(tauA-0.5) - Krw_grey/(tauB-0.5))/(Krn_grey/(tauA-0.5) + Krw_grey/(tauB-0.5));
|
||||||
|
}
|
||||||
|
else if (phi > 0.0){
|
||||||
|
mobility_ratio = 1.0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
mobility_ratio = -1.0;
|
||||||
|
}
|
||||||
|
MobilityRatio[n] = mobility_ratio;
|
||||||
|
|
||||||
// Get the 1D index based on regular data layout
|
// Get the 1D index based on regular data layout
|
||||||
ijk = Map[n];
|
ijk = Map[n];
|
||||||
@ -2181,7 +2193,8 @@ extern "C" void ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(int *neighborList, int *Map
|
|||||||
//CP: capillary penalty
|
//CP: capillary penalty
|
||||||
// also turn off recoloring for grey nodes
|
// also turn off recoloring for grey nodes
|
||||||
extern "C" void ScaLBL_D3Q19_AAeven_GreyscaleColor_CP(int *Map, double *dist, double *Aq, double *Bq, double *Den,
|
extern "C" void ScaLBL_D3Q19_AAeven_GreyscaleColor_CP(int *Map, double *dist, double *Aq, double *Bq, double *Den,
|
||||||
double *Phi, double *GreySolidW, double *GreySn, double *GreySw, double *GreyKn, double *GreyKw, double *Poros,double *Perm, double *Velocity, double *Pressure,
|
double *Phi, double *GreySolidW, double *GreySn, double *GreySw, double *GreyKn, double *GreyKw, double *Poros,double *Perm,
|
||||||
|
double *Velocity, double *MobilityRatio, double *Pressure,
|
||||||
double rhoA, double rhoB, double tauA, double tauB,double tauA_eff,double tauB_eff, double alpha, double beta,
|
double rhoA, double rhoB, double tauA, double tauB,double tauA_eff,double tauB_eff, double alpha, double beta,
|
||||||
double Gx, double Gy, double Gz, bool RecoloringOff, int strideY, int strideZ, int start, int finish, int Np){
|
double Gx, double Gy, double Gz, bool RecoloringOff, int strideY, int strideZ, int start, int finish, int Np){
|
||||||
|
|
||||||
@ -2254,27 +2267,40 @@ extern "C" void ScaLBL_D3Q19_AAeven_GreyscaleColor_CP(int *Map, double *dist, do
|
|||||||
rlx_setA = 1.f/tau;
|
rlx_setA = 1.f/tau;
|
||||||
rlx_setB = 8.f*(2.f-rlx_setA)/(8.f-rlx_setA);
|
rlx_setB = 8.f*(2.f-rlx_setA)/(8.f-rlx_setA);
|
||||||
mu_eff = (tau_eff-0.5)/3.0;//kinematic viscosity
|
mu_eff = (tau_eff-0.5)/3.0;//kinematic viscosity
|
||||||
|
|
||||||
|
mobility_ratio = 1.0;
|
||||||
Krn_grey = 0.0;
|
Krn_grey = 0.0;
|
||||||
Krw_grey = 0.0;
|
Krw_grey = 0.0;
|
||||||
if (nA/(nA+nB)<Sn_grey && porosity !=1.0){
|
if (nA/(nA+nB)<Sn_grey && porosity !=1.0){
|
||||||
perm = Kw_grey;
|
perm = Kw_grey;
|
||||||
|
Krw_grey = Kw_grey;
|
||||||
Swn = 0.0;
|
Swn = 0.0;
|
||||||
}
|
}
|
||||||
else if (nA/(nA+nB)>=Sn_grey && nA/(nA+nB) <= Sw_grey && porosity !=1.0){
|
else if (nA/(nA+nB)>=Sn_grey && nA/(nA+nB) <= Sw_grey && porosity !=1.0){
|
||||||
Swn = (nA/(nA+nB) - Sn_grey) /(Sw_grey - Sn_grey);
|
Swn = (nA/(nA+nB) - Sn_grey) /(Sw_grey - Sn_grey);
|
||||||
Krn_grey = Kn_grey*Swn*Swn; // Corey model with exponent = 2, make sure that W cannot shift to zero
|
Krn_grey = Kn_grey*Swn*Swn; // Corey model with exponent = 2, make sure that W cannot shift to zero
|
||||||
Krw_grey = Kw_grey*(1.0-Swn)*(1.0-Swn); // Corey model with exponent = 2, make sure that W cannot shift to zero
|
Krw_grey = Kw_grey*(1.0-Swn)*(1.0-Swn); // Corey model with exponent = 4, make sure that W cannot shift to zero
|
||||||
// recompute the effective permeability
|
// recompute the effective permeability
|
||||||
perm = mu_eff*(Krn_grey*3.0/(tauA-0.5) + Krw_grey*3.0/(tauA-0.5));
|
perm = mu_eff*(Krn_grey*3.0/(tauA-0.5) + Krw_grey*3.0/(tauB-0.5));
|
||||||
//mobility_ratio =(nA*Krn_grey*3.0/(tauA-0.5) - nB*Krw_grey*3.0/(tauB-0.5))/(nA*Krn_grey*3.0/(tauA-0.5) + nB*Krw_grey*3.0/(tauB-0.5));
|
//mobility_ratio =(nA*Krn_grey*3.0/(tauA-0.5) - nB*Krw_grey*3.0/(tauB-0.5))/(nA*Krn_grey*3.0/(tauA-0.5) + nB*Krw_grey*3.0/(tauB-0.5));
|
||||||
}
|
}
|
||||||
else if (nA/(nA+nB)>Sw_grey && porosity !=1.0){
|
else if (nA/(nA+nB)>Sw_grey && porosity !=1.0){
|
||||||
perm = Kn_grey;
|
perm = Kn_grey;
|
||||||
|
Krn_grey = Kn_grey;
|
||||||
Swn = 1.0;
|
Swn = 1.0;
|
||||||
}
|
}
|
||||||
mobility_ratio =(nA*Krn_grey*3.0/(tauA-0.5) - nB*Krw_grey*3.0/(tauB-0.5))/(nA*Krn_grey*3.0/(tauA-0.5) + nB*Krw_grey*3.0/(tauB-0.5));
|
/* compute the mobility ratio */
|
||||||
|
if (porosity != 1.0){
|
||||||
|
mobility_ratio =(Krn_grey/(tauA-0.5) - Krw_grey/(tauB-0.5))/(Krn_grey/(tauA-0.5) + Krw_grey/(tauB-0.5));
|
||||||
|
}
|
||||||
|
else if (phi > 0.0){
|
||||||
|
mobility_ratio = 1.0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
mobility_ratio = -1.0;
|
||||||
|
}
|
||||||
|
MobilityRatio[n] = mobility_ratio;
|
||||||
|
|
||||||
// Get the 1D index based on regular data layout
|
// Get the 1D index based on regular data layout
|
||||||
ijk = Map[n];
|
ijk = Map[n];
|
||||||
// COMPUTE THE COLOR GRADIENT
|
// COMPUTE THE COLOR GRADIENT
|
||||||
@ -2964,32 +2990,4 @@ extern "C" void ScaLBL_PhaseField_InitFromRestart(double *Den, double *Aq, doubl
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//extern "C" void ScaLBL_D3Q19_GreyscaleColor_Init(double *dist, double *Porosity, int Np){
|
|
||||||
// int n;
|
|
||||||
// double porosity;
|
|
||||||
// for (n=0; n<Np; n++){
|
|
||||||
// porosity = Porosity[n];
|
|
||||||
// if (porosity==0.0) porosity=1.f;
|
|
||||||
// dist[n] = 0.3333333333333333/porosity;
|
|
||||||
// dist[Np+n] = 0.055555555555555555/porosity; //double(100*n)+1.f;
|
|
||||||
// dist[2*Np+n] = 0.055555555555555555/porosity; //double(100*n)+2.f;
|
|
||||||
// dist[3*Np+n] = 0.055555555555555555/porosity; //double(100*n)+3.f;
|
|
||||||
// dist[4*Np+n] = 0.055555555555555555/porosity; //double(100*n)+4.f;
|
|
||||||
// dist[5*Np+n] = 0.055555555555555555/porosity; //double(100*n)+5.f;
|
|
||||||
// dist[6*Np+n] = 0.055555555555555555/porosity; //double(100*n)+6.f;
|
|
||||||
// dist[7*Np+n] = 0.0277777777777778/porosity; //double(100*n)+7.f;
|
|
||||||
// dist[8*Np+n] = 0.0277777777777778/porosity; //double(100*n)+8.f;
|
|
||||||
// dist[9*Np+n] = 0.0277777777777778/porosity; //double(100*n)+9.f;
|
|
||||||
// dist[10*Np+n] = 0.0277777777777778/porosity; //double(100*n)+10.f;
|
|
||||||
// dist[11*Np+n] = 0.0277777777777778/porosity; //double(100*n)+11.f;
|
|
||||||
// dist[12*Np+n] = 0.0277777777777778/porosity; //double(100*n)+12.f;
|
|
||||||
// dist[13*Np+n] = 0.0277777777777778/porosity; //double(100*n)+13.f;
|
|
||||||
// dist[14*Np+n] = 0.0277777777777778/porosity; //double(100*n)+14.f;
|
|
||||||
// dist[15*Np+n] = 0.0277777777777778/porosity; //double(100*n)+15.f;
|
|
||||||
// dist[16*Np+n] = 0.0277777777777778/porosity; //double(100*n)+16.f;
|
|
||||||
// dist[17*Np+n] = 0.0277777777777778/porosity; //double(100*n)+17.f;
|
|
||||||
// dist[18*Np+n] = 0.0277777777777778/porosity; //double(100*n)+18.f;
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -523,71 +523,6 @@ void ScaLBL_GreyscaleColorModel::AssignGreyPoroPermLabels()
|
|||||||
delete [] Permeability;
|
delete [] Permeability;
|
||||||
}
|
}
|
||||||
|
|
||||||
//void ScaLBL_GreyscaleColorModel::AssignGreyscalePotential()
|
|
||||||
//{
|
|
||||||
// double *psi;//greyscale potential
|
|
||||||
// psi = new double[N];
|
|
||||||
//
|
|
||||||
// size_t NLABELS=0;
|
|
||||||
// signed char VALUE=0;
|
|
||||||
// double AFFINITY=0.f;
|
|
||||||
//
|
|
||||||
// auto LabelList = greyscaleColor_db->getVector<int>( "ComponentLabels" );
|
|
||||||
// auto AffinityList = greyscaleColor_db->getVector<double>( "ComponentAffinity" );
|
|
||||||
// NLABELS=LabelList.size();
|
|
||||||
//
|
|
||||||
// //first, copy over normal phase field
|
|
||||||
// for (int k=0;k<Nz;k++){
|
|
||||||
// for (int j=0;j<Ny;j++){
|
|
||||||
// for (int i=0;i<Nx;i++){
|
|
||||||
// int n = k*Nx*Ny+j*Nx+i;
|
|
||||||
// VALUE=id[n];
|
|
||||||
// // Assign the affinity from the paired list
|
|
||||||
// for (unsigned int idx=0; idx < NLABELS; idx++){
|
|
||||||
// //printf("idx=%i, value=%i, %i, \n",idx, VALUE,LabelList[idx]);
|
|
||||||
// if (VALUE == LabelList[idx]){
|
|
||||||
// AFFINITY=AffinityList[idx];
|
|
||||||
// idx = NLABELS;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// // fluid labels are reserved
|
|
||||||
// if (VALUE == 1) AFFINITY=1.0;
|
|
||||||
// else if (VALUE == 2) AFFINITY=-1.0;
|
|
||||||
// psi[n] = AFFINITY;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// //second, scale the phase field for grey nodes
|
|
||||||
// double Cap_Penalty=1.f;
|
|
||||||
// auto GreyLabelList = greyscaleColor_db->getVector<int>( "GreySolidLabels" );
|
|
||||||
// auto PermeabilityList = greyscaleColor_db->getVector<double>( "PermeabilityList" );
|
|
||||||
// NLABELS=GreyLabelList.size();
|
|
||||||
//
|
|
||||||
// for (int k=0;k<Nz;k++){
|
|
||||||
// for (int j=0;j<Ny;j++){
|
|
||||||
// for (int i=0;i<Nx;i++){
|
|
||||||
// int n = k*Nx*Ny+j*Nx+i;
|
|
||||||
// VALUE=id[n];
|
|
||||||
// Cap_Penalty=1.f;
|
|
||||||
// // Assign the affinity from the paired list
|
|
||||||
// for (unsigned int idx=0; idx < NLABELS; idx++){
|
|
||||||
// if (VALUE == GreyLabelList[idx]){
|
|
||||||
// Cap_Penalty=alpha*W/sqrt(PermeabilityList[idx]/Dm->voxel_length/Dm->voxel_length);
|
|
||||||
// idx = NLABELS;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// //update greyscale potential
|
|
||||||
// psi[n] = psi[n]*Cap_Penalty;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// ScaLBL_CopyToDevice(Psi, psi, N*sizeof(double));
|
|
||||||
// ScaLBL_Comm->Barrier();
|
|
||||||
// delete [] psi;
|
|
||||||
//}
|
|
||||||
|
|
||||||
void ScaLBL_GreyscaleColorModel::Create(){
|
void ScaLBL_GreyscaleColorModel::Create(){
|
||||||
/*
|
/*
|
||||||
* This function creates the variables needed to run a LBM
|
* This function creates the variables needed to run a LBM
|
||||||
@ -635,7 +570,7 @@ void ScaLBL_GreyscaleColorModel::Create(){
|
|||||||
//ScaLBL_AllocateDeviceMemory((void **) &Psi, sizeof(double)*Nx*Ny*Nz);//greyscale potential
|
//ScaLBL_AllocateDeviceMemory((void **) &Psi, sizeof(double)*Nx*Ny*Nz);//greyscale potential
|
||||||
ScaLBL_AllocateDeviceMemory((void **) &Pressure, sizeof(double)*Np);
|
ScaLBL_AllocateDeviceMemory((void **) &Pressure, sizeof(double)*Np);
|
||||||
ScaLBL_AllocateDeviceMemory((void **) &Velocity, 3*sizeof(double)*Np);
|
ScaLBL_AllocateDeviceMemory((void **) &Velocity, 3*sizeof(double)*Np);
|
||||||
//ScaLBL_AllocateDeviceMemory((void **) &ColorGrad, 3*sizeof(double)*Np);
|
ScaLBL_AllocateDeviceMemory((void **) &MobilityRatio, sizeof(double)*Np);
|
||||||
//ScaLBL_AllocateDeviceMemory((void **) &GreySolidPhi, sizeof(double)*Nx*Ny*Nz);
|
//ScaLBL_AllocateDeviceMemory((void **) &GreySolidPhi, sizeof(double)*Nx*Ny*Nz);
|
||||||
//ScaLBL_AllocateDeviceMemory((void **) &GreySolidGrad, 3*sizeof(double)*Np);
|
//ScaLBL_AllocateDeviceMemory((void **) &GreySolidGrad, 3*sizeof(double)*Np);
|
||||||
ScaLBL_AllocateDeviceMemory((void **) &GreySolidW, sizeof(double)*Np);
|
ScaLBL_AllocateDeviceMemory((void **) &GreySolidW, sizeof(double)*Np);
|
||||||
@ -686,8 +621,7 @@ void ScaLBL_GreyscaleColorModel::Create(){
|
|||||||
AssignComponentLabels();//do open/black/grey nodes initialization
|
AssignComponentLabels();//do open/black/grey nodes initialization
|
||||||
AssignGreySolidLabels();
|
AssignGreySolidLabels();
|
||||||
AssignGreyPoroPermLabels();
|
AssignGreyPoroPermLabels();
|
||||||
//AssignGreyscalePotential();
|
Averages->SetParams(rhoA,rhoB,tauA,tauB,Fx,Fy,Fz,alpha,beta,GreyPorosity);
|
||||||
Averages->SetParams(rhoA,rhoB,tauA,tauB,Fx,Fy,Fz,alpha,beta,GreyPorosity);
|
|
||||||
ScaLBL_Comm->RegularLayout(Map,Porosity_dvc,Averages->Porosity);//porosity doesn't change over time
|
ScaLBL_Comm->RegularLayout(Map,Porosity_dvc,Averages->Porosity);//porosity doesn't change over time
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -787,9 +721,6 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
int nprocs=nprocx*nprocy*nprocz;
|
int nprocs=nprocx*nprocy*nprocz;
|
||||||
const RankInfoStruct rank_info(rank,nprocx,nprocy,nprocz);
|
const RankInfoStruct rank_info(rank,nprocx,nprocy,nprocz);
|
||||||
|
|
||||||
int IMAGE_INDEX = 0;
|
|
||||||
int IMAGE_COUNT = 0;
|
|
||||||
std::vector<std::string> ImageList;
|
|
||||||
bool SET_CAPILLARY_NUMBER = false;
|
bool SET_CAPILLARY_NUMBER = false;
|
||||||
bool RESCALE_FORCE = false;
|
bool RESCALE_FORCE = false;
|
||||||
bool MORPH_ADAPT = false;
|
bool MORPH_ADAPT = false;
|
||||||
@ -845,16 +776,7 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
|
|
||||||
/* defaults for simulation protocols */
|
/* defaults for simulation protocols */
|
||||||
auto protocol = greyscaleColor_db->getWithDefault<std::string>( "protocol", "none" );
|
auto protocol = greyscaleColor_db->getWithDefault<std::string>( "protocol", "none" );
|
||||||
if (protocol == "image sequence"){
|
if (protocol == "seed water"){
|
||||||
// Get the list of images
|
|
||||||
USE_DIRECT = true;
|
|
||||||
ImageList = greyscaleColor_db->getVector<std::string>( "image_sequence");
|
|
||||||
IMAGE_INDEX = greyscaleColor_db->getWithDefault<int>( "image_index", 0 );
|
|
||||||
IMAGE_COUNT = ImageList.size();
|
|
||||||
morph_interval = 10000;
|
|
||||||
USE_MORPH = true;
|
|
||||||
}
|
|
||||||
else if (protocol == "seed water"){
|
|
||||||
morph_delta = -0.05;
|
morph_delta = -0.05;
|
||||||
seed_water = 0.01;
|
seed_water = 0.01;
|
||||||
USE_SEED = true;
|
USE_SEED = true;
|
||||||
@ -908,15 +830,7 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
|
|
||||||
if (rank==0){
|
if (rank==0){
|
||||||
printf("********************************************************\n");
|
printf("********************************************************\n");
|
||||||
if (protocol == "image sequence"){
|
if (protocol == "seed water"){
|
||||||
printf(" using protocol = image sequence \n");
|
|
||||||
printf(" min_steady_timesteps = %i \n",MIN_STEADY_TIMESTEPS);
|
|
||||||
printf(" max_steady_timesteps = %i \n",MAX_STEADY_TIMESTEPS);
|
|
||||||
printf(" tolerance = %f \n",tolerance);
|
|
||||||
std::string first_image = ImageList[IMAGE_INDEX];
|
|
||||||
printf(" first image in sequence: %s ***\n", first_image.c_str());
|
|
||||||
}
|
|
||||||
else if (protocol == "seed water"){
|
|
||||||
printf(" using protocol = seed water \n");
|
printf(" using protocol = seed water \n");
|
||||||
printf(" min_steady_timesteps = %i \n",MIN_STEADY_TIMESTEPS);
|
printf(" min_steady_timesteps = %i \n",MIN_STEADY_TIMESTEPS);
|
||||||
printf(" max_steady_timesteps = %i \n",MAX_STEADY_TIMESTEPS);
|
printf(" max_steady_timesteps = %i \n",MAX_STEADY_TIMESTEPS);
|
||||||
@ -963,18 +877,9 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
}
|
}
|
||||||
// Halo exchange for phase field
|
// Halo exchange for phase field
|
||||||
ScaLBL_Comm_Regular->SendHalo(Phi);
|
ScaLBL_Comm_Regular->SendHalo(Phi);
|
||||||
//Model-1&4 with capillary pressure penalty for grey nodes
|
ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(NeighborList, dvcMap, fq, Aq, Bq, Den, Phi, GreySolidW,GreySn,GreySw,GreyKn,GreyKw,Porosity_dvc,Permeability_dvc,Velocity,MobilityRatio,Pressure,
|
||||||
ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(NeighborList, dvcMap, fq, Aq, Bq, Den, Phi, GreySolidW,GreySn,GreySw,GreyKn,GreyKw,Porosity_dvc,Permeability_dvc,Velocity,Pressure,
|
|
||||||
rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
||||||
alpha, beta, Fx, Fy, Fz, RecoloringOff, Nx, Nx*Ny, ScaLBL_Comm->FirstInterior(), ScaLBL_Comm->LastInterior(), Np);
|
alpha, beta, Fx, Fy, Fz, RecoloringOff, Nx, Nx*Ny, ScaLBL_Comm->FirstInterior(), ScaLBL_Comm->LastInterior(), Np);
|
||||||
//Model-1&4
|
|
||||||
//ScaLBL_D3Q19_AAodd_GreyscaleColor(NeighborList, dvcMap, fq, Aq, Bq, Den, Phi,GreySolidGrad,Porosity_dvc,Permeability_dvc,Velocity,Pressure,
|
|
||||||
// rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
|
||||||
// alpha, beta, Fx, Fy, Fz, Nx, Nx*Ny, ScaLBL_Comm->FirstInterior(), ScaLBL_Comm->LastInterior(), Np);
|
|
||||||
////Model-2&3
|
|
||||||
//ScaLBL_D3Q19_AAodd_GreyscaleColor(NeighborList, dvcMap, fq, Aq, Bq, Den, Phi,GreySolidPhi,Porosity_dvc,Permeability_dvc,Velocity,
|
|
||||||
// rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
|
||||||
// alpha, beta, Fx, Fy, Fz, Nx, Nx*Ny, ScaLBL_Comm->FirstInterior(), ScaLBL_Comm->LastInterior(), Np);
|
|
||||||
ScaLBL_Comm_Regular->RecvHalo(Phi);
|
ScaLBL_Comm_Regular->RecvHalo(Phi);
|
||||||
ScaLBL_Comm->RecvD3Q19AA(fq); //WRITE INTO OPPOSITE
|
ScaLBL_Comm->RecvD3Q19AA(fq); //WRITE INTO OPPOSITE
|
||||||
ScaLBL_Comm->Barrier();
|
ScaLBL_Comm->Barrier();
|
||||||
@ -992,18 +897,9 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
ScaLBL_Comm->D3Q19_Reflection_BC_Z(fq);
|
ScaLBL_Comm->D3Q19_Reflection_BC_Z(fq);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Model-1&4 with capillary pressure penalty for grey nodes
|
ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(NeighborList, dvcMap, fq, Aq, Bq, Den, Phi, GreySolidW,GreySn,GreySw,GreyKn,GreyKw,Porosity_dvc,Permeability_dvc,Velocity,MobilityRatio,Pressure,
|
||||||
ScaLBL_D3Q19_AAodd_GreyscaleColor_CP(NeighborList, dvcMap, fq, Aq, Bq, Den, Phi, GreySolidW,GreySn,GreySw,GreyKn,GreyKw,Porosity_dvc,Permeability_dvc,Velocity,Pressure,
|
|
||||||
rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
||||||
alpha, beta, Fx, Fy, Fz, RecoloringOff, Nx, Nx*Ny, 0, ScaLBL_Comm->LastExterior(), Np);
|
alpha, beta, Fx, Fy, Fz, RecoloringOff, Nx, Nx*Ny, 0, ScaLBL_Comm->LastExterior(), Np);
|
||||||
//Model-1&4
|
|
||||||
//ScaLBL_D3Q19_AAodd_GreyscaleColor(NeighborList, dvcMap, fq, Aq, Bq, Den, Phi,GreySolidGrad,Porosity_dvc,Permeability_dvc,Velocity,Pressure,
|
|
||||||
// rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
|
||||||
// alpha, beta, Fx, Fy, Fz, Nx, Nx*Ny, 0, ScaLBL_Comm->LastExterior(), Np);
|
|
||||||
////Model-2&3
|
|
||||||
//ScaLBL_D3Q19_AAodd_GreyscaleColor(NeighborList, dvcMap, fq, Aq, Bq, Den, Phi,GreySolidPhi,Porosity_dvc,Permeability_dvc,Velocity,
|
|
||||||
// rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
|
||||||
// alpha, beta, Fx, Fy, Fz, Nx, Nx*Ny, 0, ScaLBL_Comm->LastExterior(), Np);
|
|
||||||
ScaLBL_Comm->Barrier();
|
ScaLBL_Comm->Barrier();
|
||||||
|
|
||||||
// *************EVEN TIMESTEP*************
|
// *************EVEN TIMESTEP*************
|
||||||
@ -1025,18 +921,9 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
ScaLBL_Comm->Color_BC_Z(dvcMap, Phi, Den, outletA, outletB);
|
ScaLBL_Comm->Color_BC_Z(dvcMap, Phi, Den, outletA, outletB);
|
||||||
}
|
}
|
||||||
ScaLBL_Comm_Regular->SendHalo(Phi);
|
ScaLBL_Comm_Regular->SendHalo(Phi);
|
||||||
//Model-1&4 with capillary pressure penalty for grey nodes
|
ScaLBL_D3Q19_AAeven_GreyscaleColor_CP(dvcMap, fq, Aq, Bq, Den, Phi, GreySolidW,GreySn,GreySw,GreyKn,GreyKw,Porosity_dvc,Permeability_dvc,Velocity,MobilityRatio,Pressure,
|
||||||
ScaLBL_D3Q19_AAeven_GreyscaleColor_CP(dvcMap, fq, Aq, Bq, Den, Phi, GreySolidW,GreySn,GreySw,GreyKn,GreyKw,Porosity_dvc,Permeability_dvc,Velocity,Pressure,
|
|
||||||
rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
||||||
alpha, beta, Fx, Fy, Fz, RecoloringOff, Nx, Nx*Ny, ScaLBL_Comm->FirstInterior(), ScaLBL_Comm->LastInterior(), Np);
|
alpha, beta, Fx, Fy, Fz, RecoloringOff, Nx, Nx*Ny, ScaLBL_Comm->FirstInterior(), ScaLBL_Comm->LastInterior(), Np);
|
||||||
//Model-1&4
|
|
||||||
//ScaLBL_D3Q19_AAeven_GreyscaleColor(dvcMap, fq, Aq, Bq, Den, Phi,GreySolidGrad,Porosity_dvc,Permeability_dvc,Velocity,Pressure,
|
|
||||||
// rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
|
||||||
// alpha, beta, Fx, Fy, Fz, Nx, Nx*Ny, ScaLBL_Comm->FirstInterior(), ScaLBL_Comm->LastInterior(), Np);
|
|
||||||
////Model-2&3
|
|
||||||
//ScaLBL_D3Q19_AAeven_GreyscaleColor(dvcMap, fq, Aq, Bq, Den, Phi,GreySolidPhi,Porosity_dvc,Permeability_dvc,Velocity,
|
|
||||||
// rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
|
||||||
// alpha, beta, Fx, Fy, Fz, Nx, Nx*Ny, ScaLBL_Comm->FirstInterior(), ScaLBL_Comm->LastInterior(), Np);
|
|
||||||
ScaLBL_Comm_Regular->RecvHalo(Phi);
|
ScaLBL_Comm_Regular->RecvHalo(Phi);
|
||||||
ScaLBL_Comm->RecvD3Q19AA(fq); //WRITE INTO OPPOSITE
|
ScaLBL_Comm->RecvD3Q19AA(fq); //WRITE INTO OPPOSITE
|
||||||
ScaLBL_Comm->Barrier();
|
ScaLBL_Comm->Barrier();
|
||||||
@ -1054,18 +941,9 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
ScaLBL_Comm->D3Q19_Reflection_BC_Z(fq);
|
ScaLBL_Comm->D3Q19_Reflection_BC_Z(fq);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Model-1&4 with capillary pressure penalty for grey nodes
|
ScaLBL_D3Q19_AAeven_GreyscaleColor_CP(dvcMap, fq, Aq, Bq, Den, Phi, GreySolidW,GreySn,GreySw,GreyKn,GreyKw,Porosity_dvc,Permeability_dvc,Velocity,MobilityRatio,Pressure,
|
||||||
ScaLBL_D3Q19_AAeven_GreyscaleColor_CP(dvcMap, fq, Aq, Bq, Den, Phi, GreySolidW,GreySn,GreySw,GreyKn,GreyKw,Porosity_dvc,Permeability_dvc,Velocity,Pressure,
|
|
||||||
rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
||||||
alpha, beta, Fx, Fy, Fz, RecoloringOff, Nx, Nx*Ny, 0, ScaLBL_Comm->LastExterior(), Np);
|
alpha, beta, Fx, Fy, Fz, RecoloringOff, Nx, Nx*Ny, 0, ScaLBL_Comm->LastExterior(), Np);
|
||||||
//Model-1&4
|
|
||||||
//ScaLBL_D3Q19_AAeven_GreyscaleColor(dvcMap, fq, Aq, Bq, Den, Phi,GreySolidGrad,Porosity_dvc,Permeability_dvc,Velocity,Pressure,
|
|
||||||
// rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
|
||||||
// alpha, beta, Fx, Fy, Fz, Nx, Nx*Ny, 0, ScaLBL_Comm->LastExterior(), Np);
|
|
||||||
////Model-2&3
|
|
||||||
//ScaLBL_D3Q19_AAeven_GreyscaleColor(dvcMap, fq, Aq, Bq, Den, Phi,GreySolidPhi,Porosity_dvc,Permeability_dvc,Velocity,
|
|
||||||
// rhoA, rhoB, tauA, tauB,tauA_eff, tauB_eff,
|
|
||||||
// alpha, beta, Fx, Fy, Fz, Nx, Nx*Ny, 0, ScaLBL_Comm->LastExterior(), Np);
|
|
||||||
ScaLBL_Comm->Barrier();
|
ScaLBL_Comm->Barrier();
|
||||||
//************************************************************************
|
//************************************************************************
|
||||||
PROFILE_STOP("Update");
|
PROFILE_STOP("Update");
|
||||||
@ -1121,11 +999,13 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
|
|
||||||
if (timestep%analysis_interval == 0){
|
if (timestep%analysis_interval == 0){
|
||||||
ScaLBL_Comm->RegularLayout(Map,Pressure,Averages->Pressure);
|
ScaLBL_Comm->RegularLayout(Map,Pressure,Averages->Pressure);
|
||||||
|
ScaLBL_Comm->RegularLayout(Map,MobilityRatio,Averages->MobilityRatio);
|
||||||
ScaLBL_Comm->RegularLayout(Map,&Den[0],Averages->Rho_n);
|
ScaLBL_Comm->RegularLayout(Map,&Den[0],Averages->Rho_n);
|
||||||
ScaLBL_Comm->RegularLayout(Map,&Den[Np],Averages->Rho_w);
|
ScaLBL_Comm->RegularLayout(Map,&Den[Np],Averages->Rho_w);
|
||||||
ScaLBL_Comm->RegularLayout(Map,&Velocity[0],Averages->Vel_x);
|
ScaLBL_Comm->RegularLayout(Map,&Velocity[0],Averages->Vel_x);
|
||||||
ScaLBL_Comm->RegularLayout(Map,&Velocity[Np],Averages->Vel_y);
|
ScaLBL_Comm->RegularLayout(Map,&Velocity[Np],Averages->Vel_y);
|
||||||
ScaLBL_Comm->RegularLayout(Map,&Velocity[2*Np],Averages->Vel_z);
|
ScaLBL_Comm->RegularLayout(Map,&Velocity[2*Np],Averages->Vel_z);
|
||||||
|
|
||||||
Averages->Basic();
|
Averages->Basic();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1212,43 +1092,6 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
double pA = Averages->Oil.p;
|
double pA = Averages->Oil.p;
|
||||||
double pB = Averages->Water.p;
|
double pB = Averages->Water.p;
|
||||||
double pAB = (pA-pB)/(h*6.0*alpha);
|
double pAB = (pA-pB)/(h*6.0*alpha);
|
||||||
|
|
||||||
// -------- The following quantities may not make sense for greyscale simulation -----------//
|
|
||||||
// double pAc = Averages->gnc.p;
|
|
||||||
// double pBc = Averages->gwc.p;
|
|
||||||
// double pAB_connected = (pAc-pBc)/(h*6.0*alpha);
|
|
||||||
// // connected contribution
|
|
||||||
// double Vol_nc = Averages->gnc.V/Dm->Volume;
|
|
||||||
// double Vol_wc = Averages->gwc.V/Dm->Volume;
|
|
||||||
// double Vol_nd = Averages->gnd.V/Dm->Volume;
|
|
||||||
// double Vol_wd = Averages->gwd.V/Dm->Volume;
|
|
||||||
// double Mass_n = Averages->gnc.M + Averages->gnd.M;
|
|
||||||
// double Mass_w = Averages->gwc.M + Averages->gwd.M;
|
|
||||||
// double vAc_x = Averages->gnc.Px/Mass_n;
|
|
||||||
// double vAc_y = Averages->gnc.Py/Mass_n;
|
|
||||||
// double vAc_z = Averages->gnc.Pz/Mass_n;
|
|
||||||
// double vBc_x = Averages->gwc.Px/Mass_w;
|
|
||||||
// double vBc_y = Averages->gwc.Py/Mass_w;
|
|
||||||
// double vBc_z = Averages->gwc.Pz/Mass_w;
|
|
||||||
// // disconnected contribution
|
|
||||||
// double vAd_x = Averages->gnd.Px/Mass_n;
|
|
||||||
// double vAd_y = Averages->gnd.Py/Mass_n;
|
|
||||||
// double vAd_z = Averages->gnd.Pz/Mass_n;
|
|
||||||
// double vBd_x = Averages->gwd.Px/Mass_w;
|
|
||||||
// double vBd_y = Averages->gwd.Py/Mass_w;
|
|
||||||
// double vBd_z = Averages->gwd.Pz/Mass_w;
|
|
||||||
//
|
|
||||||
// double flow_rate_A_connected = Vol_nc*(vAc_x*dir_x + vAc_y*dir_y + vAc_z*dir_z);
|
|
||||||
// double flow_rate_B_connected = Vol_wc*(vBc_x*dir_x + vBc_y*dir_y + vBc_z*dir_z);
|
|
||||||
// double flow_rate_A_disconnected = (Vol_nd)*(vAd_x*dir_x + vAd_y*dir_y + vAd_z*dir_z);
|
|
||||||
// double flow_rate_B_disconnected = (Vol_wd)*(vBd_x*dir_x + vBd_y*dir_y + vBd_z*dir_z);
|
|
||||||
//
|
|
||||||
// double kAeff_connected = h*h*muA*flow_rate_A_connected/(force_mag);
|
|
||||||
// double kBeff_connected = h*h*muB*flow_rate_B_connected/(force_mag);
|
|
||||||
//
|
|
||||||
// double kAeff_disconnected = h*h*muA*flow_rate_A_disconnected/(force_mag);
|
|
||||||
// double kBeff_disconnected = h*h*muB*flow_rate_B_disconnected/(force_mag);
|
|
||||||
// //---------------------------------------------------------------------------------------//
|
|
||||||
|
|
||||||
double kAeff = h*h*muA*(flow_rate_A)/(force_mag);
|
double kAeff = h*h*muA*(flow_rate_A)/(force_mag);
|
||||||
double kBeff = h*h*muB*(flow_rate_B)/(force_mag);
|
double kBeff = h*h*muB*(flow_rate_B)/(force_mag);
|
||||||
@ -1300,22 +1143,7 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
|
|
||||||
if (MORPH_ADAPT ){
|
if (MORPH_ADAPT ){
|
||||||
CURRENT_MORPH_TIMESTEPS += analysis_interval;
|
CURRENT_MORPH_TIMESTEPS += analysis_interval;
|
||||||
if (USE_DIRECT){
|
if (USE_SEED){
|
||||||
// Use image sequence
|
|
||||||
IMAGE_INDEX++;
|
|
||||||
MORPH_ADAPT = false;
|
|
||||||
if (IMAGE_INDEX < IMAGE_COUNT){
|
|
||||||
std::string next_image = ImageList[IMAGE_INDEX];
|
|
||||||
if (rank==0) printf("***Loading next image in sequence (%i) ***\n",IMAGE_INDEX);
|
|
||||||
greyscaleColor_db->putScalar<int>("image_index",IMAGE_INDEX);
|
|
||||||
ImageInit(next_image);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
if (rank==0) printf("Finished simulating image sequence \n");
|
|
||||||
timestep = timestepMax;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (USE_SEED){
|
|
||||||
delta_volume = volA*Dm->Volume - initial_volume;
|
delta_volume = volA*Dm->Volume - initial_volume;
|
||||||
CURRENT_MORPH_TIMESTEPS += analysis_interval;
|
CURRENT_MORPH_TIMESTEPS += analysis_interval;
|
||||||
double massChange = SeedPhaseField(seed_water);
|
double massChange = SeedPhaseField(seed_water);
|
||||||
@ -1366,50 +1194,6 @@ void ScaLBL_GreyscaleColorModel::Run(){
|
|||||||
// ************************************************************************
|
// ************************************************************************
|
||||||
}
|
}
|
||||||
|
|
||||||
void ScaLBL_GreyscaleColorModel::ImageInit(std::string Filename){
|
|
||||||
if (rank==0) printf("Re-initializing fluids from file: %s \n", Filename.c_str());
|
|
||||||
Mask->Decomp(Filename);
|
|
||||||
for (int i=0; i<Nx*Ny*Nz; i++) id[i] = Mask->id[i]; // save what was read
|
|
||||||
for (int i=0; i<Nx*Ny*Nz; i++) Dm->id[i] = Mask->id[i]; // save what was read
|
|
||||||
|
|
||||||
AssignComponentLabels();
|
|
||||||
AssignGreySolidLabels();
|
|
||||||
AssignGreyPoroPermLabels();
|
|
||||||
Averages->SetParams(rhoA,rhoB,tauA,tauB,Fx,Fy,Fz,alpha,beta,GreyPorosity);
|
|
||||||
ScaLBL_Comm->RegularLayout(Map,Porosity_dvc,Averages->Porosity);
|
|
||||||
|
|
||||||
//NOTE in greyscale simulations, water may have multiple labels (e.g. 2, 21, 22, etc)
|
|
||||||
//so the saturaiton calculation is not that straightforward
|
|
||||||
// double Count = 0.0;
|
|
||||||
// double PoreCount = 0.0;
|
|
||||||
// for (int k=1; k<Nz-1; k++){
|
|
||||||
// for (int j=1; j<Ny-1; j++){
|
|
||||||
// for (int i=1; i<Nx-1; i++){
|
|
||||||
// if (id[Nx*Ny*k+Nx*j+i] == 2){
|
|
||||||
// PoreCount++;
|
|
||||||
// Count++;
|
|
||||||
// }
|
|
||||||
// else if (id[Nx*Ny*k+Nx*j+i] == 1){
|
|
||||||
// PoreCount++;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// Count=Dm->Comm.sumReduce( Count);
|
|
||||||
// PoreCount=Dm->Comm.sumReduce( PoreCount);
|
|
||||||
// if (rank==0) printf(" new saturation: %f (%f / %f) \n", Count / PoreCount, Count, PoreCount);
|
|
||||||
|
|
||||||
ScaLBL_D3Q19_Init(fq, Np);
|
|
||||||
ScaLBL_PhaseField_Init(dvcMap, Phi, Den, Aq, Bq, 0, ScaLBL_Comm->LastExterior(), Np);
|
|
||||||
ScaLBL_PhaseField_Init(dvcMap, Phi, Den, Aq, Bq, ScaLBL_Comm->FirstInterior(), ScaLBL_Comm->LastInterior(), Np);
|
|
||||||
ScaLBL_Comm->Barrier();
|
|
||||||
|
|
||||||
//ScaLBL_CopyToHost(Averages->Phi.data(),Phi,Nx*Ny*Nz*sizeof(double));
|
|
||||||
|
|
||||||
//double saturation = Count/PoreCount;
|
|
||||||
//return saturation;
|
|
||||||
|
|
||||||
}
|
|
||||||
double ScaLBL_GreyscaleColorModel::SeedPhaseField(const double seed_water_in_oil){
|
double ScaLBL_GreyscaleColorModel::SeedPhaseField(const double seed_water_in_oil){
|
||||||
srand(time(NULL));
|
srand(time(NULL));
|
||||||
double mass_loss =0.f;
|
double mass_loss =0.f;
|
||||||
@ -1713,546 +1497,3 @@ void ScaLBL_GreyscaleColorModel::WriteDebug(){
|
|||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
//void ScaLBL_GreyscaleColorModel::AssignGreySolidLabels()//Model-1
|
|
||||||
//{
|
|
||||||
// // ONLY initialize grey nodes
|
|
||||||
// // Key input parameters:
|
|
||||||
// // 1. GreySolidLabels
|
|
||||||
// // labels for grey nodes
|
|
||||||
// // 2. GreySolidAffinity
|
|
||||||
// // affinity ranges [-1,1]
|
|
||||||
// // oil-wet > 0
|
|
||||||
// // water-wet < 0
|
|
||||||
// // neutral = 0
|
|
||||||
// double *SolidPotential_host = new double [Nx*Ny*Nz];
|
|
||||||
// double *GreySolidGrad_host = new double [3*Np];
|
|
||||||
//
|
|
||||||
// size_t NLABELS=0;
|
|
||||||
// signed char VALUE=0;
|
|
||||||
// double AFFINITY=0.f;
|
|
||||||
//
|
|
||||||
// auto LabelList = greyscaleColor_db->getVector<int>( "GreySolidLabels" );
|
|
||||||
// auto AffinityList = greyscaleColor_db->getVector<double>( "GreySolidAffinity" );
|
|
||||||
//
|
|
||||||
// NLABELS=LabelList.size();
|
|
||||||
// if (NLABELS != AffinityList.size()){
|
|
||||||
// ERROR("Error: GreySolidLabels and GreySolidAffinity must be the same length! \n");
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// for (int k=0;k<Nz;k++){
|
|
||||||
// for (int j=0;j<Ny;j++){
|
|
||||||
// for (int i=0;i<Nx;i++){
|
|
||||||
// int n = k*Nx*Ny+j*Nx+i;
|
|
||||||
// VALUE=id[n];
|
|
||||||
// AFFINITY=0.f;//all nodes except the specified grey nodes have grey-solid affinity = 0.0
|
|
||||||
// // Assign the affinity from the paired list
|
|
||||||
// for (unsigned int idx=0; idx < NLABELS; idx++){
|
|
||||||
// //printf("idx=%i, value=%i, %i, \n",idx, VALUE,LabelList[idx]);
|
|
||||||
// if (VALUE == LabelList[idx]){
|
|
||||||
// AFFINITY=AffinityList[idx];
|
|
||||||
// idx = NLABELS;
|
|
||||||
// //Mask->id[n] = 0; // set mask to zero since this is an immobile component
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// SolidPotential_host[n] = AFFINITY;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// // Calculate grey-solid color-gradient
|
|
||||||
// double *Dst;
|
|
||||||
// Dst = new double [3*3*3];
|
|
||||||
// for (int kk=0; kk<3; kk++){
|
|
||||||
// for (int jj=0; jj<3; jj++){
|
|
||||||
// for (int ii=0; ii<3; ii++){
|
|
||||||
// int index = kk*9+jj*3+ii;
|
|
||||||
// Dst[index] = sqrt(double(ii-1)*double(ii-1) + double(jj-1)*double(jj-1)+ double(kk-1)*double(kk-1));
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// double w_face = 1.f;
|
|
||||||
// double w_edge = 0.5;
|
|
||||||
// double w_corner = 0.f;
|
|
||||||
// //local
|
|
||||||
// Dst[13] = 0.f;
|
|
||||||
// //faces
|
|
||||||
// Dst[4] = w_face;
|
|
||||||
// Dst[10] = w_face;
|
|
||||||
// Dst[12] = w_face;
|
|
||||||
// Dst[14] = w_face;
|
|
||||||
// Dst[16] = w_face;
|
|
||||||
// Dst[22] = w_face;
|
|
||||||
// // corners
|
|
||||||
// Dst[0] = w_corner;
|
|
||||||
// Dst[2] = w_corner;
|
|
||||||
// Dst[6] = w_corner;
|
|
||||||
// Dst[8] = w_corner;
|
|
||||||
// Dst[18] = w_corner;
|
|
||||||
// Dst[20] = w_corner;
|
|
||||||
// Dst[24] = w_corner;
|
|
||||||
// Dst[26] = w_corner;
|
|
||||||
// // edges
|
|
||||||
// Dst[1] = w_edge;
|
|
||||||
// Dst[3] = w_edge;
|
|
||||||
// Dst[5] = w_edge;
|
|
||||||
// Dst[7] = w_edge;
|
|
||||||
// Dst[9] = w_edge;
|
|
||||||
// Dst[11] = w_edge;
|
|
||||||
// Dst[15] = w_edge;
|
|
||||||
// Dst[17] = w_edge;
|
|
||||||
// Dst[19] = w_edge;
|
|
||||||
// Dst[21] = w_edge;
|
|
||||||
// Dst[23] = w_edge;
|
|
||||||
// Dst[25] = w_edge;
|
|
||||||
//
|
|
||||||
// for (int k=1; k<Nz-1; k++){
|
|
||||||
// for (int j=1; j<Ny-1; j++){
|
|
||||||
// for (int i=1; i<Nx-1; i++){
|
|
||||||
// int idx=Map(i,j,k);
|
|
||||||
// if (!(idx < 0)){
|
|
||||||
// double phi_x = 0.f;
|
|
||||||
// double phi_y = 0.f;
|
|
||||||
// double phi_z = 0.f;
|
|
||||||
// for (int kk=0; kk<3; kk++){
|
|
||||||
// for (int jj=0; jj<3; jj++){
|
|
||||||
// for (int ii=0; ii<3; ii++){
|
|
||||||
//
|
|
||||||
// int index = kk*9+jj*3+ii;
|
|
||||||
// double weight= Dst[index];
|
|
||||||
//
|
|
||||||
// int idi=i+ii-1;
|
|
||||||
// int idj=j+jj-1;
|
|
||||||
// int idk=k+kk-1;
|
|
||||||
//
|
|
||||||
// if (idi < 0) idi=0;
|
|
||||||
// if (idj < 0) idj=0;
|
|
||||||
// if (idk < 0) idk=0;
|
|
||||||
// if (!(idi < Nx)) idi=Nx-1;
|
|
||||||
// if (!(idj < Ny)) idj=Ny-1;
|
|
||||||
// if (!(idk < Nz)) idk=Nz-1;
|
|
||||||
//
|
|
||||||
// int nn = idk*Nx*Ny + idj*Nx + idi;
|
|
||||||
// double vec_x = double(ii-1);
|
|
||||||
// double vec_y = double(jj-1);
|
|
||||||
// double vec_z = double(kk-1);
|
|
||||||
// double GWNS=SolidPotential_host[nn];
|
|
||||||
// phi_x += GWNS*weight*vec_x;
|
|
||||||
// phi_y += GWNS*weight*vec_y;
|
|
||||||
// phi_z += GWNS*weight*vec_z;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// GreySolidGrad_host[idx+0*Np] = phi_x;
|
|
||||||
// GreySolidGrad_host[idx+1*Np] = phi_y;
|
|
||||||
// GreySolidGrad_host[idx+2*Np] = phi_z;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (rank==0){
|
|
||||||
// printf("Number of Grey-solid labels: %lu \n",NLABELS);
|
|
||||||
// for (unsigned int idx=0; idx<NLABELS; idx++){
|
|
||||||
// VALUE=LabelList[idx];
|
|
||||||
// AFFINITY=AffinityList[idx];
|
|
||||||
// printf(" grey-solid label=%d, grey-solid affinity=%f\n",VALUE,AFFINITY);
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// ScaLBL_CopyToDevice(GreySolidGrad, GreySolidGrad_host, 3*Np*sizeof(double));
|
|
||||||
// ScaLBL_Comm->Barrier();
|
|
||||||
// delete [] SolidPotential_host;
|
|
||||||
// delete [] GreySolidGrad_host;
|
|
||||||
// delete [] Dst;
|
|
||||||
//}
|
|
||||||
////----------------------------------------------------------------------------------------------------------//
|
|
||||||
|
|
||||||
|
|
||||||
//void ScaLBL_GreyscaleColorModel::AssignGreySolidLabels()//Model-2 & Model-3
|
|
||||||
//{
|
|
||||||
// // ONLY initialize grey nodes
|
|
||||||
// // Key input parameters:
|
|
||||||
// // 1. GreySolidLabels
|
|
||||||
// // labels for grey nodes
|
|
||||||
// // 2. GreySolidAffinity
|
|
||||||
// // affinity ranges [-1,1]
|
|
||||||
// // oil-wet > 0
|
|
||||||
// // water-wet < 0
|
|
||||||
// // neutral = 0
|
|
||||||
//
|
|
||||||
// double *GreySolidPhi_host = new double [Nx*Ny*Nz];
|
|
||||||
// //initialize grey solid phase field
|
|
||||||
// for (int k=0;k<Nz;k++){
|
|
||||||
// for (int j=0;j<Ny;j++){
|
|
||||||
// for (int i=0;i<Nx;i++){
|
|
||||||
// int n = k*Nx*Ny+j*Nx+i;
|
|
||||||
// GreySolidPhi_host[n]=0.f;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// auto LabelList = greyscaleColor_db->getVector<int>( "GreySolidLabels" );
|
|
||||||
// auto AffinityList = greyscaleColor_db->getVector<double>( "GreySolidAffinity" );
|
|
||||||
//
|
|
||||||
// size_t NLABELS=0;
|
|
||||||
// NLABELS=LabelList.size();
|
|
||||||
// if (NLABELS != AffinityList.size()){
|
|
||||||
// ERROR("Error: GreySolidLabels and GreySolidAffinity must be the same length! \n");
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// double *Dst;
|
|
||||||
// Dst = new double [3*3*3];
|
|
||||||
// for (int kk=0; kk<3; kk++){
|
|
||||||
// for (int jj=0; jj<3; jj++){
|
|
||||||
// for (int ii=0; ii<3; ii++){
|
|
||||||
// int index = kk*9+jj*3+ii;
|
|
||||||
// Dst[index] = sqrt(double(ii-1)*double(ii-1) + double(jj-1)*double(jj-1)+ double(kk-1)*double(kk-1));
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// double w_face = 1.f;
|
|
||||||
// double w_edge = 1.f;
|
|
||||||
// double w_corner = 0.f;
|
|
||||||
// //local
|
|
||||||
// Dst[13] = 0.f;
|
|
||||||
// //faces
|
|
||||||
// Dst[4] = w_face;
|
|
||||||
// Dst[10] = w_face;
|
|
||||||
// Dst[12] = w_face;
|
|
||||||
// Dst[14] = w_face;
|
|
||||||
// Dst[16] = w_face;
|
|
||||||
// Dst[22] = w_face;
|
|
||||||
// // corners
|
|
||||||
// Dst[0] = w_corner;
|
|
||||||
// Dst[2] = w_corner;
|
|
||||||
// Dst[6] = w_corner;
|
|
||||||
// Dst[8] = w_corner;
|
|
||||||
// Dst[18] = w_corner;
|
|
||||||
// Dst[20] = w_corner;
|
|
||||||
// Dst[24] = w_corner;
|
|
||||||
// Dst[26] = w_corner;
|
|
||||||
// // edges
|
|
||||||
// Dst[1] = w_edge;
|
|
||||||
// Dst[3] = w_edge;
|
|
||||||
// Dst[5] = w_edge;
|
|
||||||
// Dst[7] = w_edge;
|
|
||||||
// Dst[9] = w_edge;
|
|
||||||
// Dst[11] = w_edge;
|
|
||||||
// Dst[15] = w_edge;
|
|
||||||
// Dst[17] = w_edge;
|
|
||||||
// Dst[19] = w_edge;
|
|
||||||
// Dst[21] = w_edge;
|
|
||||||
// Dst[23] = w_edge;
|
|
||||||
// Dst[25] = w_edge;
|
|
||||||
//
|
|
||||||
// for (int k=1; k<Nz-1; k++){
|
|
||||||
// for (int j=1; j<Ny-1; j++){
|
|
||||||
// for (int i=1; i<Nx-1; i++){
|
|
||||||
//
|
|
||||||
// int n = k*Nx*Ny+j*Nx+i;
|
|
||||||
// signed char VALUE=Mask->id[n];
|
|
||||||
// double AFFINITY=0.f;
|
|
||||||
// // Assign the affinity from the paired list
|
|
||||||
// for (unsigned int idx=0; idx < NLABELS; idx++){
|
|
||||||
// //printf("idx=%i, value=%i, %i, \n",idx, VALUE,LabelList[idx]);
|
|
||||||
// if (VALUE == LabelList[idx]){
|
|
||||||
// AFFINITY=AffinityList[idx];
|
|
||||||
// idx = NLABELS;
|
|
||||||
// //Mask->id[n] = 0; // set mask to zero since this is an immobile component
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (VALUE>2){//i.e. a grey node
|
|
||||||
// double neighbor_counter = 0;
|
|
||||||
// for (int kk=0; kk<3; kk++){
|
|
||||||
// for (int jj=0; jj<3; jj++){
|
|
||||||
// for (int ii=0; ii<3; ii++){
|
|
||||||
//
|
|
||||||
// int index = kk*9+jj*3+ii;
|
|
||||||
// double weight= Dst[index];
|
|
||||||
//
|
|
||||||
// int idi=i+ii-1;
|
|
||||||
// int idj=j+jj-1;
|
|
||||||
// int idk=k+kk-1;
|
|
||||||
//
|
|
||||||
// if (idi < 0) idi=0;
|
|
||||||
// if (idj < 0) idj=0;
|
|
||||||
// if (idk < 0) idk=0;
|
|
||||||
// if (!(idi < Nx)) idi=Nx-1;
|
|
||||||
// if (!(idj < Ny)) idj=Ny-1;
|
|
||||||
// if (!(idk < Nz)) idk=Nz-1;
|
|
||||||
//
|
|
||||||
// int nn = idk*Nx*Ny + idj*Nx + idi;
|
|
||||||
// //if (Mask->id[nn] != VALUE){//Model-2:i.e. open nodes, impermeable solid nodes or any other type of greynodes
|
|
||||||
// if (Mask->id[nn] <=0){//Model-3:i.e. only impermeable solid nodes or any other type of greynodes
|
|
||||||
// neighbor_counter +=weight;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// if (neighbor_counter>0){
|
|
||||||
// GreySolidPhi_host[n] = AFFINITY;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (rank==0){
|
|
||||||
// printf("Number of grey-solid labels: %lu \n",NLABELS);
|
|
||||||
// for (unsigned int idx=0; idx<NLABELS; idx++){
|
|
||||||
// signed char VALUE=LabelList[idx];
|
|
||||||
// double AFFINITY=AffinityList[idx];
|
|
||||||
// printf(" grey-solid label=%d, grey-solid affinity=%f\n",VALUE,AFFINITY);
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// ScaLBL_CopyToDevice(GreySolidPhi, GreySolidPhi_host, Nx*Ny*Nz*sizeof(double));
|
|
||||||
// ScaLBL_Comm->Barrier();
|
|
||||||
//
|
|
||||||
// //debug
|
|
||||||
// //FILE *OUTFILE;
|
|
||||||
// //sprintf(LocalRankFilename,"GreySolidInit.%05i.raw",rank);
|
|
||||||
// //OUTFILE = fopen(LocalRankFilename,"wb");
|
|
||||||
// //fwrite(GreySolidPhi_host,8,N,OUTFILE);
|
|
||||||
// //fclose(OUTFILE);
|
|
||||||
//
|
|
||||||
// delete [] GreySolidPhi_host;
|
|
||||||
// delete [] Dst;
|
|
||||||
//}
|
|
||||||
|
|
||||||
//void ScaLBL_GreyscaleColorModel::AssignGreySolidLabels()//Model-4
|
|
||||||
//{
|
|
||||||
// // ONLY initialize grey nodes
|
|
||||||
// // Key input parameters:
|
|
||||||
// // 1. GreySolidLabels
|
|
||||||
// // labels for grey nodes
|
|
||||||
// // 2. GreySolidAffinity
|
|
||||||
// // affinity ranges [-1,1]
|
|
||||||
// // oil-wet > 0
|
|
||||||
// // water-wet < 0
|
|
||||||
// // neutral = 0
|
|
||||||
// double *SolidPotential_host = new double [Nx*Ny*Nz];
|
|
||||||
// double *GreySolidGrad_host = new double [3*Np];
|
|
||||||
//
|
|
||||||
// size_t NLABELS=0;
|
|
||||||
// signed char VALUE=0;
|
|
||||||
// double AFFINITY=0.f;
|
|
||||||
//
|
|
||||||
// auto LabelList = greyscaleColor_db->getVector<int>( "GreySolidLabels" );
|
|
||||||
// auto AffinityList = greyscaleColor_db->getVector<double>( "GreySolidAffinity" );
|
|
||||||
//
|
|
||||||
// NLABELS=LabelList.size();
|
|
||||||
// if (NLABELS != AffinityList.size()){
|
|
||||||
// ERROR("Error: GreySolidLabels and GreySolidAffinity must be the same length! \n");
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// for (int k=0;k<Nz;k++){
|
|
||||||
// for (int j=0;j<Ny;j++){
|
|
||||||
// for (int i=0;i<Nx;i++){
|
|
||||||
// int n = k*Nx*Ny+j*Nx+i;
|
|
||||||
// VALUE=id[n];
|
|
||||||
// AFFINITY=0.f;//all nodes except the specified grey nodes have grey-solid affinity = 0.0
|
|
||||||
// // Assign the affinity from the paired list
|
|
||||||
// for (unsigned int idx=0; idx < NLABELS; idx++){
|
|
||||||
// //printf("idx=%i, value=%i, %i, \n",idx, VALUE,LabelList[idx]);
|
|
||||||
// if (VALUE == LabelList[idx]){
|
|
||||||
// AFFINITY=AffinityList[idx];
|
|
||||||
// idx = NLABELS;
|
|
||||||
// //Mask->id[n] = 0; // set mask to zero since this is an immobile component
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// SolidPotential_host[n] = AFFINITY;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// // Calculate grey-solid color-gradient
|
|
||||||
// double *Dst;
|
|
||||||
// Dst = new double [3*3*3];
|
|
||||||
// for (int kk=0; kk<3; kk++){
|
|
||||||
// for (int jj=0; jj<3; jj++){
|
|
||||||
// for (int ii=0; ii<3; ii++){
|
|
||||||
// int index = kk*9+jj*3+ii;
|
|
||||||
// Dst[index] = sqrt(double(ii-1)*double(ii-1) + double(jj-1)*double(jj-1)+ double(kk-1)*double(kk-1));
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// double w_face = 1.f;
|
|
||||||
// double w_edge = 0.5;
|
|
||||||
// double w_corner = 0.f;
|
|
||||||
// //local
|
|
||||||
// Dst[13] = 0.f;
|
|
||||||
// //faces
|
|
||||||
// Dst[4] = w_face;
|
|
||||||
// Dst[10] = w_face;
|
|
||||||
// Dst[12] = w_face;
|
|
||||||
// Dst[14] = w_face;
|
|
||||||
// Dst[16] = w_face;
|
|
||||||
// Dst[22] = w_face;
|
|
||||||
// // corners
|
|
||||||
// Dst[0] = w_corner;
|
|
||||||
// Dst[2] = w_corner;
|
|
||||||
// Dst[6] = w_corner;
|
|
||||||
// Dst[8] = w_corner;
|
|
||||||
// Dst[18] = w_corner;
|
|
||||||
// Dst[20] = w_corner;
|
|
||||||
// Dst[24] = w_corner;
|
|
||||||
// Dst[26] = w_corner;
|
|
||||||
// // edges
|
|
||||||
// Dst[1] = w_edge;
|
|
||||||
// Dst[3] = w_edge;
|
|
||||||
// Dst[5] = w_edge;
|
|
||||||
// Dst[7] = w_edge;
|
|
||||||
// Dst[9] = w_edge;
|
|
||||||
// Dst[11] = w_edge;
|
|
||||||
// Dst[15] = w_edge;
|
|
||||||
// Dst[17] = w_edge;
|
|
||||||
// Dst[19] = w_edge;
|
|
||||||
// Dst[21] = w_edge;
|
|
||||||
// Dst[23] = w_edge;
|
|
||||||
// Dst[25] = w_edge;
|
|
||||||
//
|
|
||||||
// for (int k=1; k<Nz-1; k++){
|
|
||||||
// for (int j=1; j<Ny-1; j++){
|
|
||||||
// for (int i=1; i<Nx-1; i++){
|
|
||||||
// int idx=Map(i,j,k);
|
|
||||||
// if (!(idx < 0)){
|
|
||||||
// double phi_x = 0.f;
|
|
||||||
// double phi_y = 0.f;
|
|
||||||
// double phi_z = 0.f;
|
|
||||||
// for (int kk=0; kk<3; kk++){
|
|
||||||
// for (int jj=0; jj<3; jj++){
|
|
||||||
// for (int ii=0; ii<3; ii++){
|
|
||||||
//
|
|
||||||
// int index = kk*9+jj*3+ii;
|
|
||||||
// double weight= Dst[index];
|
|
||||||
//
|
|
||||||
// int idi=i+ii-1;
|
|
||||||
// int idj=j+jj-1;
|
|
||||||
// int idk=k+kk-1;
|
|
||||||
//
|
|
||||||
// if (idi < 0) idi=0;
|
|
||||||
// if (idj < 0) idj=0;
|
|
||||||
// if (idk < 0) idk=0;
|
|
||||||
// if (!(idi < Nx)) idi=Nx-1;
|
|
||||||
// if (!(idj < Ny)) idj=Ny-1;
|
|
||||||
// if (!(idk < Nz)) idk=Nz-1;
|
|
||||||
//
|
|
||||||
// int nn = idk*Nx*Ny + idj*Nx + idi;
|
|
||||||
// double vec_x = double(ii-1);
|
|
||||||
// double vec_y = double(jj-1);
|
|
||||||
// double vec_z = double(kk-1);
|
|
||||||
// double GWNS=SolidPotential_host[nn];
|
|
||||||
// phi_x += GWNS*weight*vec_x;
|
|
||||||
// phi_y += GWNS*weight*vec_y;
|
|
||||||
// phi_z += GWNS*weight*vec_z;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// if (Averages->SDs(i,j,k)<2.0){
|
|
||||||
// GreySolidGrad_host[idx+0*Np] = phi_x;
|
|
||||||
// GreySolidGrad_host[idx+1*Np] = phi_y;
|
|
||||||
// GreySolidGrad_host[idx+2*Np] = phi_z;
|
|
||||||
// }
|
|
||||||
// else{
|
|
||||||
// GreySolidGrad_host[idx+0*Np] = 0.0;
|
|
||||||
// GreySolidGrad_host[idx+1*Np] = 0.0;
|
|
||||||
// GreySolidGrad_host[idx+2*Np] = 0.0;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// if (rank==0){
|
|
||||||
// printf("Number of Grey-solid labels: %lu \n",NLABELS);
|
|
||||||
// for (unsigned int idx=0; idx<NLABELS; idx++){
|
|
||||||
// VALUE=LabelList[idx];
|
|
||||||
// AFFINITY=AffinityList[idx];
|
|
||||||
// printf(" grey-solid label=%d, grey-solid affinity=%f\n",VALUE,AFFINITY);
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// ScaLBL_CopyToDevice(GreySolidGrad, GreySolidGrad_host, 3*Np*sizeof(double));
|
|
||||||
// ScaLBL_Comm->Barrier();
|
|
||||||
// delete [] SolidPotential_host;
|
|
||||||
// delete [] GreySolidGrad_host;
|
|
||||||
// delete [] Dst;
|
|
||||||
//}
|
|
||||||
|
|
||||||
|
|
||||||
//--------- This is another old version of calculating greyscale-solid color-gradient modification-------//
|
|
||||||
// **not working effectively, to be deprecated
|
|
||||||
//void ScaLBL_GreyscaleColorModel::AssignGreySolidLabels()
|
|
||||||
//{
|
|
||||||
// // ONLY initialize grey nodes
|
|
||||||
// // Key input parameters:
|
|
||||||
// // 1. GreySolidLabels
|
|
||||||
// // labels for grey nodes
|
|
||||||
// // 2. GreySolidAffinity
|
|
||||||
// // affinity ranges [-1,1]
|
|
||||||
// // oil-wet > 0
|
|
||||||
// // water-wet < 0
|
|
||||||
// // neutral = 0
|
|
||||||
//
|
|
||||||
// //double *SolidPotential_host = new double [Nx*Ny*Nz];
|
|
||||||
// double *GreySolidPhi_host = new double [Nx*Ny*Nz];
|
|
||||||
// signed char VALUE=0;
|
|
||||||
// double AFFINITY=0.f;
|
|
||||||
//
|
|
||||||
// auto LabelList = greyscaleColor_db->getVector<int>( "GreySolidLabels" );
|
|
||||||
// auto AffinityList = greyscaleColor_db->getVector<double>( "GreySolidAffinity" );
|
|
||||||
//
|
|
||||||
// size_t NLABELS=0;
|
|
||||||
// NLABELS=LabelList.size();
|
|
||||||
// if (NLABELS != AffinityList.size()){
|
|
||||||
// ERROR("Error: GreySolidLabels and GreySolidAffinity must be the same length! \n");
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// for (int k=0;k<Nz;k++){
|
|
||||||
// for (int j=0;j<Ny;j++){
|
|
||||||
// for (int i=0;i<Nx;i++){
|
|
||||||
// int n = k*Nx*Ny+j*Nx+i;
|
|
||||||
// VALUE=id[n];
|
|
||||||
// AFFINITY=0.f;//all nodes except the specified grey nodes have grey-solid affinity = 0.0
|
|
||||||
// // Assign the affinity from the paired list
|
|
||||||
// for (unsigned int idx=0; idx < NLABELS; idx++){
|
|
||||||
// //printf("idx=%i, value=%i, %i, \n",idx, VALUE,LabelList[idx]);
|
|
||||||
// if (VALUE == LabelList[idx]){
|
|
||||||
// AFFINITY=AffinityList[idx];
|
|
||||||
// idx = NLABELS;
|
|
||||||
// //Mask->id[n] = 0; // set mask to zero since this is an immobile component
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// GreySolidPhi_host[n] = AFFINITY;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if (rank==0){
|
|
||||||
// printf("Number of grey-solid labels: %lu \n",NLABELS);
|
|
||||||
// for (unsigned int idx=0; idx<NLABELS; idx++){
|
|
||||||
// VALUE=LabelList[idx];
|
|
||||||
// AFFINITY=AffinityList[idx];
|
|
||||||
// printf(" grey-solid label=%d, solid-affinity=%f\n",VALUE,AFFINITY);
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// ScaLBL_CopyToDevice(GreySolidPhi, GreySolidPhi_host, Nx*Ny*Nz*sizeof(double));
|
|
||||||
// ScaLBL_Comm->Barrier();
|
|
||||||
//
|
|
||||||
// //debug
|
|
||||||
// FILE *OUTFILE;
|
|
||||||
// sprintf(LocalRankFilename,"GreySolidInit.%05i.raw",rank);
|
|
||||||
// OUTFILE = fopen(LocalRankFilename,"wb");
|
|
||||||
// fwrite(GreySolidPhi_host,8,N,OUTFILE);
|
|
||||||
// fclose(OUTFILE);
|
|
||||||
//
|
|
||||||
// //delete [] SolidPotential_host;
|
|
||||||
// delete [] GreySolidPhi_host;
|
|
||||||
//}
|
|
||||||
//----------------------------------------------------------------------------------------------------------//
|
|
||||||
|
@ -15,19 +15,69 @@ Implementation of two-fluid greyscale color lattice boltzmann model
|
|||||||
#include "ProfilerApp.h"
|
#include "ProfilerApp.h"
|
||||||
#include "threadpool/thread_pool.h"
|
#include "threadpool/thread_pool.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \class ScaLBL_GreyscaleColorModel
|
||||||
|
*
|
||||||
|
* @details
|
||||||
|
* The ScaLBL_GreyscaleColorModel class extends the standard color model incorporate transport
|
||||||
|
* through sub-resolution "greyscale" regions.
|
||||||
|
* Momentum transport equations are described by a D3Q19 scheme
|
||||||
|
* Mass transport equations are described by D3Q7 scheme
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
class ScaLBL_GreyscaleColorModel{
|
class ScaLBL_GreyscaleColorModel{
|
||||||
public:
|
public:
|
||||||
|
/**
|
||||||
|
* \brief Constructor
|
||||||
|
* @param RANK processor rank
|
||||||
|
* @param NP number of processors
|
||||||
|
* @param COMM MPI communicator
|
||||||
|
*/
|
||||||
ScaLBL_GreyscaleColorModel(int RANK, int NP, const Utilities::MPI& COMM);
|
ScaLBL_GreyscaleColorModel(int RANK, int NP, const Utilities::MPI& COMM);
|
||||||
~ScaLBL_GreyscaleColorModel();
|
~ScaLBL_GreyscaleColorModel();
|
||||||
|
|
||||||
// functions in they should be run
|
// functions in they should be run
|
||||||
|
/**
|
||||||
|
* \brief Read simulation parameters
|
||||||
|
* @param filename input database file that includes "Color" section
|
||||||
|
*/
|
||||||
void ReadParams(string filename);
|
void ReadParams(string filename);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Read simulation parameters
|
||||||
|
* @param db0 input database that includes "Color" section
|
||||||
|
*/
|
||||||
void ReadParams(std::shared_ptr<Database> db0);
|
void ReadParams(std::shared_ptr<Database> db0);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Create domain data structures
|
||||||
|
*/
|
||||||
void SetDomain();
|
void SetDomain();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Read image data
|
||||||
|
*/
|
||||||
void ReadInput();
|
void ReadInput();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Create color model data structures
|
||||||
|
*/
|
||||||
void Create();
|
void Create();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Initialize the simulation
|
||||||
|
*/
|
||||||
void Initialize();
|
void Initialize();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Run the simulation
|
||||||
|
*/
|
||||||
void Run();
|
void Run();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Debugging function to dump simulation state to disk
|
||||||
|
*/
|
||||||
void WriteDebug();
|
void WriteDebug();
|
||||||
|
|
||||||
bool Restart,pBC;
|
bool Restart,pBC;
|
||||||
@ -72,7 +122,7 @@ public:
|
|||||||
double *GreySw;
|
double *GreySw;
|
||||||
double *GreyKn;
|
double *GreyKn;
|
||||||
double *GreyKw;
|
double *GreyKw;
|
||||||
//double *ColorGrad;
|
double *MobilityRatio;
|
||||||
double *Velocity;
|
double *Velocity;
|
||||||
double *Pressure;
|
double *Pressure;
|
||||||
double *Porosity_dvc;
|
double *Porosity_dvc;
|
||||||
@ -91,14 +141,24 @@ private:
|
|||||||
|
|
||||||
//int rank,nprocs;
|
//int rank,nprocs;
|
||||||
void LoadParams(std::shared_ptr<Database> db0);
|
void LoadParams(std::shared_ptr<Database> db0);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Assign wetting affinity values
|
||||||
|
*/
|
||||||
void AssignComponentLabels();
|
void AssignComponentLabels();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Assign wetting affinity values in greyscale regions
|
||||||
|
*/
|
||||||
void AssignGreySolidLabels();
|
void AssignGreySolidLabels();
|
||||||
|
/**
|
||||||
|
* \brief Assign porosity and permeability in greyscale regions
|
||||||
|
*/
|
||||||
void AssignGreyPoroPermLabels();
|
void AssignGreyPoroPermLabels();
|
||||||
//void AssignGreyscalePotential();
|
/**
|
||||||
void ImageInit(std::string filename);
|
* \brief Seed phase field
|
||||||
double MorphInit(const double beta, const double morph_delta);
|
*/
|
||||||
double SeedPhaseField(const double seed_water_in_oil);
|
double SeedPhaseField(const double seed_water_in_oil);
|
||||||
double MorphOpenConnected(double target_volume_change);
|
|
||||||
void WriteVisFiles();
|
void WriteVisFiles();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user