The aim of this tutorial is to demonstrate the solution of the time-harmonic equations of linear elasticity in cylindrical polar coordinates, using a Fourier decomposition of the solution in the azimuthal direction. These equations are useful to describe forced, time-harmonic, non-axisymmetric oscillations of axisymmetric elastic bodies.
Consider a three-dimensional, axisymmetric body (of density  , Young's modulus
, Young's modulus  , and Poisson's ratio
, and Poisson's ratio  ), occupying the region
), occupying the region  whose boundary is
 whose boundary is  . Assuming that the body performs time-harmonic oscillations of frequency of
. Assuming that the body performs time-harmonic oscillations of frequency of  , we use cylindrical coordinates
, we use cylindrical coordinates  . The equations of time-harmonic linear elasticity can then be written as
. The equations of time-harmonic linear elasticity can then be written as 
![\[ \mbox{\boldmath$ \nabla^*\cdot\tau^*$}+\rho \mbox{\boldmath$ F^*$}=-\rho\omega^2\mbox{\boldmath$ u^*$}, \]](form_7.png) 
 where  , and the stresses, body force and displacements are given by
, and the stresses, body force and displacements are given by  ,
,  and
 and  respectively. Note that here and henceforth, the superscript asterisk notation is used to distinguish dimensional quantities from their non-dimensional counterparts where required. (The coordinate
 respectively. Note that here and henceforth, the superscript asterisk notation is used to distinguish dimensional quantities from their non-dimensional counterparts where required. (The coordinate  is by definition dimensionless, and so we do not use an asterisk when referencing this parameter).
 is by definition dimensionless, and so we do not use an asterisk when referencing this parameter).
The body is subject to imposed time-harmonic displacements  along
 along  , and subject to an imposed traction
, and subject to an imposed traction  along
 along  where
 where  so that
 so that 
![\[ \mbox{\boldmath$ u^*$}=\mbox{\boldmath$ \hat{u}^*$}\,\,\textrm{on $ \partial D_d $ },\quad \mbox{\boldmath$ \tau^*$} \cdot {\bf n}=\mbox{\boldmath$ \hat{\tau}^*$}\,\,\textrm{on $ \partial D_n $ } \]](form_18.png) 
 where  is the outer unit normal on the boundary.
 is the outer unit normal on the boundary.
The stresses and displacements are related by the constitutive equations
![\[ \mbox{\boldmath$ \tau^*$}=\frac{E}{1+\nu}\left( \frac{\nu}{1-2\nu}(\mbox{\boldmath$\nabla^*\cdot u^*$})\textbf{I}+ \frac{1}{2}(\mbox{\boldmath$ \nabla^* u^*$}+\mbox{\boldmath$ \nabla^* u^*$}^{{\rm T}})\right), \]](form_20.png) 
 where  represents the transpose of
 represents the transpose of  . Note that in cylindrical coordinates, the second-order tensor
. Note that in cylindrical coordinates, the second-order tensor  is given by
 is given by 
![\[ \mbox{\boldmath$ \nabla^* u^*$}= { \left(\begin{array}{ccc} \frac{\partial u^*_r}{\partial r^*}& \frac{1}{r^*}\frac{\partial u^*_r}{\partial\theta}-\frac{u^*_\theta}{r^*}& \frac{\partial u^*_r}{\partial z^*}\\ \frac{\partial u^*_\theta}{\partial r^*}& \frac{1}{r^*}\frac{\partial u^*_\theta}{\partial\theta}+\frac{u^*_r}{r^*}& \frac{\partial u^*_\theta}{\partial z^*}\\ \frac{\partial u^*_z}{\partial r^*}& \frac{1}{r^*}\frac{\partial u^*_z}{\partial\theta}& \frac{\partial u^*_z}{\partial z^*}\end{array}\right) } \]](form_23.png) 
 and  is equal to the trace of this matrix.
 is equal to the trace of this matrix.
We non-dimensionalise the equations, using a problem specific reference length,  , and a timescale
, and a timescale  , and use Young's modulus to non-dimensionalise the body force and the stress tensor:
, and use Young's modulus to non-dimensionalise the body force and the stress tensor: 
![\[ \mbox{\boldmath$ \tau^*$} = E \, \mbox{\boldmath$ \tau$}, \qquad r^* = {\cal L}\, r, \qquad z^* = {\cal L}\, z \]](form_27.png) 
![\[ \mbox{\boldmath$ u^*$} = {\cal L}\, \mbox{\boldmath$ u$}, \qquad \mbox{\boldmath$ F^*$} = \frac{E}{\rho \cal L} \, \mbox{\boldmath$ F$}, \qquad t^* = {\cal T}\, t. \]](form_28.png) 
The non-dimensional form of the linear elasticity equations is then given by
![\[ \mbox{\boldmath$ \nabla\cdot\tau$}+\mbox{\boldmath$ F$}=-\Omega^2\mbox{\boldmath$ u$}, \ \ \ \ \ \ \ \ \ \ (1) \]](form_29.png) 
 where  ,
, 
![\[ \mbox{\boldmath$ \tau $}=\frac{1}{1+\nu}\left( \frac{\nu}{1-2\nu}(\mbox{\boldmath$\nabla\cdot u$})\textbf{I}+ \frac{1}{2}(\mbox{\boldmath$ \nabla u$}+\mbox{\boldmath$ \nabla u$}^{{\rm T}})\right), \ \ \ \ \ \ \ \ \ \ (2) \]](form_31.png) 
and the non-dimensional parameter
![\[ \Omega = {\cal L}\omega \sqrt{\frac{\rho}{E}} \]](form_32.png) 
 is the ratio of the elastic body's intrinsic timescale,  , to the problem-specific timescale,
, to the problem-specific timescale,  , that we used to non-dimensionalise time. The boundary conditions are
, that we used to non-dimensionalise time. The boundary conditions are 
![\[ \mbox{\boldmath$ u$}=\mbox{\boldmath$ \hat{u}$}\,\,\textrm{on $ \partial D_d $},\quad \mbox{\boldmath$ \tau$}\cdot {\bf n} =\mbox{\boldmath$ \hat{\tau}$}\,\,\textrm{on $ \partial D_n $}.\]](form_34.png) 
Given the assumed axisymmetry of the body we expand all quantities in a Fourier series in the azimuthal coordinate  by writing,
 by writing, 
![\[ \mbox{\boldmath$ u$}(r,\theta ,z)=\sum_{n=-\infty}^{\infty}\mbox{\boldmath$ u$}^{(n)}(r,z){\rm e}^{{\rm i} n\theta},\quad \mbox{\boldmath$ F$} (r,\theta ,z)=\sum_{n=-\infty}^{\infty}\mbox{\boldmath$ F$}^{(n)}(r,z){\rm e}^{{\rm i} n\theta},\quad \mbox{\boldmath$ \tau$} (r,\theta ,z)=\sum_{n=-\infty}^{\infty}\mbox{\boldmath$ \tau$}^{(n)}(r,z){\rm e}^{{\rm i} n\theta} ,\]](form_35.png) 
 This decomposition allows us to remove the  -dependence from the equations by writing
-dependence from the equations by writing  , where
, where  represents any physical parameter in the problem. Furthermore, since the governing equations are linear, we can solve for each Fourier component separately and simply specify the Fourier wavenumber
 represents any physical parameter in the problem. Furthermore, since the governing equations are linear, we can solve for each Fourier component separately and simply specify the Fourier wavenumber  as a parameter.
 as a parameter.
Within oomph-lib, the non-dimensional version of the two-dimensional Fourier-decomposed equations (1) with the constitutive equations (2) are implemented in the TimeHarmonicFourierDecomposedLinearElasticityEquations equations class. Following our usual approach, discussed in the (Not-So-)Quick Guide, this equation class is then combined with a geometric finite element to form a fully-functional finite element. For instance, the combination of the TimeHarmonicFourierDecomposedLinearElasticityEquations class with the geometric finite element QElement<2,3> yields a nine-node quadrilateral element. As usual, the mapping between local and global (Eulerian) coordinates within an element is given by, 
![\[ x_i = \sum_{j=1}^{N^{(E)}} X^{(E)}_{ij} \, \psi_j, \qquad i=1,2, \]](form_39.png) 
 where the coordinates are enumerated as  .
.  is the number of nodes in the element,
 is the number of nodes in the element,  is the
 is the  -th global (Eulerian) coordinate (enumerated as above) of the
-th global (Eulerian) coordinate (enumerated as above) of the  -th
-th Node in the element, and the  are the element's shape functions, defined in the geometric finite element.
 are the element's shape functions, defined in the geometric finite element.
We allow for the presence of damping by allowing the constitutive parameters and forcing frequency to be complex-valued. The three components of the displacement field therefore have real and imaginary parts and we store the six real-valued nodal unknowns in the order  and use the shape functions to interpolate the displacements as
 and use the shape functions to interpolate the displacements as 
![\[ u_i^{(n)} = \sum_{j=1}^{N^{(E)}} U^{(E)}_{ij} \, \psi_j, \qquad i=1,...6, \]](form_47.png) 
 where  is the
 is the  -th displacement component (enumerated as indicated above) at the
-th displacement component (enumerated as indicated above) at the  -th
-th Node in the element.
The governing equations are fairly complicated and it is difficult to come up with non-trivial analytical solutions that could be used to validate the implementation. We therefore construct an analytical solution by postulating a displacement field and providing a body force that makes this a solution of the equations.
Specifically we consider the time-harmonic non-axisymmetric deformation of an annular elastic body that occupies the region  .
.
The displacement field
![\[ \mbox{\boldmath$u$}^{(n)}= \left(\begin{array}{c}u_r^{(n)}\\u_\theta^{(n)}\\u_z^{(n)}\end{array}\right)= \left(\begin{array}{c}r^3\cos\, z\\r^3z^3\\r^3\sin\,z\end{array}\right) \ \ \ \ \ \ \ \ \ \ (3) \]](form_50.png) 
is an exact solution of the governing equations if the body is subject to a body force
![\[ \mbox{\boldmath$ F$}^{(n)}=\left(\begin{array}{c} -r(2{\rm i} nz^3\lambda+\cos\, z\{(8+3r)\lambda-(n^2-16+r(r-3))\mu+r^2 \Lambda^2\})\\ -r\{8z^3\mu-n^2z^3(\lambda+2\mu)+r^2(z^3\Lambda^2+6\mu z)+{\rm i} n\cos\, z((4+r)\lambda+(6+r)\mu)\}\\ r\sin\, z\{(n^2-9)\mu+4r(\lambda+\mu)+r^2(\lambda+2\mu-\Lambda^2)\}-3{\rm i} nr^2z^2(\lambda+\mu)\end{array}\right), \ \ \ \ \ \ \ \ \ \ (4) \]](form_51.png) 
 where  and
 and  are the non-dimensional Lamé parameters (non-dimensionalised on
 are the non-dimensional Lamé parameters (non-dimensionalised on  ). The body is subject to a non-zero traction on all four boundaries; for example, on the inner boundary (where
). The body is subject to a non-zero traction on all four boundaries; for example, on the inner boundary (where  ) the traction is
) the traction is 
![\[ \mbox{\boldmath$ \hat{\tau}$}^{(n)}_3= \mbox{\boldmath$ \tau$}^{(n)}(r_{\rm min},z)\cdot (-{\bf e}_r) = \left(\begin{array}{c} -6r_{\rm min}^2\mu\cos\, z-\lambda({\rm i} nr_{\rm min}^2z^3+r_{\rm min}^2(4+r_{\rm min})\cos\, z) \\ -\mu r_{\rm min}^2(2z^3+{\rm i} n\cos\, z) \\ -\mu r_{\rm min}^2\sin\, z(3-r_{\rm min}) \end{array}\right). \ \ \ \ \ \ \ \ \ \ (5) \]](form_55.png) 
We choose to set this traction as a boundary condition, whilst pinning the displacements on the remaining boundaries where we impose a prescribed displacement according to (3).
The figures below show plots of  and
 and  for a Fourier wavenumber of
 for a Fourier wavenumber of  and geometric parameters
 and geometric parameters  . We set
. We set  , corresponding to an exponentially growing time-periodic forcing;
, corresponding to an exponentially growing time-periodic forcing;  , corresponding to a slightly dissipative material (see Comments ); and
, corresponding to a slightly dissipative material (see Comments ); and  . The imaginary part of the solution is small (though not identically equal to zero) but it converges to zero under mesh refinement; see Exercises .
. The imaginary part of the solution is small (though not identically equal to zero) but it converges to zero under mesh refinement; see Exercises .
 
 
 
As usual, we define all non-dimensional parameters in a namespace. In this namespace, we also define the (Fourier-decomposed) body force, the traction to be applied on boundary 3, and the exact solution. Note that, consistent with the enumeration of the unknowns, discussed above, the order of the components in the functions that specify the body force and the surface traction is  .
.
We start by setting the number of elements in each of the two coordinate directions before creating a DocInfo object to store the output directory.
 We build the problem using two-dimensional QTimeHarmonicFourierDecomposedLinearElasticityElements, solve using the Problem::newton_solve() function, and document the results.
The Problem class is very simple. As in other problems with Neumann boundary conditions, we provide separate meshes for the "bulk" elements and the face elements that apply the traction boundary conditions. The latter are attached to the relevant faces of the bulk elements by the function assign_traction_elements().
We begin by building the meshes and pin the displacements on the appropriate boundaries. Recall that the order of the six real unknowns stored at the nodes is 
Next we loop over the bulk mesh elements and assign the constitutive parameters, the body force, the Fourier wavenumber and the non-dimensional frequency to each element.
We then loop over the traction elements and specify the applied traction.
 The two sub-meshes are now added to the problem and a global mesh is constructed before the equation numbering scheme is set up, using the function assign_eqn_numbers().
We create the face elements that apply the traction to the boundary  .
.
As expected, this member function documents the computed solution.
TimeHarmonicFourierDecomposedLinearElasticityEquations::youngs_modulus_pt(). The explanation for this is that this function specifies the ratio of the material's actual Young's modulus to the Young's modulus used in the non-dimensionalisation of the equations. The capability to specify such ratios is important in problems where the elastic body is made of multiple materials with different constitutive properties. If the body is made of a single, homogeneous material, the specification of the non-dimensional Young's modulus is not required – it defaults to 1.0. In the example considered above, the specification of the non-dimensional Young's modulus as  
 A pdf version of this document is available.