1644 {
1646
1649
1650 double time = OP::getFEMethod()->ts_t;
1653 }
1654
1655
1657
1659
1660 if (bc.faces.find(fe_ent) != bc.faces.end()) {
1662 int nb_integration_pts = OP::getGaussPts().size2();
1663 auto t_w = OP::getFTensor0IntegrationWeight();
1664
1665 int nb_base_functions = data.
getN().size2();
1667
1668 auto get_ftensor1 = [](
auto &
v) {
1671 };
1672
1673
1674
1675
1676
1677
1678
1680
1681 auto get_rotation_angle = [&]() {
1682 double theta = bc.theta;
1685 }
1686 return theta;
1687 };
1688
1689 auto get_rotation = [&](auto theta) {
1691 if (bc.vals.size() == 7) {
1692 t_omega(0) = bc.vals[4];
1693 t_omega(1) = bc.vals[5];
1694 t_omega(2) = bc.vals[6];
1695 } else {
1696
1697 t_omega(
i) = OP::getFTensor1Normal()(
i);
1698 }
1699 if (t_omega.
l2() > std::numeric_limits<double>::epsilon()) {
1701 }
1702 t_omega(
i) *= theta;
1704 RotSelector::SMALL_ROT
1705 ? 0.
1706 : t_omega.l2());
1707 };
1708
1709 auto area = getMeasure();
1710 auto t_R = get_rotation(get_rotation_angle());
1711 auto t_coords = OP::getFTensor1CoordsAtGaussPts();
1712 auto t_disp_val =
1714 *this->sourceVec, nb_integration_pts)();
1715
1716 for (int gg = 0; gg != nb_integration_pts; ++gg) {
1717 auto tau_scale =
1718 area * t_w * OP::betaCoeff(t_coords(0), t_coords(1), t_coords(2));
1719
1721 t_delta(
i) = t_center(
i) - t_coords(
i);
1723 t_bc_disp(
i) = t_delta(
i) - t_R(
i,
j) * t_delta(
j);
1724
1725 auto t_nf = getFTensor1FromPtr<3>(&*OP::locF.begin());
1726 int bb = 0;
1727 for (; bb != nb_dofs /
SPACE_DIM; ++bb) {
1729 (tau_scale * t_row_base_fun) * (t_disp_val(
i) - t_bc_disp(
i));
1730 ++t_nf;
1731 ++t_row_base_fun;
1732 }
1733 for (; bb != nb_base_functions; ++bb)
1734 ++t_row_base_fun;
1735
1736 ++t_w;
1737 ++t_coords;
1738 ++t_disp_val;
1739 }
1740 }
1741 }
1742
1744}
#define FTENSOR_INDEX(DIM, I)
Tensor1< T, Tensor_Dim > normalize()
#define MoFEMFunctionBegin
First executable line of each MoFEM function, used for error handling. Final line of MoFEM functions ...
#define MoFEMFunctionReturn(a)
Last executable line of each PETSc function used for error handling. Replaces return()
FTensor::Index< 'i', SPACE_DIM > i
const double v
phase velocity of light in medium (cm/ns)
FTensor::Index< 'j', 3 > j
DataLayoutTraits< DataLayout::GaussByCoeffs > DL
decltype(GetFTensor1FromMatImpl< Tensor_Dim, S, DL, M >::get(std::declval< M & >(), 0, 0)) GetFTensor1FromMatType
static enum RotSelector rotSelector
static PetscBool physicalTimeFlg
static double currentPhysicalTime
static auto exp(A &&t_w_vee, B &&theta)
FTensor::Tensor0< FTensor::PackPtr< double *, 1 > > getFTensor0N(const FieldApproximationBase base)
Get base function as Tensor0.
MatrixDouble & getN(const FieldApproximationBase base)
get base functions this return matrix (nb. of rows is equal to nb. of Gauss pts, nb....
const VectorInt & getIndices() const
Get global indices of degrees of freedom on entity.