JOURNAL OF THEORETICAL AND APPLIED MECHANICS 43, 4, pp. 841-853, Warsaw 2005 A METHOD OF DETERMINATION OF FEASIBLE PROPELLER FORCES AND MOMENTS FOR AN UNDERWATER ROBOT Jerzy Garus Faculty of Mechanical and Electrical Engineering, Naval University e-mail: j.garus@amw.gdynia.pl The paper presents procedure for the optimal allocation of thrust for ho- rizontalmotion of underwater robotic vehicles.Computation of propeller thrusts from propelling forces andmoments is an optimisation problem based on a model, which the simplest form is unconstrained. In practi- ce, however, where physical limitations must be taken into account, the obtained in such a way solution can be unrealistic. To cope with those difficulties, an algorithm for evaluation of the capacity of a propulsion systemtoproduce required forces andmoments and, if necessary, finding their feasible values is proposed. Due to computational simplicity, such an approach is a good solution in real-time applications. A numerical example is provided to demonstrate effectiveness and correctness of the approach. Key words: underwater robot, hydrodynamic thrust allocation, propul- sion system 1. Introduction Nowadays, it is common to use underwater robotic vehicles (URVs) to accomplish such missions as inspection of coastal and off-shore structures, cablemaintenance as well as hydrographical and biological surveys.Motion of URVs in 6 degrees of freedom (DOF) canbe describedby the following vectors (see e.g. Fossen, 1994; Lisowski, 1981) η= [x,y,z,φ,θ,ψ]> v= [u,v,w,p,q,r]> (1.1) τ = [X,Y,Z,K,M,N]> 842 J.Garus where: η – vector of the position and orientation in the earth-fixed frame x,y,z – coordinates of the position φ,θ,ψ – coordinates of the orientation (Euler angles) v – vector of linear and angular velocities in the body-fixed frame u,v,w – linear velocities along the longitudinal, transversal and vertical axes p,q,r – angular velocities about the longitudinal, transversal and vertical axes τ – vector of forces andmoments acting on the vehicle in the body-fixed frame X,Y,Z – forces along the longitudinal, transversal and vertical axes K,M,N – moments about the longitudinal, transversal and vertical axes. ModernURVsaremore andmore frequently equippedwith automatic con- trol systems in order to execute complexmanoeuvreswithout constant human intervention. Basic modules of a control system are depicted in Fig.1. An au- topilot computes required propelling forces and moments (commands) τd by comparing the desired position and orientation of the robot with their cur- rent estimates. The corresponding to them propeller thrusts f are calculated in a thrust distribution module and transmitted to the propulsion system as control inputs. Fig. 1. A structure of the control system (d – vector of environmental disturbances) A method of determination of feasible propeller forces... 843 Bothmovement andpositioning of an underwater robot is realised only by changing propeller thrusts, which leads to variation of propelling forces and moments. Control laws implemented in the autopilot are of a general character and usually do not take into account constraints put on the maximum and minimum values of thrusts developed by the propellers. It may cause that the desired solution τd can not be realised by the propulsion system due to work of one or more thrusters in saturation. Such a situation can contribute to deterioration of the control, and the behaviour of the robotmay differ from the required pattern significantly. Therefore, thrust distribution is one of the tasks of the control system that has essential influence on the quality of control. A procedure of thrust allocation is proposed tobe realised in two stages (Fig.2). In thefirst stage, the generating capacity of the dmanded commands τd by the propulsion system is checked and feasible commands τ ′d are determined (i.e. such values of forces andmomentswhich can be producedby the propulsion system). In the second stage, the real allocation of thrusts among the propellers is carried out on the base of τ ′d. Fig. 2. A block diagram of the thrust distribution module 2. A procedure of thrust allocation for horizontal motion In conventional URVs, the basicmotion is movement in a horizontal plane with some variation due to diving. URVs operate in a crab-wise manner in 4 DOF with small roll and pitch angles that can be neglected during normal operations. Therefore, the spatialmotion is regarded as a superposition of two displacements:motion in thehorizontal plane andmotion in the vertical plane. It allows one to divide the propulsion system into two independent subsystems responsible for motion in the vertical and horizontal planes, respectively. A general structure of such a system is shown in Fig.3. 844 J.Garus Fig. 3. A structure of a power transmission systemwith 6 thrusters The first subsystem enables motion in heave and consists of 2 thrusters. The required force Zd is equal to the sum of their thrusts. The second one assuresmotion in surge, sway and yaw, and composes of 4 thrusters mounted askew with respect to main symmetry axes of the vehicle (seeFig.4).Hence, thedesired forces Xd and Yd acting in the longitudinal and transversal axes and themoment Nd about the vertical axis are a combination of thrusts produced by the thrusters. Fig. 4. Layout of thrusters in the subsystem responsible for horizontal motion Let us denote: τ – vector of demanded commands τd = [τd1,τd2,τd3] > = [Xd,Yd,Nd] > A method of determination of feasible propeller forces... 845 f – thrust vector f = [f1,f2,f3,f4] > and assume that components of both vectors are bounded τ2 di − (τmaxi ) 2 ¬ 0 for i =1,2,3 f2j − (f max j ) 2 ¬ 0 for j =1,2,3,4 (2.1) Values of τmaxi and f max j dependon the design of propellers and configuration of thrusters in the propulsion system. As shown in Fossen (2002), for horizontal motion, the vector of required propelling forces andmoments τd can be described as a function of the thrust vector f by the following expression τd =T(α)f (2.2) where T(α) – thruster configurationmatrix T(α)=    cosα1 cosα2 cosα3 cosα4 sinα1 sinα2 sinα3 sinα4 d1 sin(α1−ϕ1) d2 sin(α2−ϕ2) d3 sin(α3−ϕ3) d4 sin(α4−ϕ4)    α – vector of azimuth angles, α= [α1,α2,α3,α4] > αj – angle between the longitudinal axis and direction of thrust of the jth propeller fj dj – distance of the jth thruster from the centre of gravity ϕj - angle between the longitudinal axis and the line connecting the centre of gravity with the jth thruster symmetry centre. The thrust allocation problem, i.e. computation of f from τd, is usual- ly formulated as a least-squares optimisation problem and described in the following form (see e.g. Garus, 2004; Sordelen, 1997) f =T∗(α)τd (2.3) where the matrix T∗(α)=T>(α)[T(α)T>(α)]−1 is the generalized inverse. This method of thrust allocation allows one to find the minimum-norm solution, but it should be noted that (2.3) belongs to unconstrained optimi- sation problems - i.e., there are no bounds on the elements of the vector f, 846 J.Garus so the obtained values fj may not satisfy (2.1)2, and then the generation of the desired vector τd by the propulsion system is not possible. In such a case, a new vector of commands meeting condition (2.1)2 must be determined. A method of evaluation of this vector, called the vector of feasible commands and denoted by τ ′ d = [τ ′ d1 ,τ ′ d2 ,τ ′ d3 ]>, is presented in the next section. 3. An algorithm for determination of feasible propelling forces and moments Assume that the propulsion system consists of n=4 identical nonrotatio- nal thrusters. It means that the quantities like: dj, αj and ϕj are constant for every thruster. Hence, all elements of the configuration matrix T(α) are constant. Let us denote: 1. τmax1 , τ max 2 and τ max 3 – maximum values of the propelling forces and moments generated by the propulsion system for horizontal motion τmax1 = n ∑ j=1 |τmax1j |= n ∑ j=1 |fmaxj cosαj| τmax2 = n ∑ j=1 |τmax2j |= n ∑ j=1 |fmaxj sinαj| τmax3 = n ∑ j=1 |τmax3j |= n ∑ j=1 |fmaxj dj sin(αj −ϕj)| 2. O – origin of the Cartesian coordinate system, 3. P – point in the 3-dimensional space with coordinates (τd1,τd2,τd3), 4. −−→ OP – position vector of the point P . The evaluation of capacity of the propulsion system to generate the desi- red propelling forces and moment τd requires taking into consideration both limitations (2.1) simultaneously. The first one indicates that the vector τd is produced only if the position vector −−→ OP is entirely contained in a cubicoid having vertexes in points: (τmax1 ,τ max 2 ,τ max 3 ), (τ max 1 ,τ max 2 ,−τ max 3 ), (τ max 1 ,−τ max 2 ,τ max 3 ), (τmax1 ,−τ max 2 ,−τ max 3 ), (−τ max 1 ,τ max 2 ,τ max 3 ), (−τ max 1 ,τ max 2 ,−τ max 3 ), A method of determination of feasible propeller forces... 847 (−τmax1 ,−τ max 2 ,τ max 3 ), (−τ max 1 ,−τ max 2 ,−τ max 3 ) (see Fig.5). Since the components of the vector of demanded commands τd are a linear combi- nation of thrusts developed by all propellers, then fulfilling only condition (2.1)1 does not guarantee their generation. Foe example, if to any element of the vector τd there corresponds an assignment τdi = τ max i , then the full power of the propulsion system is used to its generation and the rest of the components are equal to zero. Therefore, the evaluation of the capacity of the propulsion system to generation of the vector τd requires giving consideration to inequality (2.1)2. Fig. 5. A view of the cubicoid and the position vector −−→ OP The analysis of values that elements of the vector τd may take under limitations (2.1) leads to the following conclusion: the quantities τd1, τd2 and τd3 can be produced by the propulsion system if and only if the position vector −−→ OP is entirely contained in a trisoctahedron with vertexes in points: (τmax1 ,0,0), (0,τ max 2 ,0), (0,0,τ max 3 ), (−τ max 1 ,0,0), (0,−τ max 2 ,0), (0,0,−τ max 3 ) (see Fig.6). This situation proceeds if the following inequality holds |τd1| τmax1 + |τd2| τmax2 + |τd3| τmax3 ¬ 1 (3.1) If (3.1) is false, then the point P = (τd1,τd2,τd3) lies outside the octa- hedron and the vector τd can not be generated. It means that the vector of feasible commands τ ′ d = [τ ′ d1 ,τ ′ d2 ,τ ′ d3 ]> must be determined. Its elements, 848 J.Garus Fig. 6. A view of the trisoctahedron and the position vector −−→ OP Fig. 7. A block diagram of the algorithm for the determination of feasible commands A method of determination of feasible propeller forces... 849 on the assumption that reciprocal ratios of corresponding components of the vectors τd and τ ′ d are preserved τ ′d1 τ ′ d2 = τd1 τd2 τ ′d1 τ ′ d3 = τd1 τd3 (3.2) can be computed bymeans of the following equations τ ′d1 = sgnτd1 ( 1 τmax1 + 1 τmax2 ∣ ∣ ∣ τd2 τd1 ∣ ∣ ∣ + 1 τmax3 ∣ ∣ ∣ τd3 τd1 ∣ ∣ ∣ )−1 (3.3) τ ′d2 = sgnτd2 ∣ ∣ ∣ τd2 τd1 τ ′d1 ∣ ∣ ∣ τ ′ d3 = sgnτd3 ∣ ∣ ∣ τd3 τd1 τ ′d1 ∣ ∣ ∣ Basing on the above considerations, an algorithm for the evaluation of the vector τd and determination of τ ′ d has been developed (see Fig.7). Input data to the algorithm are quantities τmax1 , τ max 2 , τ max 3 and the vector τd. The vector of feasible commands τ ′ d is computed according to (3.3). A proof of the dependence (3.3) Not to decrease of generality of considerations it is assumed that τdi ­ 0 for i =1,2,3. It allows to restrict analysis into a subspace limited by positive semi-axes of the coordinate system (see Fig.8). Let A =(τmax1 ,0,0), B =(0,τ max 2 ,0), C =(0,0,τ max 3 ), P =(τd1,τd2,τd3) and P ′ = (τ ′ d1 ,τ ′ d2 ,τ ′ d3 ) be points in the 3-dimensional space. An equation of a plane including the points A, B and C has a form τ1 τmax1 + τ2 τmax2 + τ3 τmax3 =1 (3.4) Let us assume that thepoint P ′ =(τ ′ d1 ,τ ′ d2 ,τ ′ d3 ) is a commonpoint of a line containing theposition vector −−→ OP and theplanedefinedby (3.4). Substituting the coordinates of thepoint P ′ into (3.4) and taking into account requirements (3.2), the following set of equations is formulated τ ′d1 τmax1 + τ ′d2 τmax2 + τ ′d3 τmax3 =1 (3.5) τ ′d1 τ ′ d2 = τd1 τd2 τ ′d1 τ ′ d3 = τd1 τd3 850 J.Garus Fig. 8. A view of the position vectors −−→ OP and −−→ OP ′ for positive semi-axes of the Cartesian coordinate system Hence, solving (3.5) the following expressions for calculation of τ ′d1, τ ′ d2 and τ ′d3 are obtained τ ′d1 = ( 1 τmax1 + 1 τmax2 τd2 τd1 + 1 τmax3 τd3 τd1 )−1 (3.6) τ ′d2 = τd2 τd1 τ ′d1 τ ′ d3 = τd3 τd1 τ ′d1 Finally, transformation of the above expressions to the Cartesian coordinate system yields τ ′d1 = sgnτd1 ( 1 τmax1 + 1 τmax2 ∣ ∣ ∣ τd2 τd1 ∣ ∣ ∣ + 1 τmax3 ∣ ∣ ∣ τd3 τd1 ∣ ∣ ∣ )−1 (3.7) τ ′d2 = sgnτd2 ∣ ∣ ∣ τd2 τd1 τ ′d1 ∣ ∣ ∣ τ ′ d3 = sgnτd3 ∣ ∣ ∣ τd3 τd1 τ ′d1 ∣ ∣ ∣ End of the prove 4. Numerical example The computations are done for the following data of the propulsion system of the underwater robot ”Ukwiał” designed and built for the Polish Navy (see Garus, 2004): fmaxi =250N di =0.4m for i =1,2,3,4 A method of determination of feasible propeller forces... 851 and α= [29.0◦,−29.0◦,151.0◦,209.0◦] ϕ= [−26.5◦,26.5◦,206.5◦,153.5◦] Hence τmax1 = 4 ∑ i=1 |τmax1i |= 4 ∑ i=1 |fmaxi cosαi|=875.0N τmax2 = 4 ∑ i=1 |τmax2i |= 4 ∑ i=1 |fmaxi sinαi|=485.0N τmax3 = 4 ∑ i=1 |τmax3i |= 4 ∑ i=1 |fmaxi di sin(αi−ϕi)|=332.0Nm Let us assume that τd = [700.0,−120.0,30.0] >. STEP 1 Calculate inequality (3.1) to check the capacity of the propulsion system in order to generate the vector τd |τd1| τmax1 + |τd2| τmax2 + |τd3| τmax3 ¬ 1 |700.0| 875.0 + |−120.0| 485.0 + |30.0| 332.0 ¬ 1 1.14¬ 1.0 Since the inequality is false (i.e. the point P = (700.0,−120.0,30.0) lies out- side the trisoctahedron having the vertexes in points: (875,0,0), (0,485,0), (0,0,332), (−875,0,0), (0,−485,0), (0,0,−332)), the vector of feasible com- mands τ ′d must be determined. STEP 2 Calculate the components of the vector τ ′ d τ ′d1 = sgnτd1 ( 1 τmax1 + 1 τmax2 ∣ ∣ ∣ τd2 τd1 ∣ ∣ ∣ + 1 τmax3 ∣ ∣ ∣ τd3 τd1 ∣ ∣ ∣ )−1 = = sgn700.0 ( 1 875 + 1 485 ∣ ∣ ∣ −120.0 700.0 ∣ ∣ ∣+ 1 332 ∣ ∣ ∣ 30.0 700.0 ∣ ∣ ∣ )−1 =614.6 τ ′d2 = sgnτd2 ∣ ∣ ∣ τd2 τd1 τ ′d1 ∣ ∣ ∣ = sgn(−120.0) ∣ ∣ ∣ −120.0 700.0 614.6 ∣ ∣ ∣ =−105.4 τ ′d3 = sgnτd3 ∣ ∣ ∣ τd3 τd1 τ ′d1 ∣ ∣ ∣= sgn30.0 ∣ ∣ ∣ 30.0 700.0 614.6 ∣ ∣ ∣=26.3 852 J.Garus To check the truth of the calculations, the ratios of the corresponding components of the vectors τd and τ ′ d are computed according to (3.2) τd1 τd2 = 700.0 −120.0 =−5.8 τ ′d1 τ ′ d2 = 614.6 −105.43 =−5.8 τd1 τd3 = 700.0 30.0 =22.3 τ ′d1 τ ′ d3 = 614.6 26.3 =22.3 The obtained values indicate that the ratios are preserved. It confirms the correctness of the proposed approach. 5. Conclusions The paper presents amethod of determination of feasible propelling forces and moment for underwater robotic vehicles. For a robot moving in the ho- rizontal plane, it is necessary to distribute the propelling forces and moment τd ∈< 3 among n propellers in terms of the thrust f ∈