GENERATION OF CONTROLS FOR A SIMULATOR MOBILE PLATFORM

Information

  • Patent Application
  • 20100070248
  • Publication Number
    20100070248
  • Date Filed
    September 14, 2009
    15 years ago
  • Date Published
    March 18, 2010
    14 years ago
Abstract
The present invention relates to a method for generating motion controls for a mobile platform of a vehicle simulator. The method uses, as input, accelerations calculated by a process for simulating the behavior of the vehicle. The method according to the invention comprises the steps of: filtering the accelerations calculated accelerations by use of a filter constructed according to a mathematical model of human perception of a motion; calculating successive positions of the mobile platform as a function of the filtered acceleration controls; scaling the positions of the mobile platform as a function of physical limitations of the mobile platform, to produce scaled successive positions of the mobile platform; and calculating acceleration controls to be applied by the mobile platform, as a function of the scaled successive positions of the mobile platform, to produce calculated acceleration controls.
Description
CROSS REFERENCE TO RELATED APPLICATIONS

The present application claims priority to French Patent Application Serial No. 08/05020, filed on Sep. 12, 2008, the contents of which are hereby incorporated by reference in its entirety.


FIELD OF THE INVENTION

The present invention relates to a method and a device for generating motion controls for a mobile platform of a vehicle simulator.


DESCRIPTION OF PRIOR ART

Most of the time, pilots of vehicles such as airplanes, trucks and helicopters, are trained by virtue of simulators reproducing behaviors of the vehicle. The objective of a simulator is notably to reproduce a virtual environment representing a real setting in which the vehicle is deploying and also the control station of the vehicle. The simulator therefore generally comprises a driver station at the center of an audiovisual device making it possible to reproduce an outside environment. This type of simulator, a so-called motionless simulator, does not reproduce the motions of the vehicle. Motionless simulators give rise, for the pilot using them, to sensations of slowness. These sensations of slowness are related to an inertia of the simulated vehicle which seems to be less reactive than a real vehicle. The sensation of slowness is particularly prejudicial when training pilots to react rapidly if faced with a dangerous situation. For example, tracking a trajectory with a motionless simulator requires corrections of low frequency, with a large amplitude, this hardly being realistic. Moreover, long duration training may induce nauseous states for drivers.


In order to alleviate the aforesaid drawbacks, most vehicle simulators use mobile simulation platforms to reproduce attitudes and accelerations of the simulated vehicle. The mobile platforms allow more realistic reproduction of sensations felt by a driver of a vehicle in a real situation. The performance of the drivers, thus trained, is thereby enhanced relative to the use of a motionless simulator.


Mobile platforms can have up to six degrees of freedom, including three degrees in rotation and three degrees in translation. These degrees of freedom make it possible to reproduce motions of pitch, roll, yaw, surge, sway and heave, depending on the simulated vehicle. A standard kinematics of a mobile platform is that of the Stewart platform, implementing six hydraulic or electric actuators in order to move a vehicle control cabin. This type of platform with motion can only imperfectly reproduce the sensations felt by the driver. Indeed, physical constraints, related to a maximum elongation of the actuators, limits the field of the drivers possible perceptions. For example, a typical value of maximum elongation for actuators used in aircraft simulators is one and a half meters. This maximum elongation does not make it possible to simulate accelerations of long duration for example. However, the human brain being particularly sensitive to variation in acceleration, that is to say to the third derivative of position, more satisfactory physiological effects can be obtained with limited actuator lengths, by using for example artifices. Certain artifices make it possible notably to reproduce long-duration effects. For example, pitching the nose of the cabin up, carried out with an angular velocity below a threshold of human perception, gives an impression of linear acceleration prolonged by the effect of the weight of the body on the back of the pilot's seat.


Mobile platforms are controlled by control algorithms which take account of the physical limitations of the platform. Simulation platform control algorithms make it possible to generate controls to be applied by the platform so as to carry out a motion of the control cabin in accordance with instructions originating from simulation software. Control algorithms have evolved little over the last thirty years, notably, the algorithm used to produce a control for the platform generally comprises the following steps:

    • a first step in the course of which accelerations originating from a simulated vehicle are divided by two, and then used as input to calculate the control;
    • the accelerations can thereafter be transformed into load factors, in the course of a second step, or else can pass through a filter whose coefficients are optimized empirically and then multiplied by a gain.


The result of these operations is an acceleration provided to the mobile platform in the form of a control.


The control behaves as a filter whose coefficients are determined in an empirical manner. In addition to reproducing to within a scale factor the accelerations of the real vehicle at the level of the pilot's head, the objective of the control . is also to bring the platform back to a neutral position. The calculation of the load factors and the filtering serve to optimize the sensation produced by the motions of the platform. The gain makes it possible to reduce the amplitude of the motions of the platform so as to avoid driving the actuators into mechanical bumpers. Driving the actuators into the bumpers results notably in premature wear of the actuators, which are particularly expensive to replace. The existing algorithms make it possible to bound the values of the controls to be taken into account by the platform so as to reduce the amplitude of the motion of the platform. The controls of the motion of the platform lead to unsatisfactory reproduction of sensations. Moreover, to guarantee that the platform will not bump, safety margins are taken into account in calculating the control. The safety margins restrict the domain of use as a function of the mechanical capabilities of the system notably in terms of usable length of actuators and therefore in terms of feeling of the acceleration by the pilot.


SUMMARY OF THE INVENTION

A possible improvement can consist in defining bounds of use of the platform as a function of the domain of use of the real vehicle such as the flight domain for an aircraft. Globally, the performance induced by the use of this improvement is not satisfactory in regard to reproduction of sensations as well as in terms of compliance with the mechanical constraints of the platform.


An aim of the invention is notably to alleviate the aforesaid drawbacks. For this purpose, the subject of the invention is a method for calculating motion controls for a mobile platform of a vehicle simulator. The method uses notably, as input, accelerations calculated by software for simulating the behavior of the vehicle. The method comprises notably the following steps:

    • a first calculation of acceleration controls to be applied by the platform, filtering the accelerations calculated with the aid of a filter constructed according to a mathematical model of human perception of a motion;
    • a second calculation of successive positions of the platform as a function of the filtered acceleration controls;
    • a scaling of the positions of the platform as a function of the physical limitations of the platform;
    • a third calculation of the acceleration controls to be applied by the platform, as a function of the scaled successive positions of the platform.


The positions of the platform can be defined by the positions of the geometric center of the platform and by the lengths of the actuators moving the platform.


The length of the actuators can be scaled by a first scaling function scaling(l), for example such that:







scaling


:



R
+




[


l
min

,

l
max


]






with






Avec


:



scaling


(
l
)



=

{







l
min


,



l


l
min










=
l

,



l


[


l
min

,

l
max


]












l
max


,



l


l
max











(



scaling



l


)



l
=

l
min



l
=

l
max




=
0









where


l represents a length of an actuator;


lmin represents a minimum physically possible length to be implemented by the platform;


lmax represents a maximum physically possible length to be implemented by the platform.


The scaling of the positions can take account of limitations on rate of elongation of the actuators of the platform.


The limitations on rate of elongation of the actuators can be taken into account using a second scaling function scalingν(ν), for example such that:







scaling
v



:



R


[


v
min

,

v
max


]







with






avec


:




scaling
v



(
v
)



=

{







v
min


,



v


v
min










=
v

,



v


[


v
min

,

v
max


]












v
max


,



v


v
max











(




scaling
v




v


)



v
=

v
min



v
=

v
max




=
0









where


ν represents a rate of elongation of an actuator;


νmin represents a minimum elongation rate physically achievable by the actuators of the platform;


νmax represents a maximum elongation rate physically possible by the actuators of the platform.


The accelerations provided by the simulation software can be compared with a threshold value below which the accelerations are no longer perceived by a human being. Only the accelerations above the threshold value give for example a control to be applied by the mobile platform.


The third calculation of the acceleration controls can apply a Newton algorithm in an iterative manner.


The subject of the present invention is also a device for calculating motion controls for a mobile platform of a vehicle simulator. The device according to the invention comprises notably:

    • a first block for calculating acceleration controls to be applied by the platform by filtering accelerations provided by software for simulating the behavior of the vehicle, with the aid of a filter constructed according to a mathematical model of human perception of a motion;
    • a second block for calculating controls to be applied by the platform as a function of physical limitations of the platform.


The second block can comprise:

    • a first module for calculating successive positions of the platform as a function of the accelerations of controls to be applied by the platform;
    • a second module for scaling the positions calculated as a function of the physical limitations of the platform;
    • a third module calculating accelerations to be applied by the platform as a function of the scaled positions.


The positions of the platform can be defined by the positions of the geometric center of the platform and by the lengths of the actuators of the platform.


The length of the actuators can be scaled by a first scaling function scaling(l), for example such that:







scaling


:



R
+




[


l
min

,

l
max


]






with






Avec


:



scaling


(
l
)



=

{







l
min


,



l


l
min










=
l

,



l


[


l
min

,

l
max


]












l
max


,



l


l
max











(



scaling



l


)



l
=

l
min



l
=

l
max




=
0









where


l represents a length of an actuator,


lmin represents a minimum physically possible length to be implemented by the platform;


lmax represents a maximum physically possible length to be implemented by the platform.


The scaling of the positions can take account of limitations on rate of elongation of the actuators of the platform.


The limitations on rate of elongation of the actuators can be taken into account using a second scaling function scalingν(ν) for example such that:








scaling
v



:


R



[


v
min

,

v
max


]






with






avec


:




scaling
v



(
v
)



=

{







v
min


,



v


v
min










=
v

,



v


[


v
min

,

v
max


]












v
max


,



v


v
max











(




scaling
v




v


)



v
=

v
min



v
=

v
max




=
0









where


ν represents a rate of elongation of an actuator;


νmin represents a minimum elongation rate physically achievable by the actuators of the platform;


νmax represents a maximum elongation rate physically possible by the actuators, of the platform.


The main advantages of the invention are notably that it is simple and inexpensive to implement and can be adapted to multiple mobile simulation platforms.





BRIEF DESCRIPTION OF THE DRAWINGS

Other characteristics and advantages of the invention will become apparent with the aid of the description which follows, given by way of nonlimiting illustration and with regard to the appended drawings which



FIG. 1: a schematic example of various control steps for a simulation platform according to the prior art;



FIG. 2: a schematic of various possible steps of calculating a control for a simulation platform according to the invention;



FIG. 3: a diagram of various blocks for calculating the control of the simulation platform according to the invention;



FIG. 4: a schematic of various possible steps of obtaining a filter for the calculation of an acceleration control;



FIG. 5
a: a schematic of various possible steps of calculating a direct kinematics of the actuators of the mobile simulation platform;



FIG. 5
b: a schematic representation of a mobile deck of a Stewart platform;



FIG. 5
c: a schematic representation of a fixed deck of a Stewart platform;



FIG. 6
a: a first function for scaling the acceleration control;



FIG. 6
b: a second function for scaling the acceleration control;



FIG. 7: a schematic of various possible calculation steps for defining inverse-kinematics parameters so as to produce the acceleration control.





MORE DETAILED DESCRIPTION


FIG. 1 represents a schematic of various control steps for a vehicle simulation mobile platform, according to the prior art.


Training to drive a vehicle uses notably simulation software 1 making it possible to reproduce virtually the movements of the vehicle as well as the evolution of the environment of the vehicle in the course of the movements. The simulation software 1 makes it possible for example to take account of the controls of a pilot of the vehicle so as to cause the simulated vehicle to deploy accordingly, while reproducing the real behavior of the vehicle in a similar case. The simulation software 1 calculates a software acceleration 2 characteristic of the real motion of the vehicle. Next a first module 3 calculates an acceleration control to be applied to the platform while taking account of the mechanical constraints 4 of the platform. The acceleration control thus calculated takes the form of a calculated acceleration 5, provided to the simulation platform 6, which applies it so as to execute the acceleration control 7.


The acceleration control 7 can be calculated by dividing the input acceleration by a factor so as to guarantee compliance with the physical constraints of the simulation platform.


This type of acceleration control calculation according to the prior art does not make it possible to ensure realistic representation of the accelerations felt by a pilot of a real vehicle. Indeed, the accelerations that can be implemented are limited and therefore do not make it possible to reproduce an acceleration of long duration, for example. Moreover, the platform system is not used in an optimal manner. Indeed, significant zones of incursion of the actuators are never invoked so as to guard against the wearing of the actuators by avoiding bringing them to an end-of-stroke bumper. Moreover, the acceleration division factor takes no account of very strong and sudden accelerations which may thus damage the platform system.



FIG. 2 represents a schematic example of several possible steps 21, 22, 23, 24, 25 for calculating an acceleration control for a vehicle simulator. A succession of the steps for calculating an acceleration control forms a method for generating controls for a simulator mobile platform 20 according to the invention.


Simulation software 1 provides one or more accelerations Uak of the simulated vehicle, also dubbed software accelerations. In the course of a first step 21 of thresholding of the software acceleration Uak, the modulus of the acceleration Uak of the simulated vehicle is compared with the modulus of a threshold acceleration Uthresh. The threshold acceleration Uthresh corresponds to an acceleration value short of which the acceleration of the simulated vehicle is not perceived by a human being. When the modulus of the acceleration Uak is strictly greater than the modulus of the threshold acceleration Uthresh, the acceleration used as input to the calculation of an acceleration control is the difference between the acceleration of the simulated vehicle Uak and the threshold acceleration Uthresh. When the modulus of the acceleration Uak is less than or equal to the modulus of the threshold acceleration Uthresh, then the acceleration used as input to the calculation of an acceleration control is zero. In this case, no control is calculated.


A second step 22 of the method 20 according to the invention is a step of calculating an acceleration control 22, termed the optimal control, as a function of the input acceleration, defined in the course of the first step 21. The calculation of the optimal control 22 uses a mathematical model, in the form of a transfer function. The mathematical model represents a human perception of the attitudes and accelerations of the real vehicle, by way of various organs of the inner ear. Such a mathematical model of sensations can use the model developed by R. Telban and F. Cardullo to apply a procedure termed optimal control notably described in the following publication: “Motion Cueing Algorithms: A human centered approach, State University of New York at Binghampton, NASA Langley Research Center Hampton, Va.”. Other mathematical models of perception can also be used without it being necessary to modify the method 20 according to the invention. The procedure for calculating the optimal control uses a filter applied to the acceleration defined in the course of the first step 21. The filter makes it possible to obtain an acceleration to be imposed on the simulation platform so as to reproduce sensations close to the accelerations felt in a real case.


A third step 23 of the method 20 according to the invention is a direct kinematics calculation step 23. The direct kinematics makes it possible to pass from a calculated control acceleration, the optimal control calculated in the course of the second step 22, to the positions of actuators which propel the mobile platform. The kinematics calculation makes it possible to determine the following kinematic data:

    • positions of the centroid of the mobile platform;
    • lengths of the actuators;
    • rates of elongation of the actuators, such as they would be if the optimal acceleration control arising from the second step 22 were applied directly.


      Generally, in a system of parallel forces having fixed points of application, the point through which their resultant constantly passes, whatever the direction of these forces, is dubbed the centroid of the system. In the present invention, the system is a mobile platform, the centroid is then the center of gravity of the mobile platform.


A fourth step 24 of the method 20 according to the invention is a step 24 of scaling the lengths calculated in the course of the direct kinematics step 23. The scaling step 24 makes it possible to ensure compliance with the physical constraints of the mobile platform. The lengths of the actuators must, indeed, remain between a minimum length and a maximum length, achievable by the mobile platform. The scaling of the actuator lengths can be carried out by using for example a scaling function: scaling(l) such that:











scaling


:



R
+




[


l
min

,

l
max


]







with







Avec


:



scaling


(
l
)



=

{







l
min


,



l


l
min










=
l

,



l


[


l
min

,

l
max


]












l
max


,



l


l
max











(



scaling



l


)



l
=

l
min



l
=

l
max




=
0










(
1000
)







where


l represents a length of an actuator calculated in the course of the direct kinematics step 23;


lmin represents a minimum physically possible length to be implemented by the platform;


lmax represents a maximum physically possible length to be implemented by the platform;


the condition








(



scaling



l


)



l
=

l
min



l
=

l
max




=
0




corresponds to a condition applicable to the derivatives of the function scaling(l) making it possible to avoid discontinuities in the rates of displacement of the platform.


Indeed, discontinuities in the rates of displacement of the mobile platform lead to pulses at the level of the accelerations which impede the feeling of the sensations by the pilot of the simulated vehicle. Avoiding rate discontinuities therefore makes it possible to improve the feeling of the motion by the pilot of the simulated vehicle.


Compliance with the physical constraints of the mobile platform also requires that the rates of displacement of the platform be constrained. The rates of displacement of the platform correspond to the rates of application of the lengths of the actuators calculated in the course of the direct kinematics step 23. The rates of displacement of the platform can be constrained by using a function for scaling the rates taking the rate of displacement of the mobile platform as parameter:












scaling
v



:


R



[


v
min

,

v
max


]







with







avec


:




scaling
v



(
v
)



=

{







v
min


,



v


v
min










=
v

,



v


[


v
min

,

v
max


]












v
max


,



v


v
max











(




scaling
v




v


)



v
=

v
min



v
=

v
max




=
0










(
1002
)







where


ν represents a rate of elongation of an actuator calculated in the course of the direct kinematics step 23;


νmin represents a minimum elongation rate physically achievable for the actuators of the mobile platform;


νmax represents a maximum elongation rate physically possible for the actuators of the mobile platform.


the condition








(




scaling
v




v


)



v
=

v
min



v
=

v
max




=
0




corresponds to a condition applicable to the derivatives of the function scalingν(ν) making it possible to avoid discontinuities of the accelerations in the displacement of the mobile platform, also making it possible to improve the feeling of the motion.


The scaled lengths and rates of elongation are then compatible with the mechanical limits of the mobile platform. The scaling step 24 therefore advantageously makes it possible to introduce, into the method according to the invention for calculating the optimal control, a simulation of the kinematics of the platform so as to avoid situations in which the actuators would reach an end of stroke. This advantageously makes it possible to preserve the lifetime of the actuators and therefore of the mobile platform system. Avoiding situations where the actuators are at the end of their stroke makes it possible, advantageously, to avoid unrealistic spurious sensations caused by impacts of the actuators on elastomers damping the ends of stroke of the actuators.


A fifth step 25 is an inverse kinematics calculation step 25 which makes it possible, by using a Newton algorithm in an iterative manner, to pass back from the actuator lengths, calculated in the course of the scaling step 24, to the position of the centroid of the mobile platform, and then to the control accelerations Usk necessary for the displacement of the mobile platform. The control accelerations Usk then allow displacement of the platform with actuator lengths corrected as a function of the performance of the platform.



FIG. 3 represents an example of a functional architecture defining various blocks 30, 31 for implementing the method for generating acceleration controls 20 according to the invention. The various functional blocks 30, 31 can be parts of a program executing on one or more processors of a computer.


A first functional block 30 can be a block which ensures the calculation of the optimal control as a function of the accelerations of a vehicle 35 such as the software accelerations Usk. The calculation of the optimal control 30 comprises notably the first and second steps 21, 22 of the method according to the invention.


A second functional block 31 comprises various processing modules 32, 33, 34, ensuring that the optimal control calculated by the first functional block 30 complies with the physical constraints of the platform. The second functional block 31 comprises notably:

    • a first direct kinematics calculation module 32, implementing the direct kinematics calculation step 23 of the method 20 according to the invention;
    • a second scaling module 33, carrying out the step 24 of scaling the lengths calculated in the course of the direct kinematics calculation step 23 of the method 20 according to the invention;
    • a third inverse kinematics calculation module 34, implementing the step of calculating the inverse kinematics 25 of the method 20 according to the invention.


      The second functional block 31 provides control accelerations 36 to the mobile platform.


The direct kinematics module 32 and inverse kinematics module 34 depend solely on the geometry of the mobile platform. The direct kinematics module 32 and inverse kinematics module 34 are therefore adaptable to any type of simulator with motion without it being necessary to modify the functional architecture of the program implementing the method 20 according to the invention.



FIG. 4 represents various possible steps 40 for obtaining a filter applicable for the calculation of the optimal control 22 represented in FIG. 2.


The filter for calculating the optimal control can notably be determined in the following manner:

    • definition 41 of a real specific force applied to the pilot of the simulated vehicle as a function of the acceleration Uak provided by the vehicle simulation software 1;
    • use 42 of models of a human vestibular system to define the ratios on the one hand between the specific force felt by the pilot and the real specific force applied to the pilot, and on the other hand between the angular velocity felt by the pilot and the real angular velocity applied to the pilot;
    • modeling 43 of a global system of feeling of the acceleration by the pilot of the vehicle as a function of the vestibular system model;
    • construction 44 of a system of equations defining:
      • an error of sensation of the pilot of the simulator with respect to the feeling of a pilot of a real vehicle;
      • an error between the state of a real vehicle and the state of the simulated vehicle;
    • definition 45 of a criterion for minimizing the system of equations defining the errors;
    • solution 46 of the system of equations defining the errors, as a function of the minimizing criterion defined;
    • obtaining 47 of a filter to be applied to the acceleration Uak provided by the simulation software 1 so as to obtain the optimal control in the form of an acceleration to be applied by the mobile platform.


      The application of the filter makes it possible to minimize the errors in the feeling of the acceleration by the pilot of the simulated vehicle.


Generally a human being is sensitive, when subjected to an acceleration, to a force termed the specific force {right arrow over (f)}PS. The specific force {right arrow over (f)}PS can be defined for the pilot of the simulated vehicle by taking the pilot's head as point of application of the specific force {right arrow over (f)}PS. The specific force can be defined by the following formula:






{right arrow over (f)}
PS
={right arrow over (a)}
PS
−{right arrow over (g)}  (1003)


where {right arrow over (a)}PS denotes the acceleration at the level of the pilot's head, and {right arrow over (g)} represents the gravitational force.


The acceleration {right arrow over (a)}PS can be expressed in the following manner:





{right arrow over (a)}PS={right arrow over (a)}S++2.{right arrow over (ω)}S{right arrow over ({dot over (R)}+{right arrow over ({dot over (ω)}S{right arrow over (R)}+{right arrow over (ω)}S({right arrow over (ω)}S{right arrow over (R)})  (1004)


by taking:


{right arrow over (a)}S: acceleration applied to the mobile platform of the simulator;


{right arrow over (ω)}S: the angular velocity of the platform;


{right arrow over (R)}: the vector between the center of gravity of the platform and the center of gravity of the pilot.


In expression (1004), it may be considered that:


{right arrow over (ω)}S({right arrow over (ω)}S{right arrow over (R)}) is negligible;


{right arrow over (ω)}S{right arrow over ({dot over (R)} and are zero since the distance between the pilot's head and the center of gravity of the simulator is considered to be fixed.


By putting










ω


.

S

=



(




ϕ
.






θ
.






ψ
.




)






and






R



=

(




R
X






R
Y






R
Z




)



,




we obtain:













ω


.

S



R



=

(






R
Z

·

θ
¨


-


R
Y

·

ψ
¨










R
X

·

ψ
¨


-


R
Z

·

ϕ
¨










R
Y

·

ϕ
¨


-


R
X

·

θ
¨






)





(
1005
)







And therefore:











a


PS

=

(





a
X

+


R
Z

·

θ
¨


-


R
Y

·

ψ
¨









a
Y

+


R
X

·

ψ
¨


-


R
Z

·

ϕ
¨









a
Z

+


R
Y

·

ϕ
¨


-


R
X

·

θ
¨






)





(
1006
)







{right arrow over (g)} can thereafter be expressed in the reference frame of the simulator by using a matrix Tmob-fix for passing between the terrestrial relative reference frame and the mobile reference frame of the simulator:










T

mob


-






fix


=

(




cos






θ
·
cos






ψ




cos






θ
·
sin






ψ





-
sin






θ










sin






ϕ
·
sin







θ
·
cos






ψ

-






cos






ϕ
·
sin






ψ











sin






ϕ
·
sin







θ
·
sin






ψ

+






cos






ϕ
·
cos






ψ










sin






ϕ
·







cos





θ














cos






ϕ
·
sin







θ
·
cos






ψ

+











sin






ϕ
·
sin






ψ











cos






ϕ
·
sin







θ
·
sin






ψ

-






sin






ϕ
·
cos






ψ










cos






ϕ
·







cos





θ







)





(
1007
)







We then obtain:











[

T

mob


-


fix


]

·

(



0




0




g



)


=

(






-
g

·
sin






θ







g
·
sin







ϕ
·
cos






θ







g
·
cos







ϕ
·
cos






θ




)





(
1008
)







The specific force can therefore be expressed thus:











f


PS

=




a


PS

-

g



=

(





a
X

+


R
Z

·

θ
¨


-


R
Y

·

ψ
¨


+


g
·
sin






θ








a
Y

+


R
X

·

ψ
¨


-


R
Z

·

ϕ
¨


-


g
·
sin







ϕ
·
cos






θ








a
Z

+


R
Y

·

ϕ
¨


-


R
X

·

θ
¨


-


g
·
cos







ϕ
·
cos






θ





)






(
1009
)







Among the systems available to a human being for ensuring his balance and his mobility is the vestibular system. The vestibular system is one of the main sensory systems for perceiving a movement and an orientation with respect to the vertical. Sensory receptors of the vestibular system are situated in the inner ear. The vestibular system makes it possible notably to evaluate a rate of displacement on the basis of an acceleration measured at the level of the inner ear of a human being. Indeed, the inner ear behaves like an instrument for measuring:

    • angular accelerations, by way of semi-circular canals;
    • linear accelerations, by way of otoliths.


      A modeling of the vestibular system makes it possible to represent sensations felt by a pilot to whom an acceleration is applied as a function of the acceleration applied. For example, it is possible to use models described by R. Telban, W. Wu, F. Cardullo in “Motion Cueing Algorithm Development: Initial investigation and redesign of the algorithms. State university of New York at Binghampton, NASA/CR-2000-209863, March 2005”.


A model of semi-circular canals can notably be described by the following relation:












ω
^

_


ω
_


=



H
SSC



(
s
)


=



τ
L



τ
a



s
2




(

1
+


τ
a


s


)



(

1
+


τ
S


s


)



(

1
+


τ
L


s


)








(
1010
)







and a model of otoliths can be described by the relation:












f
^

_


f
_


=



H
OTO



(
s
)


=


K


(

1
+


τ
a


s


)




(

1
+


τ
L


s


)



(

1
+


τ
S


s


)








(
1011
)







with:



{circumflex over (ω)}: an angular velocity felt;


ω: a “real” angular velocity;



{circumflex over (f)}: a specific force felt;



f: “real” specific force;


τS, τL, τa, K: time constants dependent on a degree of freedom involved and corresponding to the reaction times of the vestibular system.


On the basis of the models of the vestibular system (1010), (1011), it is possible to construct a global model of feeling of the acceleration by a pilot of the simulated vehicle moved by the mobile platform.


Several models of feeling can be constructed, the model described below is given by way of example.


Initially, it is possible to consider a global model of feeling in two dimensions, one dimension being along a first horizontal axis x and another dimension being along a second horizontal axis y for example. The acceleration Uak calculated by the simulation software can be expressed thus:










U
ak

=


u
_

=


(




u
1






u
2




)

=


(





ω
.

y






a
x




)

=

(




θ
¨






a
x




)








(
1012
)







In two dimensions, the otolith model (1011) becomes for example:












f
^

_


f
_


=



H
OTO



(
p
)


=


G
0

·


p
+

A
0




(

p
+

B
0


)



(

p
+

B
1


)









(
1013
)







with fx=ax+RZ·{umlaut over (θ)}g sin(θ)=f (1014), where G0, A0, B0, B1 are constants.


By considering that: sin(θ)=θ expression (1013) becomes:










f
^

=


G
0

·


p
+

A
0




(

p
+

B
0


)



(

p
+

B





1


)



·

[



(


R
Z

+

g
·

1

p
2




)

·

u
1


+

u
2


]






(
1014
)







Expression (1014) can then be put into the following form:









{





f
^

=



f
^

1

+


f
^

2










f
^

1

=








G
0

·

R
Z

·

p
3


+


G
0

·

A
0

·

R
Z

·

p
2


+








G
0

·
g
·
p

+


G
0

·

A
0

·
g







p
4

+


(


B
0

+

B
1


)

·

p
3


+


B
0

·

B
1

·

p
2




·

u
1










f
^

2

=





G
0

·
p

+


G
0

·

A
0





p
2

+


(


B
0

+

B
1


)

·
p

+


B
0

·

B
1




·

u
2










(
1015
)







In order to obtain a state representation of {circumflex over (f)}1, we put:














x
=

(




x
1






x
2






x
3






x
4




)


;


x
.

=

(





x
.

1







x
.

2







x
.

3







x
.

4




)


;









A

OTO_

1


=

[



A


B


0


0




C


0


0


0




0


D


0


0




0


0


E


0



]


;


B

OTO_

1


=

[



F




0




0




0



]


;













C

OTO_

1


=

[

1





1





1





1

]


;


D

OTO_





1


=

[
0
]


;




}




(
1016
)







and we seek A, B, C, D, E, F such that:









{





x
.

=



A

OTO_

1


·
x

+


B

OTO_

1


·
u










f
^

1

=



C

OTO_

1


·
x

+


D

OTO_

1


·
u













(
1017
)






(
1018
)










Expression (1018) becomes: {circumflex over (f)}1=x1+x2+x3+x4 (1019)


and expression (1017) becomes:









{





p
·

x
1


=


A
·

x
1


+

B
·

x
2


+

F
·

u
1










p
·

x
2


=

C
·

x
1









p
·

x
3


=

D
·

x
2









p
·

x
4


=

E
·

x
3










(
1020
)







Solving the system (118) gives:










x
1

=



F
·
p



p
2

-

A
·
p

+

B
·
C



·

u
1






(
1021
)







x
2

=



C
·
F



p
2

-

A
·
p

+

B
·
C



·

u
1






(
1022
)







x
3

=



D
·
C
·
F


p
·

(


p
2

-

A
·
p

+

B
·
C


)



·

u
1






(
1023
)







x
4

=



E
·
D
·
C
·
F



p
2

·

(


p
2

-

A
·
p

+

B
·
C


)



·

u
1






(
1024
)







Then, expression (1019) gives:















f
^

1

=







G
0

·

R
Z

·

p
3


+


G
0

·

A
0

·

R
Z

·








p
2

+


G
0

·
g
·
p

+


G
0

·

A
0

·
g







p
4

+


(


B
0

+

B
1


)

·

p
3


+


B
0

·

B
1

·

p
2










=







F
·

p
3


+

C
·
F
·

p
2


+







D
·
C
·
F
·
p

+

E
·
D
·
C
·
F







p
4

+

A
·

p
3


+

B
·
C
·

p
2




·

u
1






}




(

1025


)







(

1025


)



{





A
=

-

(


B
0

+

B
1


)








B
=

-



B
0

·

B
1



A
0









C
=

A
0







D
=

g


A
0

·

R
Z









E
=

A
0







F
=


G
0

·

R
Z











Hence


:







(
1025
)













A


OTO

_


1


=

[




-

(


B
0

+

B
1


)





-



B
0

-

B
1



A
0





0


0





A
0



0


0


0




0



g


A
0

·

R
Z





0


0




0


0



A
0



0



]


;








B


OTO

_


1


=

[





G
0

·

R
Z






0




0




0



]


;








C


OTO

_


1


=

[

1





1





1





1

]


;







D


OTO

_


1


=

[
0
]





}

.




(
1026
)







To obtain a state representation of {circumflex over (f)}2, we put:














x
=

(




x
1






x
2




)


;


x
.

=

(





x
.

1







x
.

2




)


;

u
=

u
2


;











A


OTO

_


2


=

[



A


B




C


D



]


;


B


OTO

_


2


=

[



E




F



]


;








C


OTO

_


2


=

[

0





1

]


;


D


OTO

_


2


=

[
0
]









}




(
1027
)







and we seek A, B, C, D, E, F such that:









{





x
.

=



A


OTO

_


2


·
x

+


B


OTO

_


2


·
u










f
^

1

=



C


OTO

_


2


·
x

+


D


OTO

_


2


·
u













(
1028
)






(
1029
)










Expression (129) then gives: {circumflex over (f)}2=x2 (1030) and expression (1028) gives:









{





p
·

x
1


=


A
·

x
1


+

B
·

x
2


+

E
·

u
2










p
·

x
2


=


C
·

x
1


+

D
·

x
2


+

F
·

u
2











(
1031
)







Solving the system of equations (1031), we obtain:
















f
^

2

=





G
0

·
p

+


G
0

·

A
0





p
2

+


(


B
0

+

B
1


)

·
p

+


B
0

·

B
1




·

u
2








=




F
·
p

+

C
·
E

-

A
·
F







p
2

-


(

A
+
D

)

·
p

+







D
·
A

-

C
·
B






·

u
2






}



{




F
=

G
0









C
·
E

-

A
·
F


=


G
0

·

A
0









A
+
D

=

-

(


B
0

+

B
1


)










D
·
A

-

C
·
B


=


B
0

·

B
1











(
1032
)







Arbitrarily fixing two parameters, we obtain:









{





A
=

1


(
prescribed
)








B
=


(


B
0

+

B
1

+
1

)

-


B
0

·

B
1









C
=

1





(
prescribed
)






(
impose
)











D
=

-

(


B
0

+

B
1

+
1

)








E
=


G
0

·

(


A
0

+
1

)








F
=

G
0











{









A


OTO

_


2


=

[



1




-

(


B
0

+

B
1

+
1

)


-


B
0

·

B
1







1



-

(


B
0

+

B
1

+
1

)





]








B


OTO

_


2


=

[





G
0

·

(


A
0

+
1

)







G
0




]








C


OTO

_


2


=

[

0





1

]








D


OTO

_


2


=

[
0
]











(
1033
)







Finally, the state representation of {circumflex over (f)} is deduced from the expression






{circumflex over (f)}={circumflex over (f)}
1
+{circumflex over (f)}
2.


The matrices relating to {circumflex over (f)} are:











A
OTO

=

[




A


OTO

_


1




0




0



A


OTO

_


2





]









B
OTO

=

[




B


OTO

_


1




0




0



B


OTO

_


2





]









C
OTO

=

[




C


OTO

_


1





C


OTO

_


2





]










D
OTO

=

[




D


OTO

_


1





D


OTO

_


2





]


,





with


:







(
1034
)












A
OTO

=

[




-

(


B
0

+

B
1


)





-



B
0

·

B
1



A
0





0


0


0


0





A
0



0


0


0


0


0




0



g


A
0

·

R
Z





0


0


0


0




0


0



A
0



0


0


0




0


0


0


0


1







-

(


B
0

+

B
1

+
1

)


-







B
0

·

B
1









0


0


0


0


1



-

(


B
0

+

B
1

+
1

)





]


;








B
OTO

=

[





R
Z

·

G
0




0




0


0




0


0




0


0




0




G
0

·

(


A
0

+
1

)






0



G
0




]


;








C
OTO

=

[

1





1





1





1





0





1

]


;







D
OTO

=

[

0





0

]









}




(
1035
)







The set of matrices (1035) is one of the possible state representations for the semi-circular canal model. Other representations can be used notably by modifying the values of the parameters fixed in an arbitrary manner.


In two dimensions, the semi-circular canal model (1010) becomes for example:










ω
^

=




p
2

·

τ
L

·

τ
A




(

1
+


τ
L

·
p


)



(

1
+


τ
S

·
p


)



(

1
+


τ
A

·
p


)




ω





(
1036
)







Knowing that










u
_

=


(




u
1






u
2




)

=


(





ω
.

y






a
x




)

=

(




θ
¨






a
x




)







(
1012
)







and that {dot over (ω)}y=p·ωy (1037) then expression (1036) becomes:










ω
^

=



p
·

τ
L

·

τ
A




(

1
+


τ
L

·
p


)



(

1
+


τ
S

·
p


)



(

1
+


τ
A

·
p


)





u
1






(
1038
)







Next we seek to express expression (1038) in the following manner:









{






x
.

_

=



A
SCC

·

x
_


+


B
SCC

·

u
_










ω
^

=



C
SCC

·

x
_


+


D
SCC

·

u
_











(
1039
)







Expanding expression (1038), we obtain the following expression:










ω
^

=



p
·

τ
L

·

τ
A








p
3

·

τ
L

·

τ
A

·

τ
S


+


p
2

·

(



τ
L

·

τ
A


+


τ
L

·

τ
S


+


τ
A

·

τ
S



)


+







p
·

(


τ
A

+

τ
L

+

τ
S


)


+
1





·

u
1






(
1040
)







Next, we put:










x
=

(




x
1









x
2






x
3







)


;


x
.

=

(





x
.

1










x
.

2







x
.

3







)


;

u
=

(




u
1






u
2




)


;









A
SCC

=

[



A


B


C




D


0


0




0


E


0



]


;









B
SCC

=

[



F


0




0


0




0


0



]


;









C
SCC

=

[

0





1





0

]


;








D
SCC

=

[

0





0

]






(
1041
)







and we seek A, B, C, D, E, F such that:









{





x
.

=



A
SCC

·
x

+


B
SCC

·
u









ω
^

=



C
SCC

·
x

+


D
SCC

·
u













(
142
)






(
143
)










Equation (1043) gives: {circumflex over (ω)}=x2 (1044) and equation (1042) gives:









{





p
·

x
1


=


A
·

x
1


+

B
·

x
2


+

C
·

x
3


+

F
·

u
1










p
·

x
2


=

D
·

x
1









p
·

x
3


=

E
·

x
2










(
1044
)







Solving the system (1044), we obtain:















ω
^

=





p
·

τ
L

·

τ
A











p
3

·

τ
L

·

τ
A

·

τ
S


+


p
2

·








(



τ
L

·

τ
A


+


τ
L

·

τ
S


+


τ
A

·

τ
S



)

+










p
·

(


τ
A

+

τ
L

+

τ
S


)


+
1





·

u
1








=





D
·
F
·
p



p
3

-

A
·

p
2


-

D
·
B
·
p

-

D
·
C
·
E



·

u
2








=






-

F

C
·
E



·
p




-

1

D
·
C
·
C





p
3


+


A

D
·
C
·
E


·

p
2


+


B

C
·
E


·
p

+
1


·

u
2










(
1045
)







and then:










(
1045
)







{





-

F

C
·
E



=


τ
L

·

τ
A









-

1

D
·
C
·
E



=


τ
L

·

τ
A

·

τ
S









A

D
·
C
·
E


=



τ
L

·

τ
A


+


τ
L

·

τ

S







+


τ
A

·

τ
S










B

C
·
E


=


τ
A

+

τ
L

+

τ
S











(
1046
)







Next we arbitrarily fix two of the variables A, B, C, D, E, F in order to solve the system (1046), thus obtaining, for example:









{




A
=

-




τ
L

·

τ
A


+


τ
L

·

τ
S


+


τ
A

·

τ
S





τ
L

·

τ
A

·

τ
S










B
=

-


(


τ
A

+

τ
L

+

τ
S


)



τ
L

·

τ
A










C
=

-

1


τ
L

·

τ
A










D
=

1

τ
S








E
=
1






F
=
1








(
1047
)







and then:





















A
CSS

=

[




-




τ
L

·

τ
A


+


τ
L

·

τ
S


+


τ
A

·

τ
S





τ
L

·

τ
A

·

τ
S







-


(


τ
A

+

τ
L

+

τ
S


)



τ
L

·

τ
A







-

1


τ
L

·

τ
A









1

τ
S




0


0




0


1


0



]








B
CSS

=

[



1


0




0


0




0


0



]











C
CSS

=

[

0





1





0

]












D
CSS

=

[
0
]














}




(
1048
)







The matrix set (1048) is one of the possible state representations for the semi-circular canal model. Other representations can be obtained by modifying the values of the parameters ascribed in an arbitrary manner.


Grouping together the state representations of the semi-circular canal and otolith models, we obtain for example:












A
V

=

(




A
SCC



0




0



A
OTO




)


;






B
V

=

(




B
SCC






B
OTO




)


;









C
V

=

(




C
SCC



0




0



C
OTO




)


;






D
V

=

(




D
SCC






D
OTO




)







(
1049
)







A representation of the global system incorporating the feeling of linear and angular accelerations by the pilot can thus take the form:









{







x
.

_

=



A
V

·

x
_


+


B
V

·

u
_











y
_

^

=



C
V

·

x
_


+


D
V

·

u
_








avec








y
_

=


feeling

feeling









(





ω
^

ressenti







f
^

ressenti




)






(
1050
)







Once the representation of the global system has been determined, the optimal control is determined by choosing and minimizing a constraining criterion:

    • an error e of sensation of the pilot of the simulated vehicle with respect to the sensations of a real vehicle pilot;
    • an error xe in the displacement of the mobile platform.


      Initially, two errors to be minimized are therefore constructed:









{






x
_

e

=


x
A

-

x
S








e
=


y
A

-

y
S










(
1051
)







The representation of the global feeling system (1050) then becomes:









{








x
.

_

e

=





x
.

_

A

-



x
.

_

S


=



A
V

·


x
_

A


+


B
V

·


u
_

A


-

(



A
V

·


x
_

S


+


B
V

·


u
_


S








)










e
_

=



C
V

·


x
_

A


+


D
V

·


u
_

A


-


C
V

·


x
_

S


-


D
V

·


u
_

S













{







x
.

_

e

=



A
V

·

(



x
_

A

-


x
_

S


)


+


B
V



(



u
_

A

-


u
_

S


)










e
_

=



C
V

·

(



x
_

A

-


x
_

S


)


+


D
V



(



u
_

A

-


u
_

S


)













(
1052
)







and then:









{







x
.

_

e

=



A
V

·


x
_

e


+


B
V

·

(



u
_

A

-


u
_

S


)










e
_

=



C
V

·


x
_

e


+


D
V

·

(



u
_

A

-


u
_

S


)











(
1053
)







An additional group of terms, namely the speed and the position of the centroid of the mobile platform, is then introduced: xd=t({dot over (x)}s xs) (1054)


The following state representation is thus obtained:









{






x
.

d

=




(



0


0




1


0



)




A
d





x
d


+



(



0


1




0


0



)




B
d





u
S










y
d

=

x
d









(
1055
)







Putting





x
=

[




x
e






x
d




]






and





y
=

[



e





y
d




]





and using the system (1055), we obtain:









{






x
.

=



(




A
v



0




0



A
d




)


x

+


(




B
v





0



)



u
a


+


(




-

B
v







B
d




)



u
s









y
=


(




C
v



0




0


I



)


x










and


:






(
1056
)






{









x
.

=


A
·
x

+
B





·

u
S


+

D
·

u
A









y
=

C
·
x










with





A

=

(




A
v



0




0



A
d




)


,





D
=

(




B
v





0



)


,





B
=

(




-

B
v







B
d




)


,





C
=

(




C
v



0




0


I



)







(
1057
)







The systems of equations (1056) and (1057) therefore define a state representation of the system to be solved in order to minimize the errors (1051).


It is then possible to define a minimization criterion that can, for example, be expressed in the following manner:









J
=

E


{




t





0


t





1





(





t



e
_


·

Q
d

·

e
_


+



x
_

d



t

·

R
d

·


x
_

d


+



u
_

s



t

·
R
·


u
_

s



)




t



}






(
1058
)







where Qd and Rd are positive semi-definite matrices and R a positive definite matrix.


The behavior of the real vehicle being unknown and given that in order to apply the procedure for the optimal acceleration control it is necessary to know a trajectory of the system in the state space, it is assumed that the displacement command for the real vehicle is constant between two instants of sampling of the trajectory of the system.


The minimization criterion (1058) can then be written in the following form:









J
=



1
2



{




t





0


t





1





(







x
_

d



t

·

R
d

·


x
_

d


+








u
_

s



t

·
R
·


u
_

s





)




t



}


+


1
2



{




t





0


t





1








t



e
_


·

Q
d

·

e
_





t



}







(
1059
)







Expression (1059) for the minimization criterion comprises:


a first term (txd·Rd·xd+tuS·R·uS) corresponding to a minimization of the error in the displacement:


a second term e·Qd·e to a minimization of the sensation error.


The criterion defined by expression (1059) therefore represents a compromise between the minimization of the two errors described by expression (1051).


Grouping the matrices Qd and Rd into a single matrix Q:









Q
=

(




Q
d



0




0



R
d




)





(
1060
)







the expression for the minimization criterion (1059) becomes:









J
=


1
2



{




t
0


t
1





(





t



y
_






·
Q
·

y
_


+


u
s



t

·
R
·

u
s



)




t



}






(
1061
)







with the matrix Q non-negative definite and the matrix R positive definite.


If we choose t1 fairly large, thus corresponding to an infinite horizon, then expression (1061) for the minimization criterion becomes:









J
=


1
2



{



0





(






t



y
_






·
Q



y
_


+




t




u
s

_


·
R
·


u
s

_



)




t



}






(
1062
)







To solve the system, we use the procedure for the optimal control which amounts to maximizing a Hamiltonian of the system defined by:









H
=


-


1
2



[





t


y





·
Q
·
y

+


u
s



t

·
R
·

u
s



]



+




t


λ



(


A
·
x

+

D
·

u
A


+

B
·

u
S



)







(
1063
)







Hamilton's canonical equations are as follows:

















x



t


=

H
λ











λ



t


=

-

H
x



,








(
1064
)





with
















x

t
=
0


=
0







λ

t
=
T


=
0








(
1065
)







The second Hamilton canonical equation









λ



t


=

-

H
x






gives:





{dot over (λ)}=tC·Q·C·x−tA·λ  (1066)


and maximizing the Hamiltonian gives: uS=R−1·tB·λ (1067).


Expression (1067) represents the optimal control.


It is then possible to define a system relating x and λ in the following manner:









{





x
.

=


A
·
x

+

B
·

R

-
1


·



t


B

·
λ

+

D
·

u
A










λ
.

=





t


C

·
Q
·
C
·
x

-




t


A

·
λ










(
1068
)







This is a case of a pursuit problem since e=yA−yS is arbitrary. We can therefore put: λ(t)=K(t)x(t)+k(t) (1069). By considering that e(t) is constant since uA is constant, we can then consider that when T is very large, K and k are constants, hence:





λ=K·x+k  (1070)


The system (1068) then becomes:









{





x
.

=


A
·
x

+

B
·

R

-
1


·



t


B

·

(


K
·
x

+
k

)


+

D
·

u
A










K
·

x
.


=





t


C

·
Q
·
C
·
x

-




t


A

·

(


K
·
x

+
k

)











(
1071
)







Replacing {dot over (x)} by its value, we then obtain:





(K·A+tA·K+K·B·R−1·tB·K−tC·Q·Cx=−(K·B·R−1·tB·k+K·D·uA+tA·k)  (1072)


for all x(t), hence:









{






K
·
A

+




t


A

·
K

+

K
·
B
·

R

-
1


·



t


B

·
K

-




t


C

·
Q
·
C


=
0








K
·
B
·

R

-
1


·



t


B

·
k

+

K
·
D
·

u
A


+




t


A

·
k


=
0








(
1073
)







Therefore K is a solution of the first equation of the system (1073): K·A+tA·+K+K·B·R·iB·K−tC·Q·C=0 the so-called Ricatti equation.


k can therefore be written in the following form:






k=−(K·B·R−1·tB+tA)−1·K·D·uA  (1074)





Let us put: M=−(K·B·R−1·tB+tA)−1·K·D  (1075)


We therefore obtain k=M·ua (1075′), the optimal control is then given by: uS=R·tB·(K·x+M·uA) (1076)


i.e. according to the expression for M: uS=R−1·tB·(K·x+M·uA) (1077)


Substituting the expression for uS into equation (1071), we obtain a differential equation making it possible to determine an evolution of the state vector x as a function of the input control ua:









{





x
.

=



(

A
+

B
·

R

-
1


·



t


B

·
K


)

·
x

+


(


B
·

R

-
1


·



t


B

·
M

+
D

)

·

u
A









0
=


K
·
A

+




t


A

·
K

+

K
·
B
·

R

-
1


·



t


B

·
K

-




t


C

·
Q
·
C










(
1078
)







Next we deduce from this an expression for a filter W(s) to be applied to the input control uas such that: uS=Ws×ua






W(s)=R−1·tB·K·[s·I−(A+B·R−1·tB·K)]−1·(B·R−1·tB·M  (1079)


The control us represents an optimal acceleration to be provided to the mobile platform so as to ensure a realistic displacement of the platform minimizing the error in sensation felt by the pilot of the simulated vehicle with respect to a pilot of a real vehicle.


It is also possible to consider a model of feeling in three dimensions, for a mobile platform system having six degrees of freedom. In this case, the acceleration used as input can be represented in the following manner:










u
_

=


(




u
1






u
2






u
3






u
4






u
5






u
6




)

=


(





ω
.

x







ω
.

y







ω
.

z






a
x






a
y






a
z




)

=

(




ϕ
¨






θ
¨






ψ
¨






x
¨






y
¨






z
¨




)







(
1080
)







The three-dimensional semi-circular canal model is given by the following expression:












ω
_




ω
_


=



H
SSC



(
s
)


=



τ
L



τ
a



s
2




(

1
+


τ
a


s


)



(

1
+


τ
S


s


)



(

1
+


τ
L


s


)








(
1010
)







with:



{dot over (ω)}=[{circumflex over ({dot over (φ)} {circumflex over ({dot over (θ)} {circumflex over ({dot over (ψ)}]′: a felt angular velocity;



ω=[{dot over (Φ)} {dot over (θ)} {dot over (ψ)}]′: a real angular velocity.


The three-dimensional otolith model is given by the following expression:












f
_




f
_


=



H
OTO



(
s
)


=


K


(

1
+


τ
a


s


)




(

1
+


τ
L


s


)



(

1
+


τ
S


s


)








(
1011
)








{circumflex over (f)}=[{circumflex over ({umlaut over (x)} {circumflex over (ÿ)} {circumflex over ({umlaut over (z)}]′: a felt specific force;



f=[{umlaut over (x)} ÿ {umlaut over (z)}]′: “real” specific force.


By considering the six degrees of freedom, the specific force may be written in a reference frame tied to the base of the simulator:










f
P

=

(





a
X

+


R
Z

·

θ
¨


-


R
Y

·

ψ
¨


+


g
·
sin






θ








a
Y

+


R
X

·

ψ
¨


-


R
Z

·

ϕ
¨


-


g
·
sin







ϕ
·
cos






θ








a
Z

+


R
Y

·

ϕ
¨


-


R
X

·

θ
¨


-


g
·
cos







ϕ
·
cos






θ





)





(
1081
)







Within the framework of an approximation for small angles and assuming that the pilot is vertically in line with the centroid of the mobile platform, that is to say RX=RY=0, the specific force may then be written:










f
P

=

(





a
X

+


R
Z

·

θ
¨


+

g
·
θ








a
Y

-


R
Z

·

ϕ
¨


-

g
·
ϕ








a
Z

-
g




)





(
1082
)







We can define us as a given comprising accelerations at the level of the centroid of the mobile platform:






u
s=[{dot over (ω)}x {dot over (ω)}y {dot over (ω)}z ax ay az]′=[u(1)u(2)u(3)u(4)u(5)u(6)]′  (1083)


We can thus express fP as a function of us:










f
P

=

(





u


(
4
)


+


(


R
Z

+


1

p
2



g


)

·

u


(
2
)










u


(
5
)


-


(


R
Z

+


1

p
2



g


)

·

u


(
1
)










u


(
6
)


-
g




)





(
1084
)







In the expression obtained (1084) the specific forces fP are decoupled along the three axes. Indeed, if we write:






f
P
=[f
px fpy fpz],u1=[{umlaut over (θ)}{umlaut over (x)}]′,u2=[{umlaut over (φ)}ÿ]′,u3=[{umlaut over (ψ)}{umlaut over (z)}]′(1085)


Then, we have: fpx=f(u1), fpy=f(u2), fpz=f(u3). It is therefore possible to apply the solution procedure for the optimal control used in the two-dimensional case for the specific forces along the x and y axes. For the specific force along the z axis, it is possible for example to use a simple reproduction of the accelerations.


We consider a state system such as constructed previously:









{





x
.

=


A
·
x

+

B
·

u
s


+

D
·

u
a









y
=

C
·
x









(
1086
)







The system (1086) must then be discretized to obtain a discrete-time acceleration control filter. Obtaining a discrete-time filter makes it possible to forecast the instant at which the physical limits of the platform will be attained. The discretized system (1086) then becomes:









{





x

k
+
1


=



A
1

·

x
k


+


B
1

·

u
sk


+


D
1

·

u
ak










y
k

=

C
·

x
k










(
1087
)







With:

Te a small discretization time-step;


Al=eA·Te·B.


Dl=Te·eA·Te·B.


If k is a time-step number, the criterion to be minimized, becomes in the three-dimensional case:









J
=



1
2






k
=
0


N
-
1





x
k



t




C
T

·
Q
·

Cx
k





+


u
sk



t

·
R
·

u
sk







(
1088
)







The Hamiltonian associated with the minimization criterion (1088) is given by the expression:










H
=



-

1
2


·




k
=
0


N
-
1





x
k



t

·



t


C

·
Q
·
C
·

x
k




+


u
sk



t

·
R
·

u
sk


+




k
=
0


N
-
1




λ

k
+
1




t






·

(




A
1

·

x
k


+

B
1





·

u
sk


+


D
1

·

u
ak




)






(
1089
)







The canonical equations corresponding to the expression for the Hamiltonian (1089) are as follows:









{





x

k
+
1


=

H

λ

k
+
1










λ
k

=

H

x
k










(
1090
)







Maximization of the Hamiltonian therefore gives:





R·usk+B1T·λk+1=0usk=R−1·B1T·λk+1  (1090)


The system relating x and λ is then:









{





x

k
+
1


=



A
1

·

x
k


+


B
1

·

R

-
1


·

B
1



t

·

λ

k
+
1



+


D
1

·

u
ak










λ
k

=



-



t


C


·
Q
·
C
·

x
k


+


A
1



t

·

λ

k
+
1












(
1092
)







If N is assumed to be large, in a stationary case with infinite horizon, we therefore have:





λk=K·xk+k∀k≧1  (1093)


The system (1092) then becomes:









{






0
=



(





t


C

·
Q
·
C

+
K

)

·

x
k


-


A
1



t

·
K
·

x

k
+
1



+


(

I





-
t



A
1




)

·
k









x

k
+
1


=



(

I
-


B
1

·

R

-
1


·

B
1



t

·
K


)


-
1


·

(






D
1

·

u
ak


+


B
1

·

R

-
1


·









B
1



t

·
k

+


A
1

·

x
k






)











(
1094
)







By substitution, we obtain the following equation:





[(tC·Q·C+K)−tA1+K·(I−B1·R−1·tB1·K)'11·A1]·xk−[tA1·K·(I−B1·R−1·tB1·K)−1·(D1·uak+B1·R−1·tB1+k)−(I−tA1k]=0  (1095)


Equation (1095) being true ∀xk, the system (1096) described in the Annex is therefore obtained.


Using the following lemma: (A−BCD)−1=A−1+A−1B·(C−1−DA−1B)−1DA−1 on the first equation of the system (1096), said equation then becomes:





(tC·Q·C+K)−tA1·K·(I−B1·R−1·tB1+K)−1·tA1=0  (1097)


And then:






t
C·Q·C+K−
t
A
1
·K·A
1

t
A
1
·K·B
1)(R−tB1·K·B1)−1·tB1·K·A1=0  (1098)


Expression (1098) being a discrete-time Ricatti equation.


The second equation of the system (1096) becomes the system (1099):















k
=



(

I
-

A
1



t

-


A
1



t

·
K
·


(




I
-


B
1

·








R

-
1


·

B
1



t

·
K




)


-
1


·

B
1

·

R

-
1


·

B
1



t



)


-
1


·








(


A
1



t

·
K
·


(

I
-


B
1

·

R

-
1


·

B
1



t

·
K


)


-
1


·

D
1


)

·

u
ak











}










Putting




(
1099
)















N
D

=

I
-

A
1



t

-


A
1



t

·
K
·


(




I
-


B
1

·








R

-
1


·

B
1



t

·
K




)


-
1







·

B
1

·

R

-
1


·

B
1



t



)


-
1


·






(



A
1



t

·
K
·


(




I
-


B
1

·








R

-
1


·

B
1



t

·
K




)


-
1






·

D
1

















}





(
1100
)







Expression (1099) can then be expressed in the following form:









{






k
=


N
D

·

u
ak













N
D

=

I
-

A
1



t

-


A
1



t

·
K
·


(


I
-

B
1




·

R

-
1





·

B
1



t




·
K


)


-
1







·

B
1

·

R

-
1


·

B
1



t



)


-
1


·






(



A
1



t

·
K



·


(

I
-


B
1

·

R

-
1


·

B
1



t

·
K


)


-
1


·

D
1












(
1101
)







We therefore obtain the following relation:









{





x

k
+
1


=



A
1

·

x
k


+


B
1

·

u
sk


+


D
1

·

u
ak










u
sk

=


R

-
1


·

B
1



t

·

(

K



·

x

k
+
1



+
k


)










(
1102
)







with K satisfying:






t
C·Q·C+K−
t
A
1
·K·
t
A
1

t
A
1
·K·B
1(R−tB1·K·B1)−1·tB1·K·A1=0





k=ND·uak






N
D
=I−
t
A
1

t
A
1
·K·(I−B1·R−1·tB1·K)−1·B1·R−1·tB1)−1−(tA1·K·(I−B1·R−1·tB1·K)−1·D1  (1103)


The system is then solved by substitution and the following form for the optimal control is obtained:






x
k+1
=[A
1
+B
1·(I−R−1·tB1·K·B1)−1·R−1·tB1·K·A1]·xk+[B1·(I−R−1·tB1·K·B1)−1)·(R−1·tB1·(K·D1+N))+D1]uak  (1104)


The filter to be applied to the input acceleration can therefore have for example the following form:





[B1·(I−R−1·tB1·K·B1)−1·(R−1·tB1·(K·D1+N))+D1]  (1105)



FIG. 5
a represents several possible steps 51, 52, 53 for the direct kinematics calculation 23 represented in FIG. 2.


A first step of the direct kinematics calculation 23 is a calculation of the length of the actuators 51 after application of the optimal control calculated in the course of the second step 22 of the control generating method according to the invention. To calculate the actuator extension length required for the application of the optimal control, it is firstly necessary to calculate the coordinates of the various points of attachment of the actuators of the mobile platform. Among the actuator attachment points, first attachment points are situated on a mobile part of the platform.


The platform considered is for example a Stewart platform. The calculations described subsequently are adapted for the example to the case of a Stewart platform.


A mobile part or mobile deck 54 of the Stewart platform can be represented, as in FIG. 5b, by a hexagon whose six vertices can be denoted B1, B2, B3, B4, B5, B5. The mobile deck 54 can be centered on a reference frame defined by two perpendicular axes, x, y. The mobile deck is defined such that: B4B5=B6B1=B2B3=E1.


We put:

C the center of the mobile deck and of the reference frame x, y;


β the angle between the vectors CB4, CB5;


R1 the radius of a circle 55 circumscribing the mobile deck 55.


Then








β
=

2
·

arctan
(


E
1


2
·




(

R
1

)

2

-


(


E
1

/
2

)

2





)






(
1106
)







and












CB
1

=

(





-

R
1




cos


(


π


/


3

-

β


/


2


)









-

R
1




sin


(


π


/


3

-

β


/


2


)






)


;













CB
2

=

(





-

R
1




cos


(


π


/


3

-

β


/


2


)









R
1



sin


(


π


/


3

-

β


/


2


)






)


;









CB
3

=

(





-

R
1




cos


(


π


/


3

+

β


/


2


)









R
1



sin


(


π


/


3

+

β


/


2


)






)


;









CB
4

=

(





R
1



cos


(

β


/


2

)









R
1



sin


(

β


/


2

)






)


;









CB
5

=

(





R
1



cos


(

β


/


2

)









-

R
1




sin


(

β


/


2

)






)


;







CB
6

=


(





-

R
1




cos


(


π


/


3

+

β


/


2


)









-

R
1




sin


(


π


/


3

+

β


/


2


)






)

.





(
1107
)







A fixed part or fixed deck 56 of the Stewart platform can be represented, as in FIG. 5c, by a hexagon whose six vertices can be denoted O1, O2, O3, O4, O5, O6. The fixed deck 56 can be centered on a reference frame defined by two perpendicular axes x_o, y_o. The mobile deck is defined such that: O1O2=O3O4=O5B6=E2.


We put:

O the center of the fixed deck and of the reference frame x_o, y_o;


α the angle between the vectors OO5, OO6;


R2 the radius of a circle 57 circumscribing the fixed deck 56.


Then








α
=

2
·

arctan
(


E
2


2
·




(

R
2

)

2

-


(


E
2

/
2

)

2





)






(
1108
)







and












OB
1

=

(





R
2



cos


(

α


/


2

)









-

R
2




sin


(

α


/


2

)






)


;













OB
2

=

(





-

R
2




cos


(

α


/


2

)









R
2



sin


(

α


/


2

)






)


;









OB
3

=

(





R
2



cos


(


π


/


3

+

α


/


2


)









R
2



sin


(


π


/


3

+

α


/


2


)






)


;









OB
4

=

(





R
2



cos


(


π


/


3

-

α


/


2


)









R
2



sin


(


π


/


2

-

α


/


2


)






)


;









OB
5

=

(





R
2



cos


(


π


/


3

-

α


/


2


)









-

R
2




sin


(


π


/


3

-

α


/


2


)






)


;







OB
6

=

(





R
2



cos


(


π


/


3

+

α


/


2


)









-

R
2




sin


(


π


/


3

+

α


/


2


)






)





(
1109
)







Expressing the vectors OiBi, i being an integer lying between one and six, in a reference frame tied to the ground, we deduce:












O
i



B
i


_

=




-


OO
i

_


+

OC
_

+


CB
i

_








=




(




-

xO
i







-

yO
i






0



)

+

(




x
c






y
c






z
c




)

+


[
T
]

·

(




xB
i






yB
i





0



)









=



(





x
C

+

cos






θ
·
cos







ψ
·

xB
i



+

cos






θ
·
sin







ψ
·

yB
i



-

xO
i








y
C

+


(




sin






ϕ
·
sin







θ
·








cos





ψ

-

cos






ϕ
·








sin





ψ




)

·

xB
i


+


(




sin






ϕ
·
sin







θ
·








sin





ψ

+

cos






ϕ
·








cos





ψ




)

·

yB
i


-

yO
i








z
C

+


(




cos






ϕ
·
sin







θ
·








cos





ψ

+

sin






ϕ
·








sin





ψ




)

·

xB
i


+


(




cos






ϕ
·
sin







θ
·








sin





ψ

-

sin






ϕ
·








cos





ψ




)

·

yB
i


-

zO
i





)








recalling that:











[




X
S






Y
S






Z
S




]

=


[
T
]

·

[




X
T






Y
T






Z
T




]



,





with


:






(
1111
)








[
T
]

=

[




cos






θ
·
cos






ψ





sin






ϕ
·
sin







θ
·
cos






ψ

-

cos






ϕ
·
sin






ψ






cos






ϕ
·
sin







θ
·
cos






ψ

-

sin






ϕ
·
sin






ψ







cos






θ
·
sin






ψ





sin






ϕ
·
sin







θ
·
sin






ψ

-

cos






ϕ
·
cos






ψ






cos






ϕ
·
sin







θ
·
sin






ψ

-

sin






ϕ
·
cos






ψ








-
sin






θ




sin






ϕ




·
cos






θ




cos






ϕ
·
cos






θ




]







and




(
1112
)








l
i

=




OB
i

_

·


OB
i

_




,




(
1113
)







li representing the extension length of each actuator.


A second step of the direct kinematics calculation 23 is a calculation of the velocity of the actuators 52, calculated as a function of the actuator lengths obtained in the course of the first step 51 of the direct kinematics calculation 23.


We have:






l
i
2

OB
i
· OBi  (1114).


by differentiation we obtain:












l
i

·




l
i




t



=






OB
i

_




t


·


OB
i

_









hence


:






(
1115
)











v
i

=




l
i




t









=


1

l
i




(






OB
i

_




t


·


OB
i

_


)



,









with




(
1116
)







l
i

=




OB
i

_

·


OB
i

_







(
1117
)







and OiBi such as described in Annex 1 by the expression, (1118)


this implies:











(






O
i



B
i


_




t


)

x

=



x
.

C

+


(


xB
i







yB
i


)

·

(






-

(

sin






θ
·
cos






ψ

)


·

θ
.


-


(

cos






θ
·
sin






ψ

)

·

ψ
.










-

(

sin






θ
·
sin






ψ

)


·

θ
.


+


(

cos






θ
·
cos






ψ

)

·

ψ
.






)







(
1119
)








(






O
i



B
i


_




t


)

y

=



y
.

C

+


(


xB
i







yB
i


)

·

ϒ
1







(
1120
)







with γ1 defined in Annex 1 by expression (1120′)











(






O
i



B
i


_




t


)

z

=



z
.

C

+


(


xB
i







yB
i


)

·

ϒ
2







(
1121
)







with γ2 defined in Annex 1 by expression (1121′)


A third step of the direct kinematics calculation 23 is a calculation of the acceleration of the actuators 53, calculated as a function of the velocity of the actuators obtained in the course of the second step 52 of the direct kinematics calculation 23.


We have:











l
i

·




l
i




t



=






OB
i

_




t


·


OB
i

_






(
1122
)







by differentiation we obtain:













l
i

·




2



l
i





t
2




+


(




l
i




t


)

2


=



(





OB
i

_




t


)

2

+





2




OB
i

_





t
2



·


OB
i

_










hence


:






(
1123
)








a
i

=





2



l
i





t
2



=


1

l
i




[



(





OB
i

_




t


)

2

+





2




OB
i

_





t
2



·


OB
i

_


-


(




l
i




t


)

2


]










with


:






(
1124
)








(




2





O
i



B
i


_





t
2



)

x

=



x
¨

C

+


(


xB
i







yB
i


)

·

ϒ
3







(
1125
)







with γ3 defined in Annex 1 by expression (1125′)











(




2





O
i



B
i


_





t
2



)

y

=



y
¨

C

+


(


xB
i







yB
i


)

·

ϒ
4







(
1126
)







with γ4 defined in Annex 1 by expression (1126′) and with the matrices (1126″) defined in Annex 1.











(




2





O
i



B
i


_





t
2



)

z

=



z
¨

C

+


(


xB
i







yB
i


)

·

ϒ
5







(
1127
)







with γ5 defined in Annex 2 by expression (1127′) and with the matrices (1127″) defined in Annex 2.


The acceleration {umlaut over (l)}i can then be put into the following form:











l
¨

i

=

h


(


ϕ
¨

,

θ
¨

,

ψ
¨

,

x
¨

,

y
¨

,

z
¨


)






(
1128
)









l
¨

i

=



A
1

·

ϕ
¨


+


A
2

·

θ
¨


+


A
3

·

ψ
¨


+

A
4

+

x
¨

+


A
5

·

y
¨


+


A
6

·

z
¨


+
ct








with


:










A
1

=




t



(



0







B

yx


ϕ
¨



·

xB
i


+


B

yy


ϕ
¨



·

yB
i










B

zx


ϕ
¨



·

xB
i


+


B

zy


ϕ
¨



·

yB
i






)


·




O
i



B
i





l
i




;









A
2

=




t



(






-
sin







θ
·
cos







ψ
·

xB
i



-

sin






θ
·
sin







ψ
·

B
i











B

yx


θ
¨



·

xB
i


+


B

yy


θ
¨



·

yB
i










B

zx


θ
¨



·

xB
i


+


B

zy


θ
¨



·

yB
i






)


·




O
i



B
i





l
i




;









A
3

=




t



(






-
cos







θ
·
sin







ψ
·

xB
i



+

cos






θ
·
cos







ψ
·

yB
i











B

yx


ψ
¨



·

xB
i


+


B

yy


ψ
¨



·

yB
i










B

zx


ψ
¨



·

xB
i


+


B

zy


ψ
¨



·

yB
i






)


·




O
i



B
i





l
i




;









A
4

=




t



(



1




0




0



)


·




O
i



B
i





l
i




;









A
5

=




t



(



0




1




0



)


·




O
i



B
i





l
i




;









A
6

=




t



(



0




0




1



)


·




O
i



B
i





l
i




;







ct
=



l
¨

i

-

(



A
1

·

ϕ
¨


+


A
2

·

θ
¨


+


A
3

·

ψ
¨


+

A
4

+

x
¨

+


A
5

·

y
¨


+


A
6

·

z
¨



)







(
1129
)








FIGS. 6
a and 6b represent functions for scaling the actuator elongations calculated as a function of the actuator length required in order to apply the optimal control.


We seek a function of the following form:











scaling


:



R
+




[


l
min

,

l
max


]







with







Avec


:



scaling


(
l
)



=

{







l
min


,



l


l
min










=
l

,



l


[


l
min

,

l
max


]












l
max


,



l


l
max











(



scaling



l


)



l
=

l
min



l
=

l
max




=
0










(
1000
)







To this end, we firstly define an elongation of the actuators E such that:









E
=

l
-

(



l
max

+

l
min


2

)






(
1130
)







with:


l: the length of an actuator;


lmin: the minimum length of an actuator;


lmax: the maximum length of an actuator.


The system (1000) then becomes:











scaling


:


R



[


-

E
max


,

E
max


]







with







Avec


:



scaling


(
E
)



=

{







-

E
max



,



E


-

E
max











=
E

,



E


[


-

E
max


,

E
max


]












E
max


,



E


E
max











(



scaling



l


)



E
=

-

E
max




E
=

E
max




=
0










(
1131
)







To retrieve the function scaling(l) from the function scaling(E), it is necessary to add a difference corresponding to the mid-stroke length of the actuators.


The sought-after function scaling(E) corresponds for example to a first sought-after function 60, represented in FIG. 6a. Corner points 61 of the sought-after function 60 are thereafter replaced with continuous joins, such as represented in FIG. 6b. A second function for scaling the elongations 62 is thus obtained. The sought-after function scaling(E) is for example an odd function, of exponential type, having a maximum Emax·Emax can be set to a constant value.


For example the following function can be used:










scaling


(
E
)


=

{






-

E
max










if




if








E




-

E
max


·

e










E
max






si





E




E
max

·

e








E
·




(


-

E
2



2
·
e
·

E
max
2



)


otherwise
sinon












(
1132
)







We then verify that the proposed function fulfills the constraints imposed by the geometry of the mobile platform. To this end, we consider an interval










[


-

E
max


,

E
max


]



:







scaling


(
E
)


=


E
·



(


-

E
2



2
·
e
·

E
max
2



)







scaling



E









=




(


-

E
2



2
·
e
·

E
max
2



)


·

(

1
-


E
2


e
·

E
max
2




)










(
1133
)







From this we deduce:









{








(



scaling



E


)


E
=


±

E
max


·

e




=
0







scaling


(


-

E
max


·

e


)


=

-

E
max









scaling


(


E
max

·

e


)


=

E
max










(
1134
)







The function scaling(E) defined by relation (1132) therefore does indeed comply with the imposed constraints described by relation (1131).


The function scaling(E) also makes it possible to bound the velocity by changing the parameters:










scaling


(
ν
)


=

{



if







-

ν

ma
if




si





ν




-

v
max


·












ν
max


si





ν




v
max

·











ν
·



(


-

ν
2



2
·

·

ν
max
2



)





sinon
otherwise










(
1135
)







The lengths can be bounded by adding a difference corresponding to a mid-stroke length of the actuators, to change the lengths into elongations:










scaling


(
l
)


=

{



if







l
min


si





l




if




(



l
max

+

l
min


2

)

-


(



l
max

-

l
min


2

)

·













l
max


si





l




(



l
max

+

l
min


2

)

+


(



l
max

-

l
min


2

)

·














l
max

+

l
min


2

+



(

l
-



l
max

-

l
min


2


)

·



(


-


(


l
-

l
min


2

)

2



2
·

·


(



l
max

-

l
min


2

)

max
2



)





sinon
otherwise











(
1136
)








FIG. 7 represents several possible steps of defining the parameters for the step of calculating the inverse kinematics 25, represented in FIG. 2. It involves, during step 25 calculating the inverse kinematics, finding six parameters (φ θ ψ x y z) determining the position of the platform, as a function of the actuator lengths calculated in the course of the scaling step 24.


A first step 71 of the inverse kinematics calculation 25 is a step of calculating the coordinates of the attachment points of the platform in a reference frame relative to the ground. The coordinates of the points of attachment of the mobile platform in the ground reference frame have, for example, the subscript “ms”. The coordinates of the points of attachment of the base of the platform in the ground reference frame have, for example, the subscript “bs”. Let us take three points of attachment on the ground to make a base of the platform. For example, it is possible to choose a first point O1, a second point O3 and a third point O5 with the first point O1 as origin point. Coordinates xms2i, yms2i, zms2i of the other points of the base can be expressed as a function of the coordinates of the chosen points O1, O3, O5, the subscript “1” corresponding to the first point O1, the subscript “3” corresponding to the second point O3, the subscript “5” corresponding to the third point O5:











i



[

1
;
3

]



{






x

ms

2

i



-

x

ms
1



=



λ

2

i




(


x

ms
3


-

x

ms
1



)


+


μ

2

i




(


x

ms
5


-

x

ms
1



)











y

ms

2

i



-

y

ms
1



=



λ

2

i




(


y

ms
3


-

y

ms
1



)


+


μ

2

i




(


y

ms
5


-

y

ms
1



)











z

ms

2

i



-

z

ms
1



=



λ

2

i




(


z

ms
3


-

z

ms
1



)


+


μ

2

i




(


z

ms
5


-

z

ms
1



)














(
1137
)







The system (1137) is satisfied by all the points of the platform whatever the reference frame in which the coordinates (xms1, yms1, zms1), (xms3, yms3, zms3), (xms5, yms5, zms5)of the first, second and third points O1, O3, O5 are written. This is in particular satisfied for the coordinates of the points in the reference frame tied to the mobile platform and defined by relation (1107). As all the points of the mobile platform have the same coordinate value along an axis z perpendicular to the plane of the platform, the third equation of the system (1137) does not afford any additional information. The systems to be solved are therefore as follows:











i



[

1
;
3

]



{






x

ms

2

i



-

x

ms
1



=



λ

2

i




(


x

ms
3


-

x

ms
1



)


+


μ

2

i




(


x

ms
5


-

x

ms
1



)











y

ms

2

i



-

y

ms
1



=



λ

2

i




(


y

ms
3


-

y

ms
1



)


+


μ

2

i




(


y

ms
5


-

y

ms
1



)














(
1138
)







The systems (1138) are linear systems of two equations in two unknowns. By using Cramer's procedure to solve the systems (1138) we then obtain the values of (λi μ2i)∀i∈1;3.


A second step 72 of the inverse kinematics calculation 25 is the application of Newton's algorithm in an iterative manner so as to calculate the coordinates of all the points of attachment of the actuators on the mobile platform in the reference frame tied to the ground.


Initially, an expression such as described below can express the fact that the distances D1, D2, D3 between the points of the mobile platform B1, B3, B5:









{





D
1

=



(


x

ms
3


-

x

ms
1



)

2

+


(


y

ms
3


-

y

ms
1



)

2









D
2

=



(


x

ms
5


-

x

ms
1



)

2

+


(


y

ms
5


-

y

ms
1



)

2









D
3

=



(


x

ms
5


-

x

ms
3



)

2

+


(


y

ms
5


-

y

ms
3



)

2










(
1139
)







The coordinates in the mobile reference frame, such as are defined in (1107), can be used to calculate D1,D2,D3.


Moreover:




i∈[1;6]:li2=(xmsi−xmbi)2+(ymsi−ymbi)2+(zmsi−zmbi)2  (1140)


with representing the lengths of actuators of the current iteration.


By combining relations (1139) and (1140), the following system is obtained:









F
=

{







i






[

1
;
6

]



:



(


xms
i

-

xmb
i


)

2

+


(


yms
i

-

ymb
i


)

2

+

(





zms
i

-






zmb
i




)

-

l
i
2










(


xms
3

-

xms
1


)

2

+


(


yms
3

-

yms
1


)

2

-

D
1









(


xms
5

-

xms
1


)

2

+


(


yms
5

-

yms
1


)

2

-

D
2









(


xms
5

-

xms
3


)

2

+


(


yms
5

-

yms
3


)

2

-

D
3










(
1141
)







Next, using relations (1138), the following relation is obtained:






F=F(X)  (1142)


with





X=(xms1 xms3 xms5 yms1 yms3 yms5 zms1 zms3 zms5)


Next, based on the following relation:











F


(

X
+

Λ
X


)


=


F


(
X
)


+


Δ
X

·


F




(
X
)











Jacobian


(
F
)






(
1143
)







with F′(X)=jacobien(F)


From relation (1143), we deduce the following relation:





Δx=F′−1(X)·(F(X+Δx)−F(X))  (1144)


We seek Δx/F(X+Δx)=0, relation (1144) then becomes:





Δx=F′−1(X)·(−F(X))  (1145)


Using relation (1138), F′(X) can be expressed in the manner defined by expression (1146) described in Annex 2.


The variable X can be initialized with values arising from the previous iteration. For example, tools for the automated solution of equation systems can be used to solve the previous system and obtain a value of Δx. The iterations performed by applying Newton's algorithm can be stopped when we have max (|Δx|)≦10−7, otherwise, we can put X=X+Δx and restart a new iteration of Newton's algorithm. A maximum number of iterations can be fixed.


Once this step has been performed, by using relations (1138), we obtain the coordinates of all the points of attachment of the actuators on the mobile platform in the reference frame tied to the ground.


A third step 73 of the inverse kinematics calculation 25 is a step of calculating the coordinates of the centroid of the mobile platform as well as the angles of displacement of the mobile platform.


Initially, the coordinates of the center of gravity of the platform are calculated:









G
=


1
6

·

(







i
=
1

6







xms
i










i
=
1

6







yms
i










i
=
1

6







zms
i





)






(
1147
)







It is possible to calculate the coordinates of the vectors GBi which connect the center of gravity to the various points of attachment of the mobile part of the platform.


It is then possible to create the following basis:















Ems
1

=




GB
1

_

+


GB
2

_



2
·

xB
1










Ems
2

=




GB
1

_

-


GB
2

_



2
·

yB
1










Ems
3

=


Ems
1



Ems
2










(
1148
)







The basis (1148) corresponds, at an instant l=0, to the canonical basis of the reference frame tied to the ground. Using the following relation, which links the fixed reference frame and the mobile reference frame:










[




Ems
1






Ems
2






Ems
3




]

=


[

T

mob


-


fix


]

·

[




Emm
1






Emm
2






Emm
3




]






(
1149
)







with:








{






Emm
1

=

[



1


0


0



]













Emm
2

=

[



0


1


0



]








Emm
3

=

[



0


0


1



]










and defined by expression (1007), from this we deduce:









{








Ems
2



(
1
)


/


Ems
1



(
1
)



=

tan


(
ψ
)










Ems
3



(
1
)


=

-

sin


(
θ
)











Ems
3



(
2
)


=


sin


(
ϕ
)


·

cos


(
θ
)











{




ψ
=


tan

-
1




(



Ems
2



(
1
)


/


Ems
1



(
1
)



)








θ
=


sin

-
1




(

-


Ems
3



(
1
)



)








ϕ
=


sin

-
1




(



Ems
3



(
2
)


/

cos


(
θ
)



)














(
1150
)












We have indeed therefore retrieved the coordinates as well as the angles (φ θ ψ x y z) associated with the centroid of the mobile platform.


By twice differentiating the coordinates (φ θ ψ x y z) we obtain the acceleration control to be applied by the mobile platform.


The acceleration control calculation method according to the invention advantageously makes it possible to realistically reproduce accelerations felt by the pilot or the driver of a vehicle in a simulator. It also makes it possible to utilize to the maximum the entirety of the dynamic resources of the motion system while avoiding reaching actuator end-of-stroke bumpers. This advantageously makes it possible to increase the lifetime of the actuators and more generally of the mobile simulation o platforms. Advantageously, the method according to the invention makes it possible to realistically reproduce extreme situations in which the actuators of the platform have an asymmetric configuration, for example in the case of missed takeoffs or following hard braking.


The direct 23 and inverse 25 kinematics calculations depend is solely on the geometry of the simulation platform used. These calculations can therefore advantageously be adapted to any simulator with motion without changing the functional architecture 30, 31 for calculating the acceleration control. Moreover, the calculations performed by the method according to the invention are exact calculations, that is to say not requiring any approximation. This advantageously makes it possible not to introduce edge effects which could impede the stability of the results produced by the method according to the invention.


The method according to the invention therefore advantageously makes it possible to improve the training of vehicle pilots by confronting them with extreme situations in a realistic manner. The vehicle pilots thus trained are therefore more able to react correctly when faced with dangerous situations, thus improving their safety and avoiding damage to the vehicles.


The method for calculating the optimal control according to the invention furthermore allows a simple calculation of the accelerations, platform related constraints being taken into account after the calculation of the optimal control generated by the vehicle's motion simulator.

Claims
  • 1. A method for calculating motion controls for a mobile platform of a vehicle simulator by use of calculated accelerations, calculated by a process for simulating behavior of a vehicle, said method comprising the steps of: filtering the calculated accelerations by use of a filter constructed according to a mathematical model of human perception of a motion, to produce filtered acceleration controls to be applied by the mobile platform;calculating successive positions of the mobile platform as a function of the filtered acceleration controls;scaling the successive positions of the mobile platform, as a function of physical limitations of the mobile platform, to produce scaled successive positions of the mobile platform;calculating acceleration controls to be applied by the mobile platform, as a function of the scaled successive positions of the mobile platform, to produce calculated acceleration controls.
  • 2. The method as claimed in claim 1, wherein the successive positions of the mobile platform are provided by positions of a geometric center of the mobile platform and by lengths of actuators moving the mobile platform.
  • 3. The method as claimed in claim 2, wherein the lengths of the actuators is scaled by a first scaling function scaling(l) determined in accordance with the following relationships: scaling(l)≧lmin, for all l≦lmin;scaling(l)=l, for all lmin≦l≦lmax;scaling(l)≦lmax, for all l≧lmax; and
  • 4. The method as claimed in claim 1, wherein the step of scaling uses limitations on one or more rates of elongation of actuators of the mobile platform.
  • 5. The method as claimed in claim 4, wherein the limitations on rate of elongation of the actuators are taken into account using a second scaling function scalingν(ν) determined in accordance with the following relationships: scalingν(ν)≧νmin, for all ν≦νmin;scalingν(ν)=ν, for all νmin≦ν≦νmax;scalingν(ν)≦νmax, for all ν≧νmax; and
  • 6. The method as claimed in claim 1 further comprising the steps of: comparing the calculated accelerations to a threshold value below which the accelerations are no longer perceived by a human being; andapplying calculated accelerations above the threshold value give a, in order to produce to produce a calculated acceleration control.
  • 7. The method as claimed in claim 1, wherein the calculating acceleration controls to be applied by the mobile platform further comprises the step of applying a Newton algorithm in an iterative manner.
  • 8. A device for calculating motion controls for a mobile platform for a vehicle simulator comprising: a first circuit configured to calculate acceleration controls to be applied by the mobile platform, the first circuit comprising a filter constructed according to a mathematical model of human perception of a motion, in order to filter accelerations provided by a process for simulating the behavior of the vehicle; anda second circuit configured to calculate controls to be applied by the mobile platform as a function of physical limitations of the mobile platform.
  • 9. The device as claimed in claim 8, wherein the second circuit comprises: a first circuit module configured to calculate successive positions of the mobile platform as a function of the accelerations of controls to be applied by the mobile platform, to produce positions calculated as a function of the physical limitations of the mobile platform;a second circuit module configured to scale the positions calculated as a function of the physical limitations of the mobile platform, to produce scaled positions;a third circuit module configured to calculate accelerations to be applied by the mobile platform as a function of the scaled positions.
  • 10. The device as claimed in claim 9, wherein the positions of the mobile platform are provided by the positions of the geometric center of the mobile platform and by the lengths of actuators of the mobile platform.
  • 11. The device as claimed in claim 10, wherein the lengths of the actuators is scaled by a first scaling function scaling(l) determined in accordance with the following relationships: scaling(l)≧lmin, for all l≦lmin;scaling(l)=l, for all lmin≦l≦lmax;scaling(l)≦lmax, for all l≧lmax; and
  • 12. The device as claimed in claim 9, wherein the second circuit uses limitations on one or more rates of elongation of actuators of the mobile platform.
  • 13. The device as claimed in claim 12, wherein the limitations on rate of elongation of the actuators are taken into account using a second scaling function scalingν(ν) determined in accordance with the following relationships: scalingν(ν)≧νmin, for all ν≦νmin,scalingν(ν)=ν, for all νmin≦ν≦νmax;scalingν(ν)≦νmax, for all ν≧νmax; and
Priority Claims (1)
Number Date Country Kind
08/05020 Sep 2008 FR national