stewart-simscape/org/simscape-model.org

16 KiB

Stewart Platform - Simscape Model

Introduction   ignore

In this document is explained how the Simscape model of the Stewart Platform is implemented.

It is divided in the following sections:

  • section sec:simscape_parameters: is explained how the parameters of the Stewart platform are set for the Simscape model
  • section sec:simulink_configuration: the Simulink configuration (solver, simulation time, …) is shared among all the Simulink files. It is explain how this is done.
  • section sec:subsystem_reference: All the elements (platforms, struts, sensors, …) are saved in separate files and imported in Simulink files using "subsystem referenced".
  • section sec:fixed_mobile_platforms: The simscape model for the fixed base and mobile platform are described in this section.
  • section sec:struts: The simscape model for the Stewart platform struts is described in this section.

Parameters used for the Simscape Model

<<sec:simscape_parameters>> The Simscape Model of the Stewart Platform is working with the stewart structure generated using the functions described here.

All the geometry and inertia of the mechanical elements are defined in the stewart structure.

By updating the stewart structure in the workspace, the Simscape model will be automatically updated.

Thus, nothing should be changed by hand inside the Simscape model.

The main advantage to have all the parameters defined in one structure (and not hard-coded in some simulink blocs) it that we can easily change the Stewart architecture/parameters in a Matlab script to perform some parametric study for instance.

Simulation Configuration - Configuration reference

<<sec:simulink_configuration>> As multiple simulink files will be used for simulation and tests, it is very useful to determine good simulation configuration that will be shared among all the simulink files.

This is done using something called "Configuration Reference" (documentation).

Basically, the configuration is stored in a mat file conf_simscape.mat and then loaded in the workspace for it to be accessible to all the simulink models. It is automatically loaded when the Simulink project is open. It can be loaded manually with the command:

  load('mat/conf_simscape.mat');

It is however possible to modify specific parameters just for one simulation using the set_param command:

  set_param(conf_simscape, 'StopTime', 1);

Subsystem Reference

<<sec:subsystem_reference>> Several Stewart platform models are used, for instance one is use to study the dynamics while the other is used to apply active damping techniques.

However, all the Simscape models share some subsystems using the Subsystem Reference Simulink block (documentation).

These shared subsystems are:

  • Fixed_Based.slx - Fixed base of the Stewart Platform
  • Mobile_Platform.slx - Mobile platform of the Stewart Platform
  • stewart_strut.slx - One strut containing two spherical/universal joints, the actuator as well as the included sensors. A parameter i is initialized to determine what it the "number" of the strut.

These subsystems are referenced from another subsystem called Stewart_Platform.slx shown in figure fig:simscape_stewart_platform, that basically connect them correctly. This subsystem is then referenced in other simulink models for various purposes (control, analysis, simulation, …).

/tdehaeze/stewart-simscape/media/commit/2f4af4914e65efda6d2a878e48261483501ce841/org/figs/simscape_stewart_platform.png
Simscape Subsystem of the Stewart platform. Encapsulate the Subsystems corresponding to the fixed base, mobile platform and all the struts.

Subsystem - Fixed base and Mobile Platform

<<sec:fixed_mobile_platforms>> Both the fixed base and the mobile platform simscape models share many similarities.

Their are both composed of:

  • a solid body representing the platform
  • 6 rigid transform blocks to go from the frame $\{F\}$ (resp. $\{M\}$) to the location of the joints. These rigid transform are using ${}^F\bm{a}_i$ (resp. ${}^M\bm{b}_i$) for the position of the joint and ${}^F\bm{R}_{a_i}$ (resp. ${}^M\bm{R}_{b_i}$) for the orientation of the joint.

As always, the parameters that define the geometry are taken from the stewart structure.

/tdehaeze/stewart-simscape/media/commit/2f4af4914e65efda6d2a878e48261483501ce841/org/figs/simscape_fixed_base.png
Simscape Model of the Fixed base
/tdehaeze/stewart-simscape/media/commit/2f4af4914e65efda6d2a878e48261483501ce841/org/figs/simscape_mobile_platform.png
Simscape Model of the Mobile platform

Subsystem - Struts

<<sec:struts>>

Strut Configuration

For the Stewart platform, the 6 struts are identical. Thus, all the struts used in the Stewart platform are referring to the same subsystem called stewart_strut.slx and shown in Figure fig:simscape_strut.

This strut as the following structure:

  • Universal Joint* connected on the Fixed base
  • Prismatic Joint* for the actuator
  • Spherical Joint* connected on the Mobile platform

This configuration is called UPS.

The other common configuration SPS has the disadvantage of having additional passive degrees-of-freedom corresponding to the rotation of the strut around its main axis. This is why the UPS configuration is used, but other configuration can be easily implemented.

/tdehaeze/stewart-simscape/media/commit/2f4af4914e65efda6d2a878e48261483501ce841/org/figs/simscape_strut.png
Simscape model of the Stewart platform's strut

Several sensors are included in the strut that may or may not be used for control:

  • Relative Displacement sensor: gives the relative displacement of the strut.
  • Force sensor: measure the total force applied by the force actuator, the stiffness and damping forces in the direction of the strut.
  • Inertial sensor: measure the absolute motion (velocity) of the top part of the strut in the direction of the strut.

There is two main types of inertial sensor that can be used to measure the absolute motion of the top part of the strut in the direction of the strut:

  • a geophone that measures the absolute velocity above some frequency
  • an accelerometer that measures the absolute acceleration below some frequency

Both inertial sensors are described bellow.

Other Elements

Payload

<<sec:initializePayload>>

This Matlab function is accessible here.

Function description

  function [payload] = initializePayload(args)
  % initializePayload - Initialize the Payload that can then be used for simulations and analysis
  %
  % Syntax: [payload] = initializePayload(args)
  %
  % Inputs:
  %    - args - Structure with the following fields:
  %        - type - 'none', 'solid', 'flexible', 'cartesian'
  %        - h [1x1] - Height of the CoM of the payload w.r.t {M} [m]
  %                    This also the position where K and C are defined
  %        - K [6x1] - Stiffness of the Payload [N/m, N/rad]
  %        - C [6x1] - Damping of the Payload [N/(m/s), N/(rad/s)]
  %        - m [1x1] - Mass of the Payload [kg]
  %        - I [3x3] - Inertia matrix for the Payload [kg*m2]
  %
  % Outputs:
  %    - payload - Struture with the following properties:
  %        - type - 1 (none), 2 (solid), 3 (flexible)
  %        - h [1x1] - Height of the CoM of the payload w.r.t {M} [m]
  %        - K [6x1] - Stiffness of the Payload [N/m, N/rad]
  %        - C [6x1] - Stiffness of the Payload [N/(m/s), N/(rad/s)]
  %        - m [1x1] - Mass of the Payload [kg]
  %        - I [3x3] - Inertia matrix for the Payload [kg*m2]

Optional Parameters

    arguments
      args.type char {mustBeMember(args.type,{'none', 'solid', 'flexible', 'cartesian'})} = 'none'
      args.K (6,1) double {mustBeNumeric, mustBeNonnegative} = 1e8*ones(6,1)
      args.C (6,1) double {mustBeNumeric, mustBeNonnegative} = 1e1*ones(6,1)
      args.h (1,1) double {mustBeNumeric, mustBeNonnegative} = 100e-3
      args.m (1,1) double {mustBeNumeric, mustBeNonnegative} = 10
      args.I (3,3) double {mustBeNumeric, mustBeNonnegative} = 1*eye(3)
    end

Add Payload Type

  switch args.type
    case 'none'
      payload.type = 1;
    case 'solid'
      payload.type = 2;
    case 'flexible'
      payload.type = 3;
    case 'cartesian'
      payload.type = 4;
  end

Add Stiffness, Damping and Mass properties of the Payload

  payload.K = args.K;
  payload.C = args.C;
  payload.m = args.m;
  payload.I = args.I;

  payload.h = args.h;

Ground

<<sec:initializeGround>>

This Matlab function is accessible here.

Function description

  function [ground] = initializeGround(args)
  % initializeGround - Initialize the Ground that can then be used for simulations and analysis
  %
  % Syntax: [ground] = initializeGround(args)
  %
  % Inputs:
  %    - args - Structure with the following fields:
  %        - type - 'none', 'solid', 'flexible'
  %        - K [3x1] - Translation Stiffness of the Ground [N/m]
  %        - C [3x1] - Translation Damping of the Ground [N/(m/s)]
  %
  % Outputs:
  %    - ground - Struture with the following properties:
  %        - type - 1 (none), 2 (solid), 3 (flexible)
  %        - K [3x1] - Translation Stiffness of the Ground [N/m]
  %        - C [3x1] - Translation Damping of the Ground [N/(m/s)]

Optional Parameters

    arguments
      args.type char {mustBeMember(args.type,{'none', 'solid', 'flexible'})} = 'none'
      args.K (3,1) double {mustBeNumeric, mustBeNonnegative} = 1e8*ones(3,1)
      args.C (3,1) double {mustBeNumeric, mustBeNonnegative} = 1e1*ones(3,1)
    end

Add Ground Type

  switch args.type
    case 'none'
      ground.type = 1;
    case 'solid'
      ground.type = 2;
    case 'flexible'
      ground.type = 3;
  end

Add Stiffness and Damping properties of the Ground

  ground.K = args.K;
  ground.C = args.C;

Z-Axis Geophone

Working Principle

From the schematic of the Z-axis geophone shown in Figure fig:z_axis_geophone, we can write the transfer function from the support velocity $\dot{w}$ to the relative velocity of the inertial mass $\dot{d}$: \[ \frac{\dot{d}}{\dot{w}} = \frac{-\frac{s^2}{{\omega_0}^2}}{\frac{s^2}{{\omega_0}^2} + 2 \xi \frac{s}{\omega_0} + 1} \] with:

  • $\omega_0 = \sqrt{\frac{k}{m}}$
  • $\xi = \frac{1}{2} \sqrt{\frac{m}{k}}$
/tdehaeze/stewart-simscape/media/commit/2f4af4914e65efda6d2a878e48261483501ce841/org/figs/inertial_sensor.png
Schematic of a Z-Axis geophone

We see that at frequencies above $\omega_0$: \[ \frac{\dot{d}}{\dot{w}} \approx -1 \]

And thus, the measurement of the relative velocity of the mass with respect to its support gives the absolute velocity of the support.

We generally want to have the smallest resonant frequency $\omega_0$ to measure low frequency absolute velocity, however there is a trade-off between $\omega_0$ and the mass of the inertial mass.

Initialization function

<<sec:initializeZAxisGeophone>>

This Matlab function is accessible here.

  function [geophone] = initializeZAxisGeophone(args)
      arguments
          args.mass (1,1) double {mustBeNumeric, mustBePositive} = 1e-3 % [kg]
          args.freq (1,1) double {mustBeNumeric, mustBePositive} = 1    % [Hz]
      end

      %%
      geophone.m = args.mass;

      %% The Stiffness is set to have the damping resonance frequency
      geophone.k = geophone.m * (2*pi*args.freq)^2;

      %% We set the damping value to have critical damping
      geophone.c = 2*sqrt(geophone.m * geophone.k);

      %% Save
      save('./mat/geophone_z_axis.mat', 'geophone');
  end

Z-Axis Accelerometer

Working Principle

From the schematic of the Z-axis accelerometer shown in Figure fig:z_axis_accelerometer, we can write the transfer function from the support acceleration $\ddot{w}$ to the relative position of the inertial mass $d$: \[ \frac{d}{\ddot{w}} = \frac{-\frac{1}{{\omega_0}^2}}{\frac{s^2}{{\omega_0}^2} + 2 \xi \frac{s}{\omega_0} + 1} \] with:

  • $\omega_0 = \sqrt{\frac{k}{m}}$
  • $\xi = \frac{1}{2} \sqrt{\frac{m}{k}}$
/tdehaeze/stewart-simscape/media/commit/2f4af4914e65efda6d2a878e48261483501ce841/org/figs/inertial_sensor.png
Schematic of a Z-Axis geophone

We see that at frequencies below $\omega_0$: \[ \frac{d}{\ddot{w}} \approx -\frac{1}{{\omega_0}^2} \]

And thus, the measurement of the relative displacement of the mass with respect to its support gives the absolute acceleration of the support.

Note that there is trade-off between:

  • the highest measurable acceleration $\omega_0$
  • the sensitivity of the accelerometer which is equal to $-\frac{1}{{\omega_0}^2}$

Initialization function

<<sec:initializeZAxisAccelerometer>>

This Matlab function is accessible here.

  function [accelerometer] = initializeZAxisAccelerometer(args)
      arguments
          args.mass (1,1) double {mustBeNumeric, mustBePositive} = 5e-3 % [kg]
          args.freq (1,1) double {mustBeNumeric, mustBePositive} = 5e3  % [Hz]
      end

      %%
      accelerometer.m = args.mass;

      %% The Stiffness is set to have the damping resonance frequency
      accelerometer.k = accelerometer.m * (2*pi*args.freq)^2;

      %% We set the damping value to have critical damping
      accelerometer.c = 2*sqrt(accelerometer.m * accelerometer.k);

      %% Gain correction of the accelerometer to have a unity gain until the resonance
      accelerometer.gain = -accelerometer.k/accelerometer.m;

      %% Save
      save('./mat/accelerometer_z_axis.mat', 'accelerometer');
  end