Jtam.dvi JOURNAL OF THEORETICAL AND APPLIED MECHANICS 46, 2, pp. 395-411, Warsaw 2008 APPLICATION OF GENETIC ALGORITHM AND FOURIER COEFFICIENTS (GA-FC) IN MECHANISM SYNTHESIS Roman Starosta Poznan University of Technology, Institute of Applied Mechanics, Poznań, Poland e-mail: roman.starosta@put.poznan.pl The paper concerns synthesis of a four-bar linkage as a curve generator. Fourier coefficients of the curvature are applied to represent a closed curve. A genetic algorithm (GA)was adapted to solve the problem. The proposedmethod was successfully verified by many examples. Key words: evolutionary algorithms, mechanism synthesis 1. Introduction Rapid increase of computer calculation power enables application anddevelop- ment of new computation techniques. It affects the development of computer methods in the mechanism synthesis. The subject of mechanism synthesis is not a new problem. The problem investigated in the presented paper consists in generation of a given curve by a chosen point of amechanism. In the paper, it is a coupler point of a four-bar linkage (Fig.1). In general, the coupler draws a curve that is not identical to the given one. Owing to this, great attention is focused on the problemof approximation and numerical costs. The genetic algorithm (GA) used in the calculation is numbered among deterministic-probabilistic methods (Goldberg, 1989, 2003; Michalewicz, 1992). GAs are used and effectively applied to various optimization tasks, among others to synthesis of mechanism (Fang, 1994; Kunjur and Krishna- murty, 1997; Laribi et al., 2004; Białas-Heltowski et al., 2004). Laribi et al. (2004) showed that in the case of small dimension of thework space, a genetic algorithm significantly improves accuracy of the solution. For a large scope of possible parameters, deterministic methods are more efficient than GAs. 396 R. Starosta Fig. 1. Parameters defining geometry and position of a four-bar linkage An approach using neural networks to synthesize a curve is also developed in the last years (Vasiliu and Yannou, 2001; Walczak, 2006; Starosta, 2006). There are 9 unknown quantities in the synthesis of a four-bar linkage: lengths of links a, b, c, d, e, angles α, β and co-ordinates of the point A, i.e. xA and yA. In the present paper, the number of unknowns was reduced to 5. Theway of defining the goal function plays themajor role in the synthesis task. In the paper, a new method to evaluate the distance between the given and the generated curve is proposed. The goal function is constructed in such a way so not to take into consideration the location, orientation in space, and scaling of the mechanism dimension in the process of synthesis. It effectively shortens the time of calculation. 2. Aim of the work Oneof themethodsof curvedescription consists in its representationbymeans of Fourier Coefficients FCs. So far, the curvature of a curve was not used in themechanism synthesis. The possibility of using the curvature and algorithm of normalization of Fourier expansion coefficients was presented inBuśkiewicz (2006). The objective of the paper is to apply such a description for construc- tion the goal function in themechanism synthesis solved by theGA.The curve descriptionminimizes the number of sought parameters of themechanismdra- wing a given curve and, therefore, the additional algorithm of determination of its dimensions, location, and orientation on the plane is elaborated. The paper introduces amethod of optimal determination of link lengths of a four-bar linkage.Themechanism is arranged in order to doa given kinematic job. Application of genetic algorithm... 397 3. Curve description The essential part of the paper is a method of description of both the given and synthesized curves (Buśkiewicz, 2006), which is presented in brief below. A curve of the length s is given by the set of m points Ai of coordinates (xi,yi). sbi = ∑i l=2 |Al−1Al| is the arc length measured from the beginning point to the point i. s∗i = sbi/s is the natural parameter taking values from the interval [0,1). s∗ =1 is the normalized length of the curve, αi is the angle between the tangent to the curve at the point i and the horizontal line. The curvature function is defined as follows fi(s ∗)= (dα ds∗ ) i ≈ αi+1(s∗i+1)−αi(s ∗ i) ∆s∗i (3.1) The curvature is approximated by the Fourier series f(s∗)= a0+ k ∑ n=1 [ancos(2nπs ∗)+ bn sin(2nπs ∗)] (3.2) with the coefficients (FC) a0 = m ∑ i=1 f(s∗i)∆s ∗ i an =2 m ∑ i=1 f(s∗i)cos(2nπs ∗ i)∆s ∗ i (3.3) bn =2 m ∑ i=1 f(s∗i)sin(2nπs ∗ i)∆s ∗ i Rotation by an angle, translation by a vector and scaling do not change the curvature function.Thenormalization of theFCsprovides their invariance with respect to the change of the beginning point, the direction reversal and the mirror reflection of the curve (Fig.2). Thedescriptionminimizes thenumberof parameters of a curveand enables one to effectively use numerical algorithms based on theGA in themechanism synthesis. The goal function is the distance norm between the FC of the given and generated curves E= n ∑ i=1 [(a′1i−a ′ 2i) 2+(b′1i− b ′ 2i) 2] (3.4) where (a′1i,b ′ 1i), (a ′ 2i,b ′ 2i) arenormalizedFCs (NFC)of the curves, respectively. 398 R. Starosta Fig. 2. Examples of curves of the same FC 4. Discussion on the genetic algorithm (GA) Themethod presented in the paper belongs to the evolutionary programming class. The algorithm searches through the space of alternative solutions using the rules of natural selection and inheritance. Themethod combines the evo- lutionary principle of survival of the best fitted individualwith systematic and partially random swap of information. There are many papers containing te- sts of optimization problems using the evolutionary idea (Michalewicz, 1992; Michalewicz et al., 1994, 1996). Many authors apply GAs to optimization of mechanical structures. Among others, optimization of shape and topology of two dimensional structures was investigated by Sokołowski and Żochowski (1999) also in combination with other methods (Burczyński andKokot, 1998, 2003). A comparison of four kinds ofGA applied tomechanisms synthesis was discused in Białas-Heltowski et al. (2004). The idea of GA is adopted from rules governing biological systems that makes them more resistant than their deterministic equivalents. This is the reason of great interest in evolutionary algorithms for solving awide spectrum of problems. A maximized quantity in a GA is the so-called ”fitting”. This is a property or a set of properties favourable with respect to the desired goal function. In the investigated synthesis problem, an individual (alternative solution, mechanism) has the better fitting when the generated curve is more ”similar” to the desired one. In calculations, the fitting is determined for each alternative individual as the inverse to distance norm (3.4) between the generated and desired curves. A block diagram of the synthesis algorithm of a four-bar linkage is presen- ted in Fig.3. The vector containing lengths of the mechanism links and the angle β is the individual. Application of genetic algorithm... 399 The basic operations of the GA are: natural selection, crossover and mu- tation. The selection of the individuals is carried out using a roulette method, i.e. by drawing of an individual with the probability proportional to its fit- ting. The crossover and mutation are made on an encoded form. The binary representation is applied, i.e. each real number being a dimension or an angle is converted into a binary chain. The crossover consists in replacing a frag- ment of the binary chain between two randomly chosen individuals. One point crossing was admitted in the paper. In each generation, the whole population is randomly divided into two parts, and every individual of the first one is crossed with another from the second part. Themutation occurs with some probability and consists in replacing a bit 0 with 1 or vice versa at a randomly chosen position in the binary represen- tation. Fig. 3. Computational algorithm The mechanism synthesis is carried out in accordance with the algori- thm presented in Fig.3 and leads to inheritance and improving advantageous 400 R. Starosta properties of individuals in the next generations. Some additional new impro- vements are implemented in order to increase the efficiency of GA. Not all of them are placed in the block diagram in order not to blur its legibility. The new enhancements are the following: • The probability of mutation is adaptively controlled, it is inversely pro- portional to the fitting of the best individual. • If the growth in fitting does not occur in the established number of gene- rations thewhole population is randomlydisturbed (the point significan- tly improves convergence to the optimum solution). The magnitude of disturbance is inversely proportional to the fitting of the best individual. • Thebest individual is always storedup, i.e. passes to the next generation which guarantees that the best properties are not lost. Each solution is constrained by theGrashof conditions.When a solution does notmeet these conditions it is rejected and one of its parents remains. Due to this, the number of populations is preserved. 5. Determination of the links lengths and mechanism location The GA searches for the optimum solutions among the mechanisms (Fig.1) attached at the origin (A=(0,0)) of the crank length a=1 andwith α=0. The found mechanism generates a curve similar to the desired one. Proper dimensions of the mechanism, its location and orientation on the plane have to be determined so as the coupler curve fits best the desired one. To perform these transformations, the following geometric quantities are used: the curve length, centroid of a curve, second moments of the curve and position of the principal axis. The desired and generated curves are defined by the coordinates of points. The geometrical properties are determined bymeans of the following formulae (5.1)-(5.4). The centroids of the curve xC = 1 2s n ∑ i=1 si(xi+1+xi) yC = 1 2s n ∑ i=1 si(yi+1+yi) (5.1) where si = √ (xi−xi+1)2+(yi−yi+1)2. Application of genetic algorithm... 401 The central secondmoments IxC = n ∑ i=1 si ((yi+1−yi)2 12 + ( yC − yi+1+yi 2 )2) IyC = n ∑ i=1 si ((xi+1−xi)2 12 + ( xC − xi+1+xi 2 )2) (5.2) IxyC = n ∑ i=1 si ((yi+1−yi)(xi+1−xi) 12 + ( yC − yi+1+yi 2 )( xC − xi+1+xi 2 )) In the foregoing equations, xn+1 =x1. The principal second moments about the centroidal axes are I1,2 = 1 2 (IxC + IyC) 2± √ 1 4 (IxC − IyC)2+ I2xyC (5.3) and the principal angle α= 1 2 arctan −2IxyC IxC − IyC (5.4) An algorithm for computing real geometrical parameters of the mechanism is presented inFig.4.Thesubscripts dand gmeanthat thequantity corresponds to the desired and generated curves, respectively. The following denotations are introduced: Sk – scaling with respect to the centroid with the scaling coefficient equal to k in the x and y directions, Rα – rotation by α about the centroid, T t – translation by a vector t. Figure 5 illustrates geometrical properties of the curve used to find the mechanism dimensions, its position and orientation on the plane. 6. Numerical solutions by GA Below are presented five examples which illustrate correctness of themethod. All calculationsweremadeonaPCclass computer, IntelCore 2Duo2.66GHz, 1GB RAM. The algorithms presented in Figs.3 and 4 were implemented in FORTRAN 95. In all examples, the length of the binary chain was assumed 32. 402 R. Starosta Fig. 4. A block diagram for determination of the real dimensions as well as location and orientation of the mechanism Fig. 5. Translation vector and orientation of the centroidal axes for both the desired and generated curves (indexed with subscripts d and g, respectively) Application of genetic algorithm... 403 Example I Thegoal of the example is to compare the results obtained by the proposed (GA-FC) method with those obtained by other authors. The example was presented byKunjur andKrishnnamuty (1997) – KK, Cabrera et al. (2002) – CSP, and Laribi et al. (2004) – LMRZ. In thementioned papers, the synthesis was made using some variants of genetic algorithms and a genetic algorithm coupled with a fuzzy logic controller . Results obtained by Laribi et al. (2004) are compared to those obtained by means of other classical methods (central difference and gradient), and superiority of the genetic algorithm is proved. The desired curve is defined by a set of points. Their coordinates are given in Table 1. Table 1.Coordinates of points defining the desired curve Point 1 2 3 4 5 6 7 8 9 x 0.5 0.4 0.3 0.2 0.1 0.005 0.02 0.0 0.0 y 1.1 1.1 1.1 1.0 0.9 0.75 0.6 0.5 0.4 Point 10 11 12 13 14 15 16 17 18 x 0.03 0.1 0.15 0.2 0.3 0.4 0.5 0.6 0.6 y 0.3 0.25 0.2 0.3 0.4 0.5 0.7 0.9 1.0 Figure 6 shows evolution of norm (3.4) with respect to the number of generations. Fig. 6. Evolution of the error considered as the value of norm (3.4) The measure of closeness and similarity of the desired and generated cu- rves proposed in Laribi et al. (2004) is the conformity of chosen geometrical parameters. The same procedure was applied in order to compare the results obtained by using GA-FC with results taken from the references. 404 R. Starosta The vector G characterizes a given curve G= [w,h,s,A,xC,yC,IxC,IyC,IxyC] (6.1) where w=max(xi)−min(xi) for i=1, . . . ,n and h=max(yi)−min(yi) for i=1, . . . ,n The remaining elements of G are expressed by Eqs. (5.1)-(5.4) and then they are normalized to be useful as a measure of the curves similarity Gn = [h w , s w , A w2 , xC w , yC w , IxC w3 , IyC w3 , IxyC w3 ] (6.2) The error is computed as follows e= |Gnd−Gng| (6.3) The subscripts d and g mean that given quantity corresponds to the desired and generated curves, respectively. The results obtained byKunjur andKrish- namurty (1997), Laribi et al. (2004) andCabrera et al. (2002) are collected in Table 2 and comparedwith those obtained by the proposed (GA-FC)method. Figure 7 shows curves generated by the computer program executing the GA-FC method in search of the desired curve. Fig. 7. Curve generated by the coupler (found with GA) and curves transformed to fit it to the desired one The dimensions of optimal mechanisms found by the GA-FC and those described above mentioned papers are collected in Table 3. Theresultspresented inTable2 showsignificantadvantageof thepresented method over the approaches used by the mentioned authors. For the tested example, the error after applying the GA-FC is about 5 times less than the Application of genetic algorithm... 405 Table 2.Geometrical parameters of curves obtained with various methods Desired KK CSP LMRZ GA- FCcurve w 0.6 0.55 0.56 0.59 0.6029 h/w 1.5 1.63 1.47 1.50 1.5285 A/w2 0.9187 0.9113 1.8∗ 2.25∗ 1.82∗ 1.96∗ L/w 3.9292 4.14 3.85 3.93 3.9097 xC/w 0.4458 0.42 0.48 0.47 0.4436 xC/w 1.1494 1.24 1.19 1.17 1.1437 IxC/w 3 0.8963 1.16 0.88 0.93 0.9032 IyC/w 3 0.4652 0.52 0.44 0.49 0.4605 IxyC/w 3 0.2880 0.2959 2.05∗ 1.97∗ 2.33∗ 2.15∗ e – 0.62 0.29 0.20 0.03775 ∗ The values A and Ixy presented in Laribi et al. (2004) are incorrect. Most likely, these values for the desired and generated curves were computed from the same wrong equation. Table 3. Parameters defining the mechanism and its location obtained by various authors a b c d e xA yA β α KK 0.42 2.32 3.36 4.07 3.90 −3.06 −1.3 −15.6◦ −9.1◦ CSP 0.27 1.18 2.13 1.87 0.91 1.13 0.66 204◦ 249◦ LMRZ 0.23 5.58 2.05 3.05 2 1.77 −0.64 67.7◦ 57◦ AG-FC 0.28 0.36 0.98 1.01 0.36 0.074 0.191 247◦ −139.8◦ error of the results cited in the papers by Kunjur and Krishnamurty (1997), Cabrera et al. (2002) andLaribi et al. (2004). The calculation time is estimated at 0.8s for the assumed parameters of GA: the number of specimens in each generation Ns = 100, the initial probability of mutation Mp = 0.01, the number of generations Gn = 200. In the last two cited papers, for the same mechanism the authorsworked for 3.25s on aPentiumprocessor 800MHzand 1.32s on the Athlon 1800MHz, respectively. Shorter times of calculation ensure fromthe computer power.Better fitting of the generated and given curves is probably due to the effective way of curve encoding as a FC and a lower number of design variables in GA. Moreover, an improvement of the convergence is caused by some amendments to theGA described in Section 4. 406 R. Starosta Example II In example II, the desired curve is generated by a four bar linkage. It is done certain that there exists a synthesized mechanism the coupler of which draws a desired curve. The parameters of the mechanism generating the desired curve are: a = 1.0, b = 2.4, c = 1.9, d = 3.12, e = 3.1, α = π/6, xA = 0.0, yA = 0.0, β=0.0. The desired curve is then reflected with respect to the axis Oy, translated by the vector [2.0,0.0] and rotated by the angle π/4with respect to the origin of the coordinate system. The parameters of the AG assumed in the calculation are the same as in example I (Ns =100, Mp =0.01, Gn = 200). The number of points defining the desired curve equals 18. The result found by theGA is presented in Fig.8. The transformations on the generated curve are done according to the scheme given in Fig.5. Figure 8 shows that the resultant curve very accurately render the original shape. Fig. 8. Resulting coupler curves and their transformations aimed at the best fitting to the desired curve To generalize the concept of the error, a new measure of the solution cor- rectness is proposed. Themeasure of congruence of the desired and generated curves is a relative error expressedby their principal secondmoments of inertia about the centroidal axis normalized with respect to the curve length e1 = |I∗1g − I ∗ 1d| I∗ 1d e2 = |I∗2g − I ∗ 2d| I∗ 2d (6.4) where I∗1g = I1g s3g I∗2g = I2g s3g I∗1d = I1d s3 d I∗2d = I2d s3 d Application of genetic algorithm... 407 The foregoing normalized quantities enable computation of the error of the AG results without necessity of performing the geometrical transformations described in Fig.4. The geometrical properties are calculated for: — desired curves sd =4.87737 I ∗ 1d =1.9498 ·10 −2 I∗2d =1.13210 ·10 −3 —curves generated by the GA sg =4.87738 I ∗ 1g =1.94983 ·10 −2 I∗2g =1.13107 ·10 −3 The errors computed from Eqs. (6.4) are e1 =4.420 ·10 −5 e2 =7.616 ·10 −4 Table 4 contains parameters defining the link lengths, position andorienta- tion of the transformed four-bar linkage on the plane, the coupler point which traces the curves presented in Fig.8. Table 4.Parameters defining the mechanism and its location a b c d e xA yA β α 0.66 1.25 1.58 2.05 2.46 −0.95 1.56 0.87 −0.61 The time of numerical evaluations is below 1s. The comparison of I1 and I2 allows one to state that the synthesis problem is executed satisfactorily. Example III An arc of an ellipse is taken as the desired curve. The method of curve description presented in this paper is related to closed curves. It is assumed that the coupler point goes through the given curve and returns by the same trajectory. Parametric equations of the arc are x=2+2cosφ y=3+sinφ where φ∈ 〈π/6,2π/3〉. The number of points defining the path is 30. The other parameters of the GA are the same as in Examples I and II (Ns =100, Mp =0.01, Gn =200). The results of synthesis are shown in Fig.9. 408 R. Starosta Fig. 9. Results of the ellipse arc synthesis and the curve drawn by the coupler point K The geometrical properties are calculated for: — desired curves sd =5.697 I ∗ 1d =2.010 ·10 −2 I∗2d =2.372 ·10 −4 —curves generated by the AG sg =9.136 I ∗ 1g =2.003 ·10 −2 I∗2g =2.581 ·10 −4 The errors computed from Eqs. (6.4) are e1 =3.48 ·10 −3 e2 =8.82 ·10 −2 Table 5. Dimensions of the four-bar linkage which generates the arc a b c d e xA yA β α 0.623 1.77 1.95 1.29 2.57 2.27 −0.013 0.22 −0.59 Time of numerical evaluations is estimated at 0.7s. Example IV The problem of synthesis of a straight-line mechanism is now considered – the coupler draws a straight line. Table 6. Points of the straight line Point 1 2 3 4 5 6 7 8 9 10 x 1.0 2.0 3.0 4.0 5.0 6.0 7.0 8.0 9.0 10.0 y 1.0 2.0 3.0 4.0 5.0 6.0 7.0 8.0 9.0 10.0 Figure 10 presents the final solution. Application of genetic algorithm... 409 Fig. 10. Results of the straight line synthesis The geometrical properties calculated for the line segment are: — for desired line segment sd =25.46 I ∗ 1d =2.083 ·10 −2 I∗2d =0.0 — segment generated by the AG sg =4.34 I ∗ 1g =2.082 ·10 −2 I∗2g =5.145 ·10 −6 The error computed from Eqs. (6.4)1 is: e1 =4.8 ·10 −4 The dimensions of the four-bar linkage generating the straight line approxi- mation are collected in Table 7. Table 7.Dimensions of the four-bar linkage which generates the straight line a b c d e xA yA β α 5.87 19.38 31.77 36.73 21.46 4.99 1.90 0.409 −3.37 Parameters of the AG assumed in the calculation are: Ns =100, Mp =0.01, Gn =600. Time of calculations: 1.56s. 7. Conclusions The synthesis carried out by the GA-FC method gives satisfactory results in comparison with other methods (example I). The reduction in the number of coefficients describing a curve effectively improves the convergence of theGA. The relevant geometric transformations are performedon themechanismafter completing a particular synthesis. It enables one to determine all 9 parameters defining the position and orientation of the four-bar linkage. 410 R. Starosta In every run of the GA, the results are slightly different. It is known that evolutionary programs usually do not give an absolutely optimal solution. The presented method may be used as a convenient way to obtain a good approximation to start a classical deterministic method. References 1. Białas-Heltowski K., Klekiel T., Rohatyński R., 2004, Investigation of evolutionary algorithm effectiveness in optimal synthesis of certainmechanism, IUTAMSymposium onEvolutionaryMethods inMechanics, T. Burczyński and A. Osyczka (Edit.), Kluwer Academic Publishers Dordrecht, 13-22 2. Burczyński T., Kokot G., 1998, Topology optimization using boundary elements and genetic algorithms, Proceeding of the Fourth Congress on Com- putational Mechanics, New Trends and Applications, Idelsohn S.R., Onate E., Dvorkin E.N. (Edit.), on CD, Barcelona 3. Burczyński T., Kokot G., 2003, Evolutionary algorithms and boundary element method in generalized shape optimization, Journal of Theoretical and Applied Mechanics, 41, 2, 341-364 4. Buśkiewicz J., 2006,Synthesis ofworkspacebyusing anglederivative function (ADF), 77th Annual Meeting of GAMM, Book of Abstracts, Berlin 5. CabreraJ.A., SimonA.,PradoM., 2002,Optimal synthesis ofmechanisms with genetic algorithms,Mech. Mach. Theory, 37, 1165-1177 6. FangW.E., 1994,Simultaneous type anddimensional synthesis ofmechanisms by genetic algorithms-DE,Mechanism Synthesis Analysis, 70 7. Goldberg D.E., 1989,Genetic Algorithms in Search, Optimization and Ma- chine Learning, AddisonWesley, Massachusetts 8. Goldberg D.E., 2003,Algorytmy genetyczne i ich zastosowania,WNT,War- szawa 9. Kunjur A., Krishnamurty S., 1997, Genetic algorithms inmechanical syn- thesis, Journal of Applied Mechanisms and Robotics, 4, 2, 18-24 10. LaribiM.A.,MlikaA.,RomdhaneL., ZeghloulS., 2004,Combinedgene- tic algorithm-fuzzy logicmethod (GA-FL) inmechanisms synthesis,Mechanism and Machine Theory, 39, 717-735 11. Michalewicz Z., 1992, Genetic Algorithms+Data Structures=Evolutionary Programs, Springer-Verlag, AI Series, NewYork Application of genetic algorithm... 411 12. Michalewicz Z., Logan T.D., Swaminathan S., 1994, Evolutionary ope- rators for continuous convex parameter spaces, Proc. of the 3rd Annual Con- ference on Evolutionary Programming, A.V. Sebald, L.J. Fogel (Edit.), World Scientific Publishing, River Edge, NJ, 84-97 13. Michalewicz Z., Nazhiyath G., Michalewicz M., 1996, A note of useful- ness of Geometrical Crossover for Numerical Optimization Problems,Proc. of the 5th Annual Conference on Evolutionary Programming, San Diego, CA 14. SokołowskiM., ŻochowskiA., 1999,On the topologicalderivative in shape optimization, SIAM Journal on Control and Optimization, 37, 1251-1272 15. Starosta R., 2006, On some application of genetic algorithm in mechanism synthesis, 77th Annual Meeting of GAMM, Book of Abstracts, Berlin 16. Vasiliu A., Yannou B., 2001, Dimensional synthesis of planar mechanisms using neural networks: application to path generator linkages,Mechanism and Machine Theory, 36, 299-310 17. Walczak T., 2006,Mechanism synthesis with the use of neural network, 77th Annual Meeting of GAMM, Book of Abstracts, Berlin Zastosowanie algorytmu genetycznego i współczynników Fouriera (GA-FC) w syntezie mechanizmów Streszczenie Rozważanymzagadnieniem jest synteza czworobokuprzegubowego jako generato- ra krzywej. Zastosowanonowy sposób reprezentowaniakrzywej zamkniętej za pomocą współczynnikówFouriera. Do rozwiązania zadania został zaadaptowanyalgorytm ge- netyczny. Proponowanametoda została z sukcesem przetestowana na przykładach. Manuscript received October 8, 2007; accepted for print February 27, 2008