IBN AL- HAITHAM J. FOR PURE & APPL. S CI. VOL.23 (2) 2010 On-Line Navigatio nal Problem of a Mobile Robot Using Genetic Algorithm W. N. Abdullah Departme nt of Computer Science, College of Education- Ibn Al- Haitham,Unive rsity of Baghdad Abstract M anufacturing sy st ems of t he future foresee the use of intelligent vehicles, op timizing and navigating. The navigational p roblem is an imp ortant and challenging p roblem in the field of robotics. T he robots oft en find themselves in a situation where they must find a trajectory to another p osition in their environment, subject to constraints p osed by obst acles and the cap abilities of t he robot itself. On-line navigation is a set of algorithms t hat p lans and executes a trajectory at t he same time. The sy st em adopted in this research searches for a robot collision-free trajectory in a dy namic environment in which obst acles can move while the robot was moving toward the target. So, the robot must op erate in real-time such that the sy st em reacts to unexp ected obst acles. Genetic algorithms that have been used successfully in many search p roblems are used to solve the on-line navigation p roblem with less comp utational cost. The sy st em uses genetic algorithm as a search method for an optimal trajectory . Key Words Navigational Problem, On-line Navigational Problem, Genetic algorithm. Introduction Planning is an important asp ect of the effort to design robots t hat p erform their task with some degree of flexibility and resp onse to the outside world [1]. Navigational p roblems would involve a worksp ace that cap tures all p ossible actions that could exist [2]. Hence, p lans are created by searching through the worksp ace of p ossible actions until the sequence necessary to accomp lish t he task is discovered [1]. A successful action plan allows t he robot t o comp lete the task without violating any p hy sical const raints of t he robot or t ask [3]. M any AI p lanning p roblems involve navigational p lanning. In navigational p lanning p roblem, a mobile robot has to identify the trajectories between a starting and a goal p osition within its environment. T he robot environment includes many obst acles (p ortions of the world that are p ermanently occup ied; for examp le, the walls of a building) and thus finding the short est trajectory without touching the obst acles in many cases is an extremely comp lex p roblem [4]. The object of this p aper is to identify the sequence of st eps and ty p e of p rocesses necessary to imp lement a navigational sy st em using genetic algorithm that can generate op timal or near-op timal trajectory according to a given worksp ace that does not make any p rior assumptions about feasible knot p oints. The rest of this p aper is organized as follows: the on-line navigational p roblem, the genetic algorithm p rocess, the design of the sy st em of p lanning on-line trajectory using genetic algorithm including the representation of the chromosome, and finally , the results of t he sy st em and some concluding remarks are given. IHJPAS IBN AL- HAITHAM J. FOR PURE & APPL. S CI. VOL.23 (2) 2010 On-Line Navigational Problem Navigational p lanning is the science of directing the course of a mobile as it traverses the environment and reaching a dest ination without gett ing lost or crashing into any obst acles [5] in the worksp ace. The requirement t hat t he navigational p lanning must meet is finding quickly an optimal trajectory due to some imp osed criteria for the solution of the problem (which are referred to as trajectory metrics). For examp le, trajectory length, evaluation of clearance between the robot and obst acles, and others [6, 7]. The on-line navigational reacts in real-time to unforeseen obst acles such as human, and it cap able of changing the motion direction while the robot is moving and can adjust the direction commanded by the p lanner based on sensing readings [8] where there is no p rior information about the environment which the robot is sup p orted to travel the p roblem of finding a trajectory between a start p oint and a target p oint. The initial data are in this case only the coordinates of the two p oints or equivalently the direction and distance to the target. The p roblem can be solved only if the robot is equip p ed with some sensor sy st em which can detect the obstacles around. Examp les of such sensors are: touch sensors, range finding sensors (based on triangulation or time of flight techniques), or video cameras [9]. In on-line navigation, the robot can p erform a sequence of actions with resp onding to changes in its environment and would be able to detect and correct errors in its own p lans as it executes the navigation [1]. The task of on-line navigation is to navigate the robot to sub-goals generated by the navigator while avoiding collisions with obst acles [8] and reacting to sensory data as quickly as p ossible while driving towards a sub-goal. Genetic Algorithm Genetic algorithms (GAs) are st ochast ic search algorithms based on evolutionary and biological p rocesses that enable organisms t o adap t more to their environment. They are being successfully app lied to p roblem in business, engineering and science [10]. GA works on a set of p ossible solutions, which is called the p op ulation. A GA encodes a p otential solution to a sp ecific p roblem on a chromosome-like data st ructure and app lies recombination op erators to these st ructures in a manner that p reserves critical information. Reproduction op p ortunities are app lied in such a way that those chromosomes representing a bett er solution to the target p roblem are given more chances to reproduce than chromosomes with p oorer solutions. GA is a promising heurist ic app roach for locating near-op timal solutions in large search sp aces [11]. Ty p ically, a GA is composed of two main comp onents, which are problem dependent: the encoding problem and the evaluation function. The encoding problem involves generating an encoding scheme to represent the p ossible solutions to the op timization p roblem. In this p aper, a candidate solution (i.e., a chromosome) is encoded to represent a trajectory from the st art p osition to t he goal p osition. The evaluation function measures the quality of a p articular solution. Each chromosome is associated with a fitness value, which in this case is the length of the chromosome. For t his p aper, the smallest fitness value rep resents the better solution. Chromosomes evolve through successive iterations, called generations. To create the next generation, new chromosomes, called offsp ring, are formed by (a) selecting chromosomes to be merged (b) merging two chromosomes from the current p op ulation together using a crossover op erator and (c) modify ing a chromosome using a mutation op erator. Selection is the p rocess of keep ing and eliminating chromosomes in the p op ulation based on their relative quality or fitness. There are several possible selection strategies. One of them is Tournament selection which is adopted in this p aper. In Tournament selection, s chromosomes are taken at random, and the bett er chromosome is selected from them. The winner of the tournament is t he chromosome with the lowest fitness of the s tournament IHJPAS IBN AL- HAITHAM J. FOR PURE & APPL. S CI. VOL.23 (2) 2010 comp etitors, and the winner is inserted into mating p ool. The mating p ool, being filled with tournament winners, has a lower average fitness than the average p op ulation fitness. Crossover generates valid offsp ring by combining features of two p arent chromosomes. Chromosomes are combined together at a defined crossover rate, which is defined as the ratio of the number of offsp ring p roduced in each generation to the p op ulation size. M utation p roduces random changes in various chromosomes. M utation serves the critical role of either replacing the chromosomes lost from the p op ulation during the selection p rocess or introducing new chromosomes that were not p resent in the initial p op ulation. The mutation rate controls the rate at which new chromosomes are introduced into t he pop ulation. On-Line Navigational Problem Using Genetic Algorithm The design of the Sy st em adopted here is based on On-line navigation. The general st eps of this sy st em and the details description of its steps are presented in the following: Before app lying genetic algorithm op erations, the robot worksp ace must be translated in a form that comp uter p rograms can deal with. So, two-dimensional array of grids is used for representing the map of the worksp ace with a given st art and goal p oints and obstacles are represented by rectangular shap es. Re presentation and Initialization The first st ep in this navigational p roblem is to set up the initial p op ulation. For this p urp ose, we have taken the sensor information into account and the coordinates obt ained from those sensors are used to set up the initial p op ulation. In this case, it is assured that all the initial p op ulation are feasible, in the sense they are obst acle-free p oints and the st raight line trajectories between the st arting and the selected next p oints are obst acle-free. The chromosome representation is extremely simple due to that in one genetic iteration, we p lan the trajectory up to the selected next p oint. The data st ructure to represent the chromosome consists of four fields (Xi , Yi , Xj ,and Yj ). The first two fields (Xi , Yi) are the coordinates of the starting p oint and the second two fields (Xj , Yj ) are the coordinates of one of the 2D p oints, obtained from the sensor information. For examp le, the starting p oint is (30,50), the robot sensing range=10, and the coordinates of some points sensed by the robot are (40,40),(20,60),(40,60). Then, the chromosomes corresp ond to those p oint are formed as (30,50,40,40), (30,50,20,60), and (30,50,40,60) resp ectively. All these chromosomes form the initial pop ulation. Checking the Feasibility The p rocess of evaluating the feasibility of the trajectory includes two asp ects: (a) checking that t he trajectory does not fall on an obst acle. To do so, t he sy st em should check the feasibility of each trajectory p oints. The sy st em modifies Digital Differential Analyzer (DDA) algorithm [13] to check each trajectory p oint if it is feasible or not (b) checking that it is sufficient sp aces between obst acles in the environment for the easy movement of the robot through the trajectory (the sp ace should be greater than the robot size). If any trajectory p oint is on an obst acle or if there insufficient sp ace between obst acles around the trajectory then this t rajectory is infeasible Genetic Algorithm Operators To create a sequence of p op ulations that will contain the next p oints to the current p oint as time goes on, the main genetic op erators (Crossover, M utation and Selection) are app lied iteratively on each pop ulation. IHJPAS IBN AL- HAITHAM J. FOR PURE & APPL. S CI. VOL.23 (2) 2010 The integer crossover op eration is emp loyed in this sy st em. The crossover p oint should be selected such that most of the offsp rings generated in this p rocess are feasible. The crossover p oint is set between the third and the fourth integer for every chromosome [12]. Aft er making crossover between all p airs of p op ulation, we will get the new p op ulation. For this new p op ulation, we will find the feasibility , i.e.; they are reachable from the starting p oint by the straight line or not. If t he trajectory resulted from crossover operation is not feasible, this trajectory will not st ore in the new p op ulation in order not t o comp ete with the other trajectories stored in the mating p ool. The next st ep of the algorithm is making the mutation. In this p rocess a binary bit is randomly selected on the bit stream of the sensor coordinates and alters that binary bit value, such that t he feasibility should not be lost for that chromosome. Evaluation of Fitness Value The next task is estimating the fitness of each chromosome of the total p resent p op ulation (both for the initial and new p op ulations). Calculation of the fitness involves finding the sum of the straight line dist ance from the st arting p oint to the coordinate obtained from the sensor information and the distance from the current p oint t o the goal p oint. The formula of fitness function is: Fitness of chromosome (Xi,Yi,Xj 1,Yj 1)= 1/((xj 1 - xi) 2 + (Yj 1 - Yi) 2 + (xg – xj 1) 2 + (Yg – Yj 1) 2 ) Where: (Xi,Yi) is the coordinate of the st arting p oint, (Xj 1,Yj 1) is the coordinate of the current p oint, and (Xg,Yg) is the coordinate of the goal p oint. Evaluation of Best Fit Chromosome Aft er finding the fitness value of the chromosomes, we will evaluate the best chromosome, i.e.; for which the fitness is the best. In this case, the best fit chromosome represents the predicted short est trajectory from the st arting p oint t o the goal. In the first generation itself, we are gett ing a near-op timal intermediate p oint to move that third and fourth integer field of the best fit chromosome that will become the next intermediate point t o move. Then, we update the starting p oint with t his bett er point. Termination Criteria The whole p rocess of the genetic algorithm, from setting up the initial p op ulation, is repeated until the best fit chromosome will have its third and fourth field equal to the x- and y -coordinates of t he goal location. The algorithm is formally p resented below. The Algorithm {(xi,y i)=starting p oint; (xg,y g)=goal p oint} Add-t rajectory list (xi,y i) Repeat i) Intialization - Get sensor information in all possible directions (xj 1,y j 1) , (xj 2,y j 2) , … , (xj n,y j n) - Form chromosomes like (xi,y i,xj ,y j ) ii) Crossover - Select crossover p oint on t he third and the fourth fields of the chromosome. - Allow crossover between all chromosomes and get new p op ulation as (xi,y i,xj 1,y j 1) , (xi,y i,xj 2,y j 2) , (xi,y i,xj 1 i ,y j 1 i ) , (xi,y i,xj 2 ii ,y j 2 ii ). IHJPAS IBN AL- HAITHAM J. FOR PURE & APPL. S CI. VOL.23 (2) 2010 iii) M utation Select a mutation point in bit stream randomly and complement that bit p osition for every chromosome. iv) Selection - Discard all chromosomes (Xi,Yi,Xj ,Yj ) from pop ulation whose line segment on obst acle region. - For all chromosomes in p op ulation: find fitness using Fitness(xi,y i,xj ,y j ) = 1/ ((xj - xi) 2 + (y j - y i) 2 + (xg – xj ) 2 + (y g – y j ) 2 ); - Identify the best fit chromosome (xi,y i,xbf,y bf); - Add-t rajectory list (xbf,y bf) - xi = xbf ; yi = y bf ; End For, Unt il (xi = xg)) and (yi = y g); End. Experimental Results The sy st em was run on many different cases. These cases are taken from different p ersp ectives: number and distribution of obst acles, size of obst acles, the value of robot sensing range, number of exp eriments p er a worksp ace, and robot size. As samples, the figures -represented by case1, case2, and case3- show some of the cases of t hese exp eriments. Each figure of each case shows the robot location after some generations while some obst acles move randomly within the environment (i.e., in each case, the distribution of obst acles will be changed form figure to another because of the movement of some obst acles). In each case, the values of robot size (Rsize) in square grid unit, robot sensing range (SR) in grid unit, and maximum number of generations at which the robot reaches to the goal (M axGen) are given. The sy mbols "S", "G", and "R" refer to st art p osition, goal p osition, and the location of robot after some generations resp ectively. Conclusions From the previous results, we can conclude the following: 1- The sy st em op erates on entire free sp ace and does not make any p rior assump tions about feasible knot p oint of t he trajectory . 2- The sy st em can deal with any moving obst acles while avoiding collisions with the robot. 3- At each generation, the robot moves to a new p osition toward the goal. 4- As the robot ability of sensing the environment (sensing range) becomes bigger, the trajectory p oints become less and consequently the time of reaching the goal becomes less and vice versa. 5- At each iteration, the p lanner produces a trajectory which is based on the obstacle most recently sensed p ositions and assumes t hat t he obstacles are now fixed. 6- The sy st em does not give an acceptable trajectory if the robot's environment contains a very large number of obst acles and there is no sufficient sp ace to move the robot through it. Re ferences 1.Lugar, G. F. and Stubblefield, W. A. (1989), Art ificial Intelligence and the Design of Exp ert Sy st ems. Redwood City , CA: Benjamin /Cummings. 2.LaValle, S.M . (2003): Planning Algorithm. University of Illinois. IHJPAS IBN AL- HAITHAM J. FOR PURE & APPL. S CI. VOL.23 (2) 2010 3.Farritor, S. and Dubowsky , S. (2002), A Genetic Planning M ethod and its app lication to Planetary Exp loration. Cambridge, M A 02139 U.S.A. 4.Rich, E. and Knight, K.(1991): artificial intelligence, M c-Graw Hill, Inc. 5.M ichalewicz, Z.(1999), Genetic Algorithms + Data Structures =Evolution Programs. New York: Sp ringer Verlag. 6.Podsedkowski, L.(1999), VERY WELL INFORM ED A*SEARCHING ALGORITHM AND ITS APPLICAT ION FOR NONHOLONOM IC M OBILE ROBOT M OT ION PLANNING. International Journal of Science & Technology (1999), 10(2) & 11(1,2), 33- 43. 7.M chenry , M . C.(1998), Slice – Based Path Planning, Ph.D. Dissertation, Faculty of the Graduate School, University of Southern California. 8.Kort enkamp, D.; Bonasso R. P., and M urp hy , R.(1997), Art ificial Intelligence and M obile Robot: Case Studies of Successful Robot Sy st ems. 9. Lazea, Gh. and Lupu, As. E. (1996), Asp ects on p ath p lanning for mobile robots. 10.Goldberg, D. E. (1994), “Genetic and Evolutionary Algorithms Come of Age”, Communication of the ACM, 37(3): 113-119, M arch. 11.Wang, L.; Siegel, H. J.; Roy chowdhury , V. P., and M aciejewski, A. A. (1997), “Task M atching and Scheduling in Heterogeneous Computing Environments Using a Genetic- Algorithm-Based Ap p roach,” Journal of Parallel and Distributed Computing, Sp ecial Issue on Parallel Evolutionary Computing, 47( 1): 8-22, Nov. 25, 12.Konar A. (2000), Art ificial Intelligence and Soft Computing: Behavioral and Cognitive M odeling of The Human Brain. 13.Salmon, R. and Slater, M . (1987), Computer Grap hics: Sy st ems & Concep ts. Reading, M A: Addison-Wesely . IHJPAS IBN AL- HAITHAM J. FOR PURE & APPL. S CI. VOL.23 (2) 2010 Figures: Case 1 Rsi ze = 9 S R= 15 Maxgen = 43 (a) (b) (c) (d) IHJPAS IBN AL- HAITHAM J. FOR PURE & APPL. S CI. VOL.23 (2) 2010 Case 2 (a) (b) Rsi ze = 20 S R= 6 Maxgen = 80 IHJPAS 2010) 2( 32المجلد مجلة ابن الهیثم للعلوم الصرفة والتطبیقیة مشكلة التجول المباشر لإلنسان اآللي باستخدام الخوارزمیة الجینیة واثق نجاح عبداهللا إبن الهیثم، جامعة بغداد –كلیة التربیة قسم علوم الحاسبات، الخالصة التجـول مشـكلة مهمـة وصـعبة فـي إّن مشـكلة، تتوقع أنظمة التصنیع المستقبلیة إستخدام العربات الذكیة للتحسین والتجـول إلـى الموقـع اآلخـر "ااألنسان اآللي یجد نفسه فـي أغلـب األحیـان فـي حالـة یجـب أن یجـد فیهـا مسـار . حقل علم اإلنسان اآللي المباشـر هـو جـولالت .في بیئته، تلـك الحالـة تكـون خاضـعة لقیـود تتمثـل بـالحواجز داخـل البیئـة وقابلیـات اإلنسـان اآللـي نفسـه .هنفس الخوارزمیات التي تخّطط المسار وتنّفذه في الوقت مجموعة وهـي البیئـة التــي -النظـام المقتـرح فــي هـذا البحـث یحــاول ایجـاد مسـار للروبــوت خـالي مـن التصــادم فـي بیئـة دینامیكیــة الوقـت الحقیقـي یمكن ان تتحرك الحواجز فیها بینما یواصل الروبوت حركته بأتجاه الهـدف، لـذا فـالروبوت یجـب أن یعمـل فـي .بحیث یكون النظام قادرا على التعامل مع حركة الحواجز غیر المعروفة مسبقا بكلفــة ) التجــول المباشـر(أسـتخدمت لحــل مشـكلة -التـي أثبتــت نجاحهـا فــي كثیـر مــن مشـاكل البحــث -الخوارزمیـة الجینیــة .طریقة بحث عن أفضل مسارأستخدم نظام الخوارزمیة الجینیة . حساب قلیلة IHJPAS Case 3 Rsi ze = 20 S R= 6 Maxgen = 80 (c) (d) (a) (b) IHJPAS