41 _if_propagation (true) {
70 std::unique_ptr<MAST::FEBase> fe(
_elem.
init_fe(
true,
false,
73 const std::vector<Real>& JxW = fe->get_JxW();
74 const std::vector<libMesh::Point>& xyz = fe->get_xyz();
76 n_phi = fe->n_shape_functions(),
80 eye = RealMatrixX::Identity(1, 1),
81 tau = RealMatrixX::Zero( 1, 1),
82 mat1_n1n2 = RealMatrixX::Zero( 1, n_phi),
83 mat2_n1n2 = RealMatrixX::Zero( 1, n_phi),
84 mat_n2n2 = RealMatrixX::Zero(n_phi, n_phi);
86 vec1_n1 = RealVectorX::Zero(1),
87 vec2_n1 = RealVectorX::Zero(1),
88 vec2_n2 = RealVectorX::Zero(n_phi),
89 flux = RealVectorX::Zero(1),
90 vel = RealVectorX::Zero(dim);
95 std::vector<MAST::FEMOperatorMatrix> dBmat(dim);
99 for (
unsigned int qp=0; qp<JxW.size(); qp++) {
105 _tau(*fe, qp, Bmat, dBmat, vel, tau);
112 for (
unsigned int j=0; j<dim; j++) {
114 dBmat[j].right_multiply(vec1_n1,
_sol);
115 flux += vel(j) * vec1_n1;
116 dBmat[j].left_multiply(mat1_n1n2, eye);
117 mat2_n1n2 += mat1_n1n2 * vel(j);
123 f += JxW[qp] * vec2_n2;
124 f += JxW[qp] * mat2_n1n2.transpose() * tau * flux;
127 for (
unsigned int j=0; j<dim; j++) {
129 dBmat[j].vector_mult(vec1_n1,
_sol);
130 dBmat[j].vector_mult_transpose(vec2_n2, vec1_n1);
131 f += JxW[qp] * dc * vec2_n2;
135 if (request_jacobian) {
137 for (
unsigned int j=0; j<dim; j++) {
140 jac += JxW[qp] * vel(j) * mat_n2n2;
143 dBmat[j].right_multiply_transpose(mat_n2n2, dBmat[j]);
144 jac += JxW[qp] * dc * mat_n2n2;
147 jac += JxW[qp] * mat2_n1n2.transpose() * tau * mat2_n1n2;
151 return request_jacobian;
166 std::unique_ptr<MAST::FEBase> fe(
_elem.
init_fe(
true,
false,
169 const std::vector<Real>& JxW = fe->get_JxW();
170 const std::vector<libMesh::Point>& xyz = fe->get_xyz();
172 n_phi = fe->n_shape_functions(),
176 eye = RealMatrixX::Identity(1, 1),
177 tau = RealMatrixX::Zero( 1, 1),
178 mat1_n1n2 = RealMatrixX::Zero( 1, n_phi),
179 mat2_n1n2 = RealMatrixX::Zero( 1, n_phi),
180 mat_n2n1 = RealMatrixX::Zero(n_phi, 1),
181 mat_n2n2 = RealMatrixX::Zero(n_phi, n_phi);
183 vec1_n1 = RealVectorX::Zero(1),
184 vec2_n2 = RealVectorX::Zero(n_phi),
185 flux = RealVectorX::Zero(1),
186 vel = RealVectorX::Zero(dim);
190 std::vector<MAST::FEMOperatorMatrix> dBmat(dim);
194 for (
unsigned int qp=0; qp<JxW.size(); qp++) {
200 _tau(*fe, qp, Bmat, dBmat, vel, tau);
205 for (
unsigned int j=0; j<dim; j++) {
207 dBmat[j].left_multiply(mat1_n1n2, eye);
208 mat2_n1n2 += mat1_n1n2 * vel(j);
214 f += JxW[qp] * vec2_n2;
215 f += JxW[qp] * mat2_n1n2.transpose() * tau * vec1_n1;
217 if (request_jacobian) {
220 jac_xdot += JxW[qp] * mat_n2n2;
222 mat_n2n1 = mat2_n1n2.transpose()*tau;
224 jac_xdot += JxW[qp] * mat_n2n2;
228 return request_jacobian;
239 std::multimap<libMesh::boundary_id_type, MAST::BoundaryConditionBase*>& bc) {
241 libmesh_assert(
false);
254 std::multimap<libMesh::subdomain_id_type, MAST::BoundaryConditionBase*>& bc) {
256 libmesh_assert(
false);
267 std::multimap<libMesh::boundary_id_type, MAST::BoundaryConditionBase*>& bc) {
269 libmesh_assert(
false);
281 std::multimap<libMesh::subdomain_id_type, MAST::BoundaryConditionBase*>& bc) {
283 libmesh_assert(
false);
296 libmesh_assert(
false);
297 return request_jacobian;
308 libmesh_assert(
false);
309 return request_jacobian;
317 std::unique_ptr<MAST::FEBase> fe(
_elem.
init_fe(
true,
false,
320 const std::vector<Real>& JxW = fe->get_JxW();
325 phi = RealVectorX::Zero(1);
330 std::vector<MAST::FEMOperatorMatrix> dBmat(dim);
334 for (
unsigned int qp=0; qp<JxW.size(); qp++) {
339 if (phi(0) > 0.) vol += JxW[qp];
349 std::unique_ptr<MAST::FEBase> fe(
_elem.
init_fe(
true,
false,
352 const std::vector<Real>& JxW = fe->get_JxW();
357 phi = RealVectorX::Zero(1);
364 std::vector<MAST::FEMOperatorMatrix> dBmat(dim);
368 for (
unsigned int qp=0; qp<JxW.size(); qp++) {
374 heav += .5 * (1. + 2./pi * atan(phi(0)/delta)) * JxW[qp];
385 std::unique_ptr<MAST::FEBase> fe(
_elem.
init_fe(
true,
false,
388 const std::vector<Real>& JxW = fe->get_JxW();
393 phi = RealVectorX::Zero(1),
394 dphidp = RealVectorX::Zero(1);
401 std::vector<MAST::FEMOperatorMatrix> dBmat(dim);
405 for (
unsigned int qp=0; qp<JxW.size(); qp++) {
412 heav += 1./pi/delta/(1.+pow(phi(0)/delta, 2)) * dphidp(0) * JxW[qp];
423 std::unique_ptr<MAST::FEBase> fe(
_elem.
init_fe(
true,
false,
426 const std::vector<Real>& JxW = fe->get_JxW();
431 phi = RealVectorX::Zero(1);
437 std::vector<MAST::FEMOperatorMatrix> dBmat(dim);
441 for (
unsigned int qp=0; qp<JxW.size(); qp++) {
446 per += 1./pi/d/(1.+pow(phi(0)/d, 2)) * JxW[qp];
456 std::unique_ptr<MAST::FEBase> fe(
_elem.
init_fe(
true,
false,
459 const std::vector<Real>& JxW = fe->get_JxW();
464 phi = RealVectorX::Zero(1),
465 dphidp = RealVectorX::Zero(1);
471 std::vector<MAST::FEMOperatorMatrix> dBmat(dim);
475 for (
unsigned int qp=0; qp<JxW.size(); qp++) {
481 dper_dp -= 2.*phi(0)/pi/pow(d,3)/pow(1.+pow(phi(0)/d, 2),2) * dphidp(0) * JxW[qp];
495 const std::vector<Real>& JxW = fe->get_JxW();
500 phi = RealVectorX::Zero(1),
501 gradphi = RealVectorX::Zero(dim),
502 dphidp = RealVectorX::Zero(1),
503 vel = RealVectorX::Zero(dim);
509 std::vector<MAST::FEMOperatorMatrix> dBmat(dim);
513 for (
unsigned int qp=0; qp<JxW.size(); qp++) {
519 for (
unsigned int i=0; i<dim; i++) {
520 dBmat[i].right_multiply(phi,
_sol);
534 vn = dphidp(0) / gradphi.norm();
538 dvoldp += vn * JxW[qp];
548 const libMesh::Point& p,
551 const std::vector<MAST::FEMOperatorMatrix>& dBmat,
559 v = RealVectorX::Zero(1),
560 grad_phi = RealVectorX::Zero(dim);
563 for (
unsigned int i=0; i<dim; i++) {
565 dBmat[i].right_multiply(v,
_sol);
575 (*_phi_vel)(p, t, Vn);
576 vel = grad_phi * (-Vn/grad_phi.norm());
588 grad_phi_norm = grad_phi.norm();
590 source = ref_phi/pow(pow(ref_phi,2)+ tol*pow(grad_phi_norm,2), 0.5);
592 if (grad_phi_norm > tol)
593 vel = grad_phi * source/grad_phi.norm();
604 const std::vector<MAST::FEMOperatorMatrix>& dBmat,
608 const std::vector<std::vector<libMesh::RealVectorValue> >& dphi = fe.
get_dphi();
611 phi = RealVectorX::Zero(n_phi);
623 for (
unsigned int i_nd=0; i_nd<n_phi; i_nd++ ) {
625 nvec = dphi[i_nd][qp];
627 for (
unsigned int i_dim=0; i_dim<
_elem.
dim(); i_dim++)
628 val2 += nvec(i_dim) * vel(i_dim);
630 val1 += std::fabs(val2);
644 const unsigned int qp,
645 const std::vector<MAST::FEMOperatorMatrix>& dB_mat,
653 dphi = RealVectorX::Zero(dim),
654 vec1 = RealVectorX::Zero(1),
655 dflux = RealVectorX::Zero(1);
658 dxi_dX = RealMatrixX::Zero(dim, dim);
663 for (
unsigned int i=0; i<dim; i++) {
665 dB_mat[i].vector_mult(vec1,
_sol);
666 dflux(0) += vel(i) * vec1(0);
673 for (
unsigned int i=0; i<dim; i++) {
677 for (
unsigned int j=0; j<dim; j++)
678 vec1(0) += dxi_dX(i, j) * dphi(j);
681 val1 += pow(vec1.norm(), 2);
684 dc = 0.5*dflux.norm()/pow(val1, 0.5);
692 const unsigned int qp,
703 for (
unsigned int i_dim=0; i_dim<dim; i_dim++)
704 for (
unsigned int j_dim=0; j_dim<dim; j_dim++)
757 dxi_dX(i_dim, j_dim) = val;
768 std::vector<MAST::FEMOperatorMatrix>& dBmat) {
770 const std::vector<std::vector<Real> >& phi_fe = fe.
get_phi();
771 const std::vector<std::vector<libMesh::RealVectorValue> >& dphi = fe.
get_dphi();
773 const unsigned int n_phi = (
unsigned int)phi_fe.size();
776 phi = RealVectorX::Zero(n_phi);
780 for (
unsigned int i_nd=0; i_nd<n_phi; i_nd++ )
781 phi(i_nd) = phi_fe[i_nd][qp];
786 for (
unsigned int i_dim=0; i_dim<
_elem.
dim(); i_dim++) {
789 for (
unsigned int i_nd=0; i_nd<n_phi; i_nd++ )
790 phi(i_nd) = dphi[i_nd][qp](i_dim);
791 dBmat[i_dim].reinit(1, phi);
virtual bool internal_residual(bool request_jacobian, RealVectorX &f, RealMatrixX &jac)
internal force contribution to system residual
void _calculate_dxidX(const MAST::FEBase &fe, const unsigned int qp, RealMatrixX &dxi_dX)
MAST::NonlinearSystem & system()
virtual const std::vector< Real > & get_dxidy() const
virtual const std::vector< Real > & get_dzetadz() const
const MAST::GeomElem & _elem
geometric element for which the computations are performed
virtual const std::vector< Real > & get_dxidz() const
const MAST::FieldFunction< Real > * _phi_vel
element property
void reinit(unsigned int n_interpolated_vars, unsigned int n_discrete_vars, unsigned int n_discrete_dofs_per_var)
this initializes the operator for number of rows and variables, assuming that all variables has the s...
bool volume_external_residual(bool request_jacobian, RealVectorX &f, RealMatrixX &jac, std::multimap< libMesh::subdomain_id_type, MAST::BoundaryConditionBase *> &bc)
volume external force contribution to system residual
const RealVectorX & sol(bool if_sens=false) const
virtual const std::vector< Real > & get_detadz() const
LevelSetElementBase(MAST::SystemInitialization &sys, const MAST::GeomElem &elem)
Constructor.
virtual const std::vector< Real > & get_dzetady() const
virtual bool velocity_residual(bool request_jacobian, RealVectorX &f, RealMatrixX &jac_xdot, RealMatrixX &jac)
inertial force contribution to system residual
void _tau(const MAST::FEBase &fe, unsigned int qp, const MAST::FEMOperatorMatrix &Bmat, const std::vector< MAST::FEMOperatorMatrix > &dBmat, const RealVectorX &vel, RealMatrixX &tau)
initializes the tau operator
RealVectorX _vel
local velocity
virtual unsigned int n_shape_functions() const
RealVectorX _ref_sol
reference solution for reinitialization of the level set
Real volume_boundary_velocity_on_side(unsigned int s)
MAST::SystemInitialization & _system
SystemInitialization object associated with this element.
virtual const std::vector< std::vector< libMesh::RealVectorValue > > & get_dphi() const
virtual const std::vector< std::vector< Real > > & get_phi() const
void set_reference_solution_for_initialization(const RealVectorX &sol)
For reinitialization to , the solution before initialization is used to calculate the source and velo...
virtual std::unique_ptr< MAST::FEBase > init_fe(bool init_grads, bool init_second_order_derivative, int extra_quadrature_order=0) const
initializes the finite element shape function and quadrature object with the order of quadrature rule...
bool volume_external_residual_sensitivity(bool request_jacobian, RealVectorX &f, RealMatrixX &jac, std::multimap< libMesh::subdomain_id_type, MAST::BoundaryConditionBase *> &bc)
sensitivity of the volume external force contribution to system residual
virtual ~LevelSetElementBase()
Matrix< Real, Dynamic, Dynamic > RealMatrixX
void right_multiply(T &r, const T &m) const
[R] = [this] * [M]
virtual bool velocity_residual_sensitivity(bool request_jacobian, RealVectorX &f, RealMatrixX &jac)
sensitivity of the damping force contribution to system residual
void vector_mult_transpose(T &res, const T &v) const
res = v^T * [this]
Matrix< Real, Dynamic, 1 > RealVectorX
RealVectorX _sol_sens
local solution sensitivity
void right_multiply_transpose(T &r, const T &m) const
[R] = [this]^T * [M]
RealVectorX _sol
local solution
Real perimeter(Real delta=0.1)
Approximates the integral of the Dirac delta function to approximate the perimeter.
This class acts as a wrapper around libMesh::Elem for the purpose of providing a uniform interface fo...
virtual const std::vector< Real > & get_dzetadx() const
Real homogenized_volume_fraction(Real delta=0.1)
Approximates the volume fraction of the element based on integration of approximated Heaviside functi...
bool side_external_residual(bool request_jacobian, RealVectorX &f, RealMatrixX &jac, std::multimap< libMesh::boundary_id_type, MAST::BoundaryConditionBase *> &bc)
side external force contribution to system residual
virtual std::unique_ptr< MAST::FEBase > init_side_fe(unsigned int s, bool init_grads, bool init_second_order_derivative, int extra_quadrature_order=0) const
initializes the finite element shape function and quadrature object for the side with the order of qu...
bool _if_propagation
this can operate in one of two modes: propagation of level set given Vn, or reinitialization of level...
void _initialize_fem_operators(const unsigned int qp, const MAST::FEBase &fe, MAST::FEMOperatorMatrix &Bmat, std::vector< MAST::FEMOperatorMatrix > &dBmat)
When mass = false, initializes the FEM operator matrix to the shape functions as ...
virtual const std::vector< Real > & get_detady() const
void left_multiply(T &r, const T &m) const
[R] = [M] * [this]
virtual const std::vector< Real > & get_detadx() const
Real homogenized_volume_fraction_sensitivity(Real delta=0.1)
Sensitivity of the homogenized volume fraction for the specified level set value and its sensitivity...
const Real & _time
time for which system is being assembled
bool side_external_residual_sensitivity(bool request_jacobian, RealVectorX &f, RealMatrixX &jac, std::multimap< libMesh::boundary_id_type, MAST::BoundaryConditionBase *> &bc)
sensitivity of the side external force contribution to system residual
virtual const std::vector< Real > & get_dxidx() const
void _velocity_and_source(const unsigned int qp, const libMesh::Point &p, const Real t, const MAST::FEMOperatorMatrix &Bmat, const std::vector< MAST::FEMOperatorMatrix > &dBmat, RealVectorX &vel, Real &source)
calculates the velocity at the quadrature point
Real perimeter_sensitivity(Real delta=0.1)
computes the partial derivative of the integral of the Dirac delta function using the solution and se...
virtual bool internal_residual_sensitivity(bool request_jacobian, RealVectorX &f, RealMatrixX &jac)
sensitivity of the internal force contribution to system residual
void _dc_operator(const MAST::FEBase &fe, const unsigned int qp, const std::vector< MAST::FEMOperatorMatrix > &dB_mat, const RealVectorX &vel, Real &dc)
This is the base class for elements that implement calculation of finite element quantities over the ...