jacobian_det_triangle_first Module Function

pure elemental module function jacobian_det_triangle_first(self, r) result(jacobian_det)

Arguments

Type IntentOptional Attributes Name
class(type_triangle_first), intent(in) :: self
type(type_dp_vector_3d), intent(in) :: r

Return Value real(kind=real64)


Calls

proc~~jacobian_det_triangle_first~~CallsGraph proc~jacobian_det_triangle_first jacobian_det_triangle_first interface~jacobian_triangle_first type_triangle_first%jacobian_triangle_first proc~jacobian_det_triangle_first->interface~jacobian_triangle_first proc~jacobian_triangle_first jacobian_triangle_first interface~jacobian_triangle_first->proc~jacobian_triangle_first interface~dpsi_triangle_first type_triangle_first%dpsi_triangle_first proc~jacobian_triangle_first->interface~dpsi_triangle_first proc~get_coordinate abst_mesh%get_coordinate proc~jacobian_triangle_first->proc~get_coordinate proc~get_num_nodes~3 abst_mesh%get_num_nodes proc~jacobian_triangle_first->proc~get_num_nodes~3 proc~dpsi_triangle_first dpsi_triangle_first interface~dpsi_triangle_first->proc~dpsi_triangle_first

Called by

proc~~jacobian_det_triangle_first~~CalledByGraph proc~jacobian_det_triangle_first jacobian_det_triangle_first interface~jacobian_det_triangle_first type_triangle_first%jacobian_det_triangle_first interface~jacobian_det_triangle_first->proc~jacobian_det_triangle_first proc~get_area_triangle_first get_area_triangle_first proc~get_area_triangle_first->interface~jacobian_det_triangle_first proc~is_in_triangle_first is_in_triangle_first proc~is_in_triangle_first->interface~jacobian_det_triangle_first interface~get_area_triangle_first type_triangle_first%get_area_triangle_first interface~get_area_triangle_first->proc~get_area_triangle_first interface~is_in_triangle_first type_triangle_first%is_in_triangle_first interface~is_in_triangle_first->proc~is_in_triangle_first

Source Code

    pure elemental module function jacobian_det_triangle_first(self, r) result(jacobian_det)
        implicit none
        class(type_triangle_first), intent(in) :: self
        type(type_dp_vector_3d), intent(in) :: r
        real(real64) :: jacobian_det

        real(real64) :: dx_xi, dx_eta
        real(real64) :: dy_xi, dy_eta

        dx_xi  = self%jacobian(1, 1, r) !&
        dx_eta = self%jacobian(1, 2, r) !&
        dy_xi  = self%jacobian(2, 1, r) !&
        dy_eta = self%jacobian(2, 2, r) !&

        jacobian_det = dx_xi * dy_eta - dx_eta * dy_xi
    end function jacobian_det_triangle_first