Architectures for Controlling an Intelligent Autonomous Vehicle
By John Stevens
Presented as a Partial Fulfillment of the Requirements for an MSc. in
Intelligent Knowledge-Based Systems Department of Computer Science University of Essex Supervisor: Dr. Sam Steel
Presented September, 1994
Abstract
Surname: Stevens
Other Names: John Kenneth
Qualification Sought: MSc in Intelligent Knowledge Based Systems
Title of Project: Architectures for Controlling an Intelligent Autonomous Vehicle Supervisor: Dr Sam Steel
Artificial intelligence researchers have developed several styles of IA V architectures, mapping systems, and planners. Considerable debate surrounds the utility of each. This dissertation contributes to these debates. This document reports on the experimental testing of three architectures: a reaction-based architecture implemented on an economical mobile vehicle developed for this project; a subsumption architecture, and a combined architecture integrating subsumption with a non-linear planner, the latter two of which were implemented on a University of Essex Marvin vehicle. The results of this research suggest four conclusions. First, simple, inexpensive mobile vehicles can successfully perform basic behaviours, and the technology and software for such vehicles can be rapidly developed and tested. Second, ultrasound and infra-red sensors limit the ability of a mobile vehicle. Future use of alternative sensors, such as vision, may well yield improved performance. Third, while sUbsumption architecture does not live up to some of the claims made by its designers, it can facilitate successful goal completion by an IA V. Fourth, subsumption architectures can be effectively integrated with non-linear planners to improve vehicle performance. The final chapter summarises the findings of this work and explores the potential avenues for future research suggested by these findings.
ii
Acknowledgements
My first thanks have to go to Kimberly Fisher who has spent many hours copy-editing and correcting English mistakes in my draft texts, assistance rendered necessary by my dyslexia. This special lady also has to be thanked for putting up with me during the production of this report.
I would also like to express my gratitude to Paul Chernett, and Robin Dowling, who provided both technical support and comments to assist the implementation of my ideas on the robots. I extend similar gratitude to Stuart Soltysiak, who also offered advice over many cans of coke and games of pool.
I would like to acknowledge Mr. Malcom Lear's input into the development of the clocking circuitry, PCB board art work, and the small mobile vehicle. Without his technical input this development would have been more difficult to complete.
Finally, of course, I wish to thank my supervisor, who nudged me in constructive directions, while allowing me to do the hard work myself.
iii
Acknowledgement of Examination Regulation 6.5(c)
I declare that any use of, or reference to, the work of others has been explicitly acknowledged in this dissertation.
John Stevens
iv
Table of Contents
Title Page
Abstract Acknowledgements
Acknowledgement of Exam Regulation 6.5(c) Table of Contents
Table of Figures
1 ii iii iv v vii
1. Introduction
1
2. The Subject Area
2.1 IA V Architectures Process Control Systems
Plan then Execute Architectures Subsumption Architectures Combined Architectures
Non Symbolic Methods
Self Organising Architectures Summary
2.2 Mapping Systems
Geometric Mapping Systems and Dead Reckoning Landmark Mapping
Topological Mapping
Summary
2.3 Planning Systems Path Planners Non-Liner Planning Hierarcal Plans Planning to Plan
2.4 Attention 2.5 Summary
5 6 6 7 9 12 13 15 16 16 17 17 18 18 19 19 21 22 23 23 23
3. An Implementation of a Reactionary IA V Architecture 3.1. Vehicle Developed
3.2. Software Developed
3.3. Experimental Results
3.4. Future Work
3.5. Summary
24 26 28 29 30 30
v
4. An Implementation of a Subsumption IA V Architecture 32
4.1. Hardware 33
Sensor Details 34
Hardware Modification 35
4.2. Subsumption Software developed 36
Reflex Module 36
Obstacle Avoidance Module 37
Wall Following Module 37
Infra Red Location Module 38
Implementation Details 39
4.3. Experimental Results 39
Comments on the Performance of the Vehicle 41
Comments on the Performance of Subsumption 41
4.4. Future Work 42
4.5. Summary 42
5. Combing Subsumption and Plan then Execute IA V Architectures 43
5.1. Architecture Developed 44
5.2. Implementation Details 47
Mixing 'C' with PROLOG 47
Plan-then-Execute Behaviour 48
Topological Path Planner 48
Subsumption Interface with Topological Path Planner 50
5.2. Experimental Results 50
5.3. Future Work 53
5.4. Summary 53
6. Conclusions 56
6.1 Introduction 56
6.2 Conclusions About Hardware 57
6.3 Conclusions About the Implementation of the Architectures 58
6.4 Closing Notes 60
Bibliography 61
Appendices
a. Mouse PCB board
b. Reactionary Software
c. Reactionary Test Results
d. Marvins Dimensions
e. Marvins Memory map
f. std_ops.h
g. subsumption.c
h. Subsumption Test Results
i. Wall following algorithms
j. comb.c
k. top_planner.pl
1. Combination Test result
Al A2 A3 A7 A8 AlO A19 A25 A29 A31 A38 A40
vi
Table of Figures
1.1. Picture of Robots 3
2.1. Diagram of Process Control Architecture 7
2.2. Diagram of Process Control Architecture 7
2.3. Diagram of Plan-then-Execute Architecture 7
2.4. Diagram of Plan-then-Execute Architecture 7
2.5. Brooks' Modular AI Diagram 9
2.6. Brooks' Behaviour Based Control Architecture Diagram 9
2.7. A Subsumption Network 10
2.8. Alice Architecture 13
2.9. Fuzzy Logic Language 14
2.10. Topological Map 18
2.11. Free Space Representation Map 20
2.12. NaT Map 20
2.13. Non-Linear Plan 22
2.14. Hierarchical Plan 22
3.1. Picture of Small Robot 25
3.2. Circuit Diagram for Small Robot 27
3.3. Circuit Diagram for Op-amp 27
3.4. Pseudo Code for Reaction Software 28
3.5. Table of Results of Reaction Software Experiments 29
4.1. Picture of Department Robot 33
4.2. Diagram of Positioning of Ultrasound Sensors 35
4.3. Subsumption Network Diagram 36
4.4. Pseudo Code of Wall Following 38
4.5. Pseudo Code of Subsumption Control Network 39
4.6. Table of Results of Subsumption Experiments 40
5.1. Architecture Diagram of Combined Approach 46
5.2. Pseudo Code for Plan-then-Exicute Behaviour 48
5.3. Topological Map Reprsentations 49
5.4. Topological Map Used in Testing 50
5.5. Table of Results of Combined Architecture Experiments 51
5.6 Architecture Diagram of Possible Future Work 54
Vll
Chapter 1
Introduction
1.0 Introduction
For centuries, people have pondered the possibility of developing machines capable of independent thought. In the nineteenth century, writers like Robert Lewis Stevenson founded the literary genre which would develop into today's science fiction - a genre replete with robotic beings who have reached a level of sentiency and ability which exceeds human capacities. While the fans of science fiction literature and fihns may fantasise about interactions with the likes of Data or C3PO, the real life world of artificial intelligence research is now - and for some time in the future, will remain - far more mundane. The researchers who undertook the first attempts to write programs to allow autonomous mobile vehicles to act with a degree of intelligence soon made two discoveries. First, they learned that artificial intelligence programming must enable the mobile vehicle to perform basic levels of decision making, such as figuring out how to navigate differing terrains and learning to avoid obstacles. Second, they learned that humans must develop complex programs to enable machines to perform even such seemingly simple tasks.
To make this programming challenge manageable, researchers have split the levels of decision-making into manageable and understandable modules. Many early
experiments centred on the execution of a single behaviour, such as path planning. By adopting this simplified approach, computer scientists soon succeeded in expanding the capacity of Intelligent Autonomous Vehicles (IAVs). This success, however, generated a new and challenging problem - mobile vehicles cannot cope with independent movement without constant attention from researchers if they do not possess the ability to integrate the performance of several behaviours. Until very recently, only a few research groups demonstrated interest in the design of integrated architectures. The process of organising behaviours into functional, combined control systems has recently become one of the major themes of IA V research. This project, investigates such systems through the implementation of three different control strategies.
Chapter Two offers a brief overview and analysis of the literature on IA V behaviour control. The major developments in IA V architecture research, discussed in this chapter in a slightly idealised chronological order, are: 1) early process control systems; 2) plan-then-execute architectures; 3) reaction-based systems; 4) subsumption architectures; 5) combined architectures; 6) non-symbolic methods; and 7) selforganising architectures. This chapter additionally offers discussion of the techniques developed to facilitate mapping, planning, and attention in mobile vehicles.
The three subsequent chapters discuss the implementation of three of these architectures and the mobile vehicles on which they were tested. Both of these vehicles are pictured in Figure 1.1.
Chapter Three records the results of the implementation of a reaction-based architecture. As such architectures may have a simple design, this chapter details an effort to develop a minimal architecture to produce a single behaviour from a small mobile vehicle. The vehicle designed for this experiment (see Figure 1.1) uses a single layer reactive control system which enables it to move around its environment without damaging itself. The simplicity of this design permitted rapid development and testing of the architecture, and also demonstrated that utility of this hardware and software for low-budget projects.
2
Figure 1.1.
Chapter Four reports on a re-evaluation of subsumption architecture. This architecture which was developed by Rodney Brooks and detailed in Brooks (1986) was implemented on one of the departmental Marvin vehicles, Ford, shown in Figure 1.1. Chapter Four begins with a description of the test vehicle, then proceeds to discussion of modifications made on Ford, including justification for these changes. The chapter then offers an evaluation of the architecture. Ford was able to perform behaviours such as ret1ex action: avoid obstacles: follow walls: and tind infra red beacons.
Chapter Five records the implementation and testing of an architecture combining subsllmption and plan-then-execute techniques. Ford again served as the base vehicle for these experiments. The results reponed in Chapter Five indicate the compatibility of these two architectures. This combination pemlits a vehicle to make lise of the advantages of both systems: the suitability of reaction-based subsllmption for addressing immediate dewlopments in the environment: and the capacity of the
plan-then-execute architecture for looking ahead and creating plans to circumvent problems.
Chapter Six fIrst provides additional comment on the different architectures presently under investigation in the artificial intelligence community. The experimental results obtained are then summarised, and possible future applications of these findings are considered. The text closes with discussion of the directions in which research into Intelligent Autonomous Vehicle architectures could head in the future.
4
Chapter 2
Related Work
Contents
2.0 Introduction
2.1 IA V Architectures
Process Control Systems Plan-then-Execute Architectures Subsumption Architecture Combined Architectures
Non Symbolic Methods Self-Organising Architectures Summary
2.2 Mapping systems
Geometric Mapping and Dead Reckoning Landmark Mapping
Topological Mapping
Summary
2.3 Planning Systems
Path Planners Non-Linear Planners Hierarchical Plans Planning to Plan
2.4 Attention 2.5 Summary
5
2.0 Introduction
In this chapter, I detail the major developments in the published research on the control of autonomous mobile vehicles which I have reviewed to ground my own architectural experiments detailed later in this dissertation. The first and largest section contains discussion of the major IA V control architectures described in the literature, focusing on the connections between the individual modules of the control system. I then examine the research covering two of the more important modules. The second section of this chapter details developments in IA V mapping, and the third section offers an examination of the research on planning. The fourth section contains discussion of IA V attention.
2.1 IA V Architectures
Initially, the researchers working with IA V s concentrated on functionality of individual behaviours, such as obstacle avoidance or path planning. Only a few devoted minimal effort to designing strategies for organising these behaviours into a combined control system. The following sub-sections of this report provide details of the major developments in IA V architecture research in chronological order, beginning with process control systems, then moving on to plan-then-execute architectures, subsumption architectures, combined architectures, non-symbolic methods, and selforganising architectures. Members of the IA V community now generally regard architectural design as one of the most important areas of research on this field.
2.1.1 Process Control Systems
Before the AI community developed an interest in IA V s, industrial technicians had designed process control architectures for robots. Examples of early process control architectures can be found in Grover (1987). Academic research consequently began with examination of these systems, which are generally implemented by a single layer of process control through which a given input stimulates an output. This structure may be diagrammed as follows:
6
Sense
--_\ /
React (Execute)
Figure 2.1
This architecture has been implemented by many people to control IA V s, an example of which can be found in Miller et. al. (1992), and is shown in Figure 2.2.
Sense for obstacle
--_\ /
If obstacle in front, tum left
Figure 2.2
The simplicity of these initial IA V architectures enables a mobile vehicle to
function in a relatively static environment, such as a production line, where it would
perform generally uncomplicated manoeuvres to achieve a single goal. AI researchers
soon found that process control systems did not facilitate more complex behaviour in dynamic environments, and instigated a search for a more flexible IA V architecture.
2.1.2 Plan-then-Execute Architectures
This search gave rise to a second approach to IA V control, a functionally
decomposed "sense, plan-then-execute" architecture. Much like the process control
systems, plan-then-execute architectures also generally have only a single layer of abstraction, although there are exceptions. The reader will notice the similarities between Figure 2.3 and the preceding figures:
Sense
--_\ /
Plan
--_\ /
Execute
Figure 2.3
The similarities likewise appear with the adaptation for a mobile vehicle: