Next Article in Journal
Cryptococcus: History, Epidemiology and Immune Evasion
Next Article in Special Issue
An Overview of Variants and Advancements of PSO Algorithm
Previous Article in Journal
Cross Talk between Synthetic Food Colors (Azo Dyes), Oral Flora, and Cardiovascular Disorders
Previous Article in Special Issue
Potential Contribution of the Grey Wolf Optimization Algorithm in Reducing Active Power Losses in Electrical Power Systems
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Real Coded Mixed Integer Genetic Algorithm for Geometry Optimization of Flight Simulator Mechanism Based on Rotary Stewart Platform †

by
Miloš D. Petrašinović
*,
Aleksandar M. Grbović
,
Danilo M. Petrašinović
,
Mihailo G. Petrović
and
Nikola G. Raičević
Faculty of Mechanical Engineering, University of Belgrade, Kraljice Marije 16, 11000 Belgrade, Serbia
*
Author to whom correspondence should be addressed.
This paper is an extended version of our paper published in Computational and Experimental Approaches in Materials Science and Engineering, Zlatibor, Serbia, 2–5 July 2019.
Appl. Sci. 2022, 12(14), 7085; https://doi.org/10.3390/app12147085
Submission received: 1 June 2022 / Revised: 27 June 2022 / Accepted: 12 July 2022 / Published: 13 July 2022
(This article belongs to the Collection Heuristic Algorithms in Engineering and Applied Sciences)

Abstract

:

Featured Application

Low-cost flight simulators with electric rotary actuators and optimized geometry for flight simulation.

Abstract

Designing the motion platform for the flight simulator is closely coupled with the particular aircraft’s flight envelope. While in training, the pilot on the motion platform has to experience the same feeling as in the aircraft. That means that flight simulators need to simulate all flight cases and forces acting upon the pilot during flight. Among many existing mechanisms, parallel mechanisms based on the Stewart platform are suitable because they have six degrees of freedom. In this paper, a real coded mixed integer genetic algorithm (RCMIGA) is applied for geometry optimization of the Stewart platform with rotary actuators (6-RUS) to design a mechanism with appropriate physical limitations of workspace and motion performances. The chosen algorithm proved that it can find the best global solution with all imposed constraints. At the same time, the obtained geometry can be manufactured because integer solutions can be mapped to available discrete values. Geometry is defined with a minimum number of parameters that fully define the mechanism with all constraints. These geometric parameters are then optimized to obtain custom-tailored geometry for aircraft flight simulation.

1. Introduction

From the very beginning of aviation, in addition to the construction of the aircraft, the most demanding task was to master the aircraft piloting. The rapid development of civil aviation soon required the possibility of instrumental flying. Pilots had to be able to control the aircraft in conditions when visibility from the cockpit was so reduced that the flight was no longer safe. In 1929, to reduce the risk and cost of training, the American constructor Edwin A. Link constructed the Link Trainer flight simulator. The cockpit was mounted on a carrier which enabled change of position and orientation, depending on the given command, in the same way as a real aircraft. It is also crucial to have the same instruments which react accordingly.
Today, flight simulators play an irreplaceable role in pilot training and certification. Their full potential was discovered when there was not enough time to train a large number of pilots on real planes. With these machines, pilots could learn how to fly under conditions in which flight by visual reference is not safe anymore. In such situations, the pilot needs to know how to control the aircraft, relying only on information collected from the instruments and its own vestibular system.
Over time, flight simulators have become complex mechatronic systems, but their main purpose, to enable pilots to feel what they see with their eyes, remains the same. In order to achieve realistic simulation in all flight cases and all forces acting upon the pilot during the flight, a moving part of the simulator needs to have six degrees of freedom. The chosen mechanism with six degrees of freedom has to have a sufficiently large workspace to simulate aircraft motion, which is why the determination of motion boundaries is very important.
A free rigid body has six degrees of freedom, it can perform six independent motions, three translations and three rotations. A kinematic chain is a series of bodies or segments connected together by joints. A kinematic chain can be simple or complex, and both can be divided into open and closed. One segment of a simple kinematic chain cannot be connected to more than two other segments, while one segment of a complex kinematic chain can be connected to more than two other segments. Open kinematic chains have segments that are connected to only one other segment, while all closed chain segments are connected to at least two other segments, as shown in Figure 1.
Among many existing designs, parallel mechanisms (mechanisms with closed chains) based on the Stewart platform, defined in [1], are most frequently used for flight simulators. From this first work until today, this mechanism is a popular research topic in robotics with many research papers published about inverse and forward kinematics problems [2,3], dynamics [2,4,5,6,7], singularities and workspace estimation [2,8,9,10,11]. In a paper [12] written in 1998, the authors presented a state-of-the-art review of the literature on the Stewart platform and mentioned papers are still the basis of research. A similar overview paper was written in 2016 [13].
Even after so many years (almost six decades) of research, there is still the opportunity to find a new or better way of practical use of this mechanism. Besides flight simulators, this mechanism is currently used, for instance, for machining tools [14], as part of medical instruments for precision surgeries [15], for high-precision vibration damping for spacecraft payload [16], within marine satellite tracking antenna stabilization system [17], for non-destructive inspection tool [18], for assembly of flaps [19], for testing of micro-electro-mechanical system dynamic inclinometer [20], for energy-efficient machining bed [21], gait rehabilitation [22,23], stabilization system for optoelectronic devices [24], docking mechanism [25] and even for helicopter floating helideck [26]; additional applications are shown in [27].
There are many different types of geometrical interpretations of the Stewart platform, but the main objective of this paper is geometry optimization of the Stewart platform with rotary actuators, as shown in Figure 2. It has six pairs of upper and lower levers (together called legs), and the movement of the upper platform relative to the base is achieved by rotating the lower lever around an axis going through one end of a lever. This is the revolute joint between the base and a lower lever controlled by an electric motor. The upper and lower levers are connected with universal or spherical joints, which connect the upper lever and platform. This is why this type is also called 6-RUS, in accordance with the types of joints.
The contribution of this paper is significant as it provides solutions to both inverse and forward kinematics problems for the rotary Stewart platform, besides the geometrical definition of the mechanism and algorithm for its optimization.
To control the position and orientation of the platform, the part of the simulator that connects the base and platform (leg) needs to have an actuator. Some of the other geometrical types use six levers with variable lengths (linear or prismatic actuators) or six pairs of two levers, of which one lever is fixed but has a variable length. The most critical design aspects of the mechanism besides the types of actuators are spatial configuration (locations of connections) and the type of connections (joints).
A design solution based on rotary actuators, in this case, electric motors with proper gearboxes, is adopted due to its simplicity in terms of simulation, production, and maintenance. If the servo motor with servo drive is not cost-effective, an induction motor or asynchronous motor can be controlled using a variable-frequency drive (VFD) and both products are standardized and widely available. The current angle of the shaft can be measured with an encoder or potentiometer. The mechanism with this type of actuator is the simplest one to scale down and test on a smaller model. Even before investing in the first prototype, kinematics and control algorithms can be physically tested.
After selecting the type of actuator and spatial configuration, the remaining part of the simulator design is choosing values of predefined geometrical parameters that fully define the mechanism with all constraints. Due to many different combinations and their interrelated influence on the simulator performance, it is challenging to find optimal values for these parameters. In this case, with many parameters, often some optimization algorithms must be employed to get sufficiently good results in the desired time. For problems like this, the optimization algorithms are often numerical and do not provide the solution in the closed form. These algorithms are traditionally iterative. Constrained minimization problems can be solved with minimization of the fitness function by successive approaching within a sequence of calculations. There are already reasonable efforts in employing the genetic algorithm [28,29,30] for optimization of this kind of problem. It is suitable because there are many local minima, and it is not easy to find a global one. Brute force and exhaustive algorithms are not chosen in this case because of the computational power and time necessary for optimization. There are also more recent evolutionary and bio-inspired metaheuristic algorithms that can be used for this kind of problem, such as the ones described in [31,32,33].
The implementation of the fitness function defines the goal of optimization. Many performance indicators can be considered in this case while calculating fitness functions, such as the maximum feasible orientation of the platform, the volume of workspace, needed joint movements, manipulability, dexterity, singularities, and physical interference between segments. This paper proposes novel constraints, performance indicators, and fitness function for flight simulation on a low-cost flight simulator with electric rotary actuators. While constructing fitness function and choosing performance indicators, the goal was to lower the necessary computation time and to be able to find geometry with sufficient characteristics in a short time. On the other hand, the purpose of constraints is to make sure that obtained geometry can be materialized, that it is really suitable for flight simulation, and that there is no physical limitation on the materialized mechanism. Previously, inverse and forward kinematics problems had to be solved many times in this kind of optimization, the goal of the proposed algorithm is to greatly reduce the number of these calculations within optimization.

2. Geometric Parameters

In order to analyze whether the shown type of mechanism can be successfully applied in practice for the flight simulator, foremost, the geometry must be defined. The geometry should be defined with a minimum number of parameters that fully define the mechanism with all constraints. Changing the values of these parameters within the optimization process should provide better characteristics for the flight simulator.
As shown in Figure 3, the first step is to define two reference frames. A global reference frame ( O b x b y b z b ) is fixed to the center of the base and a moving platform reference frame ( O p x p y p z p ) is fixed to the center of the platform.
Control values are defined by vector x = x y z ψ θ φ T , and they represent external coordinates of the moving platform’s local reference frame in reference to the global frame fixed to the nonmoving base of the platform. In other words, translation of the platform’s frame in reference to the global frame is defined by T = x b , O p y b , O p z b , O p T , while orientation is defined using Euler angles ( ψ , θ , φ ), with yaw, pitch, and roll about for z, y, and x global axes, respectively.
The rotary actuator is fixed to the base of the mechanism, and it rotates the lower lever. Figure 4 shows point B i ; this is the point of connection between the rotary actuator and the lower lever, which means that it is the intersection point of the actuator’s axis of rotation (defined with i m , i ) and the lower lever. The lower lever has a constant length (from point B i to point A i ), and it is equal to parameter a, while the constant length of the upper lever that connects points B i and P i is equal to parameter s. These are the first two geometric parameters. In reference to the horizontal plane on which the base lies, the actuator’s axis of rotation is tilted by the ε angle, the third geometric parameter.
Point P i is a point on the platform around which the spherical joint rotates, the sphere’s center. Point A i is the center of the spherical joint connecting the upper and lower lever. Due to the six legs of this mechanism i = 1 , 2 , , 6 .
The vector p i = x P i y P i z P i T is the position vector of a point P i in the reference frame of the platform. A vector b i = x B i y B i z B i T is the position vector of a point B i in the global reference frame.
Coordinates of points B i and P i must be determined in corresponding reference frames in order to fully define the mechanism’s base and platform. The intuitive way to do this is to use polar coordinates, noticing that points B i and P i lie on constant diameter circles and that there are three axes of symmetry between these points (point B 1 can be mapped to point B 2 , while the axis of symmetry is at a certain angle to the x axis of global frame).
As shown in Figure 5, the axis of symmetry between points B 1 and B 2 is defined by angle β s , i . This angle has a constant value for all considered geometries, and its purpose is to define three segments for points B i . The axis of symmetry of points B 1 and B 2 is rotated by 30° in reference to the x-axis, then the axis of symmetry of points B 3 and B 4 is rotated by 150°, and the axis of symmetry of points B 5 and B 6 is rotated by −90°. These three axes of symmetry make the distribution of points uniform. Angle β s , i is not a geometrical parameter for optimization, but it is necessary for determining the coordinates of points B i with other parameters. The value of this angle for all legs is defined with vector β s = 1 6 π 1 6 π 5 6 π 5 6 π 1 2 π 1 2 π T .
Angle γ b and radius R b are the next two variable geometric parameters that are used to define the position of the point B i relative to the previously defined axis of symmetry. In order to define both points B 1 and B 2 , located on different sides relative to the axis of symmetry, a vector σ l = 1 1 1 1 1 1 is introduced. This vector also has a constant value for all considered geometries. Its purpose is also to define different rotation directions of even and odd indexed actuators.
Finally, the position of all six points B i is defined as follows:
x B , i = R b cos ( δ b , i ) , y B , i = R b sin ( δ b , i ) , z B , i = 0 , δ b = β s + γ b σ l
Similar to points B i , the position of all six points P i in reference to the platform’s reference frame is defined by the following two variable geometric parameters, radius R p and angle γ p , as shown in Figure 6. There are again three axes of symmetry between points, the same as in the case of the base.
x p , i = R p cos ( δ p , i ) , y p , i = R p sin ( δ p , i ) , z p , i = 0 , δ p = β s + γ p σ l
It is now necessary to define the position of points A i , which depends on the previously mentioned vector, i m , i which is the unit vector of the actuator’s axis of rotation.
As shown in Figure 7, the actuator’s axis of rotation does not have to be normal to the line passing through points B 1 and B 2 but this line is a referent line for the definition of the orientation of lower levers in the horizontal plane (when lower levers are in the home position). This referent line is defined with the angle ν ll , i measured from the x axis of the global reference frame. The valueof this angle is defined with a vector ν ll = β s π 2 σ l for each lower lever.
Finally, the angle between the lower lever’s referent line and the actual orientation of the lower lever in the home position is the next geometric parameter τ l l , which is the same for all six lower levers. Then, the angle between the lower lever and the x b axis is given by the following equation:
β ll = ν ll + τ l l σ l
The projection of the unit vector of the actuator’s axis of rotation in the horizontal plane is normal to the lower lever. Based on that and the already defined tilt angle ε , the unit vector of the actuator’s axis of rotation is:
i m , i = cos ( β l l , i + π 2 σ l , i ) cos ε sin ( β l l , i + π 2 σ l , i ) cos ε sin ε
Point A 0 i (shown in Figure 4) is the referent point that represents a point A i in the home position and its position vector a 0 i = x A 0 i y A 0 i z A 0 i T is defined with:
x A 0 i = a cos β l l , i + x B , i , y A 0 i = a sin β l l , i + y B , i , z A 0 i = z B , i
To define a point A i and position vector a i = x A i y A i z A i T in the global reference frame, it is first necessary to define or find angle α i (also shown in Figure 4). Then, based on Rodrigues’ rotation formula, coordinates of the vector a i can be expressed as follows:
a i = b i + B i A 0 i + ( 1 cos α i ) Rm 1 B i A i + ( sin α i ) Rm 2 B i A i ,
where Rm 2 B i A i and Rm 1 B i A i are:
Rm 2 B i A i = i m , i × B i A 0 i , Rm 1 B i A i = i m , i × Rm 2 BA
With all previously defined points, the geometry of the mechanism is fully defined. Still, it is necessary to define two more unit vectors for each leg in order to be able to model the constraints of spherical joints. These unit vectors of spherical joints are essential for optimization, as their orientation is used for the calculation of the physical limitations of this mechanism. This physical limitation is modeled as a nonlinear constraint because at a certain maximal angle of the joint, there is contact between different parts of the joint, and further movement is denied. It is expected that the optimization algorithm adapts the orientation of these vectors in order to get the largest possible workspace.
Figure 8 shows a projection of the unit vector of the upper joint axis i jp , i in the plane defined by x p and y p . It is also shown that angle τ j p is used to define its orientation. This angle is the next geometric parameter. The orientation of the unit vector of the upper joint axis in this plane (angle between vector projection and x p axis) is defined as follows:
β jp = β s + τ j p σ l
A previously analyzed unit vector is used for the calculation of the physical limitation of the spherical joint that connects the platform and upper lever. The last unit vector is i ll , which defines the axis of the spherical joint that connects the upper and lower lever. This unit vector is already shown in Figure 7. In the home position, its projection to the horizontal plane has the same direction as the projection of the actuator’s axis of rotation.
Unit vectors of joints are again shown in Figure 9; their orientation in planes of the platform and the base are already discussed, but two more and two last geometric parameters are introduced for total orientation. Vectors are tilted in reference to the corresponding planes by angles μ j p and μ l l . The same principle is already used for the actuators, and the following equation is obtained:
i jp , i = cos β j p , i cos μ j p sin β j p , i cos μ j p sin μ j p T
Because one part of the joint between the lower and upper lever is fixed to the lower lever, it rotates together with the lower lever, and it is necessary to define the referent vector of the axis in home position i ll 0 , i with:
i ll 0 , i = cos ( β l l , i + π 2 σ l , i ) cos ( ε + μ l l ) sin ( β l l , i + π 2 σ l , i ) cos ( ε + μ l l ) sin ( ε + μ l l )
Then, again based on Rodrigues’ rotation formula, the vector i ll , i can be expressed as follows:
i ll , i = i ll 0 , i + ( 1 cos α i ) Rm 1 i ll + ( sin α i ) Rm 2 i ll ,
where Rm 2 i ll and Rm 1 i ll are:
Rm 2 i ll = i m , i × i ll 0 , i , Rm 1 i ll = i m , i × Rm 2 i ll
To optimize the geometry, eleven geometric parameters that determine the geometry of the mechanism for flight simulators are precisely defined. They unambiguously describe platform geometry. It should be noted that the geometry could be defined in other ways. Still, because no restrictions are imposed besides symmetry between joints (mirroring of, i.e., point B 1 to point B 2 ), any usable configuration can be obtained. It is necessary only once to implement the previously described algorithm for calculating the position and axes vectors based on geometric parameters. Then it is as simple as changing 11 numbers to obtain different mechanism geometry. One example of values for all geometric parameters is given in Table 1.

3. Inverse and Forward Kinematics Problems

In kinematics, joint movements are referred to as generalized or internal coordinates, and external coordinates are the ones that define the position and orientation of segments in reference to a global reference frame. Changing internal coordinates changes external coordinates, i.e., the position and orientation of the platform. The process of determining external coordinates for a given set of internal coordinates (joint movements) is referred to as forward kinematics. Determining internal coordinates (joint movements) for a given set of external coordinates (position and orientation) is referred to as inverse kinematics.

3.1. Coordinate System Transformation

Besides the translation vector T of the platform’s frame in reference to the global frame, it is necessary also to define a matrix R that represents the rotation matrix, whose elements are functions of the three Euler angles that determine the orientation of the moving platform’s reference frame in reference to the global frame. To ease writing, a condensed notation of the trigonometric functions sine and the cosine, “s” and “c”, respectively, are used to define the rotation matrix R as follows:
R = R z ( ψ ) R y ( θ ) R x ( φ ) = c ψ c θ s ψ c φ + c ψ s θ s φ s ψ s φ + c ψ s θ c φ s ψ c θ c ψ c φ + s ψ s θ s φ c ψ s φ + s ψ s θ c φ s θ c θ s φ c θ c φ

3.2. Inverse Kinematics

Calculating the required rotations of rotary actuators and lower levers for a given position and orientation of the platform requires solving the inverse kinematics. The most intuitive way of solving this type of problem is often referred to as a geometric method. Using translation vector T and rotation matrix R , it is possible to obtain a position vector of a point P i in reference to the global reference frame.
The necessary length of the leg (distance between points B i and P i ) can be computed by the Euclidean norm of the vector L i shown in Figure 4 as l i = L i 2 . After calculating the vector L i , the next step is to find the angle of rotation α i for the rotary actuator. This angle defines rotation around the axis of the actuator, while this axis is defined by a unit vector i m , i . The purpose of finding the angle α i is to define the position of the point A i , which provides the correct position of upper and lower levers for the defined leg length. Angle α i is measured from the initial vector B i A i , which lies in the horizontal plane. The actuator’s axis of rotation and the circle representing all possible positions of the point A i are also shown in Figure 4. For the introduced reference frames, the following relation determines the vector of the i-th leg.
L i = T + R p i b i
Home position offset can be implemented in the already defined translation vector T as follows:
T = x y z 0 + z T
The home position is the selected position in which lower levers are in plane with the base. This position of the platform is defined as:
z 0 = s 2 ( x P 1 x A 1 ) 2 ( y P 1 y A 1 ) 2 + z A 1
Using now known vectors p i and b i , and known lengths a, s, and L i , angle α i can be obtained from coordinates of vector a i . After solving a system of equations and using trigonometric identities, the following equation is obtained:
α = sin 1 D E 2 + F 2 atan2 F , E
The function atan2 from the previous equation is defined as:
atan2 F i , E i = tan 1 F i E i , E i > 0 , tan 1 F i E i + π , E i < 0 F i 0 , tan 1 F i E i π , E i < 0 F i < 0 , + π 2 , E i = 0 F i > 0 , π 2 , E i = 0 F i < 0 , NaN , E i = 0 F i = 0 .
In Equation (17), variables D , E , and F are:
D = l 2 + a 2 s 2 2 ( Rm 1 BA + BA 0 ) BP
E = 2 Rm 2 BA · BP
F = 2 Rm 1 BA · BP
With the obtained Equation (17), the inverse kinematics problem is solved. This equation is the explicit solution to the inverse kinematics problem. If there is a real solution to this equation for all angles α i , then the desired position and orientation of the platform are achievable if there are no other physical constraints.
In the process of designing a mechanism like this for practical usage as a flight simulator, the physical constraints of the kinematic chains, such as lever interference and limitations of joints, must be considered [9]. Whenever some mechanism has spherical or universal joints, their angular limits should be considered [29]. The range of work has to be defined for each joint of the mechanism. The most commonly available spherical joint is called rod end bearing. The nominal position of levers for this joint is when levers are orthogonal to each other. Based on this, if the rotation between the ends of the upper lever is possible, the constraints of the upper and lower joints can be defined as follows:
λ p , i = | cos 1 P i A i · i jpb , i s 90 | < λ m a x , i jpb , i = R i jp , i
λ b , i = | cos 1 P i A i · i ll , i s 90 | < λ m a x
The maximal cone angle of this type of joint is λ m a x , and it needs to be determined in advance for a specific joint.

3.3. Forward Kinematics

In the case of the inverse kinematics problem, the external coordinates are known, but if it is necessary to determine the external coordinates based on the known lower lever orientation, it would require solving the forward kinematics problem. The forward kinematics of this system is very complex and a lot of effort has been invested in solving it analytically and numerically.
The Jacobian matrix (matrix of all functions’ first-order partial derivatives) maps the change of internal coordinates to the change of external coordinates with respect to time [34]. Based on the principle of virtual work, the Jacobian matrix, as a relationship between joint velocities and the platform velocities is also a direct relation between the necessary torque of actuators and applied load to the platform [35]. For each leg of the mechanism, the equation of the loop closure (shown in Figure 10) is given by:
O b B i + B i A i + A i P i = O b O p + O p P i
By differentiating Equation (24) with respect to time, the following equation is obtained:
ω α , i × B i A i + ω ul , i × A i P i = v p + ω p × O p P i ,
where v p is platform linear velocity, ω α , i , ω ul , i , and ω p are angular velocities of the actuator (and lower lever), upper lever, and platform, respectively. By introducing the unit vector of the upper lever as A i P i = s i ul , i , multiplying both sides of the equality with it, and using characteristics of the cross product, the equation becomes:
i ul , i ω α , i × B i A i + ω ul , i s i ul , i × i ul , i = i ul , i v p + O p P i × i ul , i ω p
By introducing the unit vector of rotary actuator i m , i and his angular velocity α i ˙ with ω α , i = σ l , i α i ˙ i m , i and by eliminating the second member of the equation, the following equation is obtained:
σ l , i i ul , i i m , i × B i A i α i ˙ = i ul , i v p + O p P i × i ul , i ω p
Based on the previous equation, the Jacobian matrix of external coordinates J x and internal coordinates J α can be defined as follows:
J α α ˙ = J x x ˙
J x = i ul , 1 O p P 1 × i ul , 1 i ul , 6 O p P 6 × i ul , 6
J α = σ l , 1 i ul , 1 i m , 1 × B 1 A 1 σ l , 6 i ul , 6 i m , 6 × B 6 A 6
x ˙ = v p x v p y v p z ω p x ω p y ω p z T , α ˙ = α ˙ 1 α ˙ 6 T
Finally, the Jacobian matrix J can be expressed with the following equation:
J = J x 1 J α
If α * is a vector of desired angles, then based on Newton’s method, the solution of the forward kinematics problem would be:
x k + 1 = x k J α ( x k ) α *
In this way, the simple iterative numerical solution to the forward kinematics problem of the rotary Stewart platform is obtained. A good approximation (with an error smaller than the defined threshold [36]) of external coordinates is obtained from Equation (33) after just a few iterations.

4. Mechanism Performance Indicators

The first requirement in order to apply optimization is that there is a certain parameter on the basis of which it is possible to measure the success of individual solutions and then compare different solutions. It is necessary to construct a function whose value will be a measure of the success of the solution. This function is not always easy to form when it comes to complex engineering problems. It is necessary to determine the parameter that will represent the performance indicators, in this case, of the flight simulator mechanism.

4.1. Required Actuator Torque

Based on Jacobian matrix that is for this mechanism defined with Equation (32), it is possible to find a required torque of actuators for payload on the platform.
With the inverse of the matrix J , and if the load acting upon the platform F x is known, the required torque of actuators M m can be found with:
M m = J T F x
The previous equation was obtained based on the principle of virtual work because:
δ x = J δ α
In case of static equilibrium, if C in is the center of inertia of the payload, and if just the weight of the payload ( m g ) is acting upon the platform, then the vector F x can be written as:
F x = m g C in O p × m g T
Required actuator torque for motion (dynamic case) can be defined using the static case and load factor or by dynamic analysis and simulation of the platform, as in [37].

4.2. Workspace

One of the most important characteristics of the mechanism used for flight simulation is its workspace. A good example is a flight simulator for fighter aircraft, as shown in [38], for which the Stewart platform is not suitable because of workspace limits. The workspace of any mechanism (including parallel mechanisms, which has a closed kinematic chain) is a set of positions and orientations reachable by its end-effector. In order to be able to successfully simulate flight with a motion platform, on which the pilot sits while in training, its workspace has to meet some criteria. Based on the preceding, it is essential to have a computationally fast and efficient but at the same time also accurate workspace determination process in order to design and optimize the geometry of the mechanism used for the flight simulator.
There is no analytical solution for the workspace of this type of mechanism that considers all constraints (such as motion limits of joints), which can be practically used in the design process. One option is to simply test all significant positions and orientations. This includes defining the range for each axis and value change step (increment between consecutive values) and then testing all possible combinations. In order to lower the number of combinations that must be tested, space is divided a few times, first with the coarser step and then with the finer one just around the boundary of the workspace. The final step is defining the boundary surface based on points that are within the workspace.
The workspace of the mechanism is embedded in a six-dimensional space that cannot be graphically represented. Because of that, Figure 11 shows the workspace for constant orientation, in this case when all Euler angles are zero.
When the workspace is not suitable for the desired motion, filters called washout algorithms are used to provide the feeling as if the real motion has been achieved. For flight simulators, motion cueing [39,40,41] and washout filters [42,43,44] are used in order to improve the capabilities of the mechanism itself, but the degree of improvement depends on the pilot. Paper [45] presents an emulation of pilot control behavior on a flight simulator to further improve control of the mechanism.

4.3. Other Performance Indicators

As previously mentioned, performance indicators must allow solutions to be compared and, for that reason, must be based on normalized quantities. From many performance indicators that can be considered while calculating fitness functions, dexterity and the maximum feasible Euler angles have been selected as the most valuable for flight simulation. In this case, it is necessary to normalize the Jacobian matrix because the elements have different units of measurement. Certain elements are divided by the platform’s radius or by the length of the lower lever to perform normalization.
J xn = i ul O p P i × i ul / R p , J α n = J α / a
Based on the previous two equations, the normalized Jacobian matrix is:
J n = J xn 1 J α n
In order to calculate the Local Dexterity Index (LDI) η as the reciprocal value of the Jacobian matrix condition number [16], a homogeneous Jacobian matrix J h should first be obtained. As shown in [20], the Jacobian matrix of external coordinates J x can be separated into two matrices that have different physical dimensions. Then some sort of normalization can be applied to obtain a homogeneous matrix. The first matrix, obtained as the first three columns, is related to forces, while the last three columns are related to torques.
Paper [46] defines robot manipulability as the absolute value of the determinant of the Jacobian matrix, which in this case was previously normalized.
w = | det J n |
Paper [34] defines robot dexterity as the reciprocal value of the condition number of the Jacobian matrix, which in this case was previously normalized. The condition number of the matrix is the product of the Euclidean norm of the matrix and the Euclidean norm of the inverse matrix.
η = 1 k = 1 cond J n = 1 J n 2 · J n 1 2
Manipulability and dexterity of this type of mechanism are also analyzed in papers [47,48,49]. For some applications, performance indicators can also be partial or full isotropy of the mechanism described in [50].
The third and fourth performance indicators are based on the maximum absolute value of the feasible independent Euler pitch and roll angles ( θ j , m a x and φ j , m a x ) about global y- and x-axes for the given position. In relation to the method with the incremental change of angle with constant step, until the maximum value (with a certain tolerance) is determined, a significantly more efficient method is implemented. This new method is based on the variable step and determining the node in which the indicator of feasibility changes value, certain tolerance is met.
An additional indicator, for high-precision robots, is the elasticity of their structure. The mechanism can be designed to withstand all loads within some allowed limits of displacement, or this can be computed or even measured and then compensated with a control algorithm. In both cases, in the design process, displacement of the structure under load has to be calculated. The interesting part of this analysis is the numerical modeling of joints. The finite element method can be applied to obtain displacements of this mechanism, while joints can be implemented using the Lagrangian-multiplier method.

5. Real Coded Mixed Integer Genetic Algorithm

Genetic algorithm (GA) is one of the optimization and search techniques based on genetics and natural selection, modeled on the idea of Darwin’s theory of species origin by means of natural selection. Using this technique, the problem is solved for a different set of inputs, and each set is given some score which is then used as a selection criterion. This set of inputs is called the population of one generation. Before solving the problem again, the set of inputs is changed using elitism, selection, crossover, and mutation functions. The score which is given to an individual solution is in fact the value of a fitness function for a given set of inputs. The idea is to provide an algorithm that evolves toward a globally optimal solution.
Figure 12 shows a flowchart of the real coded mixed integer genetic algorithm (RCMIGA) that is defined in [51]. This particular algorithm is selected because of the large number of inputs (in this case, eleven geometric parameters) and the highly nonlinear and discontinuous nature of the problem with many constraints and many local minima.
In aerospace engineering, genetic algorithms are used even for the design of the whole aircraft, as in [52]. It is also chosen for washout filter tunning in [44].
This type of GA was chosen because the manufacturing technology requires that the geometric parameters are not continuous values, but there is some accuracy with which it is possible to manufacture parts. From this comes the explanation for the term “mixed integer” in the name, it is simply possible to define some variables so that they take only integer values. In addition, “real coded” describes that real numbers are used to represent individuals. Obtained integer values can be mapped to available discrete values, these discrete values can be real numbers. Values to which integers are mapped can be arbitrary, but they are more often linearly spaced.
As one real engineering problem is analyzed here, limitations inevitably narrow the scope of possible solutions. Due to the need to define limits, the penalty method defined in the paper [53] is used. This method is reflected in the evaluation of nonlinear conditions and by summing the values of nonlinear conditions with the fitness function value. It should be noted that the value for the penalty based on the evaluation of the constraint function is obtained by normalizing the value of the constraint function.
Elitism has been implemented to ensure that the best individuals pass from generation to generation unchanged. Despite the fact that they remain unchanged, these individuals, together with others, participate in the selection process so that they can be selected for crossover and mutation, i.e., the application of genetic operators over them.
In order to enter the optimization process at all, the first generation of the population is generated based on a uniform distribution. As for every subsequent generation, this initial population must have the parameter values within the defined limits, and if there are integer parameters, they are required to have an integer value.
When there is an initial population, it is possible to start the optimization process. First, the elite individuals are separated, and the selection is made. In this case, a selection based on a tournament between two individuals is used.
The genetic crossover operator is then applied to the selected individuals, a crossover based on the Laplace distribution. This crossover is defined in the paper [54]. This method has three parameters for adjustment and their values are taken from the same paper.
a = 0 , b r e a l = 0.15 , b i n t = 0.35
Then the genetic operator of the mutation is applied, and this mutation is based on the power distribution law. This mutation is defined in the paper [55]. This method has two parameters for adjustment, and their values are taken from the same paper.
p r e a l = 10 , p i n t = 4
Because the optimization process can take a long time, functions have been implemented to show the optimization status so that data is displayed at the end of each generation’s evaluation. Based on this data, a conclusion can be made about the course of that optimization.
Once all genetic operators have been implemented, and the evaluation of constraint and fitness functions are enabled, it remains to define stopping criteria for process termination. A total of seven stopping criteria have been implemented, and if any of these criteria are met, the loop optimization interrupt occurs.

6. Geometry Optimization

After defining all necessary geometric parameters, after adopting all the required vectors to describe the mechanism, and when the genetic algorithm is fully implemented, it remains to define constraints and fitness function as well as to determine values for all optimization settings.
The optimum design of Stewart platform for particular applications is analyzed in papers [56,57,58]. Their goals are maximum rigidity over the workspace, improved dexterity, sufficient dexterity, and regular target workspace while minimizing the lengths of the elements, minimizing energy consumption, and the tracking error of a target trajectory.
Besides that, paper [59] presents an optimization method for obtaining the desired workspace, while papers [60,61] are focused on Stewart platform optimization for flight simulators.

6.1. Constraints

An engineering design problem, such as this one, often has some constraints such as, for example, manufacturing limitations. For the optimization process, these limitations must be, in some way, taken into account.
The first optimization constraints are the upper and lower bounds of the proposed geometric parameters. It is easier to find a solution for a smaller search space. For this specific problem, the boundaries could be determined based on allowable overall dimensions of the flight simulator and dimensions of the payload. Even when bounds are known, often there is a standard set of values to choose from. This type of problem is known as a mixed integer problem. Table 2 shows predefined ranges of geometric parameter values and possible steps for values between bounds. If the precision of the manufacturing process is 0.01 mm, then the step can be 0.01 mm. If a larger step is chosen, the search space is smaller and if a smaller step is chosen, it is not possible to produce obtained geometry with that precision. These values for steps are chosen in order to lower search space. In this way, search space and the standard set for values of geometric parameters are defined.
The next step is the definition of nonlinear constraints; two constraints of this type are given with Equations (22) and (23). If these inequalities are satisfied, then the desired position and orientation of the platform are achievable in terms of joints motion. In addition, there must be no interference between the legs of the mechanism. This type of constraint for lower levers can be defined as follows:
min D i D j 2 > r m i n , i j ,
where D i and D j are any points on closed line segments (from B i to A i and from B j to A j , respectively) of two lower levers that are part of different legs. This ensures that the minimum distance (expressed with Euclidean norm) between any two lower levers is always larger than the predefined value r m i n , and this can be adapted for any part of a mechanism.
The following constraints ensure that the selected actuator can be used. Nonlinear constraints based on necessary torque and allowed forces for actuators are given with the following inequality:
| M m , i |   < M m , m a x , | Fr R |   < F r R , m a x , | Fa R | < F a R , m a x ,
where M m , m a x is maximum allowable torque while F r R , m a x and F a R , m a x are maximal allowable radial and axial force for gearbox.

6.2. Fitness Function

If all defined constraints are satisfied for one set of geometric parameter values, then for this set, the corresponding score in the fitness function must be calculated. In this case, the implementation of the fitness function and chosen performance indicators need to ensure that the final solution is optimal for the flight simulator. It should be noted that the implementation of the fitness function should be tailored to a specific aircraft or class of aircraft.
To determine the value of the performance indicators, 27 points in space were selected (shown in Figure 13). These points are obtained as a mesh grid constructed with the following three vectors (dimensions are in mm):
x g = 150 , 0 , 150 T , y g = 150 , 0 , 150 T , z g = 75 , 0 , 75 T
Values of dexterity, maximal pitch, and roll angles as performance indicators ( η j , θ j , m a x , and φ j , m a x , where j = 1 , 2 , , 27 ) are combined within a fitness function using a weighted sum approach (defined with the following equation). In addition, the boundaries for angles are introduced to obtain values between 0 and 1, while the value of η j is already in this interval. The largest possible angles are calculated within predefined boundaries and with all constraints for each point.
y o f = 100 k = 1 3 100 27 j = 1 27 b k I k , j , k = 1 3 b k = 1
After introducing performance indicators, the previous equation for calculation of penalty value (score) within the fitness function becomes:
y o f = 100 100 27 j = 1 27 b 1 η j + b 2 θ j , m a x θ j , m i n 2 θ m a x + b 3 φ j , m a x φ j , m i n 2 φ m a x

6.3. Settings

Table 3 shows the values of variables introduced in previous equations and which are necessary for the optimization process. These values are selected based on available electric actuators and gearboxes on the market, payload weight and size, and based on desired values of possible angles.
Settings for RCMIGA are shown in Table 4. These values were chosen as most suitable for this problem after comparative analysis with different values.
Optimization stopping criteria are shown in Table 5.

7. Results

The obtained values of the geometric parameters for the final optimization solution are given in Table 6. This is the obtained optimal solution for the values which are adopted and shown in Table 3 and for the chosen implementation of the fitness function (Equation (47)).
It should be noted that optimization settings and fitness function implementation can be easily adapted for other applications.
This paper’s primary result is an algorithm capable of designing mechanisms with sufficient characteristics for flight simulation, taking into account all imposed constraints. Starting from values of geometric parameters that are generated based on a random uniform distribution with integer values within lower and upper bounds (later mapped to real values of geometric parameters), the algorithm has obtained a solution that can be manufactured and used for flight simulation.
Termination of optimization occurred because the max stall generation stopping criterion was reached. As shown in Figure 14, optimization stopped before reaching 600 generations, with the best penalty value of 52.842. Optimization found a solution that satisfies all constraints after five generations and reached a penalty value of 55 after the first 100 generations.
The kinematic model of optimized mechanism geometry is shown in Figure 15, and it is verified that this geometry of the mechanism has values of performance indicators the same as they are calculated within the optimization process. Figure 11 and Figure 13 show the workspace for this particular set of geometric parameters.
Optimization began without any assumption or known solution. In the first generation, values of geometric parameters for each individual of the population are generated using a random uniform distribution. In the first five generations, none of the 5000 individuals in the population satisfied implemented nonlinear constraints. In the sixth generation, the first individuals satisfied all constraints and obtained the penalty value as a result of the evaluation of the fitness function. This search for individuals capable of satisfying all constraints is possible thanks to the implementation of crossover and mutation functions. Later these functions, together with elitism and selection, enabled convergence towards the final result, as shown in Figure 14.
Figure 16a shows the maximum required actuator torque in the O x y plane when all other external coordinates have zero value. Figure 16b shows the value of the dexterity indicator in the same plane.
Figure 17a,b shows maximal reachable values of pitch and roll angles in the O x y plane when all other external coordinates have zero value. As expected, the mechanism has the best performance near the home position, and its capabilities are reduced by changing the value of any external coordinate.
The following two tables (Table 7 and Table 8) show maximal and minimal values of each external coordinate. These values are maximal and minimal values of the particular external coordinate that the platform can reach (a solution of inverse kinematics exists). During this calculation, only coordinate z was variable, and all other external coordinates had zero value. These results show the capabilities of the obtained mechanism.
In order to experimentally verify the characteristics of the mechanism and everything that was analyzed in this paper, a first scaled-down prototype of the flight simulator mechanism was made (shown in Figure 18).
Based on the presented solution of the inverse kinematic problem, all equations are implemented in the microcontroller of the control system. As part of the verification process, the platform moved in accordance with the desired movement, which was preprogrammed. All the assumed physical limitations of the mechanism also proved to be correctly implemented, and the calculated workspace corresponds to the one actually obtained. Using different sensors, it is possible to measure the positioning precision of the platform. It was first successfully tested whether actuators are able to achieve the desired angle based on the sent control value. Experiments with the assembled mechanism were based on sending control values to the mechanism and measuring the position and orientation of the platform in order to compare it with calculated values. This method is used to test each position and orientation within the workspace.
The motion monitoring system for the Stewart platform is presented in paper [62], and it can be used for verification. There are also vision-based control systems, as described in [63] that can also be used for monitoring and verification of motion.
When the mechanism is geometrically unambiguously defined, it is possible to move on to its materialization, in the sense of transforming a kinematic model into a three-dimensional model with all the accompanying information on the basis of which it can be manufactured. The beginning and the end of the materialization process are shown in Figure 19.
Besides physical experiments, for research and verification, it is very useful to do computer-based simulations. In paper [64], computer-aided design (CAD) software is used for visualization of the workspace, while papers [65,66] presented simulation environments for this type of mechanism.
After all the programs were tested on a scaled-down prototype of the flight mechanism simulator and after the optimized geometry was obtained, a functional full-size prototype of the flight simulator mechanism is developed and manufactured with sufficient precision to match obtained values of geometric parameters. This prototype of a low-cost flight simulator with electric rotary actuators and optimized geometry for flight simulation is then used for all experiments. The mechanism for different control values is shown in Figure 20.
This system can be used with flight simulation software that supplies the system with necessary motion data, or it can be used for a replay of captured data from the flight, but it can also be manually controlled. The system proved capable of flight simulation after testing with preprogrammed trajectory characteristic for flight simulation in accordance with the most used airplane maneuvers.

8. Conclusions

In this paper, an algorithm for obtaining optimal geometry for the mechanism of the flight simulator based on the Stewart platform with rotary actuators is shown. There are algorithms that can be used in cases when the simulator cannot reach a particular position due to saturation of some degrees of freedom, to provide the feeling as if the real motion has been achieved (washout algorithms). Besides that, a good workspace and dynamic response are still a critical part of the design. Very important are the eleven geometric parameters which are proposed. They can fully define the geometry of the simulator with all constraints. Optimal values of geometric parameters were obtained using the real coded mixed integer genetic algorithm with all constraints and the appropriate fitness function that can be defined to suit many different design criteria and requirements. The considered optimization process is time efficient and can take advantage of parallel computing. No software library is required for determining geometry based on geometric parameters, for solving inverse and forward kinematics, or for the optimization algorithm. They can be implemented in any programming language using basic mathematical functions. Described algorithms are programmed, and they are fully automatic from the initial population to the final result.
It is shown that obtained geometry based on defined geometrical parameters can materialize, and two different prototypes were successfully developed. All obtained results and proposed algorithms are experimentally tested on the scaled-down model and on a full-scale prototype. A whole electrical system is developed for these prototypes, including angle sensing for lower levers and high-speed control of variable frequency drives. Developed programs for microcontrollers and desktop applications for sending configuration parameters and desired commands for the system are equally important.
Shown solutions for inverse and kinematics problems of the rotary Stewart platform in the first placed allowed optimization of the geometry, but equally important are imposed constraints and chosen performance indicators for flight simulation.
The optimization approach shown in this paper is not specific to this mechanism and can be easily adapted to other types of parallel mechanisms mentioned earlier. Further works should consider other optimization algorithms and compare their performances.

Author Contributions

Conceptualization, M.D.P., A.M.G. and D.M.P.; methodology, M.D.P. and A.M.G.; software, M.D.P. and N.G.R.; validation, A.M.G. and D.M.P.; formal analysis, M.D.P. and M.G.P.; investigation, M.D.P., M.G.P. and N.G.R.; resources, M.D.P., A.M.G. and D.M.P.; data curation, M.D.P., M.G.P. and N.G.R.; writing—original draft preparation, M.D.P.; writing—review and editing, M.D.P. and A.M.G.; visualization, M.D.P. and N.G.R.; supervision, A.M.G. and D.M.P.; project administration, M.D.P. All authors have read and agreed to the published version of the manuscript.

Funding

This research received no external funding.

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Data Availability Statement

Not applicable.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Stewart, D. A platform with six degrees of freedom. Proc. Inst. Mech. Eng. 1965, 180, 371–386. [Google Scholar] [CrossRef]
  2. Fichter, E.F. A Stewart Platform-Based Manipulator: General Theory and Practical Construction. Int. J. Robot. Res. 1986, 5, 157–182. [Google Scholar] [CrossRef]
  3. Gao, X.; Lei, D.; Liao, Q.; Zhang, G. Generalized Stewart-Gough platforms and their direct kinematics. IEEE Trans. Rob. 2005, 21, 141–151. [Google Scholar]
  4. Lee, J.D.; Geng, Z. A dynamic model of a flexible Stewart platform. Comput. Struct. 1993, 48, 367–374. [Google Scholar] [CrossRef]
  5. Dasgupta, B.; Mruthyunjaya, T. Closed-form dynamic equations of the general Stewart platform through the Newton-Euler approach. Mech. Mach. Theory 1998, 33, 993–1012. [Google Scholar] [CrossRef]
  6. Dasgupta, B.; Mruthyunjaya, T. A Newton-Euler formulation for the inverse dynamics of the Stewart platform manipulator. Mech. Mach. Theory 1998, 33, 1135–1152. [Google Scholar] [CrossRef]
  7. Dasgupta, B.; Choudhury, P. A general strategy based on the Newton-Euler approach for the dynamic formulation of parallel manipulators. Mech. Mach. Theory 1999, 34, 801–824. [Google Scholar] [CrossRef]
  8. Ji, Z. Analysis of design parameters in platform manipulators. J. Mech. Des. 1996, 118, 526–531. [Google Scholar] [CrossRef]
  9. Hua, C.; Weishan, C.; Junkao, L. Optimal design of stewart platform safety mechanism. Chin. J. Aeronaut. 2007, 20, 370–377. [Google Scholar]
  10. Jiang, Q.; Gosselin, C. The maximal singularity-free workspace of the Gough-Stewart platform for a given orientation. J. Mech. Des. 2008, 130, 112304-1–112304-8. [Google Scholar] [CrossRef]
  11. Jiang, Q.; Gosselin, C. Maximal singularity-free total orientation workspace of the Gough-Stewart platform. J. Mech. Robot. 2009, 1, 034501-1–034501-4. [Google Scholar] [CrossRef]
  12. Dasgupta, B.; Mruthyunjaya, T. The Stewart platform manipulator: A review. Mech. Mach. Theory 2000, 35, 15–40. [Google Scholar] [CrossRef]
  13. Furqan, M.; Suhaib, M.; Ahmad, N. Studies on Stewart platform manipulator: A review. J. Mech. Sci. Technol. 2017, 31, 4459–4470. [Google Scholar] [CrossRef]
  14. Harib, K.; Srinivasan, K. Kinematic and dynamic analysis of Stewart platform based machine tool structures manipulator. Robotica 2003, 21, 541–554. [Google Scholar] [CrossRef]
  15. Wapler, M.; Urban, V.; Weisner, T.; Stallkamp, J.; Durr, M.; Hiller, A. A Stewart platform for precision surgery. Trans. Inst. Meas. Control. 2003, 25, 329–334. [Google Scholar] [CrossRef]
  16. Chi, W.; Ma, H.; Wang, C.; Zhao, T. Research on Control of Stewart Platform Integrating Small Attitude Maneuver and Vibration Isolation for High-Precision Payloads on Spacecraft. Aerospace 2021, 8, 333. [Google Scholar] [CrossRef]
  17. Wang, Y.; Soltani, M.; Hussain, D.M.A.; Christensen, R.M. Design and Implementation of Attitude Stabilization System for Marine Satellite Tracking Antenna. Electronics 2018, 7, 398. [Google Scholar] [CrossRef] [Green Version]
  18. Velasco, J.; Calvo, I.; Barambones, O.; Venegas, P.; Napole, C. Experimental Validation of a Sliding Mode Control for a Stewart Platform Used in Aerospace Inspection Applications. Mathematics 2020, 8, 2051. [Google Scholar] [CrossRef]
  19. Neitmann, M.; Rothe, T.; Kappel, E.; Hühne, C. Assembly of Compliant Structures with Autonomous Industrial Mobile Manipulators (AIMM) Using an End Effector with Active Deformation Compensation for the Assembly of Flaps. Machines 2022, 10, 291. [Google Scholar] [CrossRef]
  20. Liu, Z.; Cai, C.; Yang, M.; Zhang, Y. Testing of a MEMS Dynamic Inclinometer Using the Stewart Platform. Sensors 2019, 19, 4233. [Google Scholar] [CrossRef] [Green Version]
  21. Kausar, Z.; Shah, M.F.; Masood, Z.; Rehman, H.Z.U.; Khaydarov, S.; Saeed, M.T.; Razmkhah, O.; Yaqoob, H. Energy Efficient Parallel Configuration Based Six Degree of Freedom Machining Bed. Energies 2021, 14, 2642. [Google Scholar] [CrossRef]
  22. Bo, A.P.L.; Casas, L.; Cucho-Padin, G.; Hayashibe, M.; Elias, D. Control Strategies for Gait Tele-Rehabilitation System Based on Parallel Robotics. Appl. Sci. 2021, 11, 11095. [Google Scholar] [CrossRef]
  23. Summa, S.; Gori, R.; Freda, L.; Castelli, E.; Petrarca, M. Development of a Dynamic Oriented Rehabilitative Integrated System (DORIS) and Preliminary Tests. Sensors 2019, 19, 3402. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  24. Stenzel, T.; Sajkowski, M.; Hetmańczyk, J.; Boratyński, T. Application of 6-DOF parallel manipulator for optoelectronic surveillance systems development. In Proceedings of the IEEE 19th International Power Electronics and Motion Control Conference (PEMC), Gliwice, Poland, 25–29 April 2021. [Google Scholar]
  25. Zhan, G.; Niu, S.; Zhang, W.; Zhou, X.; Pang, J.; Li, Y.; Zhan, J. A Docking Mechanism Based on a Stewart Platform and Its Tracking Control Based on Information Fusion Algorithm. Sensors 2022, 22, 770. [Google Scholar] [CrossRef] [PubMed]
  26. Campos, A.; Quintero, J.; Saltaren, R.; Ferre, M.; Aracil, R. An Active helideck testbed for floating structures based on a Stewart-Gough platform. In Proceedings of the 2008 IEEE/RSJ International Conference on Intelligent Robots and Systems, Tegucigalpa, Honduras, 22–26 September 2008. [Google Scholar]
  27. Patel, Y.D.; George, P.M. Parallel Manipulators Applications—A Survey. Mod. Mech. Eng. 2012, 2, 57–64. [Google Scholar] [CrossRef] [Green Version]
  28. Su, Y.; Duan, B.; Zheng, C. Genetic design of kinematically optimal fine tuning Stewart platform for large spherical radio telescope. Mechatronics 2001, 11, 821–835. [Google Scholar] [CrossRef]
  29. Joumah, A.; Albitar, C. Design Optimization of 6-RUS Parallel Manipulator Using Hybrid Algorithm. Int. J. Inf. Technol. Comput. Sci. 2018, 2, 83–95. [Google Scholar] [CrossRef] [Green Version]
  30. Gao, Z.; Zhang, D.; Ge, Y. Design optimization of a spatial six degree-of-freedom parallel manipulator based on artificial intelligence approaches. Robot. Comput. Integr. Manuf. 2010, 26, 180–189. [Google Scholar] [CrossRef]
  31. Zamani, H.; Nadimi-Shahraki, H.M.; Gandomi, H.A. QANA: Quantum-based avian navigation optimizer algorithm. Eng. Appl. Artif. Intell. 2021, 104, 104314. [Google Scholar] [CrossRef]
  32. Zamani, H.; Nadimi-Shahraki, H.M.; Gandomi, H.A. Starling murmuration optimizer: A novel bio-inspired algorithm for global and engineering optimization. Comput. Methods Appl. Mech. Eng. 2022, 392, 114616. [Google Scholar] [CrossRef]
  33. Nadimi-Shahraki, H.M.; Zamani, H. DMDE: Diversity-maintained multi-trial vector differential evolution algorithm for non-decomposition large-scale global optimization. Expert Syst. Appl. 2022, 198, 116895. [Google Scholar] [CrossRef]
  34. Stoughton, R.; Arai, T. A Modified Stewart Platform Manipulator with improved Dexterity. IEEE Trans. Robot. Autom. 1993, 9, 166–173. [Google Scholar] [CrossRef]
  35. Xie, Z.; Li, G.; Liu, G.; Zhao, J. Optimal design of a Stewart platform using the global transmission index under determinate constraint of workspace. Adv. Mech. Eng. 2017, 9, 1–14. [Google Scholar] [CrossRef]
  36. Cardona, M. A new approach for the forward kinematics of general stewart-gough platforms. In Proceedings of the 2015 IEEE Thirty Fifth Central American and Panama Convention (CONCAPAN XXXV), Nice, France, 11–13 November 2015. [Google Scholar]
  37. Guo, H.B.; Li, H.R. Dynamic analysis and simulation of a six degree of freedom Stewart platform manipulator. Proc. Inst. Mech. Eng. Part C J. Mech. Eng. Sci. 2006, 220, 61–72. [Google Scholar] [CrossRef]
  38. Zhou, C.; Fang, Y. Design and Analysis for a Three-Rotational-DOF Flight Simulator of Fighter-Aircraft. Chin. J. Mech. Eng. 2018, 31, 55. [Google Scholar] [CrossRef] [Green Version]
  39. Advani, S.; Hosmann, R.; Haeck, N. Integrated Design of a Motion Cueing Algorithm and Motion-Base Mechanism for a Wright Flyer Simulator. In Proceedings of the AIAA Modeling and Simulation Technologies Conference and Exhibit, Monterey, CA, USA, 5–8 August 2002. [Google Scholar]
  40. Jones, M. Motion cueing optimisation applied to rotorcraft flight simulation. CEAS Aeronaut. J. 2017, 8, 523–539. [Google Scholar] [CrossRef]
  41. Wei, M.-Y. Design of a DSP-Based Motion-Cueing Algorithm Using the Kinematic Solution for the 6-DoF Motion Platform. Aerospace 2022, 9, 203. [Google Scholar] [CrossRef]
  42. Wang, S.; Fu, L. Predictive washout filter design for VR-based motion simulator. In Proceedings of the 2004 IEEE International Conference on Systems, Man and Cybernetics, The Hague, The Netherlands, 10–13 October 2004. [Google Scholar]
  43. Liao, C.; Huang, C.; Chieng, W. A Novel Washout Filter Design for a Six Degree-of-Freedom Motion Simulator. JSME Int. J. Ser. C 2004, 47, 626–636. [Google Scholar] [CrossRef] [Green Version]
  44. Asadi, H.; Mohamed, S.; Nelson, K.; Nahavandi, S.; Zadeh, D. Human Perception-Based Washout Filtering Using Genetic Algorithm. In Proceedings of the LNCS 22nd International Conference on Neural Information Processing (ICONIP 2015), Istanbul, Turkey, 9–12 November 2015. [Google Scholar]
  45. Eftekhari, M.; Karimpour, H. Emulation of pilot control behavior across a Stewart platform simulator. Robotica 2018, 36, 588–606. [Google Scholar] [CrossRef]
  46. Yoshikawa, T. Manipulability of Robotic Mechanisms. Int. J. Robot. Res. 1985, 4, 3–9. [Google Scholar] [CrossRef]
  47. Huang, T.; Whitehouse, D.J.; Wang, J. The local dexterity, optimal architecture and design criteria of parallel machine tools. Ann. CIRP 1998, 47, 347–351. [Google Scholar] [CrossRef]
  48. Merlet, J.P. Jacobian, Manipulability, Condition Number, and Accuracy of Parallel Robots. J. Mech. Des. 2006, 128, 199–206. [Google Scholar] [CrossRef]
  49. Liu, G.; Zheng, S.; Liu, X.; Wang, Y.; Han, J. Formulating an Invariant Manipulability Index of Gough-Stewart Platform. Adv. Mater. Res. 2012, 479–481, 2321–2326. [Google Scholar] [CrossRef]
  50. Fassi, I.; Legnani, G.; Tosi, D. Geometrical conditions for the design of partial or full isotropic hexapods. J. Robot. Syst. 2005, 22, 507–518. [Google Scholar] [CrossRef]
  51. Deep, K.; Singh, K.P.; Kansal, M.L.; Mohan, C. A real coded genetic algorithm for solving integer and mixed integer optimization problems. Appl. Math. Comput. 2009, 212, 505–518. [Google Scholar] [CrossRef]
  52. Bakar, A.; Ke, L.; Liu, H.; Xu, Z.; Wen, D. Design of Low Altitude Long Endurance Solar-Powered UAV Using Genetic Algorithm. Aerospace 2021, 8, 228. [Google Scholar] [CrossRef]
  53. Deb, K. An efficient constraint handling method for genetic algorithms. Comput. Methods Appl. Mech. Eng. 2000, 186, 311–338. [Google Scholar] [CrossRef]
  54. Deep, K.; Tahakur, M. A new crossover operator for real coded genetic algorithms. Appl. Math. Comput. 2007, 188, 895–911. [Google Scholar] [CrossRef]
  55. Deep, K.; Tahakur, M. A new mutation operator for real coded genetic algorithms. Appl. Math. Comput. 2007, 193, 211–230. [Google Scholar] [CrossRef]
  56. Bhattacharya, S.; Hatwal, H.; Ghosh, A. On the optimum design of Stewart platform type parallel manipulators. Robotica 1995, 13, 133–140. [Google Scholar] [CrossRef]
  57. Molina, F.A.L.; Rosario, J.M.; Dumur, D. Multi-Objective Design of Parallel Manipulator Using Global Indices. Open Mech. Eng. J. 2010, 4, 37–47. [Google Scholar] [CrossRef] [Green Version]
  58. Ríos, A.; Hernández, E.E.; Valdez, S.I. A Two-Stage Mono- and Multi-Objective Method for the Optimization of General UPS Parallel Manipulators. Mathematics 2021, 9, 543. [Google Scholar] [CrossRef]
  59. Chatterjee, D.; Ghosal, A. Design of a semi-regular Stewart platform manipulator for a desired workspace. In Proceedings of the 14th National Conference on Machines and Mechanisms (NaCoMM-09), Durgapur, India, 17–18 December 2009. [Google Scholar]
  60. Advani, S.; Nahon, M.; Albronda, J. Optimization of Six-Degrees-of-Freedom Motion Systems for Flight Simulators. In Proceedings of the Modeling and Simulation Technologies Conference, New Orleans, LA, USA, 11–13 August 1997. [Google Scholar]
  61. Advani, S.; Giovannetti, D.; Blum, M. Design of a Hexapod Motion Cueing System for the NASA Ames Vertical Motion Simulator. In Proceedings of the AIAA Modeling and Simulation Technologies Conference and Exhibit, Monterey, CA, USA, 5–8 August 2002. [Google Scholar]
  62. Wei, M.-Y. Design and Implementation of Inverse Kinematics and Motion Monitoring System for 6DoF Platform. Appl. Sci. 2021, 11, 9330. [Google Scholar] [CrossRef]
  63. Zhu, M.; Huang, C.; Song, S.; Gong, D. Design of a Gough–Stewart Platform Based on Visual Servoing Controller. Sensors 2022, 22, 2523. [Google Scholar] [CrossRef]
  64. St-Onge, B.M.; Gosselin, C. Singularity Analysis and Representation of the General Gough-Stewart Platform. Int. J. Robot. Res. 2000, 19, 271–288. [Google Scholar] [CrossRef]
  65. Molina, F.A.L.; Rosario, J.M.; Sanchez, O.F.A. Simulation environment proposal, analysis and control of a stewart platform manipulator. In Proceedings of the 7th Brazilian Conference on Dynamics, Control and Applications (DINCON 2008), Sao Paulo, Brazil, 7–9 May 2008. [Google Scholar]
  66. Inner, B.; Kucuk, S. A novel kinematic design, analysis and simulation tool for general Stewart platforms. Simulation 2013, 89, 876–897. [Google Scholar] [CrossRef]
Figure 1. Closed kinematic chain.
Figure 1. Closed kinematic chain.
Applsci 12 07085 g001
Figure 2. Stewart platform with rotary actuators.
Figure 2. Stewart platform with rotary actuators.
Applsci 12 07085 g002
Figure 3. Global and platform’s reference frame.
Figure 3. Global and platform’s reference frame.
Applsci 12 07085 g003
Figure 4. Geometric parameters of one leg.
Figure 4. Geometric parameters of one leg.
Applsci 12 07085 g004
Figure 5. Geometric parameters of the mechanism’s base.
Figure 5. Geometric parameters of the mechanism’s base.
Applsci 12 07085 g005
Figure 6. Geometric parameters of the mechanism’s platform.
Figure 6. Geometric parameters of the mechanism’s platform.
Applsci 12 07085 g006
Figure 7. Axes of actuator and lower lever joint.
Figure 7. Axes of actuator and lower lever joint.
Applsci 12 07085 g007
Figure 8. Axes of platform and upper lever joint.
Figure 8. Axes of platform and upper lever joint.
Applsci 12 07085 g008
Figure 9. Axes of spherical joints.
Figure 9. Axes of spherical joints.
Applsci 12 07085 g009
Figure 10. Single leg loop closure.
Figure 10. Single leg loop closure.
Applsci 12 07085 g010
Figure 11. (a) Top and (b) bottom view of the workspace for zero orientation.
Figure 11. (a) Top and (b) bottom view of the workspace for zero orientation.
Applsci 12 07085 g011
Figure 12. Flowchart of real coded mixed integer genetic algorithm.
Figure 12. Flowchart of real coded mixed integer genetic algorithm.
Applsci 12 07085 g012
Figure 13. Red points are for evaluation of the performance indicators.
Figure 13. Red points are for evaluation of the performance indicators.
Applsci 12 07085 g013
Figure 14. Change of penalty value (score) in reference to generation.
Figure 14. Change of penalty value (score) in reference to generation.
Applsci 12 07085 g014
Figure 15. Kinematic model of optimized mechanism geometry.
Figure 15. Kinematic model of optimized mechanism geometry.
Applsci 12 07085 g015
Figure 16. (a) Maximal required actuator torque and (b) dexterity of mechanism.
Figure 16. (a) Maximal required actuator torque and (b) dexterity of mechanism.
Applsci 12 07085 g016
Figure 17. (a) Maximal pitch and (b) roll angles.
Figure 17. (a) Maximal pitch and (b) roll angles.
Applsci 12 07085 g017
Figure 18. Scaled-down prototype of the mechanism (physical and 3D model).
Figure 18. Scaled-down prototype of the mechanism (physical and 3D model).
Applsci 12 07085 g018
Figure 19. Materialization of the mechanism.
Figure 19. Materialization of the mechanism.
Applsci 12 07085 g019
Figure 20. Experiment with a prototype of an optimized flight simulator mechanism.
Figure 20. Experiment with a prototype of an optimized flight simulator mechanism.
Applsci 12 07085 g020
Table 1. Example of geometric parameter values for some mechanism.
Table 1. Example of geometric parameter values for some mechanism.
ParameterValue
a230 mm
s1110 mm
R p 520 mm
R b 840 mm
γ p
γ b 35°
ε −39°
τ l l −122°
τ j p −12°
μ l l −18°
μ j p −1°
Table 2. Value range of geometric parameters for optimization.
Table 2. Value range of geometric parameters for optimization.
ParameterValue RangeStep
a100 mm to 400 mm10 mm
s600 mm to 1000 mm10 mm
R p 400 mm to 800 mm10 mm
R b 700 mm to 1500 mm10 mm
γ p 5° to 55°
γ b 5° to 55°
ε −90° to 90°
τ l l −180° to 180°
τ j p −90° to 90°
μ l l −90° to 90°
μ j p −90° to 90°
Table 3. Necessary optimization variables and their values.
Table 3. Necessary optimization variables and their values.
VariableValue
Vector of sum weights b = 0.4 0.3 0.3 T
Boundaries for angles θ m a x = 35 °, φ m a x = 35 °, λ m a x = 35 °
Gearbox characteristics x R = 110 mm, a R = 162 mm, b R = 122 mm
Max allowed torque M m , m a x = 200 Nm
Max allowed radial and axial forces F r R , m a x = 5000 N, F a R , m a x = 1000 N
Allowed lever distance r m i n = 100 mm
Payload mass and center of inertia m = 250 kg, C in = 0 0 500 T mm
Table 4. Settings for the Genetic Algorithm.
Table 4. Settings for the Genetic Algorithm.
OptionValue
Population size5000
Elite count500
Crossover fraction0.3
Table 5. Settings for stopping criteria of optimization.
Table 5. Settings for stopping criteria of optimization.
CriterionValue
Max generations1000
Max stall generations200
Max time12 h
Max stall time1 h
Desired fitness function value0
Fitness function value tolerance10−9
Table 6. Values of geometric parameters for the final solution.
Table 6. Values of geometric parameters for the final solution.
ParameterValue
a250 mm
s1000 mm
R p 490 mm
R b 700 mm
γ p 44°
γ b 25°
ε 39°
τ l l 19°
τ j p −81°
μ l l −31°
μ j p 14°
Table 7. Maximal values of external coordinates.
Table 7. Maximal values of external coordinates.
External CoordinateValueCoordinate z
x640 mm−38 mm
y670 mm−91 mm
z290 mm290 mm
ψ 67.5°43 mm
θ 31.5°33 mm
φ 38.5°−6 mm
Table 8. Minimal values of external coordinates.
Table 8. Minimal values of external coordinates.
External CoordinateValueCoordinate z
x−640 mm−38 mm
y−750 mm−89 mm
z−180 mm−180 mm
ψ −67.5°43 mm
θ −31.5°33 mm
φ −35°78 mm
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Petrašinović, M.D.; Grbović, A.M.; Petrašinović, D.M.; Petrović, M.G.; Raičević, N.G. Real Coded Mixed Integer Genetic Algorithm for Geometry Optimization of Flight Simulator Mechanism Based on Rotary Stewart Platform. Appl. Sci. 2022, 12, 7085. https://doi.org/10.3390/app12147085

AMA Style

Petrašinović MD, Grbović AM, Petrašinović DM, Petrović MG, Raičević NG. Real Coded Mixed Integer Genetic Algorithm for Geometry Optimization of Flight Simulator Mechanism Based on Rotary Stewart Platform. Applied Sciences. 2022; 12(14):7085. https://doi.org/10.3390/app12147085

Chicago/Turabian Style

Petrašinović, Miloš D., Aleksandar M. Grbović, Danilo M. Petrašinović, Mihailo G. Petrović, and Nikola G. Raičević. 2022. "Real Coded Mixed Integer Genetic Algorithm for Geometry Optimization of Flight Simulator Mechanism Based on Rotary Stewart Platform" Applied Sciences 12, no. 14: 7085. https://doi.org/10.3390/app12147085

APA Style

Petrašinović, M. D., Grbović, A. M., Petrašinović, D. M., Petrović, M. G., & Raičević, N. G. (2022). Real Coded Mixed Integer Genetic Algorithm for Geometry Optimization of Flight Simulator Mechanism Based on Rotary Stewart Platform. Applied Sciences, 12(14), 7085. https://doi.org/10.3390/app12147085

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop