31 return TTetrahedron::numberInstance++;
90 default:
THROW( ExcAssertMsg() << EI_Message(
"Unknown number of the triangle of the tetrahedron.") );
108 default:
THROW( ExcAssertMsg() << EI_Message(
"Unknown number of the triangle of the tetrahedron.") );
122 default:
THROW( ExcAssertMsg() << EI_Message(
"Unknown number of the point of the tetrahedron.") );
127 double min =
X1.
Get(i);
129 if (
X2.
Get(i) < min) {
132 if (
X3.
Get(i) < min) {
135 if (
X4.
Get(i) < min) {
143 double max =
X1.
Get(i);
145 if (
X2.
Get(i) > max) {
148 if (
X3.
Get(i) > max) {
151 if (
X4.
Get(i) > max) {
165 a[ 0 ][ 0 ] =
X2.
X() -
X1.
X();
166 a[ 0 ][ 1 ] =
X2.
Y() -
X1.
Y();
167 a[ 0 ][ 2 ] =
X2.
Z() -
X1.
Z();
168 a[ 1 ][ 0 ] =
X3.
X() -
X1.
X();
169 a[ 1 ][ 1 ] =
X3.
Y() -
X1.
Y();
170 a[ 1 ][ 2 ] =
X3.
Z() -
X1.
Z();
171 a[ 2 ][ 0 ] =
X4.
X() -
X1.
X();
172 a[ 2 ][ 1 ] =
X4.
Y() -
X1.
Y();
173 a[ 2 ][ 2 ] =
X4.
Z() -
X1.
Z();
200 TVector N, U1(
X1,
X2), U2(
X1,
X3), U3(
X1,
X4), U4(
X2,
X3), U5(
X2,
X4), U6(
X2,
X1);
204 if (
Dot(N, U3) *
Dot(N, Up1) < 0) {
209 if (
Dot(N, U2) *
Dot(N, Up1) < 0) {
214 if (
Dot(N, U1) *
Dot(N, Up1) < 0) {
219 if (
Dot(N, U6) *
Dot(N, Up2) < 0) {
void SetPoints(const TPoint &P1, const TPoint &P2, const TPoint &P3, const TPoint &P4)
const TAbscissa & GetAbscissa(int) const
bool IsInner(const TPoint &) const
static int numberInstance
void SetPoints(const TPoint &, const TPoint &)
double Determinant3(double[3][3])
double Dot(const TVector &, const TVector &)
const TPoint & GetPoint(int) const
const TTriangle & GetTriangle(int) const
void SetPoints(const TPoint &, const TPoint &, const TPoint &)
TVector Cross(const TVector &, const TVector &)
#define THROW(whole_exception_expr)
Wrapper for throw. Saves the throwing point.