
IEEE/CAA Journal of Automatica Sinica
Citation: | Mohammad Javad Mahmoodabadi and Saideh Arabani Mostaghim, "Stability of Nonlinear Systems Using Optimal Fuzzy Controllers and Its Simulation by Java Programming," IEEE/CAA J. Autom. Sinica, vol. 6, no. 6, pp. 1519-1527, Nov. 2019. doi: 10.1109/JAS.2017.7510388 |
Recently, the internet technologies such as Java Applets have been widely used for designing simulation programs for complicated systems. In [1], the simulation of fuzzy control for an inverted pendulum system based on Java Applets is presented. Mahmoodabadi et al. [2] applied Java programming to internet-based explanation of state feedback control for dynamic systems, e.g., the inverted pendulum and ball-beam system.
On the other hand, the development of high-performance controllers for various complex problems has been a major research topic among the control engineering practitioners in recent years. For example, Liu et al [3]. proposed a type-2 fuzzy switching control system for biped robots. Tseng et al. [4] designed a robust fuzzy controller for nonlinear discrete-time systems with persistent bounded disturbances. Huang et al. [5] designed and implemented a fuzzy controller for a two-wheel inverted pendulum system. Zhu [6] applied a fuzzy optimal controller for multistage fuzzy systems. Wang et al. [7] proposed an adaptive fuzzy backstepping controller for a class of nonlinear systems with sampled and delayed measurements.
In this way, synthesis of control policies has been presented as optimization problems of certain performance measures of the controlled systems. A very effective method of solving such optimum controller design problems is evolutionary algorithms. Yi et al. [8] applied single input rule modules dynamically connected fuzzy inference models for stabilizing a double inverted pendulum system and tuned parameters by a random optimization method. Shook et al. [9] used the genetic algorithm to optimize fuzzy logic controllers which were designed to manage two dampers for mitigation of seismic loads. The membership functions of multi-stage fuzzy load frequency control were automatically designed by the particle swarm optimization in [10]. A 2DOF planer robot has been controlled by the fuzzy logic controller and the particle swarm optimization has been utilized to tune fuzzy parameters in [11].
However, the design criteria (objective functions) of these practical engineering problems may conflict with each other so that improving one of them will deteriorate another. This inherent conflicting behavior of such objective functions leads to a set of optimal solutions named Pareto. This type of problems can be solved by using the multi-objective evolutionary algorithms. For instance, Ahmadi et al. [12] applied a new multi-objective uniform-diversity genetic algorithm with a diversity preserving mechanism to optimize a robust reliability-based controller with probabilistic uncertainties. Mahmoodabadi et al. [13] used and multi-objective particle swarm optimization for optimum design of fuzzy controllers for nonlinear systems.
One of the modern heuristic algorithms is particle swarm optimization (PSO) introduced by Kennedy and Eberhart [14], which is developed through simulation of simplified social systems and is robust for solving nonlinear optimization problems [15]. The PSO technique can generate a high quality solution with less calculation time and a more stable convergence characteristic in comparison with other evolutionary algorithms [16]. These advantages make PSO widely used in many engineering applications. In the recent years, several state-of-the-art PSO variants have been proposed, such as those in [17]-[23]. Furthermore, recently, several approaches, such as dynamic neighborhood PSO [24], dominated tree [25], Sigma method [26], vector evaluated PSO [27], dynamic multiple swarms [28], dynamic population size and adaptive local archives [29], etc., have been proposed to extend the PSO algorithm to deal with multi-objective optimization problems. This paper is aimed at improving multi-objective particle swarm optimization (MOPSO) by increasing the rate of convergence and diversity of solutions. The proposed MOPSO is applied to Pareto optimal fuzzy control design of a doubled inverted pendulum system. In the other words, by using the MOPSO algorithm, the important parameters of the single input rule modules dynamically connected fuzzy inference model are optimized in order to simultaneously decrease the distance error of the cart and summation errors of angles for the shorter and longer pendulums.
Yubazaki et al. [30] originally proposed single input rule modules (SIRMs) dynamically connected fuzzy inference model for plural input fuzzy control. In this controller, for each input item (the states of the system), an SIRM and a dynamic importance degree (DID) are defined. DID consists of a base value that insures the role of the input item through a control process, and a dynamic value that changes with control situations to adjust DID. In the following, the concepts of the SIRM and DID are described.
Consider a dynamic system with n input items and 1 output item. Since there are n input items, n SIRMs would be defined as
SIRMi:{Rji:ifxi=Ajithenui=Cji}mij=1} | (1) |
where SIRMi means the SIRM referred to the ith input item, and Rji is the jth rule in the SIRMi. xi corresponds to the variable in the antecedent part, and ui is the variable in the consequent part. Aji and Cji are the membership functions of the xi and ui in the jth rule of the SIRMi, respectively. j=1, 2, …, m is the index number of the rules in the SIRMi. Here, the rules and membership functions for SIRMs to stabilize the double inverted pendulum system are from [8].
To express the different role of each input item in system performance, the dynamic importance degree wDi for each input item xi (i=1,2,…,n) is defined as
wDi=w0i+BiΔw0i | (2) |
where w0i is a base value, Δw0i is a fuzzy variable, and Bi is a breadth for the ith input item (i=1,2,…,n). In this paper, the fuzzy variable Δw0i of the inputs xi (i=1,2,…,n) to stabilize the double inverted pendulum system is completely similar to [8].
Once SIRMs and DID are determined, the driving force F could be obtained by the following equation:
F=OSF×u=OSF×n∑i=1wDiu0i | (3) |
where OSF is the output scaling factor, u0i is the fuzzy inference result obtained from SIRMi.
In this paper, the base values w0i (i=1,2,…,n), the breadths Bi (i=1,2,…,n), and the output scaling factor OSF would be determined by using the multi-objective particle swarm optimization algorithm.
In Fig. 1, the structure of a double inverted pendulum shows that the state vector x=[x1,x2,x3,x4,x5,x6]T=[α,˙α, β, ˙β,x,˙x]T includes the angle and angular velocity of the longer pendulum, the angle and angular velocity of the shorter pendulum, the position and velocity of the cart. The dynamical equations of the system are as follows:
(M+m1+m2)¨x+m1l1¨αcos(α)+m2l2¨βcos(β)=F+m1l1˙α2sin(α)+m2l2˙β2sin(β)m1l1¨xcos(α)+4m1l213¨α=m1l1gsin(α)m2l2¨xcos(β)+4m2l223¨β=m2l2gsin(β). | (4) |
The masses of the cart, longer pendulum, and shorter pendulum are M, m1 and m2, respectively. g represents the gravity acceleration. l1 and l2 are half length of the longer and shorter pendulums, respectively. The driving force applied horizontally to the cart is denoted as F. For simulation, the following specifications are used. M=1, m1=0.3kg, m2 =0.1kg, l1=0.6m, l2=0.2m, and g=9.8m/s2. Furthermore, the initial and desired values are x=[x1,x2, x3, x4,x5,x6]T=[π/36,0,π/36,0,0,0]T and x=[x1,x2, x3, x4,x5,x6]T=[0,0,0,0,0,0]T, respectively.
Particle swam optimization is a population-based evolutionary algorithm where the candidate solutions are called particles and the position of each particle is changed via its own experience and its neighbors according to the following equations [31]−[34]:
xxi(t+1)= xxi(t)+vvi(t+1) | (5) |
vvi(t+1)= Wvvi(t)+C1r1(xxpbesti−xxi(t))+C2r2(xxgbest−xxi(t)) | (6) |
where xxi(t) and vvi(t) denote the position and velocity of particle i, at time step t. r1,r2∈[0,1] are random values. C1 are C2 are the cognitive and social learning factors, respectively, and W is the inertia weight. The personal best position of the particle i is xxpbesti and xxgbest is the position of the best particle of the entire swarm.
Experimental results illustrated that the linearly decreasing inertia weight over the iterations improves the performance of PSO [35]. Furthermore, it has shown that best solutions were determined when C1 is linearly decreased and C2 is linearly increased over the iterations [36]. Hence, the following linear formula for the inertia weight and learning factors are used.
W=W1−(W1−W2)×titermax | (7) |
C1=C1i−(C1i−C1f)×titermax | (8) |
C2=C2i−(C2i−C2f)×titermax | (9) |
where W1 and W2 are the initial and final values of the inertia weight, respectively. C1i, C2i, C1f, and C2f are the initial and final values of the learning factors, respectively. t is the current iteration number and itermax is the maximum number of allowable iterations.
In the following, the selection strategies of global best position and personal best position for the multi-objective PSO are described. Furthermore, a turbulence operator and a dynamic elimination method are introduced in order to enhance the solution searching ability of particles and to maintain the diversity of non-dominated solutions.
1) Selection of Global Best Position: A leader should be selected as xxgbest for each particle in order to update its position. Here, a leader selection technique based on density measures is used. In fact, a neighborhood radius (Rneighborhood) is considered for all non-dominated solutions. Two non-dominated solutions are neighbors if the Euclidean distance (measured in the objective domain) between them is less than Rneighborhood. Using this definition, the neighbors of all non-dominated solutions are calculated in the objective function domain, and the particle with fewer neighbors is considered as the leader.
2) Selection of Personal Best Position: The Sigma method proposed in [26] is applied to determining the personal best position of a particle. After assigning parameter σ to all particles in the population and archive (10), particle k in the archive would be selected as the personal best position for particle i in the population, if the distance between σi and σk is minimum
σ=f21−f22f21+f22 | (10) |
where f1 and f2 are two objective functions of the considered particle.
3) Turbulence Operator In order to escape from local minima and find better solutions, a turbulence operator is used. N particles from the population are randomly chosen to perform that according to the following equation:
xxi(t)=xxmin+rand×(xxmax−xxmin) | (11) |
where rand is a random number which is generated uniformly in the interval [0, 1]. xxmax and xxmin are upper and lower bounds of the search space respectively. In this paper, N= Pm × number of particles, where Pm is the probability of the turbulence operator.
4) Dynamic Elimination Technique: Elimination techniques are used to prune the archive and limit its size [37]−[40]; and here, the method introduced in [41] is applied. In this approach, for each particle in the archive, an elimination radius equal to εDynamic is defined. If the Euclidean distance (in the objective function space) between two particles is less than εDynamic, then one of them will be eliminated [41].
5) Details of the Proposed Algorithm: Initially, the particles of the population should be randomly generated. Then, the inertia weight, the learning factors, and turbulence probability can be determined. In each iteration, the archive can be formed, and xxpbesti and xxgbest are assigned. Then, for each particle, a random number ρ∈[0,1] will be considered. If a particle has ρ<proturb, where proturb denotes turbulence probability, then a new particle will be produced by the turbulent operator. Other particles that are not selected for turbulent operation will be enhanced by PSO. This cycle should be repeated until the criterion of the maximum iteration is reached. The pseudo code of this algorithm is illustrated in Algorithm 1.
Algorithm 1 The pseudo code of MOPSO algorithm |
Initialize population and the algorithm configuration of the proposed MOPSO. |
For t= 1:itermax |
Assign the inertia weight, the learning factors, and turbulence prob-ability; |
Calculate the fitness values of all particles, update and prune thearchive with respect to εDynamic; |
Determine xgbest(t); |
For i= 1:population size |
Determine xpbesti (t); |
ρ= rand; |
If ρ < proturb then update position xi(t) using turbulent operators. |
Else update velocity and position xi(t) using PSO formulations. |
End if |
End for |
End for. |
In this section, Pareto design of SIRMs dynamically connected fuzzy controllers using the multi-objective particle swarm optimization is performed for the double inverted pendulum system. The distance error of the cart and the summation errors of angles for the shorter and longer pendulums are regarded as the objective functions that should be minimized simultaneously. The vector [w01, w02, w03, w04, w05, w06, B1, B2, B3, B4, B5, B6, OSF] is the vector of design variables where w0i (i=1,2,3,4,5,6), Bi (i=1,2,3,4,5,6), and OSF are the base values, the breadths, and the output scaling factor, respectively. To compare the performance of the proposed method, two well-known versions of multi-objective optimization algorithms are used (Table Ⅰ). Also, the configuration of the MOPSO algorithm is as follows: population size = 100, itermax =1000, W1=0.9, W1=0.4, C1i=2.5, C1f=0.5, C2i =0.5, C2f=2.5, Rneighborhood=0.02, Pm=5/t.
When the multi-objective optimization algorithms are applied to this problem, Pareto fronts will be achieved that are demonstrated in Fig. 2. In Fig. 2, Points A and C stand for the minimum distance error of the cart and the summation errors of angles for the shorter and longer pendulums, respectively.
It is clear from Fig. 2 that some points obtained by the proposed algorithm dominate to the suggested optimum point by [8] (such as Point B). Furthermore, the point A has the best distance control of the cart and the worst angular control of the pendulums, while Point C has the best angular control of the pendulums and the worst distance control of the cart. Design variables, objective functions, and maximum driving forces corresponding to the optimum design points are presented in Table Ⅱ. The time responses of cart and pendulums related to these points are shown in Figs. 3-5. Furthermore, Fig. 6 shows the driving forces of the optimum design points.
Optimum design points | A | B | C |
w10 | 2.1641 | 2.1836 | 2.3155 |
w20 | 4.6814 | 4.5599 | 4.5901 |
w30 | 1.6095 | 1.6606 | 1.8544 |
w40 | 1.7101 | 1.7806 | 1.8062 |
w50 | 0.6906 | 0.4942 | 0.1584 |
w60 | 0.3902 | 0.2728 | 0.2391 |
B1 | 0.3754 | 0.4749 | 0.5054 |
B2 | 0.3731 | 0.2781 | 0.1263 |
B3 | 0.2986 | 0.3211 | 0.2213 |
B4 | 1.4978 | 1.3056 | 1.3865 |
B5 | 0.0000 | 0.0000 | 0.0000 |
B6 | 0.1055 | 0.1157 | 0.0851 |
OSF | 14. 4369 | 14.5621 | 14.7365 |
The distance error of the cart (m) | 0.4927 | 0.7183 | 1.9520 |
The summation of angle errorsof the pendulums (rad) | 0.4228 | 0.3082 | 0.2428 |
Maximum driving force (N) | 2.7922 | 2.7954 | 2.7302 |
Java is an object-oriented programming language, a runtime system, a set of development tools, and an application programming interface (API). The relationships among these elements are described in [1], [2].
Here, the Java applet is used to create the double inverted pendulum system and its SIRM fuzzy controller based on the proposed multi-objective particle swarm optimization. In fact, the coding of stability simulation via a computational tool as Java is to verify the obtained results in the previous section and education of internet-based control [1].
In the following, the main concepts of the Java programming are reviewed [43]−[45].
1) Classes, Methods, and Packages: Java programs consist of classes included methods. Java has many predefined named packages.
2) Java Development Environment: Java programs mainly have five phases: edit, compile, load, verify, and execute.
3) Inheritance: In Java, inheritance is a compile-time mechanism that extends a class to another class.
4) Applet: An applet program written in the Java programming language can be placed in an HTML page and has five methods: init, start, paint, stop, and destroy.
5) Multithreading: Multithreaded programs support more than one concurrent thread of execution and are able to execute the multiple sequences of instructions simultaneously.
For coding of stability simulation via Java, a package named JavaDoubleInvPend is defined. This package includes three classes named MainDIPClass, SIRMClass, and DIDClass as shown in Algorithms 2-4, respectively. Two classes, DIDClass and SIRMClass include methods that implement the equations in Sections Ⅲ and Ⅳ. MainDIPClass is one of Applet's subclasses and can inherit the Applet properties. Moreover, a method named DoubleInvPendSys( ) is defined in order to use the dynamic equations introduced in Section Ⅲ to achieve the position of the cart and pendulums (Algorithm 5). Hence, by using of these classes, we could achieve the position of the cart and pendulums. The simulation program can draw the double inverted pendulum system and its SIRM fuzzy controller based on the multi-objective particle swarm optimization. This action occurred every 0.01 s; so the Java animation would be created as shown in Fig. 7.
Algorithm 2 MainDIPC lass used in Java code |
MainDIPClass |
Package javadoubleinvepend; |
Public class MainDIPClass extends Applet implements Runnable{ |
Thread P1 = null; |
boolean ThreadD; |
public void init(){…} |
public void run(){…} |
public void start(){…} |
public void stop(){… |
public void paint(){…} |
public void DoubleInvPend(){…}} |
Algorithm 3 SIRMClass used to implement the equations in Section Ⅲ |
SIRMClass |
Package javadoubleinvepend; |
Public class SIRMClass { |
MainDIPClass Obj = new MainDIPClass(); |
Public static double MainSIRMMeth(int index) |
{ |
for (int i= 1; i < 7; i++) |
nxi[i]=MainDIPClass. Nx[i]; |
for (int i = 1;i < 7;i++) |
{ |
if (nxi[i] < -1) |
{ |
NB[i]= 1; |
ZO[i]= 0; |
PB[i]=0; |
} |
else if (nxi[i] < = 0) |
{ |
NB[i]=-nxi[i]; |
ZO[i] = nxi[i]+ 1; |
PB[i]= 0; |
} |
else if (nxi[i] < = 1) |
{ |
NB[i] = 0; |
ZO[i]=-nxi[i]+1; |
PB[i] = nxi[i]; |
} |
else if (nxi[i] > 1) |
{ |
NB[i] = 0; |
ZO[i]= 0; |
PB[i]= 1; |
} |
} |
fi[index] = (NB[index]* f_NB[index] + ZO[index]* f_ZO[index] |
+ PB[index]*f_PB[index])/(NB[index]+ZO[index]+PB[index]); |
return fi[index]; |
} |
} |
Algorithm 4 DIDC lass used to implement the equations in Section Ⅳ |
DIDClass |
Package javadoubleinvepend; |
Public class DIDC lass |
{ |
Public static double DID (double N_x1, double N_x3, int i) |
{ |
double p = Math.abs(N_x1); |
if (p < = 0.5) |
{ |
DS1 = -2*p+ 1; |
DM1=2*p; |
DB1 = 0; |
} |
else if (p < = 1) |
{ |
DS1 = 0; |
DM1=-2*p+2; |
DB1=2*p-1; |
} |
double q = Math.abs (N_x3); |
if (q < = 0.5) |
{ |
DS3= -2*q+1; |
DM3 =2*q; |
DB3= 0; |
} |
else if(q < = 1) |
{ |
DS3= 0; |
DM3=-2*q+2; |
DB3=2*q-1; |
} |
delta_wD[1]= (w_DS1*DS1+ w_DM1*DM1 |
+w_DB1*DB1)/(DS1+DM1+DB1); |
delta_wD[2] = delta_wD[1]; delta_wD[3] |
=(w_DS3*DS3+w_DM3*DM3+w_DB3*DB3) |
/(DS3+DM3+DB3); |
delta_wD[4]=delta_wD[3]; |
delta_wD[5]= (w_DS1_DS3 * (DS1*DS3)+ w_DS1_DM3 |
*(DS1 * DM3)+ w_DM1__DS3 * (DM1 * DS3)) |
/(DS1 *DS3)+(DS1 *DM3)+(DS1 *DB3)+ (DM1 *DS3) |
+(DMI * DM3)+ (DM1 * DB3) + (DB1 * DS3) |
+(DB1 * DM3)+ (DB1 *DB3)); |
delta_wD[6] = delta_wD[5]; |
wD= w[i] + B[i] * delta_wD[i]; |
return wD; |
} |
} |
Algorithm 5 Method DoubleInvPend used in Java code |
DoubleInvPend |
public void DoubleInvPend() |
{ |
a11=m1+m2+M; |
a12=m1∗l1 * Math.cos(x1); |
a13=m2∗l2 * Math.cos(x3); |
a21=a12; |
a22=4∗m1∗l1∗l1/3; |
a31=a13; |
a33=4∗m2∗l2∗l2/3; |
Nx[1]=x1/(Math.PI/12); |
Nx[2]=x2/(Math.PI/1.8); |
Nx[3]=x3/(Math.PI/12); |
Nx[4]=x4/(Math.PI/1.8); |
Nx[5]=x5/(2.4); |
Nx[6]=x6; |
for (int i=1;i<7;i++) |
wD[i] = DIDClass.DID (Nx[1],Nx[3s],i); |
for (int i=1;i<7;i++) |
fi[i] = SIRMClass.MainSIRMMeth(i); |
for (int j=1;j<7;j++) |
{ |
f+ = wD[j] * fi[j] |
} |
u=f∗Zf; |
dx1=x2; |
b1=u+m1∗l1∗x2∗x2∗ Math.sin(x1)+m2∗l2∗x4∗x4 |
∗ Math.sin(x3); |
b2=m1∗l1∗ gravity * Math.sin(x1); |
b3=m2∗l2∗ gravity * Math.sin(x3); |
dx2=(b2−a21∗((b1∗a22∗a33−a12∗b2∗a33−a13∗b3∗a22) |
/(a11∗a22∗a33−a12∗a21∗a33−a13∗a31∗a22)))/a22; |
dx3=x4; |
dx4=(b3−a31∗((b1∗a22∗a33−a12∗b2∗a33−a13∗b3∗a22) |
(a11∗a22∗a33−a12∗a21∗a33−a13∗a31∗a22)))/a33; |
dx5=x6; |
dx6=(b1∗a22∗a33−a12∗b2∗a33−a13∗b3∗a22) |
/(a11∗a22∗a33−a12∗a21∗a33−a13∗a31∗a22); |
x1+ = deltaT * dx1; |
x2+ = deltaT * dx2; |
x3+ = deltaT * dx3; |
x4+ = deltaT * dx4; |
x5+ = deltaT * x6; |
x6+ = deltaT * dx6; |
posx = (int)(x5 * coef); |
posxl1 = (int) (l1 * coef * Math.sin(x1)); |
posxl1 = (int) (l1 * coef * Math.cos(x1)); |
posxl2 = (int) (l2 * coef * Math.sin(x3)); |
posyl2 = (int) (l2 * coef * Math.cos(x3)); |
The variables of the DoubleInvPend( ) method are introduced in Table Ⅲ. Fig. 7 shows the results of Java program simulation. For this animation, the design variables of Point C in Section Ⅴ are used. This figure and attached video file reveal when the pendulums are going to fall, the cart is moving to the same side until the pendulums go up. As it is seen from Fig. 7, the cart will reach the desired position at the end of simulation. These observations reinforce the obtained simulation results in Section Ⅴ.
Variables | Description |
u | Control effort |
posx | The position of the cart |
posxll | The x component of the position of the longer pendulum |
posxl2 | The x component of the position of the shorter pendulum |
posyll | The y component of the position of the longer pendulum |
posyl2 | The y component of the position of the shorter pendulum |
coef | The coefficient of pixels to appropriate and balance number for design |
In this paper, an MOPSO algorithm was used, of which the leader selection method was based on density measures, the personal best positions were determined via Sigma method, the dynamic elimination technique was applied to prune the archive, and the turbulence operator was utilized to escape from the local minima. The proposed multi-objective algorithm was successfully used to obtain the Pareto frontiers of SIRMs dynamically connected fuzzy controllers for the double inverted pendulum system. The distance error of the cart and the summation errors of angles for the shorter and longer pendulums were considered as conflicting objective functions. The feasibility and efficiency of the proposed algorithm were shown in comparison with those obtained by two well-known multi-objective algorithms reported in the literature on this control problem. Furthermore, the modeling, control and stability simulation of the double inverted pendulum system were presented on the net using Java Applets with educational goals.
[1] |
Y. Becerikli and B. K. Celik, "Fuzzy control of inverted pendulum and concept of stability using Java application, " Math. Comput. Model., vol. 46, no. 1-2, pp. 24-37, Jul, 2007.
|
[2] |
M. J. Mahmoodabadi, A. Bagheri, S. Arabani Mostaghim, and M. Bisheban, "Simulation of stability using Java application for Pareto design of controllers based on a new multi-objective particle swarm optimization, " Math. Comput. Model., vol. 54, no. 5-6, pp. 1584-1607, Sep. 2011.
|
[3] |
Z. Liu, Y. Zhang, and Y. N. Wang, "A type-2 fuzzy switching control system for biped robots, " IEEE Trans. Syst. Man Cybern. Part C Appl. Rev., vol. 37, no. 6, pp. 1202-1213, Nov. 2007.
|
[4] |
C. S. Tseng and B. S. Chen, "Robust fuzzy observer-based fuzzy control design for nonlinear discrete-time systems with persistent bounded disturbances, " IEEE Trans. Fuzzy Syst., vol. 17, no. 3, pp. 711-723, Jun. 2009.
|
[5] |
C. H. Huang, W. J. Wang, and C. H. Chiu, "Design and implementation of fuzzy control on a two-wheel inverted pendulum, " IEEE Trans. Industr. Electron., vol. 58, no. 7, pp. 2988-3001, Jul. 2011.
|
[6] |
Y. G. Zhu, "Fuzzy optimal control for multistage fuzzy systems, " IEEE Trans. Syst. Man Cybern. Part B, vol. 41, no. 4, pp. 964-975, Aug. 2011.
|
[7] |
T. Wang, Y. F. Zhang, J. B. Qiu, and H. J. Gao, "Adaptive fuzzy backstepping control for a class of nonlinear systems with sampled and delayed measurements, " IEEE Trans. Fuzzy Syst., vol. 23, no. 2, pp. 302-312, Apr. 2015.
|
[8] |
J. Q. Yi, N. Yubazaki, and K. Hirota, "A new fuzzy controller for stabilization of parallel-type double inverted pendulum system, " Fuzzy Sets Syst., vol. 126, no. 1, pp. 105-119, Feb. 2002.
|
[9] |
D. A. Shook, P. N. Roschke, P. Y. Lin, and C. H. Loh, "GA-optimized fuzzy logic control of a large-scale building for seismic loads, "Eng. Struct., vol. 30, no. 2, pp. 436-449, Feb. 2008.
|
[10] |
H. Shayeghi, A. Jalili, and H. A. Shayanfar, " Multi-stage fuzzy load frequency control using PSO, "Energy Conver. Manage., vol. 49, no. 10, pp. 2570-2580, Oct. 2008.
|
[11] |
Z. Bingul and O. Karahan, " A fuzzy logic controller tuned with PSO ¨ for 2 DOF robot trajectory control, "Expert Syst. Appl., vol. 38, no. 1, pp. 1017-1031, Jan. 2011.
|
[12] |
B. Ahmadi, M. Ghamati, A. Jamali, and N. Nariman-Zadeh, " Pareto robust reliability-based controller design for probabilistic uncertain systems using fuzzy rules, "in Proc. IEEE Int. Symp. Innovations in Intelligent Systems and Applications (INISTA), Istanbul, Turkey, 2011, pp. 59-63.
|
[13] |
M. J. Mahmoodabadi, M. B. Salahshoor Mottaghi, and A. Mahmodinejad, " Optimum design of fuzzy controllers for nonlinear systems using multi-objective particle swarm optimization, "J. Vib. Control, vol. 22, no. 3, pp. 769-783, Feb. 2016. doi: 1077546314532116.
|
[14] |
J. Kennedy and R. Eberhart, " Particle swarm optimization, "in Proc. IEEE Int. Conf. Neural Networks, Perth, WA, Australia, 1995, pp. 1942- 1948.
|
[15] |
P. J. Angeline, " Using selection to improve particle swarm optimization, in Proc. IEEE Int. Conf. Evolutionary Computation Proc. IEEE World Congr. Computational Intelligence, Anchorage, AK, USA, 1998, pp. 84-89.
|
[16] |
H. Yoshida, K. Kawata, Y. Fukuyama, S. Fukuyama, and Y. Fukuyama, A particle swarm optimization for reactive power and voltage control considering voltage security assessment, "IEEE Trans. Power Syst., vol. 15, no. 4, pp. 1232-1239, Nov. 2000.
|
[17] |
X. Chen and Y. M. Li, " A modified PSO structure resulting in high exploration ability with convergence guaranteed, "IEEE Trans. Syst. Man Cybern. Part B, vol. 37, no. 5, pp. 1271-1289, Oct. 2007.
|
[18] |
Y. P. Chen, W. C. Peng, and M. C. Jian, " Particle swarm optimization with recombination and dynamic linkage discovery, "IEEE Trans. Syst. Man Cybern. Part B, vol. 37, no. 6, pp. 1460-1470, Dec. 2007.
|
[19] |
C. K. Monson and K. D. Seppi, " The Kalman swarm: A new approach to particle motion in swarm optimization, "in Proc. Genetic and Evolutionary Computation Conf., Seattle, WA, USA, 2004, pp. 140-150.
|
[20] |
S. Janson and M. Middendorf, " A hierarchical particle swarm optimizer and its adaptive variant, "IEEE Trans. Syst. Man Cybern. Part B, vol. 35, no. 6, pp. 1272-1282, Dec. 2005.
|
[21] |
R. A. Krohling and L. Dos Santos Coelho, " Coevolutionary particle swarm optimization using Gaussian distribution for solving constrained optimization problems, "IEEE Trans. Syst. Man Cybern. Part B, vol. 36, no. 6, pp. 1407-1416, Dec. 2006.
|
[22] |
F. Van Den Bergh and A. P. Engelbrecht, " A new locally convergent particle swarm optimiser, "in Proc. IEEE Int. Conf. Systems, Man, and Cybernetics, Yasmine Hammamet, Tunisia, 2002, pp. 96-101.
|
[23] |
W. J. Zhang and X. F. Xie, " DEPSO: hybrid particle swarm with differential evolution operator, "in Proc. IEEE Int. Conf. Systems, Man, and Cybernetics, Washington, DC, USA, 2003, pp. 3816-3821.
|
[24] |
X. H. Hu and R. C. Eberhart, " Multiobjective optimization using dynamic neighborhood particle swarm optimization, "in Proc. Congr. Evolutionary Computation, Honolulu, HI, USA, 2002, pp. 1677-1681.
|
[25] |
J. E. Fieldsend and S. Singh, " A multi-objective algorithm based upon particle swarm optimisation, an efficient data structure and turbulence, in Proc. Workshop on Computational Intelligence, Birmingham, UK, 2002, pp. 34-44.
|
[26] |
S. Mostaghim and J. Teich, "Strategies for finding good local guides in multi-objective particle swarm optimization (MOPSO), " in Proc. IEEE Swarm Intelligence Symp., Indianapolis, IN, USA, 2003, pp. 26-33.
|
[27] |
K. E. Parsopoulos, D. K. Tasoulis, and M. N. Vrahatis, "Multiobjective optimization using parallel vector evaluated particle swarm optimization, " in Proc. IASTED Int. Conf. Artificial Intelligence and Applications, Innsbruck, Austria, 2004.
|
[28] |
G. G. Yen and W. F. Leong, "Dynamic multiple swarms in multiobjective particle swarm optimization, " IEEE Trans. Syst. Man Cybern. Part A Syst. Hum., vol. 39, no. 4, pp. 890-911, Jul. 2009.
|
[29] |
W. F. Leong and G. G. Yen, "PSO-based multiobjective optimization with dynamic population size and adaptive local archives, " IEEE Trans. Syst. Man Cybern. Part B, vol. 38, no. 5, pp. 1270-1293, Oct. 2008
|
[30] |
N. Yubazaki, J. Yi, M. Otani, and K. Hirota, "SIRMs connected fuzzy inference model and its applications to first-order lag systems and second-order lag systems, " in Proc. Asian Fuzzy Systems Symp. Soft Computing in Intelligent Systems and Information Processing, Kenting, China, 1996, pp. 545-550.
|
[31] |
R. C. Eberhart, R. Dobbins, and P. K. Simpson, Computational Intelligence PC Tools. British Columbia, Canada: Morgan Kaufmann Publishers, 1996.
|
[32] |
A. P. Engelbrecht, Computational Intelligence: An Introduction. West Sussex, England: John Wiley & Sons, 2002.
|
[33] |
A. P. Engelbrecht, Fundamentals of Computational Swarm Intelligence. Hoboken, NJ, USA: John Wiley & Sons, 2005.
|
[34] |
R. C. Eberhart and Y. H. Shi, "Comparison between genetic algorithms and particle swarm optimization, " in Proc. 7th Int. Conf. Evolutionary Programming Ⅶ, San Diego, California, USA, 1998, pp. 611-616.
|
[35] |
R. C. Eberhart and J. Kennedy, "A new optimizer using particle swarm theory, " in Proc. 6th Int. Symp. Micro Machine and Human Science, Nagoya, Japan, 1995, pp. 39-43.
|
[36] |
A. Ratnaweera, S. K. Halgamuge, and H. C. Watson, "Self-organizing hierarchical particle swarm optimizer with time-varying acceleration coefficient, " IEEE Trans. Evol. Comput., vol. 8, no. 3, pp. 240-255, Jun. 2004.
|
[37] |
S. J. Tsai, T. Y. Sun, C. C. Liu, S. T. Hsieh, W. C. Wu, and S. Y Chiu, "An improved multi-objective particle swarm optimizer for multiobjective problems, " Expert Syst. Appl., vol. 37, no. 8, 5872-5886, Aug. 2010.
|
[38] |
S. Mostaghim and J. Teich, " The role of ε-dominance in multi objective particle swarm optimization methods, " in Proc. Congr. Evolutionary Computation, Canberra, ACT, Australia, 2003, pp. 1764-1771.
|
[39] |
Y. J. Wang and Y. P. Yang, "Particle swarm optimization with preference order ranking for multi-objective optimization, " Inf. Sci., vol. 179, no. 2, pp. 1944-1959, May 2009.
|
[40] |
G. Hernández-Díaz, L. V. Santana-Quintero, C. A. Coello Coello, J. Molina, and R. Caballero, "Improving the efficiency of"-dominance based grids, "Inf. Sci., vol. 181, no. 15, pp. 3101-3129, Aug. 2011.
|
[41] |
M. J. Mahmoodabadi, S. Arabani Mostaghim, A. Bagheri, and N. Nariman-Zadeh, " Pareto optimal design of the decoupled sliding mode controller for an inverted pendulum system and its stability simulation via Java programming, " Math. Comput. Model., vol. 57, no. 5-6, pp. 1070-1082, Mar. 2013.
|
[42] |
K. Deb, A. Pratap, S. Agarwal, and T. Meyarivan, " A fast and elitist multiobjective genetic algorithm: NSGA-Ⅱ, "IEEE Trans. Evol. Comput., vol. 6, no. 2, pp. 182-197, Apr. 2002.
|
[43] |
H. Gould, J. Tobochnik, and W. Christian, An Introduction to Computer Simulation Methods: Applications to Physical Systems, 3rd ed. Reading, Mass., USA: Addison-Wesley Publishing, 2006.
|
[44] |
H. M. Deitel and P. J. Deitel, Java? How to Program, 6th ed. Upper Saddle River, NJ, USA: Prentice Hall Publishing, 2004.
|
[45] |
P. Chan and S. E. Ingram, Developing Professional Java Applets. Indianapolis, IN, USA: Macmillan Publishing Co., 1996.
|
Algorithm 1 The pseudo code of MOPSO algorithm |
Initialize population and the algorithm configuration of the proposed MOPSO. |
For t= 1:itermax |
Assign the inertia weight, the learning factors, and turbulence prob-ability; |
Calculate the fitness values of all particles, update and prune thearchive with respect to εDynamic; |
Determine xgbest(t); |
For i= 1:population size |
Determine xpbesti (t); |
ρ= rand; |
If ρ < proturb then update position xi(t) using turbulent operators. |
Else update velocity and position xi(t) using PSO formulations. |
End if |
End for |
End for. |
Optimum design points | A | B | C |
w10 | 2.1641 | 2.1836 | 2.3155 |
w20 | 4.6814 | 4.5599 | 4.5901 |
w30 | 1.6095 | 1.6606 | 1.8544 |
w40 | 1.7101 | 1.7806 | 1.8062 |
w50 | 0.6906 | 0.4942 | 0.1584 |
w60 | 0.3902 | 0.2728 | 0.2391 |
B1 | 0.3754 | 0.4749 | 0.5054 |
B2 | 0.3731 | 0.2781 | 0.1263 |
B3 | 0.2986 | 0.3211 | 0.2213 |
B4 | 1.4978 | 1.3056 | 1.3865 |
B5 | 0.0000 | 0.0000 | 0.0000 |
B6 | 0.1055 | 0.1157 | 0.0851 |
OSF | 14. 4369 | 14.5621 | 14.7365 |
The distance error of the cart (m) | 0.4927 | 0.7183 | 1.9520 |
The summation of angle errorsof the pendulums (rad) | 0.4228 | 0.3082 | 0.2428 |
Maximum driving force (N) | 2.7922 | 2.7954 | 2.7302 |
Algorithm 2 MainDIPC lass used in Java code |
MainDIPClass |
Package javadoubleinvepend; |
Public class MainDIPClass extends Applet implements Runnable{ |
Thread P1 = null; |
boolean ThreadD; |
public void init(){…} |
public void run(){…} |
public void start(){…} |
public void stop(){… |
public void paint(){…} |
public void DoubleInvPend(){…}} |
Algorithm 3 SIRMClass used to implement the equations in Section Ⅲ |
SIRMClass |
Package javadoubleinvepend; |
Public class SIRMClass { |
MainDIPClass Obj = new MainDIPClass(); |
Public static double MainSIRMMeth(int index) |
{ |
for (int i= 1; i < 7; i++) |
nxi[i]=MainDIPClass. Nx[i]; |
for (int i = 1;i < 7;i++) |
{ |
if (nxi[i] < -1) |
{ |
NB[i]= 1; |
ZO[i]= 0; |
PB[i]=0; |
} |
else if (nxi[i] < = 0) |
{ |
NB[i]=-nxi[i]; |
ZO[i] = nxi[i]+ 1; |
PB[i]= 0; |
} |
else if (nxi[i] < = 1) |
{ |
NB[i] = 0; |
ZO[i]=-nxi[i]+1; |
PB[i] = nxi[i]; |
} |
else if (nxi[i] > 1) |
{ |
NB[i] = 0; |
ZO[i]= 0; |
PB[i]= 1; |
} |
} |
fi[index] = (NB[index]* f_NB[index] + ZO[index]* f_ZO[index] |
+ PB[index]*f_PB[index])/(NB[index]+ZO[index]+PB[index]); |
return fi[index]; |
} |
} |
Algorithm 4 DIDC lass used to implement the equations in Section Ⅳ |
DIDClass |
Package javadoubleinvepend; |
Public class DIDC lass |
{ |
Public static double DID (double N_x1, double N_x3, int i) |
{ |
double p = Math.abs(N_x1); |
if (p < = 0.5) |
{ |
DS1 = -2*p+ 1; |
DM1=2*p; |
DB1 = 0; |
} |
else if (p < = 1) |
{ |
DS1 = 0; |
DM1=-2*p+2; |
DB1=2*p-1; |
} |
double q = Math.abs (N_x3); |
if (q < = 0.5) |
{ |
DS3= -2*q+1; |
DM3 =2*q; |
DB3= 0; |
} |
else if(q < = 1) |
{ |
DS3= 0; |
DM3=-2*q+2; |
DB3=2*q-1; |
} |
delta_wD[1]= (w_DS1*DS1+ w_DM1*DM1 |
+w_DB1*DB1)/(DS1+DM1+DB1); |
delta_wD[2] = delta_wD[1]; delta_wD[3] |
=(w_DS3*DS3+w_DM3*DM3+w_DB3*DB3) |
/(DS3+DM3+DB3); |
delta_wD[4]=delta_wD[3]; |
delta_wD[5]= (w_DS1_DS3 * (DS1*DS3)+ w_DS1_DM3 |
*(DS1 * DM3)+ w_DM1__DS3 * (DM1 * DS3)) |
/(DS1 *DS3)+(DS1 *DM3)+(DS1 *DB3)+ (DM1 *DS3) |
+(DMI * DM3)+ (DM1 * DB3) + (DB1 * DS3) |
+(DB1 * DM3)+ (DB1 *DB3)); |
delta_wD[6] = delta_wD[5]; |
wD= w[i] + B[i] * delta_wD[i]; |
return wD; |
} |
} |
Algorithm 5 Method DoubleInvPend used in Java code |
DoubleInvPend |
public void DoubleInvPend() |
{ |
a11=m1+m2+M; |
a12=m1∗l1 * Math.cos(x1); |
a13=m2∗l2 * Math.cos(x3); |
a21=a12; |
a22=4∗m1∗l1∗l1/3; |
a31=a13; |
a33=4∗m2∗l2∗l2/3; |
Nx[1]=x1/(Math.PI/12); |
Nx[2]=x2/(Math.PI/1.8); |
Nx[3]=x3/(Math.PI/12); |
Nx[4]=x4/(Math.PI/1.8); |
Nx[5]=x5/(2.4); |
Nx[6]=x6; |
for (int i=1;i<7;i++) |
wD[i] = DIDClass.DID (Nx[1],Nx[3s],i); |
for (int i=1;i<7;i++) |
fi[i] = SIRMClass.MainSIRMMeth(i); |
for (int j=1;j<7;j++) |
{ |
f+ = wD[j] * fi[j] |
} |
u=f∗Zf; |
dx1=x2; |
b1=u+m1∗l1∗x2∗x2∗ Math.sin(x1)+m2∗l2∗x4∗x4 |
∗ Math.sin(x3); |
b2=m1∗l1∗ gravity * Math.sin(x1); |
b3=m2∗l2∗ gravity * Math.sin(x3); |
dx2=(b2−a21∗((b1∗a22∗a33−a12∗b2∗a33−a13∗b3∗a22) |
/(a11∗a22∗a33−a12∗a21∗a33−a13∗a31∗a22)))/a22; |
dx3=x4; |
dx4=(b3−a31∗((b1∗a22∗a33−a12∗b2∗a33−a13∗b3∗a22) |
(a11∗a22∗a33−a12∗a21∗a33−a13∗a31∗a22)))/a33; |
dx5=x6; |
dx6=(b1∗a22∗a33−a12∗b2∗a33−a13∗b3∗a22) |
/(a11∗a22∗a33−a12∗a21∗a33−a13∗a31∗a22); |
x1+ = deltaT * dx1; |
x2+ = deltaT * dx2; |
x3+ = deltaT * dx3; |
x4+ = deltaT * dx4; |
x5+ = deltaT * x6; |
x6+ = deltaT * dx6; |
posx = (int)(x5 * coef); |
posxl1 = (int) (l1 * coef * Math.sin(x1)); |
posxl1 = (int) (l1 * coef * Math.cos(x1)); |
posxl2 = (int) (l2 * coef * Math.sin(x3)); |
posyl2 = (int) (l2 * coef * Math.cos(x3)); |
Variables | Description |
u | Control effort |
posx | The position of the cart |
posxll | The x component of the position of the longer pendulum |
posxl2 | The x component of the position of the shorter pendulum |
posyll | The y component of the position of the longer pendulum |
posyl2 | The y component of the position of the shorter pendulum |
coef | The coefficient of pixels to appropriate and balance number for design |
Algorithm 1 The pseudo code of MOPSO algorithm |
Initialize population and the algorithm configuration of the proposed MOPSO. |
For t= 1:itermax |
Assign the inertia weight, the learning factors, and turbulence prob-ability; |
Calculate the fitness values of all particles, update and prune thearchive with respect to εDynamic; |
Determine xgbest(t); |
For i= 1:population size |
Determine xpbesti (t); |
ρ= rand; |
If ρ < proturb then update position xi(t) using turbulent operators. |
Else update velocity and position xi(t) using PSO formulations. |
End if |
End for |
End for. |
Optimum design points | A | B | C |
w10 | 2.1641 | 2.1836 | 2.3155 |
w20 | 4.6814 | 4.5599 | 4.5901 |
w30 | 1.6095 | 1.6606 | 1.8544 |
w40 | 1.7101 | 1.7806 | 1.8062 |
w50 | 0.6906 | 0.4942 | 0.1584 |
w60 | 0.3902 | 0.2728 | 0.2391 |
B1 | 0.3754 | 0.4749 | 0.5054 |
B2 | 0.3731 | 0.2781 | 0.1263 |
B3 | 0.2986 | 0.3211 | 0.2213 |
B4 | 1.4978 | 1.3056 | 1.3865 |
B5 | 0.0000 | 0.0000 | 0.0000 |
B6 | 0.1055 | 0.1157 | 0.0851 |
OSF | 14. 4369 | 14.5621 | 14.7365 |
The distance error of the cart (m) | 0.4927 | 0.7183 | 1.9520 |
The summation of angle errorsof the pendulums (rad) | 0.4228 | 0.3082 | 0.2428 |
Maximum driving force (N) | 2.7922 | 2.7954 | 2.7302 |
Algorithm 2 MainDIPC lass used in Java code |
MainDIPClass |
Package javadoubleinvepend; |
Public class MainDIPClass extends Applet implements Runnable{ |
Thread P1 = null; |
boolean ThreadD; |
public void init(){…} |
public void run(){…} |
public void start(){…} |
public void stop(){… |
public void paint(){…} |
public void DoubleInvPend(){…}} |
Algorithm 3 SIRMClass used to implement the equations in Section Ⅲ |
SIRMClass |
Package javadoubleinvepend; |
Public class SIRMClass { |
MainDIPClass Obj = new MainDIPClass(); |
Public static double MainSIRMMeth(int index) |
{ |
for (int i= 1; i < 7; i++) |
nxi[i]=MainDIPClass. Nx[i]; |
for (int i = 1;i < 7;i++) |
{ |
if (nxi[i] < -1) |
{ |
NB[i]= 1; |
ZO[i]= 0; |
PB[i]=0; |
} |
else if (nxi[i] < = 0) |
{ |
NB[i]=-nxi[i]; |
ZO[i] = nxi[i]+ 1; |
PB[i]= 0; |
} |
else if (nxi[i] < = 1) |
{ |
NB[i] = 0; |
ZO[i]=-nxi[i]+1; |
PB[i] = nxi[i]; |
} |
else if (nxi[i] > 1) |
{ |
NB[i] = 0; |
ZO[i]= 0; |
PB[i]= 1; |
} |
} |
fi[index] = (NB[index]* f_NB[index] + ZO[index]* f_ZO[index] |
+ PB[index]*f_PB[index])/(NB[index]+ZO[index]+PB[index]); |
return fi[index]; |
} |
} |
Algorithm 4 DIDC lass used to implement the equations in Section Ⅳ |
DIDClass |
Package javadoubleinvepend; |
Public class DIDC lass |
{ |
Public static double DID (double N_x1, double N_x3, int i) |
{ |
double p = Math.abs(N_x1); |
if (p < = 0.5) |
{ |
DS1 = -2*p+ 1; |
DM1=2*p; |
DB1 = 0; |
} |
else if (p < = 1) |
{ |
DS1 = 0; |
DM1=-2*p+2; |
DB1=2*p-1; |
} |
double q = Math.abs (N_x3); |
if (q < = 0.5) |
{ |
DS3= -2*q+1; |
DM3 =2*q; |
DB3= 0; |
} |
else if(q < = 1) |
{ |
DS3= 0; |
DM3=-2*q+2; |
DB3=2*q-1; |
} |
delta_wD[1]= (w_DS1*DS1+ w_DM1*DM1 |
+w_DB1*DB1)/(DS1+DM1+DB1); |
delta_wD[2] = delta_wD[1]; delta_wD[3] |
=(w_DS3*DS3+w_DM3*DM3+w_DB3*DB3) |
/(DS3+DM3+DB3); |
delta_wD[4]=delta_wD[3]; |
delta_wD[5]= (w_DS1_DS3 * (DS1*DS3)+ w_DS1_DM3 |
*(DS1 * DM3)+ w_DM1__DS3 * (DM1 * DS3)) |
/(DS1 *DS3)+(DS1 *DM3)+(DS1 *DB3)+ (DM1 *DS3) |
+(DMI * DM3)+ (DM1 * DB3) + (DB1 * DS3) |
+(DB1 * DM3)+ (DB1 *DB3)); |
delta_wD[6] = delta_wD[5]; |
wD= w[i] + B[i] * delta_wD[i]; |
return wD; |
} |
} |
Algorithm 5 Method DoubleInvPend used in Java code |
DoubleInvPend |
public void DoubleInvPend() |
{ |
a11=m1+m2+M; |
a12=m1∗l1 * Math.cos(x1); |
a13=m2∗l2 * Math.cos(x3); |
a21=a12; |
a22=4∗m1∗l1∗l1/3; |
a31=a13; |
a33=4∗m2∗l2∗l2/3; |
Nx[1]=x1/(Math.PI/12); |
Nx[2]=x2/(Math.PI/1.8); |
Nx[3]=x3/(Math.PI/12); |
Nx[4]=x4/(Math.PI/1.8); |
Nx[5]=x5/(2.4); |
Nx[6]=x6; |
for (int i=1;i<7;i++) |
wD[i] = DIDClass.DID (Nx[1],Nx[3s],i); |
for (int i=1;i<7;i++) |
fi[i] = SIRMClass.MainSIRMMeth(i); |
for (int j=1;j<7;j++) |
{ |
f+ = wD[j] * fi[j] |
} |
u=f∗Zf; |
dx1=x2; |
b1=u+m1∗l1∗x2∗x2∗ Math.sin(x1)+m2∗l2∗x4∗x4 |
∗ Math.sin(x3); |
b2=m1∗l1∗ gravity * Math.sin(x1); |
b3=m2∗l2∗ gravity * Math.sin(x3); |
dx2=(b2−a21∗((b1∗a22∗a33−a12∗b2∗a33−a13∗b3∗a22) |
/(a11∗a22∗a33−a12∗a21∗a33−a13∗a31∗a22)))/a22; |
dx3=x4; |
dx4=(b3−a31∗((b1∗a22∗a33−a12∗b2∗a33−a13∗b3∗a22) |
(a11∗a22∗a33−a12∗a21∗a33−a13∗a31∗a22)))/a33; |
dx5=x6; |
dx6=(b1∗a22∗a33−a12∗b2∗a33−a13∗b3∗a22) |
/(a11∗a22∗a33−a12∗a21∗a33−a13∗a31∗a22); |
x1+ = deltaT * dx1; |
x2+ = deltaT * dx2; |
x3+ = deltaT * dx3; |
x4+ = deltaT * dx4; |
x5+ = deltaT * x6; |
x6+ = deltaT * dx6; |
posx = (int)(x5 * coef); |
posxl1 = (int) (l1 * coef * Math.sin(x1)); |
posxl1 = (int) (l1 * coef * Math.cos(x1)); |
posxl2 = (int) (l2 * coef * Math.sin(x3)); |
posyl2 = (int) (l2 * coef * Math.cos(x3)); |
Variables | Description |
u | Control effort |
posx | The position of the cart |
posxll | The x component of the position of the longer pendulum |
posxl2 | The x component of the position of the shorter pendulum |
posyll | The y component of the position of the longer pendulum |
posyl2 | The y component of the position of the shorter pendulum |
coef | The coefficient of pixels to appropriate and balance number for design |