144 lines
3.2 KiB
C
144 lines
3.2 KiB
C
|
Info<< "Reading incremental displacement field DU\n" << endl;
|
||
|
volVectorField DU
|
||
|
(
|
||
|
IOobject
|
||
|
(
|
||
|
"DU",
|
||
|
runTime.timeName(),
|
||
|
mesh,
|
||
|
IOobject::MUST_READ,
|
||
|
IOobject::AUTO_WRITE
|
||
|
),
|
||
|
mesh
|
||
|
);
|
||
|
|
||
|
volTensorField gradDU = fvc::grad(DU);
|
||
|
|
||
|
Info<< "Reading accumulated displacement field U\n" << endl;
|
||
|
volVectorField U
|
||
|
(
|
||
|
IOobject
|
||
|
(
|
||
|
"U",
|
||
|
runTime.timeName(),
|
||
|
mesh,
|
||
|
IOobject::READ_IF_PRESENT,
|
||
|
IOobject::AUTO_WRITE
|
||
|
),
|
||
|
mesh,
|
||
|
dimensionedVector("zero", dimLength, vector::zero)
|
||
|
);
|
||
|
|
||
|
Info << "Reading accumulated strain field epsilon\n" << endl;
|
||
|
volSymmTensorField epsilon
|
||
|
(
|
||
|
IOobject
|
||
|
(
|
||
|
"epsilon",
|
||
|
runTime.timeName(),
|
||
|
mesh,
|
||
|
IOobject::READ_IF_PRESENT,
|
||
|
IOobject::AUTO_WRITE
|
||
|
),
|
||
|
mesh,
|
||
|
dimensionedSymmTensor("zero", dimless, symmTensor::zero)
|
||
|
);
|
||
|
|
||
|
volSymmTensorField DEpsilon
|
||
|
(
|
||
|
IOobject
|
||
|
(
|
||
|
"DEpsilon",
|
||
|
runTime.timeName(),
|
||
|
mesh,
|
||
|
IOobject::READ_IF_PRESENT,
|
||
|
IOobject::AUTO_WRITE
|
||
|
),
|
||
|
mesh,
|
||
|
dimensionedSymmTensor("zero", dimless, symmTensor::zero)
|
||
|
);
|
||
|
|
||
|
Info << "Reading accumulated stress field sigma\n" << endl;
|
||
|
volSymmTensorField sigma
|
||
|
(
|
||
|
IOobject
|
||
|
(
|
||
|
"sigma",
|
||
|
runTime.timeName(),
|
||
|
mesh,
|
||
|
IOobject::READ_IF_PRESENT,
|
||
|
IOobject::AUTO_WRITE
|
||
|
),
|
||
|
mesh,
|
||
|
dimensionedSymmTensor("zero", dimForce/dimArea, symmTensor::zero)
|
||
|
);
|
||
|
|
||
|
|
||
|
Info << "Reading incremental stress field DSigma\n" << endl;
|
||
|
volSymmTensorField DSigma
|
||
|
(
|
||
|
IOobject
|
||
|
(
|
||
|
"DSigma",
|
||
|
runTime.timeName(),
|
||
|
mesh,
|
||
|
IOobject::READ_IF_PRESENT,
|
||
|
IOobject::AUTO_WRITE
|
||
|
),
|
||
|
mesh,
|
||
|
dimensionedSymmTensor("zero", dimForce/dimArea, symmTensor::zero)
|
||
|
);
|
||
|
|
||
|
//- explicit terms in the momentum equation
|
||
|
volVectorField divDSigmaExp
|
||
|
(
|
||
|
IOobject
|
||
|
(
|
||
|
"divDSigmaExp",
|
||
|
runTime.timeName(),
|
||
|
mesh,
|
||
|
IOobject::NO_READ,
|
||
|
IOobject::NO_WRITE
|
||
|
),
|
||
|
mesh,
|
||
|
dimensionedVector("zero", dimensionSet(1, -2, -2, 0, 0, 0, 0), vector::zero)
|
||
|
);
|
||
|
|
||
|
volVectorField divDSigmaLargeStrainExp
|
||
|
(
|
||
|
IOobject
|
||
|
(
|
||
|
"divDSigmaLargeStrainExp",
|
||
|
runTime.timeName(),
|
||
|
mesh,
|
||
|
IOobject::NO_READ,
|
||
|
IOobject::AUTO_WRITE
|
||
|
),
|
||
|
mesh,
|
||
|
dimensionedVector("zero", dimensionSet(1, -2, -2, 0, 0, 0, 0), vector::zero)
|
||
|
);
|
||
|
|
||
|
rheologyModel rheology(sigma);
|
||
|
volScalarField mu = rheology.mu();
|
||
|
volScalarField lambda = rheology.lambda();
|
||
|
surfaceScalarField muf = fvc::interpolate(rheology.mu());
|
||
|
surfaceScalarField lambdaf = fvc::interpolate(rheology.lambda());
|
||
|
|
||
|
surfaceVectorField n = mesh.Sf()/mesh.magSf();
|
||
|
|
||
|
volScalarField rho
|
||
|
(
|
||
|
IOobject
|
||
|
(
|
||
|
"rho",
|
||
|
runTime.timeName(),
|
||
|
mesh,
|
||
|
IOobject::READ_IF_PRESENT,
|
||
|
IOobject::AUTO_WRITE
|
||
|
),
|
||
|
rheology.rho()
|
||
|
);
|
||
|
|
||
|
volTensorField F = I + gradDU;
|
||
|
volScalarField J = det(F);
|