Skip to content

Commit

Permalink
fix KL shell
Browse files Browse the repository at this point in the history
  • Loading branch information
rath3t committed Jan 10, 2024
1 parent 3506d9d commit 9b08563
Show file tree
Hide file tree
Showing 5 changed files with 34 additions and 28 deletions.
3 changes: 2 additions & 1 deletion ikarus/finiteelements/mechanics/membranestrains.hh
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,8 @@ namespace Ikarus {
const Eigen::Matrix<ScalarType, 2, 3> j = J + gradu.transpose();

epsV << J.row(0).dot(gradu.col(0)) + 0.5 * gradu.col(0).squaredNorm(),
J.row(1).dot(gradu.col(1)) + 0.5 * gradu.col(1).squaredNorm(), j.row(0).dot(j.row(1));
J.row(1).dot(gradu.col(1)) + 0.5 * gradu.col(1).squaredNorm(),
j.row(0).dot(j.row(1)) - J.row(0).dot(J.row(1));
return epsV;
}

Expand Down
8 changes: 1 addition & 7 deletions python/ikarus/finite_elements/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -104,13 +104,7 @@ def KirchhoffLoveShell(
includes = ["ikarus/python/finiteelements/kirchhoffloveshell.hh"]

includes += ["ikarus/finiteelements/febases/autodifffe.hh"]
autodiffWrapper = "AutoDiffFE"
element_type = (
"Ikarus::"
+ autodiffWrapper
+ f"<Ikarus::KirchhoffLoveShell<{basis.cppTypeName},Ikarus::FErequirements<Eigen::Ref<Eigen::VectorXd>>,true>,"
f"Ikarus::FErequirements<Eigen::Ref<Eigen::VectorXd>>,true>"
)
element_type = f"Ikarus::KirchhoffLoveShell<{basis.cppTypeName},Ikarus::FERequirements<Eigen::Ref<Eigen::VectorXd>>,true>"

# else:
# element_type = "Ikarus::" + func.__name__ + f"<{basis.cppTypeName}, {material.cppTypeName} ,Ikarus::FErequirements<Eigen::Ref<Eigen::VectorXd>>,true>"
Expand Down
9 changes: 3 additions & 6 deletions tests/src/checkfebyautodiff.hh
Original file line number Diff line number Diff line change
Expand Up @@ -11,17 +11,16 @@

template <template <typename...> class FE, typename GridView, typename PreBasis, typename... ElementArgsType>
auto checkFEByAutoDiff(const GridView& gridView, const PreBasis& pb, const ElementArgsType&... eleArgs) {
auto basis = Ikarus::makeBasis(gridView, pb);
auto basis = Ikarus::makeBasis(gridView, pb);
Eigen::VectorXd d;
d.setRandom(basis.flat().dimension());
double lambda = 7.3;

auto req = Ikarus::FErequirements().addAffordance(Ikarus::AffordanceCollections::elastoStatics);
req.insertGlobalSolution(Ikarus::FESolutions::displacement, d)
.insertParameter(Ikarus::FEParameter::loadfactor, lambda);
Dune::TestSuite t("Check calculateScalarImpl() and calculateVectorImpl() by Automatic Differentiation"
);
for(auto element : elements(gridView)) {
Dune::TestSuite t("Check calculateScalarImpl() and calculateVectorImpl() by Automatic Differentiation");
for (auto element : elements(gridView)) {
auto localView = basis.flat().localView();
localView.bind(element);
auto nDOF = localView.size();
Expand All @@ -34,8 +33,6 @@ auto checkFEByAutoDiff(const GridView& gridView, const PreBasis& pb, const Eleme
using AutoDiffBasedFE = Ikarus::AutoDiffFE<decltype(fe), typename decltype(fe)::FERequirementType, false, true>;
AutoDiffBasedFE feAutoDiff(fe);



Eigen::MatrixXd K, KAutoDiff;
K.setZero(nDOF, nDOF);
KAutoDiff.setZero(nDOF, nDOF);
Expand Down
23 changes: 14 additions & 9 deletions tests/src/testadaptivestepsizing.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,9 @@

#include <config.h>

#include "checkfebyautodiff.hh"
#include "testcommon.hh"
#include "testhelpers.hh"
#include "checkfebyautodiff.hh"

#include <dune/common/test/testsuite.hh>
#include <dune/functions/functionspacebases/boundarydofs.hh>
Expand Down Expand Up @@ -112,8 +112,8 @@ auto KLShellAndAdaptiveStepSizing(const PathFollowingType& pft, const std::vecto
for (auto& element : elements(gridView))
fes.emplace_back(basis, element, E, nu, thickness, utils::LoadDefault{}, &neumannBoundary, neumannBoundaryLoad);

t.subTest(checkFEByAutoDiff<KirchhoffLoveShellHelper>(gridView, power<3>(nurbs()), E, nu, thickness, utils::LoadDefault{},
&neumannBoundary, neumannBoundaryLoad));
t.subTest(checkFEByAutoDiff<KirchhoffLoveShellHelper>(gridView, power<3>(nurbs()), E, nu, thickness,
utils::LoadDefault{}, &neumannBoundary, neumannBoundaryLoad));

auto basisP = std::make_shared<const decltype(basis)>(basis);
DirichletValues dirichletValues(basisP->flat());
Expand Down Expand Up @@ -166,7 +166,6 @@ auto KLShellAndAdaptiveStepSizing(const PathFollowingType& pft, const std::vecto
auto nonLinOpFull
= Ikarus::NonLinearOperator(functions(energyFunction, residualFunction, KFunction), parameter(d, lambda));


auto nonLinOp = nonLinOpFull.template subOperator<1, 2>();
auto linSolver = LinearSolver(SolverTypeTag::sd_SimplicialLDLT);

Expand Down Expand Up @@ -219,13 +218,16 @@ auto KLShellAndAdaptiveStepSizing(const PathFollowingType& pft, const std::vecto

resetNonLinearOperatorParametersToZero(nonLinOp);
const auto controlInfoWSS = crWSS.run();
checkScalars(t, std::ranges::max(d), expectedResults[0][0], message1 + "<Max Displacement>");
checkScalars(t, lambda, expectedResults[0][1], message1 + "<Lambda>");
const double tolDisp = 1e-13;
const double tolLoad = 1e-12;
checkScalars(t, std::ranges::max(d), expectedResults[0][0], message1 + " <Max Displacement>", tolDisp);
checkScalars(t, lambda, expectedResults[0][1], message1 + " <Lambda>", tolLoad);
resetNonLinearOperatorParametersToZero(nonLinOp);

const auto controlInfoWoSS = crWoSS.run();
checkScalars(t, std::ranges::max(d), expectedResults[1][0], message2 + "<Max Displacement>");
checkScalars(t, lambda, expectedResults[1][1], message2 + "<Lambda>");

checkScalars(t, std::ranges::max(d), expectedResults[1][0], message2 + " <Max Displacement>", tolDisp);
checkScalars(t, lambda, expectedResults[1][1], message2 + " <Lambda>", tolLoad);
resetNonLinearOperatorParametersToZero(nonLinOp);

const int controlInfoWSSIterations
Expand All @@ -246,6 +248,9 @@ auto KLShellAndAdaptiveStepSizing(const PathFollowingType& pft, const std::vecto
checkSolverInfos(t, expectedIterations[0], controlInfoWSS, loadSteps, message1);
checkSolverInfos(t, expectedIterations[1], controlInfoWoSS, loadSteps, message2);

t.check(utils::checkGradient(nonLinOpFull, {.draw = false})) << "Check gradient failed";
t.check(utils::checkHessian(nonLinOpFull, {.draw = false})) << "Check hessian failed";

return t;
}

Expand All @@ -264,7 +269,7 @@ int main(int argc, char** argv) {
const std::vector<std::vector<double>> expectedResultsALC
= {{0.1032139637288574, 0.0003103004514250302}, {0.162759603260405, 0.0007765975850229621}};
const std::vector<std::vector<double>> expectedResultsLC
= {{0.08741028329554587, 0.0002318693543601816}, {0.144353999993308, 6e-4}};
= {{0.08741028329554552, 0.0002318693543601816}, {0.144353999993308, 6e-4}};

t.subTest(KLShellAndAdaptiveStepSizing(alc, expectedIterationsALC, expectedResultsALC, 3, 0.4));
t.subTest(KLShellAndAdaptiveStepSizing(lc, expectedIterationsLC, expectedResultsLC, 2, 1e-4));
Expand Down
19 changes: 14 additions & 5 deletions tests/src/testhelpers.hh
Original file line number Diff line number Diff line change
Expand Up @@ -31,14 +31,23 @@ requires(std::convertible_to<Derived, Eigen::EigenBase<Derived> const&>and std::
}

template <typename TestSuiteType, typename ScalarType>
requires std::is_integral_v<ScalarType>
void checkScalars(TestSuiteType& t, const ScalarType val, const ScalarType expectedVal,
const std::string& messageIfFailed = "") {
if constexpr (std::is_integral_v<ScalarType>)
t.check(val == expectedVal) << std::setprecision(16) << "Incorrect Scalars:\t" << expectedVal << " Actual:\t" << val
<< messageIfFailed;
else
t.check(Dune::FloatCmp::eq(val, expectedVal))
<< std::setprecision(16) << "Incorrect Scalars:\t" << expectedVal << " Actual:\t" << val << messageIfFailed;
t.check(val == expectedVal) << std::setprecision(16) << "Incorrect Scalar integer:\t" << expectedVal << " Actual:\t"
<< val << messageIfFailed;
}

template <typename TestSuiteType, typename ScalarType>
requires(not std::is_integral_v<ScalarType>) void checkScalars(TestSuiteType& t, const ScalarType val,
const ScalarType expectedVal,
const std::string& messageIfFailed = "",
double tol
= Dune::FloatCmp::DefaultEpsilon<ScalarType>::value()) {
t.check(Dune::FloatCmp::eq(val, expectedVal, tol))
<< std::setprecision(16) << "Incorrect Scalar floating point:\t" << expectedVal << " Actual:\t" << val
<< ". The used tolerance was " << tol << messageIfFailed;
}

template <typename TestSuiteType, typename ControlInformation>
Expand Down

0 comments on commit 9b08563

Please sign in to comment.