momentOfInertia Class Reference

Calculates the inertia tensor and principal axes and moments of a polyhedra/cells/triSurfaces. Inertia can either be of the solid body or of a thin shell. More...

Static Public Member Functions

static void massPropertiesSolid (const pointField &pts, const triFaceList &triFaces, scalar density, scalar &mass, vector &cM, tensor &J)
 
static void massPropertiesShell (const pointField &pts, const triFaceList &triFaces, scalar density, scalar &mass, vector &cM, tensor &J)
 
static void massPropertiesSolid (const triSurface &surf, scalar density, scalar &mass, vector &cM, tensor &J)
 
static void massPropertiesShell (const triSurface &surf, scalar density, scalar &mass, vector &cM, tensor &J)
 
static tensor applyParallelAxisTheorem (scalar mass, const vector &cM, const tensor &J, const vector &refPt)
 
static tmp< tensorFieldmeshInertia (const polyMesh &mesh)
 
static tensor meshInertia (const polyMesh &mesh, label celli)
 

Detailed Description

Calculates the inertia tensor and principal axes and moments of a polyhedra/cells/triSurfaces. Inertia can either be of the solid body or of a thin shell.

Source files

Definition at line 52 of file momentOfInertia.H.

Member Function Documentation

◆ massPropertiesSolid() [1/2]

void massPropertiesSolid ( const pointField pts,
const triFaceList triFaces,
scalar  density,
scalar &  mass,
vector cM,
tensor J 
)
static

◆ massPropertiesShell() [1/2]

void massPropertiesShell ( const pointField pts,
const triFaceList triFaces,
scalar  density,
scalar &  mass,
vector cM,
tensor J 
)
static

Definition at line 189 of file momentOfInertia.C.

References triangle< Point, PointRef >::centre(), forAll, triangle< Point, PointRef >::mag(), momentOfInertia::massPropertiesSolid(), and Foam::Zero.

Referenced by momentOfInertia::massPropertiesSolid().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ massPropertiesSolid() [2/2]

void massPropertiesSolid ( const triSurface surf,
scalar  density,
scalar &  mass,
vector cM,
tensor J 
)
static

Definition at line 245 of file momentOfInertia.C.

References forAll, momentOfInertia::massPropertiesShell(), PrimitivePatch< FaceList, PointField >::points(), List< T >::size(), and triFace().

Here is the call graph for this function:

◆ massPropertiesShell() [2/2]

void massPropertiesShell ( const triSurface surf,
scalar  density,
scalar &  mass,
vector cM,
tensor J 
)
static

Definition at line 265 of file momentOfInertia.C.

References momentOfInertia::applyParallelAxisTheorem(), forAll, PrimitivePatch< FaceList, PointField >::points(), List< T >::size(), and triFace().

Here is the call graph for this function:

◆ applyParallelAxisTheorem()

Foam::tensor applyParallelAxisTheorem ( scalar  mass,
const vector cM,
const tensor J,
const vector refPt 
)
static

Definition at line 285 of file momentOfInertia.C.

References Foam::I, and momentOfInertia::meshInertia().

Referenced by momentOfInertia::massPropertiesShell().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ meshInertia() [1/2]

Foam::tmp< Foam::tensorField > meshInertia ( const polyMesh mesh)
static

Definition at line 303 of file momentOfInertia.C.

References forAll, primitiveMesh::nCells(), tmp< T >::ref(), and tf.

Referenced by momentOfInertia::applyParallelAxisTheorem().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ meshInertia() [2/2]

Foam::tensor meshInertia ( const polyMesh mesh,
label  celli 
)
static

Definition at line 321 of file momentOfInertia.C.

References forAll, polyMesh::points(), List< T >::size(), and Foam::Zero.

Here is the call graph for this function:

The documentation for this class was generated from the following files: