685 {
687
690
691 int nb_integration_pts = OP::getGaussPts().size2();
693
694 int nb_base_functions = data.
getN().size2() / 3;
696 auto t_w = OP::getFTensor0IntegrationWeight();
697
699 auto t_kappa = getFTensor0FromVec<0>(*
kappaPtr);
701 auto t_face_normal = getFTensor1NormalsAtGaussPts();
702
703 auto next = [&]() {
704 ++t_P;
705 ++t_face_normal;
706 ++t_kappa;
707 ++t_delta_kappa;
708 ++t_w;
709 };
710
711 for (auto gg = 0; gg != nb_integration_pts; ++gg) {
715 t_normalized_normal(
J) = t_normal(
J);
718 t_traction(
i) = t_P(
i,
J) * t_normalized_normal(
J);
719
720 auto dJ_dtraction = [](auto &t_traction, auto &t_normalized_normal,
721 auto &t_delta_kappa, auto &t_kappa, auto gc) {
722 double kappa =
static_cast<double>(t_kappa);
723 double delta_kappa = static_cast<double>(t_delta_kappa);
726 t_traction_double(
i) = t_traction(
i);
727 auto t_dM =
729 t_traction_double, delta_kappa,
kappa, t_normalized_normal, gc,
732 t_dJ_double(
i) = t_dM(
i);
733 return t_dJ_double;
734 };
735
737
738 auto t_nf = getFTensor1FromPtr<3>(&*OP::locF.begin());
739 int bb = 0;
740 for (; bb != nb_dofs /
SPACE_DIM; ++bb) {
741 double row_base = t_w * (t_row_base_fun(
J) * t_normal(
J));
742 t_nf(
i) += row_base * t_dJ(
i);
743 ++t_nf;
744 ++t_row_base_fun;
745 }
746 for (; bb != nb_base_functions; ++bb)
747 ++t_row_base_fun;
748 };
749
750 assemble(dJ_dtraction(t_traction, t_normalized_normal, t_delta_kappa,
752
753
754 next();
755 }
756
758 };
#define FTENSOR_INDEX(DIM, I)
Tensor1< T, Tensor_Dim > normalize()
FTensor::Index< 'i', SPACE_DIM > i
FTensor::Index< 'J', DIM1 > J
static auto calculateDissipationSurplusDiffTraction(const FTensor::Tensor1< T, 3 > &t_traction, const T &delta_kappa, const T &kappa, FTensor::Tensor1< double, 3 > &t_n_normalize, double gc, double beta)
boost::shared_ptr< MatrixDouble > fluxMatPtr
boost::shared_ptr< double > gcPtr
boost::shared_ptr< VectorDouble > kappaDeltaPtr
boost::shared_ptr< VectorDouble > kappaPtr
MatrixDouble & getN(const FieldApproximationBase base)
get base functions this return matrix (nb. of rows is equal to nb. of Gauss pts, nb....
FTensor::Tensor1< FTensor::PackPtr< double *, Tensor_Dim >, Tensor_Dim > getFTensor1N(FieldApproximationBase base)
Get base functions for Hdiv/Hcurl spaces.
const VectorInt & getIndices() const
Get global indices of degrees of freedom on entity.