Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[GeoMechanicsApplication] Simplified fluid flux for pw element #12338

Merged
merged 8 commits into from
May 6, 2024
Original file line number Diff line number Diff line change
Expand Up @@ -621,41 +621,20 @@ void UPwSmallStrainElement<TDim, TNumNodes>::CalculateOnIntegrationPoints(
ElementVariables Variables;
this->InitializeElementVariables(Variables, rCurrentProcessInfo);

const PropertiesType& rProp = this->GetProperties();

array_1d<double, TDim> GradPressureTerm;
array_1d<double, TDim> FluidFlux;

// Create general parameters of retention law
RetentionLaw::Parameters RetentionParameters(this->GetProperties(), rCurrentProcessInfo);

std::vector<double> permeability_update_factors;
for (unsigned int GPoint = 0; GPoint < NumGPoints; ++GPoint) {
// Compute Np, GradNpT, B and StrainVector
this->CalculateKinematics(Variables, GPoint);

// Compute strain, needed for update permeability
this->CalculateStrain(Variables, GPoint);
this->CalculatePermeabilityUpdateFactor(Variables);
permeability_update_factors.push_back(Variables.PermeabilityUpdateFactor);
}

GeoElementUtilities::InterpolateVariableWithComponents<TDim, TNumNodes>(
Variables.BodyAcceleration, Variables.NContainer, Variables.VolumeAcceleration, GPoint);
Variables.FluidPressure = CalculateFluidPressure(Variables);

RetentionParameters.SetFluidPressure(Variables.FluidPressure);

Variables.RelativePermeability =
mRetentionLawVector[GPoint]->CalculateRelativePermeability(RetentionParameters);

noalias(GradPressureTerm) = prod(trans(Variables.GradNpT), Variables.PressureVector);

noalias(GradPressureTerm) +=
PORE_PRESSURE_SIGN_FACTOR * rProp[DENSITY_WATER] * Variables.BodyAcceleration;

noalias(FluidFlux) = PORE_PRESSURE_SIGN_FACTOR * Variables.DynamicViscosityInverse *
Variables.RelativePermeability * Variables.PermeabilityUpdateFactor *
prod(Variables.PermeabilityMatrix, GradPressureTerm);

GeoElementUtilities::FillArray1dOutput(rOutput[GPoint], FluidFlux);
const auto fluid_fluxes = CalculateFluidFluxes(permeability_update_factors, rCurrentProcessInfo);
for (unsigned int GPoint = 0; GPoint < NumGPoints; ++GPoint) {
GeoElementUtilities::FillArray1dOutput(rOutput[GPoint], fluid_fluxes[GPoint]);
}
} else {
if (rOutput.size() != mConstitutiveLawVector.size())
Expand Down Expand Up @@ -1112,6 +1091,47 @@ void UPwSmallStrainElement<TDim, TNumNodes>::InitializeBiotCoefficients(ElementV
KRATOS_CATCH("")
}

template <unsigned int TDim, unsigned int TNumNodes>
std::vector<array_1d<double, TDim>> UPwSmallStrainElement<TDim, TNumNodes>::CalculateFluidFluxes(
const std::vector<double>& rPermeabilityUpdateFactors, const ProcessInfo& rCurrentProcessInfo)
{
const GeometryType& rGeom = this->GetGeometry();
const IndexType NumGPoints = rGeom.IntegrationPointsNumber(this->GetIntegrationMethod());

std::vector<array_1d<double, TDim>> FluidFluxes;
ElementVariables Variables;
this->InitializeElementVariables(Variables, rCurrentProcessInfo);

const PropertiesType& rProp = this->GetProperties();

array_1d<double, TDim> GradPressureTerm;

// Create general parameters of retention law
RetentionLaw::Parameters RetentionParameters(this->GetProperties(), rCurrentProcessInfo);

for (unsigned int GPoint = 0; GPoint < NumGPoints; ++GPoint) {
this->CalculateKinematics(Variables, GPoint);
Variables.PermeabilityUpdateFactor = rPermeabilityUpdateFactors[GPoint];

GeoElementUtilities::InterpolateVariableWithComponents<TDim, TNumNodes>(
Variables.BodyAcceleration, Variables.NContainer, Variables.VolumeAcceleration, GPoint);
Variables.FluidPressure = CalculateFluidPressure(Variables);
RetentionParameters.SetFluidPressure(Variables.FluidPressure);

Variables.RelativePermeability =
mRetentionLawVector[GPoint]->CalculateRelativePermeability(RetentionParameters);

noalias(GradPressureTerm) = prod(trans(Variables.GradNpT), Variables.PressureVector);
noalias(GradPressureTerm) += PORE_PRESSURE_SIGN_FACTOR * rProp[DENSITY_WATER] * Variables.BodyAcceleration;

FluidFluxes.push_back(PORE_PRESSURE_SIGN_FACTOR * Variables.DynamicViscosityInverse *
Variables.RelativePermeability * Variables.PermeabilityUpdateFactor *
prod(Variables.PermeabilityMatrix, GradPressureTerm));
}

return FluidFluxes;
}

template <unsigned int TDim, unsigned int TNumNodes>
void UPwSmallStrainElement<TDim, TNumNodes>::CalculatePermeabilityUpdateFactor(ElementVariables& rVariables)
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -240,7 +240,8 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) UPwSmallStrainElement : public UPwBa

virtual void CalculateAndAddCompressibilityMatrix(MatrixType& rLeftHandSideMatrix, ElementVariables& rVariables);

virtual void CalculateAndAddPermeabilityMatrix(MatrixType& rLeftHandSideMatrix, const ElementVariables& rVariables);
virtual void CalculateAndAddPermeabilityMatrix(MatrixType& rLeftHandSideMatrix,
const ElementVariables& rVariables);

virtual void CalculateAndAddRHS(VectorType& rRightHandSideVector, ElementVariables& rVariables, unsigned int GPoint);

Expand Down Expand Up @@ -283,6 +284,8 @@ class KRATOS_API(GEO_MECHANICS_APPLICATION) UPwSmallStrainElement : public UPwBa

void InitializeProperties(ElementVariables& rVariables);
double CalculateFluidPressure(const ElementVariables& rVariables);
std::vector<array_1d<double, TDim>> CalculateFluidFluxes(const std::vector<double>& rPermeabilityUpdateFactors,
const ProcessInfo& rCurrentProcessInfo);

void CalculateRetentionResponse(ElementVariables& rVariables,
RetentionLaw::Parameters& rRetentionParameters,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -383,8 +383,17 @@ void TransientPwElement<TDim, TNumNodes>::CalculateOnIntegrationPoints(const Var
{
KRATOS_TRY

const GeometryType& rGeom = this->GetGeometry();
const IndexType NumGPoints = rGeom.IntegrationPointsNumber(this->GetIntegrationMethod());
if (rOutput.size() != NumGPoints) rOutput.resize(NumGPoints);

if (rVariable == FLUID_FLUX_VECTOR) {
BaseType::CalculateOnIntegrationPoints(rVariable, rOutput, rCurrentProcessInfo);
std::vector<double> permeability_update_factors(NumGPoints, 1.0);
const auto fluid_fluxes = this->CalculateFluidFluxes(permeability_update_factors, rCurrentProcessInfo);

for (unsigned int GPoint = 0; GPoint < NumGPoints; ++GPoint) {
GeoElementUtilities::FillArray1dOutput(rOutput[GPoint], fluid_fluxes[GPoint]);
}
} else {
if (rOutput.size() != mRetentionLawVector.size())
rOutput.resize(mRetentionLawVector.size());
Expand Down
Loading