Autonomous Mobile Robots CPE 470/670 Lecture 9 Instructor: Monica Nicolescu.

Slides:



Advertisements
Similar presentations
ARCHITECTURES FOR ARTIFICIAL INTELLIGENCE SYSTEMS
Advertisements

Elephants Don’t Play Chess
Lecture 8: Three-Level Architectures CS 344R: Robotics Benjamin Kuipers.
5-1 Chapter 5: REACTIVE AND HYBRID ARCHITECTURES.
Embedded System Lab Kim Jong Hwi Chonbuk National University Introduction to Intelligent Robots.
AuRA: Principles and Practice in Review
A Summary of the Article “Intelligence Without Representation” by Rodney A. Brooks (1987) Presented by Dain Finn.
Autonomous Mobile Robots CPE 470/670 Lecture 11 Instructor: Monica Nicolescu.
Topics: Introduction to Robotics CS 491/691(X) Lecture 10 Instructor: Monica Nicolescu.
Robotics CSPP Artificial Intelligence March 10, 2004.
Topics: Introduction to Robotics CS 491/691(X) Lecture 11 Instructor: Monica Nicolescu.
Brent Dingle Marco A. Morales Texas A&M University, Spring 2002
Software Architecture Design Instructor: Dr. Jerry Gao.
Autonomous Mobile Robots CPE 470/670 Lecture 11 Instructor: Monica Nicolescu.
Experiences with an Architecture for Intelligent Reactive Agents By R. Peter Bonasso, R. James Firby, Erann Gat, David Kortenkamp, David P Miller, Marc.
Autonomous Mobile Robots CPE 470/670 Lecture 10 Instructor: Monica Nicolescu.
Autonomous Mobile Robots CPE 470/670 Lecture 8 Instructor: Monica Nicolescu.
Topics: Introduction to Robotics CS 491/691(X) Lecture 8 Instructor: Monica Nicolescu.
Autonomous Mobile Robots CPE 470/670 Lecture 9 Instructor: Monica Nicolescu.
Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu.
Integration of Representation Into Goal- Driven Behavior-Based Robots By Dr. Maja J. Mataric` Presented by Andy Klempau.
Autonomous Mobile Robots CPE 470/670 Lecture 10 Instructor: Monica Nicolescu.
Autonomous Mobile Robots CPE 470/670 Lecture 8 Instructor: Monica Nicolescu.
Topics: Introduction to Robotics CS 491/691(X)
Behavior- Based Approaches Behavior- Based Approaches.
A Robust Layered Control System for a Mobile Robot Rodney A. Brooks Presenter: Michael Vidal.
On Three-Layer Architecture Erann Gat Jet Propulsion Laboratory California Institute of Technology Presentation by: Ekkasit Tiamkaew Date: 09/09/04.
Architectural Design Establishing the overall structure of a software system Objectives To introduce architectural design and to discuss its importance.
Mobile Robot Control Architectures “A Robust Layered Control System for a Mobile Robot” -- Brooks 1986 “On Three-Layer Architectures” -- Gat 1998? Presented.
Introduction to Behavior- Based Robotics Based on the book Behavior- Based Robotics by Ronald C. Arkin.
Lab 3 How’d it go?.
Object-Oriented Software Engineering Practical Software Development using UML and Java Chapter 8: Modelling Interactions and Behaviour.
1/19 Component Design On-demand Learning Series Software Engineering of Web Application - Principles of Good Component Design Hunan University, Software.
Autonomous Mobile Robots CPE 470/670 Lecture 9 Instructor: Monica Nicolescu.
Robotica Lecture 3. 2 Robot Control Robot control is the mean by which the sensing and action of a robot are coordinated The infinitely many possible.
An Introduction to Software Architecture
SAMANVITHA RAMAYANAM 18 TH FEBRUARY 2010 CPE 691 LAYERED APPLICATION.
Autonomous Mobile Robots CPE 470/670 Lecture 8 Instructor: Monica Nicolescu.
SOFTWARE DESIGN.
Copyright 2002 Prentice-Hall, Inc. Chapter 2 Object-Oriented Analysis and Design Modern Systems Analysis and Design Third Edition Jeffrey A. Hoffer Joey.
Robotica Lecture 3. 2 Robot Control Robot control is the mean by which the sensing and action of a robot are coordinated The infinitely many possible.
Electrical Engineering Design Project - Fall 2002 Electrical/Computer Engineering Design Project Fall 2002 Lecture 4 – Robotics.
University of Windsor School of Computer Science Topics in Artificial Intelligence Fall 2008 Sept 11, 2008.
Robotica Lecture Review Reactive control Complete control space Action selection The subsumption architecture –Vertical vs. horizontal decomposition.
Brooks’ Subsumption Architecture EEL 6838 T. Ryan Fitz-Gibbon 1/24/2004.
Introduction of Intelligent Agents
Instructional Objective  Define an agent  Define an Intelligent agent  Define a Rational agent  Discuss different types of environment  Explain classes.
Robotics Club: 5:30 this evening
Subsumption Architecture and Nouvelle AI Arpit Maheshwari Nihit Gupta Saransh Gupta Swapnil Srivastava.
Abstract A Structured Approach for Modular Design: A Plug and Play Middleware for Sensory Modules, Actuation Platforms, Task Descriptions and Implementations.
© 2006 Pearson Addison-Wesley. All rights reserved 2-1 Chapter 2 Principles of Programming & Software Engineering.
Mike Graves Summer 2005 University of Texas at Dallas Implicit Invocation: The Task Control Architecture Mike Graves CS6362 Term Paper Dr. Lawrence Chung.
Behavior-based Multirobot Architectures. Why Behavior Based Control for Multi-Robot Teams? Multi-Robot control naturally grew out of single robot control.
Autonomous Mobile Robots CPE 470/670 Lecture 10 Instructor: Monica Nicolescu.
ROBOTICS COE 584 Robotic Control Architecture.
Intelligent Agents Chapter 2. How do you design an intelligent agent? Definition: An intelligent agent perceives its environment via sensors and acts.
Robotic Architectures Lezione 8. Robotic architecture Computer architecture: Computer architecture:  discipline devoted to the design of highly specific.
Middle East Technical University
CSPP Artificial Intelligence March 10, 2004
CMSC Artificial Intelligence March 11, 2008
Analysis Classes Unit 5.
Build Intelligence from the bottom up!
Build Intelligence from the bottom up!
Intelligent Agents Chapter 2.
An Introduction to Software Architecture
Build Intelligence from the bottom up!
Subsuption Architecture
Robot Intelligence Kevin Warwick.
Chapter 12: Building Situated Robots
Behavior Based Systems
Presentation transcript:

Autonomous Mobile Robots CPE 470/670 Lecture 9 Instructor: Monica Nicolescu

CPE 470/670 - Lecture 92 Review Reactive control Complete control space Action selection The subsumption architecture –Vertical vs. horizontal decomposition –The Subsumption Language and AFSMs

CPE 470/670 - Lecture 93 Vertical v. Horizontal Systems Traditional (SPA): sense – plan – act Subsumption:

CPE 470/670 - Lecture 94 The Subsumption Architecture Principles of design –systems are built from the bottom up –components are task-achieving actions/behaviors (avoid-obstacles, find-doors, visit-rooms) –components are organized in layers, from the bottom up –lowest layers handle most basic tasks –all rules can be executed in parallel, not in a sequence –newly added components and layers exploit the existing ones

CPE 470/670 - Lecture 95 Subsumption Layers First, we design, implement and debug layer 0 Next, we design layer 1 –When layer 1 is designed, layer 0 is taken into consideration and utilized, its existence is subsumed –Layer 0 continues to function Continue designing layers, until the desired task is achieved Higher levels can –Inhibit inputs of lower levels –Suppress outputs of lower levels level 2 level 1 level 0 sensorsactuators AFSM inputsoutputs inhibitor suppressor I s

CPE 470/670 - Lecture 96 Communication Through the World Collecting soda cans: Herbert Herbert’s capabilities –Move around without running into obstacles –Detect soda cans using a camera and a laser –An arm that could: extend, sense if there is a can in the gripper, close the gripper, tuck the arm in

CPE 470/670 - Lecture 97 Herbert Look for soda cans, when seeing one approach it When close, extend the arm toward the soda can If the gripper sensors detect something, close the gripper If can is heavy, put it down, otherwise pick it up If gripper was closed, tuck the arm in and head home The robot did not keep internal state about what it had just done and what it should do next: it just sensed!

CPE 470/670 - Lecture 98 More on Herbert There is no internal wire between the layers that achieve can finding, grabbing, arm tucking, and going home However, the events are all executed in proper sequence. Why? Because the relevant parts of the control system interact and activate each other through sensing the world

CPE 470/670 - Lecture 99 World as the Best Model This is a key principle of reactive systems & Subsumption Architecture: –Use the world as its own best model! If the world can provide the information directly (through sensing), it is best to get it that way, than to store it internally in a representation (which may be large, slow, expensive, and outdated)

CPE 470/670 - Lecture 910 Subsumption System Design What makes a Subsumption Layer, what should go where? There is no strict recipe, but some solutions are better than others, and most are derived empirically How exactly layers are split up depends on the specifics of the robot, the environment, and the task

CPE 470/670 - Lecture 911 Designing in Subsumption Qualitatively specify the overall behavior needed for the task Decompose that into specific and independent behaviors (layers) Determine behavior granularity Ground low-level behaviors in the robot’s sensors and effectors Incrementally build, test, and add

CPE 470/670 - Lecture 912 Genghis (MIT) Walk over rough terrain and follow a human (Brooks ’89) –Standup Control leg’s swing position and lift –Simple walk –Force balancing Force sensors provide information about the ground profile –Leg lifting: step over obstacles –Obstacle avoidance (whiskers) –Pitch stabilization –Prowling –Steered prowling

CPE 470/670 - Lecture 913 The Nerd Herd (MIT) Foraging example (Matarić ’93) –R1 robots (IS robotics) Behaviors involved: –Wandering –Avoiding –Pickup –Homing

CPE 470/670 - Lecture 914 Tom and Jerry (MIT) fsdf Tom Jerry

CPE 470/670 - Lecture 915 Pros and Cons Some critics consider the lack of detail about designing layers to be a weakness of the approach Others feel it is a strength, allowing for innovation and creativity Subsumption has been used on a vast variety of effective implemented robotic systems It was the first architecture to demonstrate many working robots

CPE 470/670 - Lecture 916 Benefits of Subsumption Systems are designed incrementally –Avoid design problems due to the complexity of the task –Helps the design and debugging process Robustness –If higher levels fail, the lower ones continue unaffected Modularity –Each “competency” is included into a separate layer, thus making the system manageable to design and maintain –Rules and layers can be reused on different robots and for different tasks

CPE 470/670 - Lecture 917 Behavior-Based Control Reactive systems –too inflexible, use no representation, no adaptation or learning Deliberative systems –Too slow and cumbersome Hybrid systems –Complex interactions among the hybrid components Behavior-based control involves the use of “behaviors” as modules for control

CPE 470/670 - Lecture 918 What Is a Behavior? Behavior-achieving modules Rules of implementation Behaviors achieve or maintain particular goals (homing, wall-following) Behaviors are time-extended processes Behaviors take inputs from sensors and from other behaviors and send outputs to actuators and other behaviors Behaviors are more complex than actions (stop, turn- right vs. follow-target, hide-from-light, find-mate etc.)

CPE 470/670 - Lecture 919 Principles of BBC Design Behaviors are executed in parallel, concurrently –Ability to react in real-time Networks of behaviors can store state (history), construct world models/representation and look into the future –Use representations to generate efficient behavior Behaviors operate on compatible time-scales –Ability to use a uniform structure and representation throughout the system

CPE 470/670 - Lecture 920 Internal vs. Observable Behavior Observable behaviors do not always have a matching internal behavior Why not? –Emergent behavior: interesting behavior can be produced from the interaction of multiple internal behaviors Start by listing the desired observable behaviors Program those behaviors with internal behaviors Behavior-based controllers are networks of internal behaviors which interact in order to produce the desired, external, observable behavior

CPE 470/670 - Lecture 921 An Example A robot that water plants around a building when they get dry Behaviors: avoid-collision, find-plant, check-if- dry, water, refill-reservoir, recharge-batteries Complex behaviors may consist of internal behaviors themselves –Find-plant: wander-around, detect-green, approach- green, etc. Multiple behaviors may share the same underlying component behavior –Refill-reservoir may also use wander-around

CPE 470/670 - Lecture 922 An Example Task: Mapping Design a robot that is capable of: –Moving around safely –Make a map of the environment –Use the map to find the shortest paths to particular places Navigation & mapping are the most common mobile robot tasks

CPE 470/670 - Lecture 923 Map Representation The map is distributed over different behaviors We connect parts of the map that are adjacent in the environment by connecting the behaviors that represent them The network of behaviors represents a network of locations in the environment Topological map: Toto (Matarić ’90)

CPE 470/670 - Lecture 924 Toto’s Behaviors Toto the robot –Ring of 12 sonars, low-resolution compas Lowest level: move around safely, without collisions Next level: following boundaries, a behavior that keeps the robot near walls and other objects

CPE 470/670 - Lecture 925 Landmark Detection Keep track of what was sensed and how it was moving –meandering  cluttered area –constant compass direction, go straight  left, right walls –moving straight, both walls  corridor

CPE 470/670 - Lecture 926 Toto’s Mapping Behaviors Each landmark was stored in a behavior Each such landmark behavior stored (remembered) some information –landmark type (wall, corridor, irregular) –compass heading –approximate length/size –some odometry my-behavior-type: corridor my-compass-direction: NV my-approximate-location: x,y my-approximate-length: length whenever received (input) if input(behavior-type)= my-behavior-type and input (compass-direction) = my-compass-direction then active <- true

CPE 470/670 - Lecture 927 Building a Map Whenever a new landmark was discovered a new behavior was added Adjacent landmarks are connected by communication wires This resulted in a topological representation of the environment, i.e., a topological world model

CPE 470/670 - Lecture 928 Localization Whenever a landmark is detected, its description (type and compass direction) is sent to all behaviors in parallel  the one that matches becomes active When nothing in the map matches  a new place/landmark was discovered and added to the map If an existing behavior was activated, it inhibited any other active behaviors

CPE 470/670 - Lecture 929 Getting Around Toto can use the map to navigate The behavior that corresponds to the goal sends messages (spreads activation) to all of its neighbors The neighbors send messages to their neighbors in turn So on, until the messages reach the currently active behavior This forms path(s) from the current state to the goal

CPE 470/670 - Lecture 930 Path Following Toto did not keep a sequence of behaviors Instead, messages were passed continuously –Useful in changing environments How does Toto decide where to go if multiple choices are available? –Rely on the landmark size: behaviors add up their own length as messages are passed from one behavior to another  give path length –Choose the shortest path Thus, one behavior at a time, it reached the goal

CPE 470/670 - Lecture 931 Toto’s Controller

CPE 470/670 - Lecture 932 Toto - Video

CPE 470/670 - Lecture 933 Expression of Behaviors Example: –Going from a classroom to another What does it involve? –Getting to the destination from the current location –Not bumping into obstacles along the way –Making your way around students on corridors –Deferring to elders –Coping with change in the environment

CPE 470/670 - Lecture 934 Stimulus-Response Diagrams Behaviors are represented as a general response to a particular stimulus move-to-class avoid-object dodge-student stay-right defer-to-elder COORDINATORCOORDINATOR class location detected object detected student detected path detected elder Actions

CPE 470/670 - Lecture 935 Finite State Acceptor Diagrams Useful for describing aggregations and sequences of behaviors Finite state acceptor: –Q: set of allowable behavioral states –  : transition function from (input, current state)  new state –q 0 : initial state –F: set of accepting (final) states StartJourney Lost At-class move error reached-class othernot-at-classall

CPE 470/670 - Lecture 936 Formal Methods Have very useful properties for the programmer –Can be used to verify designer intentions –Facilitate the automatic generation of control systems –Provide a common language for expressing robot behaviors –Provide a framework for formal analysis of the program, adequacy and completeness –Provide support for high-level programming language design

CPE 470/670 - Lecture 937 Situated Automata Kaelbling & Rosenschein (’91) Controllers are designed as logic circuits Capable of reasoning REX: Lisp-based language –First language to encode a reactive systems with synchronous digital circuitry Gapps: goals are specified more directly –Achievement, maintenance, execution –Logical boolean operators are used to create higher-level goals  generate circuits

CPE 470/670 - Lecture 938 Situated Automata (defgoalr (ach in-classroom) (if (not start-up) (maint (and (maint move-to-classroom) (maint avoid-objects) (maint dodge-students) (maint stay-to-right-on-path) (maint defer-to-elders) )

CPE 470/670 - Lecture 939 Readings M. Matarić: Chapter 16