**2.2 New Scientific Achievements**

**4.2.6 Implementation of New Genetic Continuous Periodic Fuzzy System Grey-**

As proposed in [s5] we identify *D**ij* components of the dynamic model in equation (44)
as FLSs defined by equations (24) to (27), where the FLS general input variable 𝒒 will
be substituted for appropriate state variables of (ϕ, θ, ψ).

Instead of simple TSK FLSs we will use cpFLSs. Where the *D** _{ij}* inertia matrix
components are modelled by cpFLSs, forming the

*D*

*ijk*components as Christoffel symbols is to be expressed by partial derivatives of equation (27) like:

𝜕𝑓(𝒒)/𝜕𝑞_{𝑖} = ∑^{𝑀}_{𝑖=1}(𝜕𝜔_{𝑙}(𝒒)/𝜕𝑞_{𝑖} ∙ 𝑦_{𝑙}(𝒒) +𝜔_{𝑙}(𝒒) ∙ 𝜕𝑦_{𝑙}(𝒒)/𝜕𝑞_{𝑖}), (49)

The unknown four inertia matrix components of torques defined in equation (43), which have to be identified for a 3DOF rigid body rotational motion model, are:

𝑫_{13}(𝜃) = 𝑓_{1}(𝜃), 𝑫_{22}(𝜙) = 𝑓_{2}(𝜙), 𝑫_{23}(𝜙, 𝜃) = 𝑓_{3}(𝜙, 𝜃), 𝑫_{33}(𝜙, 𝜃) = 𝑓_{4}(𝜙, 𝜃), (50)
Based on the multi-rotor system structure and inertia matrix symmetry the remaining
inertia components are known to be:

𝐷_{11} = 𝐼_{𝑥𝑥}, 𝐷_{12} = 0, 𝑫_{21} = 𝑫_{12}, 𝑫_{31}= 𝑫_{13}, 𝑫_{32}= 𝑫_{23}, (51)
where 𝐼_{𝑥𝑥} is the constant multi-rotor body inertia around the x axis.

Based on equation (46) the following Coriolis term matrix **D*** _{ijk}* components can be
calculated by equations (49):

𝑫_{122}= −^{1}_{2}^{𝛿𝑫}_{𝛿𝜙}^{22}, 𝑫_{123} = ^{1}_{2}(^{𝛿𝑫}_{𝛿𝜃}^{13}−^{𝛿𝑫}_{𝛿𝜙}^{23}) , 𝑫_{322} =^{𝛿𝑫}_{𝛿𝜃}^{23}

𝑫_{133}= −^{1}_{2}^{𝛿𝑫}_{𝛿𝜙}^{33}, 𝑫_{223} = −^{1}_{2}^{𝛿𝑫}_{𝛿𝜃}^{33}, 𝑫_{312} =^{1}_{2}(^{𝛿𝑫}_{𝛿𝜙}^{23}+^{𝛿𝑫}_{𝛿𝜃}^{13}) (52)
The remaining **D*** _{ijk}* components are trivial identities as defined in equation (46). This
way we can model the complete multi-rotor rotation dynamics as defined in equation
(43) by only 1 linear constant and 4 cpFLSs, where 2 cpFLSs are functions of a single
input, and 2 are functions of 2 inputs.

We have for these fuzzy systems 6 Zadeh type fuzzy partitions. Each partition consists
of 1 𝜇_{𝑧}-, 1 𝜇_{𝑠}-, and 3 𝜇_{𝜋}-type MFs as presented by equations (25) and (37), such a fuzzy
partition is defined by 3 nonlinear 𝑎_{𝑖} parameters; 6 partitions totalling in 24 nonlinear
𝒂_{𝜅} parameters.

These 4 cpFLSs consist of 2 times 4 rules for single input functions an 2 times 16 rules
*y**l* as defined in equation (27) for two input functions. Each rule consequent y*l* is defined
by 2 (single input case) or 3 (two inputs case) c* _{il}* linear parameters, these 4 cpFLSs total
in 112 linear parameters. The grand total for our model is 24 nonlinear 𝒂

_{𝜅}and 113 linear c parameters.

Linear parameters are best directly evaluated by a singular value decomposition (SVD) based least squares (LS) fitting method. We first substitute equations (16, 18, 20, 48) to (51, 52, 53) and all to (43) expressed as (53), then we express all the 113 linear 𝒄 parameters as:

(𝕁^{∗}(𝒒, 𝒂_{𝜿}) ∙ 𝒒̈ + ℂ^{∗}(𝒒, 𝒒̇, 𝒂_{𝜅}) ∙ 𝒒̇) ∙ 𝒄 = 𝑨(𝒒, 𝒒̇, 𝒒̈, 𝒂_{𝜅}) ∙ 𝒄 = 𝝉, (53)
For SVD decomposition of 𝑨(𝒒, 𝒒̇, 𝒒̈, 𝒂_{𝜅}) = 𝑈 ∙ 𝑆 ∙ 𝑉^{𝑇} we obtain 𝒄 = 𝑉 ∙ 𝑆^{−1}∙ 𝑈^{𝑇}∙ 𝝉.

The used training data is from calculated roll and pitch motions based on my Thesis IV, as presented in Figure 22. The simulated resultant torque full training data set is presented in Figure 23; its size is reduced for calculations based on my Thesis V.

Figure 22.

Smooth roll, pitch and yaw motions of the multirotor.

Figure 23.

Smooth resultant torques – full training set before reduction.

The list of nonlinear cpFLS parameters consists of six times four integer parameters for
defining six fuzzy partitions having five MFs each, where each partition consists of
three classical π-type MFs and for the cpFLS setup one virtual π-type MF composed by
one Z-type MF at the beginning of the input interval and one S-type MF in the end of
the input interval as in equation (25). These six fuzzy partitions serve as antecedents for
the four fuzzy systems like in equation (27) and (48), used for identifying *D**ij**, ij=(13, *
*22, 23, 33) as defined in equations (44)-(46) and (49)-(52). *

The unknown linear parameter D11 of the multi-rotor model as in equation (53), together with 112 linear parameters of the four TSK FLSs (2 FLSs with 5 MFs on one input, each rule with 2 c parameters, plus 2 FLSs with 5 MFs on both of the 2 inputs, each rule with 3 c parameters) of equations (43) are first substituted to (27) and (49), then based on (45), (46) and (44) to (50), (51) and (52), that they can be determined by the SVD-based LS method from equation (43) expressed as (53).

Concluded from equation (25) and (37) six fuzzy partitions (antecedent part of 2 FLSs with 1 input, plus 2 FLSs with 2 inputs are covered by 6 independent fuzzy partitions) are represented by a vector of six times four parameters, which are optimized by a multi-objective hybrid genetic algorithm as detailed in [s9]. Chromosomes are evaluated and subjected to a local gradient based search. Chromosome values are updated with the result of fine-tuning after each evaluation, so the GA does not waste time on local optimization; only global search capabilities of the GA are utilized.

The GA is set to work on a population of 200 chromosomes, divided into 5 subpopulations, with migration rate 0.2 taking place after each 5 completed generations.

Chromosomes are comprised of 24 Gray-coded integers, each consisting of 16 bits. The initial population is set up in a completely random manner. Crossover rate, generation gap and insertion rate is set to 0.8, selection pressure is 1.5. In each generation 4% of individuals are subject to mutation, when 1% of the binary genotype is mutated.

Matrix of the linear equation ℚ(𝒒, 𝒒̇, 𝒒̈) from equation (53) is pre-processed, as FLSs
like equation (27) and their partial derivatives like equation (49) are substituted as
defined by equations (50)-(52). Unknown linear parameters are *D** _{11}* and the 112

*parameters of fuzzy rule consequents.*

**c**Evaluation of each individual is conducted as follows:

(a) Convert coded a* _{i}* values from the chromosome to b

*by equation (37).*

_{k}(b) Evaluate all MFs, and antecedents which will comprise six fuzzy partitions from
each of six *b**k* quadruplets by equations (23) and (25). Also evaluate antecedent
derivatives of equation (49).

(c) Calculate the matrix coefficients of linear equations ℚ(𝒒, 𝒒̇, 𝒒̈) by values of triggered MFs and their partial derivatives.

(d) Linear components [D*11*, c] of equations (27), (43) and (49) are calculated by SVD
decomposition as in (53).

(e) Fine-tune *a**i* parameters, for example by the Matlab “lsqnonlin” function, while
re-calculating steps (a)-(d) for each a* _{i}* tuning iteration.

(g) Re-insert optimized a*i* parameters into the evaluated chromosome.

For the multi-objective rank assignment described in [s2], the objective vector is created from:

(i) the mean square of the identified torque error,

(ii) the maximum absolute torque identification error and (iii) the condition number of the matrix of the linear equation.

Stochastic universal sampling is used for selecting the next generation without explicit elitism. To speed up the GA processing, a database of evaluated chromosomes and their objective vectors is created, so only unique new individuals are evaluated in each generation.

**4.2.7 ** **Results of New Genetic Continuous Periodic Fuzzy System Grey-box **