digital-brain/content/article/mcinroy02_model_desig_flexur_joint_stewar.md

12 KiB
Raw Blame History

+++ title = "Modeling and design of flexure jointed stewart platforms for control purposes" author = ["Dehaeze Thomas"] draft = false +++

Tags :

Reference
(McInroy 2002)
Author(s)
McInroy, J.
Year
2002

This short paper is very similar to (McInroy 1999).

This paper develops guidelines for designing the flexure joints to facilitate closed-loop control.

Introduction

When pursuing micro-meter/micro-radian scale motion, two new phenomena become important:

  1. joint friction and backlash can cause extremely nonlinear micro-dynamics
  2. base and/or payload vibrations become significant contributor to the motion

If the spherical flexure is not properly matched to the particular application, it is shown that the complexity of the dynamics can greatly increase, thus limiting the control performance.

Flexure Jointed Hexapod Dynamics

{{< figure src="/ox-hugo/mcinroy02_leg_model.png" caption="<span class="figure-number">Figure 1: The dynamics of the ith strut. A parallel spring, damper, and actautor drives the moving mass of the strut and a payload" >}}

The strut can be modeled as consisting of a parallel arrangement of an actuator force, a spring and some damping driving a mass (Figure 1).

Thus, the strut does not output force directly, but rather outputs a mechanically filtered force.

The model of the strut are shown in Figure 1 with:

  • \(m_{s_i}\) moving strut mass
  • \(k_i\) spring constant
  • \(b_i\) damping constant
  • \(f_{m_i}\) force applied by the actuator
  • \(f_{p_i}\) force exerted by the payload
  • \(p_i\) three dimensional position of the top
  • \(q_i\) three dimensional position of the bottom
  • \(l_i\) strut length
  • \(l_{r_i}\) relaxed strut length

In general, the strut mass and spherical flexure stiffness will cause payload forces that are not perfectly aligned with the strut.

Applying Newton's second law and stacking the equations into a vector form gives:

\begin{equation} f_p = f_m - M_s \ddot{l} - B \dot{l} - K(l - l_r) - M_s \ddot{q}_u - M_s g_u + M_s v_2 \label{eq:strut_dynamics_vec} \end{equation}

where:

  • \(\ddot{q}_u = \left[ \hat{u}_1^T \ddot{q}_1 \ \dots \ \hat{u}_6^T \ddot{q}_6 \right]^T\) notes the vector of base accelerations in the strut directions
  • \(g_u\) denotes the vector of gravity accelerations in the strut directions
  • \(Ms = \text{diag}([m_1\ \dots \ m_6])\), \(f_p = [f_{p_1}\ \dots \ f_{p_6}]^T\)
  • \(v_2 = [ \dot{\hat{u}}_1^T \dot{v}_1 \ \dots \ \dot{\hat{u}}_6^T \dot{v}_6 ]^T\) contains nonlinear Coriolis and centripetal accelerations

Payload Dynamics

The payload is modeled as a rigid body:

\begin{equation} \underbrace{\begin{bmatrix} m I_3 & 0_{3\times 3} \\ 0_{3\times 3} & {}^cI \end{bmatrix}}_{M_x} \ddot{\mathcal{X}} + \underbrace{\begin{bmatrix} 0_{3 \times 1} \\ \omega \times {}^cI\omega \end{bmatrix}}_{c(\omega)} = \mathcal{F} \label{eq:payload_dynamics} \end{equation}

where:

  • \(\ddot{\mathcal{X}}\) is the \(6 \times 1\) generalized acceleration of the payload's center of mass
  • \(\omega\) is the \(3 \times 1\) payload's angular velocity vector
  • \(\mathcal{F}\) is the \(6 \times 1\) generalized force exerted on the payload
  • \(M_x\) is the combined mass/inertia matrix of the payload, written in the payload frame {P}
  • \(c(\omega)\) represents the shown vector of Coriolis and centripetal terms

Note \(\dot{\mathcal{X}} = [\dot{p}^T\ \omega^T]^T\) denotes the time derivative of the payload's combined position and orientation (or pose) with respect to a universal frame of reference {U}.

First, consider the generalized force due to struts. Denoting this force as \(\mathcal{F}_s\), it can be calculated form the strut forces as:

\begin{equation} \mathcal{F}_s = {}^UJ^T f_p = {}^U_BR J^T f_p \end{equation}

where \(J\) is the manipulator Jacobian and \({}^U_BR\) is the rotation matrix from {B} to {U}.

The total generalized force acting on the payload is the sum of the strut, exogenous, and gravity forces:

\begin{equation} \mathcal{F} = {}^UJ^T f_p + \mathcal{F}_e - \begin{bmatrix} mg \\ 0_{3\times 1} \end{bmatrix} \label{eq:generalized_force} \end{equation}

where:

  • \(\mathcal{F}_e\) represents a vector of exogenous generalized forces applied at the center of mass
  • \(g\) is the gravity vector

By combining eq:strut_dynamics_vec, eq:payload_dynamics and eq:generalized_force, a single equation describing the dynamics of a flexure jointed hexapod can be found:

\begin{equation} {}^UJ^T [ f_m - M_s \ddot{l} - B \dot{l} - K(l - l_r) - M_s \ddot{q}_u - M_s g_u + M_s v_2] + \mathcal{F}_e - \begin{bmatrix} mg \\ 0_{3\times 1} \end{bmatrix} = M_x \ddot{\mathcal{X}} + c(\omega) \label{eq:eom_fjh} \end{equation}

Joint (\(l\)) and Cartesian (\(\mathcal{X}\)) terms are still mixed. In the next section, a connection between the two will be found to complete the formulation

Direction of Payload Force

Many prior hexapod dynamic formulations assume that the strut exerts force only along its direction of motion.

The flexure joints Hexapods transmit forces (or torques) proportional to the deflection of the joints. This section establishes design guidelines for the spherical flexure joint to guarantee that the dynamics remain tractable for control.

{{< figure src="/ox-hugo/mcinroy02_model_strut_joint.png" caption="<span class="figure-number">Figure 2: A simplified dynamic model of a strut and its joint" >}}

Figure 2 depicts a strut, along with the corresponding force diagram. The force diagram is obtained using standard finite element assumptions (\(\sin \theta \approx \theta\)). Damping terms are neglected. \(k_r\) denotes the rotational stiffness of the spherical joint.

From Figure 2 (b), Newton's second law yields:

\begin{equation} f_p = \begin{bmatrix} -f_m + m_s \Delta \ddot{x} + k\Delta x \\ m_s \Delta \ddot{y} + \frac{k_r}{l^2} \Delta y \\ m_s \Delta \ddot{z} + \frac{k_r}{l^2} \Delta z \end{bmatrix} \end{equation}

Note that the payload force is not in general aligned with the strut. The force is aligned perfectly with the strut only if \(m_s = 0\) and \(k_r = 0\) (i.e. the struts have negligible mass and the spherical joints have negligible rotational stiffness).

To examine the passive behavior, let \(f_m = 0\) and consider a sinusoidal motion:

\begin{equation} \begin{bmatrix} \Delta x \\ \Delta y \\ \Delta z \end{bmatrix} = \begin{bmatrix} A_x \cos \omega t \\ A_y \cos \omega t \\ A_z \cos \omega t \end{bmatrix} \end{equation}

This yields:

\begin{equation} f_p = \begin{bmatrix} \Big( -m_s \omega^2 + k \Big) A_x \cos \omega t \\ \Big( -m_s \omega^2 + \frac{k_r}{l^2} \Big) A_y \cos \omega t \\ \Big( -m_s \omega^2 + \frac{k_r}{l^2} \Big) A_z \cos \omega t \end{bmatrix} \end{equation}

The direction of \(f_p\) depends upon to motion specifications, leg inertia and control algorithm.

The hypothesis that it is mostly along the strut direction can be tested by dividing the magnitude of the \(x\) component by the magnitude of the combined \(y\) and \(z\) components:

\begin{equation} x_\text{gain} = \frac{|-m_s \omega^2 + k|}{|-m_s \omega^2 + \frac{k_r}{l^2}|} \frac{|A_x|}{\sqrt{A_y^2 + A_z^2}} \end{equation}

Note that large \(x_\text{gain}\) indicates \(x\) direction dominance.

\(x_\text{gain}\) is divided into two parts. The first part depends on the mechanical terms and the frequency of the movement:

\begin{equation} x_{\text{gain}_\omega} = \frac{|-m_s \omega^2 + k|}{|-m_s \omega^2 + \frac{k_r}{l^2}|} \end{equation}

In order to get dominance at low frequencies, the hexapod must be designed so that:

\begin{equation} \frac{k_r}{l^2} \ll k \label{eq:cond_stiff} \end{equation}

This puts a limit on the rotational stiffness of the flexure joint and shows that as the strut is made softer (by decreasing \(k\)), the spherical flexure joint must be made proportionately softer.

By satisfying eq:cond_stiff, \(f_p\) can be aligned with the strut for frequencies much below the spherical joint's resonance mode: \[ \omega \ll \sqrt{\frac{k_r}{m_s l^2}} \rightarrow x_{\text{gain}_\omega} \approx \frac{k}{k_r/l^2} \gg 1 \] At frequencies much above the strut's resonance mode, \(f_p\) is not dominated by its \(x\) component: \[ \omega \gg \sqrt{\frac{k}{m_s}} \rightarrow x_{\text{gain}_\omega} \approx 1 \]

To ensure that the control system acts only in the band of frequencies where dominance is retained, the control bandwidth can be selected so that:

\begin{equation} \text{control bandwidth} \ll \sqrt{\frac{k_r}{m_s l^2}} \label{eq:cond_bandwidth} \end{equation}

The control bandwidth can be increase for hexapods that are designed so that \(x_{\text{gain}_\omega} \gg 1\) for \(\omega \ll \sqrt{k/m_s}\). This can be achieve, for instance, by adding damping. In this case, it is reasonable to use:

\begin{equation} \text{control bandwidth} \ll \sqrt{\frac{k}{m_s}} \end{equation}

By designing the flexure jointed hexapod and its controller so that both eq:cond_stiff and eq:cond_bandwidth are met, the dynamics of the hexapod can be greatly reduced in complexity.

Relationships between joint and cartesian space

Equation eq:eom_fjh is not suitable for control analysis and design because \(\ddot{\mathcal{X}}\) is implicitly a function of \(\ddot{q}_u\).

This section will derive this implicit relationship. Let denote:

  • \(\mathcal{X}_B\) the pose of {B} with respect to {U}
  • \({}^B\mathcal{X}_P\) the pose of {P} with respect to {B}
  • \({}^Uq_i = {}^U_BR {}^Bq_i + {}^UP_{BORG}\) the position of the ith base attachment point, expressed in the universal frame {U}
  • \(P_{BORG}\) the position of the origin of frame {B}

Note that although \({}^Bq_i\) is fixed, \({}^Uq_i\) varies due to base motion.

Differentiating twice and converting derivatives of rotation matrices into angular velocity cross products yields:

\begin{equation} {}^U\dot{q}_i = \omega_B \times {}^U_BR {}^Bq_i + \underbrace{{}^U_BR {}^B\dot{q}_i}_{= 0} + v_B \end{equation}

\begin{equation} {}^U\ddot{q}_i = \dot{\omega}_B \times {}^U_BR {}^Bq_i + \omega_B \times \omega_B \times {}^U_BR {}^Bq_i + \dot{v}_B \end{equation}

where:

  • \(\omega_B\) denotes the angular velocity of {B} with respect to {U}
  • \(v_B = {}^U\dot{P}_{BORG}\) denotes the linear velocity of the origin of {B} with respect to {U}

By using the vector triple identity \(a \cdot (b \times c) = b \cdot (c \times a)\) and putting the equation in a matrix form:

\begin{equation} {}^U \hat{u}_i^T {}^U\ddot{q}_i = \left[ {}^U\hat{u}_i^T \left( {}^U_BR {}^Bq_i \times {}^U\hat{u}_i \right)^T \right] \ddot{\mathcal{X}}_B + {}^U\hat{u}_i^T \left( \omega_B \times \left[ \omega_B \times {}^U_BR {}^Bq_i \right] \right) \end{equation}

Bibliography

McInroy, J.E. 1999. “Dynamic Modeling of Flexure Jointed Hexapods for Control Purposes.” In Proceedings of the 1999 IEEE International Conference on Control Applications (Cat. No.99CH36328). doi:10.1109/cca.1999.806694.
———. 2002. “Modeling and Design of Flexure Jointed Stewart Platforms for Control Purposes.” IEEE/ASME Transactions on Mechatronics 7 (1): 9599. doi:10.1109/3516.990892.