Skip to content

Commit

Permalink
fix after rebase
Browse files Browse the repository at this point in the history
  • Loading branch information
tarun-mitruka committed Jan 10, 2024
1 parent 746cb55 commit ea093d1
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 29 deletions.
42 changes: 21 additions & 21 deletions ikarus/finiteelements/mechanics/kirchhoffloveshell.hh
Original file line number Diff line number Diff line change
Expand Up @@ -194,8 +194,8 @@ namespace Ikarus {
}

Dune::CachedLocalBasis<std::remove_cvref_t<LocalBasisType>> localBasis;
std::function<Eigen::Vector<double, worldDim>(const Eigen::Vector<double, worldDim>&, const double&)> volumeLoad;
std::function<Eigen::Vector<double, worldDim>(const Eigen::Vector<double, worldDim>&, const double&)>
std::function<Eigen::Vector<double, worldDim>(const Dune::FieldVector<double, worldDim>&, const double&)> volumeLoad;
std::function<Eigen::Vector<double, worldDim>(const Dune::FieldVector<double, worldDim>&, const double&)>
neumannBoundaryLoad;
const BoundaryPatch<GridView>* neumannBoundary;
DefaultMembraneStrain membraneStrain;
Expand Down Expand Up @@ -233,7 +233,7 @@ namespace Ikarus {
KinematicVariables<ScalarType> kin;
using namespace Dune;
using namespace Dune::DerivativeDirections;
const auto [X, Jd, Hd] = geo.impl().zeroFirstAndSecondDerivativeOfPosition(gpPos);
const auto [X, Jd, Hd] = geo->impl().zeroFirstAndSecondDerivativeOfPosition(gpPos);
kin.J = toEigen(Jd);
kin.H = toEigen(Hd);
const Eigen::Matrix<double, 2, 2> A = kin.J * kin.J.transpose();
Expand All @@ -257,7 +257,7 @@ namespace Ikarus {
kin.a3 = kin.a3N.normalized();
Eigen::Vector<ScalarType, 3> bV = kin.h * kin.a3;
bV(2) *= 2; // Voigt notation requires the two here
const auto BV = toVoigt(toEigen(geo.impl().secondFundamentalForm(gpPos)));
const auto BV = toVoigt(toEigen(geo->impl().secondFundamentalForm(gpPos)));
kin.kappaV = BV - bV;
return kin;
}
Expand All @@ -273,7 +273,7 @@ namespace Ikarus {
const auto geo = this->localView().element().geometry();

for (const auto& [gpIndex, gp] : uFunction.viewOverIntegrationPoints()) {
const auto intElement = geo.integrationElement(gp.position()) * gp.weight();
const auto intElement = geo->integrationElement(gp.position()) * gp.weight();
const auto [C, epsV, kappaV, jE, J, h, H, a3N, a3]
= computeMaterialAndStrains(gp.position(), gpIndex, geo, uFunction);
const Eigen::Vector<ScalarType, membraneStrainSize> membraneForces = thickness_ * C * epsV;
Expand All @@ -282,21 +282,21 @@ namespace Ikarus {
const auto& Nd = localBasis.evaluateJacobian(gpIndex);
const auto& Ndd = localBasis.evaluateSecondDerivatives(gpIndex);
for (size_t i = 0; i < numberOfNodes; ++i) {
Eigen::Matrix<ScalarType, membraneStrainSize, worlddim> bopIMembrane
Eigen::Matrix<ScalarType, membraneStrainSize, worldDim> bopIMembrane
= membraneStrain.derivative(gp.position(), jE, Nd, geo, uFunction, localBasis, i);

Eigen::Matrix<ScalarType, bendingStrainSize, worlddim> bopIBending = bopBending(jE, h, Nd, Ndd, i, a3N, a3);
Eigen::Matrix<ScalarType, bendingStrainSize, worldDim> bopIBending = bopBending(jE, h, Nd, Ndd, i, a3N, a3);
for (size_t j = i; j < numberOfNodes; ++j) {
auto KBlock = K.template block<worlddim, worlddim>(worlddim * i, worlddim * j);
Eigen::Matrix<ScalarType, membraneStrainSize, worlddim> bopJMembrane
auto KBlock = K.template block<worldDim, worldDim>(worldDim * i, worldDim * j);
Eigen::Matrix<ScalarType, membraneStrainSize, worldDim> bopJMembrane
= membraneStrain.derivative(gp.position(), jE, Nd, geo, uFunction, localBasis, j);
Eigen::Matrix<ScalarType, bendingStrainSize, worlddim> bopJBending = bopBending(jE, h, Nd, Ndd, j, a3N, a3);
Eigen::Matrix<ScalarType, bendingStrainSize, worldDim> bopJBending = bopBending(jE, h, Nd, Ndd, j, a3N, a3);
KBlock += thickness_ * bopIMembrane.transpose() * C * bopJMembrane * intElement;
KBlock += Dune::power(thickness_, 3) / 12.0 * bopIBending.transpose() * C * bopJBending * intElement;

Eigen::Matrix<ScalarType, worlddim, worlddim> kgMembraneIJ
Eigen::Matrix<ScalarType, worldDim, worldDim> kgMembraneIJ
= membraneStrain.secondDerivative(gp.position(), Nd, geo, uFunction, localBasis, membraneForces, i, j);
Eigen::Matrix<ScalarType, worlddim, worlddim> kgBendingIJ
Eigen::Matrix<ScalarType, worldDim, worldDim> kgBendingIJ
= kgBending(jE, h, Nd, Ndd, a3N, a3, moments, i, j);
KBlock += kgMembraneIJ * intElement;
KBlock += kgBendingIJ * intElement;
Expand Down Expand Up @@ -330,21 +330,21 @@ namespace Ikarus {
= membraneStrain.derivative(gp.position(), jE, Nd, geo, uFunction, localBasis, i);
Eigen::Matrix<ScalarType, 3, 3> bopIBending = bopBending(jE, h, Nd, Ndd, i, a3N, a3);
force.template segment<3>(3 * i)
+= bopIMembrane.transpose() * membraneForces * geo.integrationElement(gp.position()) * gp.weight();
+= bopIMembrane.transpose() * membraneForces * geo->integrationElement(gp.position()) * gp.weight();
force.template segment<3>(3 * i)
+= bopIBending.transpose() * moments * geo.integrationElement(gp.position()) * gp.weight();
+= bopIBending.transpose() * moments * geo->integrationElement(gp.position()) * gp.weight();
}
}

// External forces volume forces over the domain
if (volumeLoad) {
const auto u = getDisplacementFunction(par, dx);
for (const auto& [gpIndex, gp] : uFunction.viewOverIntegrationPoints()) {
Eigen::Vector<double, Traits::worlddim> fext = volumeLoad(geo.global(gp.position()), lambda);
Eigen::Vector<double, Traits::worldDim> fext = volumeLoad(geo->global(gp.position()), lambda);
for (size_t i = 0; i < numberOfNodes; ++i) {
const auto udCi = uFunction.evaluateDerivative(gpIndex, wrt(coeff(i)));
force.template segment<worlddim>(worlddim * i)
-= udCi * fext * geo.integrationElement(gp.position()) * gp.weight();
force.template segment<worldDim>(worldDim * i)
-= udCi * fext * geo->integrationElement(gp.position()) * gp.weight();
}
}
}
Expand All @@ -368,7 +368,7 @@ namespace Ikarus {

// Value of the Neumann data at the current position
auto neumannValue = neumannBoundaryLoad(intersection.geometry().global(curQuad.position()), lambda);
force.template segment<worlddim>(worlddim * i) -= udCi * neumannValue * intElement;
force.template segment<worldDim>(worldDim * i) -= udCi * neumannValue * intElement;
}
}
}
Expand All @@ -385,17 +385,17 @@ namespace Ikarus {

for (const auto& [gpIndex, gp] : uFunction.viewOverIntegrationPoints()) {
const auto [C, epsV, kappaV, j, J, h, H, a3N, a3]
= computeMaterialAndStrains(gp.position(), gpIndex, geo, uFunction);
= computeMaterialAndStrains(gp.position(), gpIndex, geo_, uFunction);

const ScalarType membraneEnergy = 0.5 * thickness_ * epsV.dot(C * epsV);
const ScalarType bendingEnergy = 0.5 * Dune::power(thickness_, 3) / 12.0 * kappaV.dot(C * kappaV);
energy += (membraneEnergy + bendingEnergy) * geo.integrationElement(gp.position()) * gp.weight();
energy += (membraneEnergy + bendingEnergy) * geo_->integrationElement(gp.position()) * gp.weight();
}

if (volumeLoad) {
for (const auto& [gpIndex, gp] : uFunction.viewOverIntegrationPoints()) {
const auto u = uFunction.evaluate(gpIndex);
const Eigen::Vector<double, Traits::worlddim> fExt = volumeLoad(toEigen(geo_->global(gp.position())), lambda);
const Eigen::Vector<double, Traits::worldDim> fExt = volumeLoad(geo_->global(gp.position()), lambda);
energy -= u.dot(fExt) * geo_->integrationElement(gp.position()) * gp.weight();
}
}
Expand Down
8 changes: 4 additions & 4 deletions ikarus/finiteelements/mechanics/linearelastic.hh
Original file line number Diff line number Diff line change
Expand Up @@ -219,8 +219,8 @@ namespace Ikarus {
}

Dune::CachedLocalBasis<std::remove_cvref_t<LocalBasisType>> localBasis;
std::function<Eigen::Vector<double, worldDim>(const Eigen::Vector<double, worldDim>&, const double&)> volumeLoad;
std::function<Eigen::Vector<double, worldDim>(const Eigen::Vector<double, worldDim>&, const double&)>
std::function<Eigen::Vector<double, worldDim>(const Dune::FieldVector<double, worldDim>&, const double&)> volumeLoad;
std::function<Eigen::Vector<double, worldDim>(const Dune::FieldVector<double, worldDim>&, const double&)>
neumannBoundaryLoad;
const BoundaryPatch<GridView>* neumannBoundary;
double emod_;
Expand Down Expand Up @@ -252,7 +252,7 @@ namespace Ikarus {
if (volumeLoad) {
for (const auto& [gpIndex, gp] : eps.viewOverIntegrationPoints()) {
const auto uVal = uFunction.evaluate(gpIndex);
Eigen::Vector<double, Traits::worlddim> fext = volumeLoad(toEigen(geo_->global(gp.position())), lambda);
Eigen::Vector<double, Traits::worlddim> fext = volumeLoad(geo_->global(gp.position()), lambda);
energy -= uVal.dot(fext) * geo_->integrationElement(gp.position()) * gp.weight();
}
}
Expand Down Expand Up @@ -308,7 +308,7 @@ namespace Ikarus {
// External forces volume forces over the domain
if (volumeLoad) {
for (const auto& [gpIndex, gp] : uFunction.viewOverIntegrationPoints()) {
Eigen::Vector<double, Traits::worlddim> fext = volumeLoad(toEigen(geo_->global(gp.position())), lambda);
Eigen::Vector<double, Traits::worlddim> fext = volumeLoad(geo_->global(gp.position()), lambda);
for (size_t i = 0; i < numberOfNodes; ++i) {
const auto udCi = uFunction.evaluateDerivative(gpIndex, wrt(coeff(i)));
force.template segment<myDim>(myDim * i)
Expand Down
8 changes: 4 additions & 4 deletions ikarus/finiteelements/mechanics/nonlinearelastic.hh
Original file line number Diff line number Diff line change
Expand Up @@ -260,8 +260,8 @@ namespace Ikarus {
}

Dune::CachedLocalBasis<std::remove_cvref_t<LocalBasisType>> localBasis;
std::function<Eigen::Vector<double, worldDim>(const Eigen::Vector<double, worldDim>&, const double&)> volumeLoad;
std::function<Eigen::Vector<double, worldDim>(const Eigen::Vector<double, worldDim>&, const double&)>
std::function<Eigen::Vector<double, worldDim>(const Dune::FieldVector<double, worldDim>&, const double&)> volumeLoad;
std::function<Eigen::Vector<double, worldDim>(const Dune::FieldVector<double, worldDim>&, const double&)>
neumannBoundaryLoad;
const BoundaryPatch<GridView>* neumannBoundary;
Material mat;
Expand Down Expand Up @@ -289,7 +289,7 @@ namespace Ikarus {
if (volumeLoad) {
for (const auto& [gpIndex, gp] : uFunction.viewOverIntegrationPoints()) {
const auto u = uFunction.evaluate(gpIndex);
const Eigen::Vector<double, Traits::worlddim> fExt = volumeLoad(toEigen(geo_->global(gp.position())), lambda);
const Eigen::Vector<double, Traits::worlddim> fExt = volumeLoad(geo_->global(gp.position()), lambda);
energy -= u.dot(fExt) * geo_->integrationElement(gp.position()) * gp.weight();
}
}
Expand Down Expand Up @@ -345,7 +345,7 @@ namespace Ikarus {
if (volumeLoad) {
for (const auto& [gpIndex, gp] : uFunction.viewOverIntegrationPoints()) {
const double intElement = geo_->integrationElement(gp.position()) * gp.weight();
const Eigen::Vector<double, Traits::worlddim> fExt = volumeLoad(toEigen(geo_->global(gp.position())), lambda);
const Eigen::Vector<double, Traits::worlddim> fExt = volumeLoad(geo_->global(gp.position()), lambda);
for (size_t i = 0; i < numberOfNodes; ++i) {
const auto udCi = uFunction.evaluateDerivative(gpIndex, wrt(coeff(i)));
force.template segment<myDim>(myDim * i) -= udCi * fExt * intElement;
Expand Down

0 comments on commit ea093d1

Please sign in to comment.