topics: introduction to robotics cs 491/691(x) lecture 7 instructor: monica nicolescu
Post on 21-Dec-2015
226 views
TRANSCRIPT
![Page 1: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/1.jpg)
Topics: Introduction to Robotics
CS 491/691(X)
Lecture 7
Instructor: Monica Nicolescu
![Page 2: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/2.jpg)
CS 491/691(X) - Lecture 7 2
Mid-Term
• Tuesday, March 9, in classroom
• Tentative exam structure
– 5 (6) homework like questions
– From lecture and lab material
![Page 3: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/3.jpg)
CS 491/691(X) - Lecture 7 3
Review
Feedback control
• General principles
• Proportional Control
• Derivative Control
• PD Control
• Integrative Control
• PID Control
• An example: the Robo Pong contest
![Page 4: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/4.jpg)
CS 491/691(X) - Lecture 7 4
Robo-Pong Contest
• Run at MIT January 1991• Involved 2 robots and 15 plastic golf balls• Goal:
– have your robot transport balls from its side of table to opponent’s in 60 seconds
– Robot with fewer balls on its side is the winner
• Table 4x6 feet, inclined surfaces, small plateau area in center
• Robots start in circles, balls placed as shown
• Robots could use reflectance sensors to determine which side they were on
• Plan encouraged diversity in robot strategies
![Page 5: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/5.jpg)
CS 491/691(X) - Lecture 7 5
Robo-Pong Contest
Strategy pattern of Groucho, an algorithmic ball-harvester
• Linear series of actions, which are performed in a repetitive loop
• Sensing may be used in the service of these actions, but it does not change the order in which they will be performed.
• Some feedback based on the surrounding environment would be necessary
![Page 6: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/6.jpg)
CS 491/691(X) - Lecture 7 6
Exit Conditions
• Problem with simple algorithmic approach:
– No provision for detecting or correcting for, problem situations
• Groucho’s program:
– A touch sensor triggers the next phase of action
– If something would impede its travel, without striking a touch
sensor, Groucho would be unable to take corrective action
– While crossing the top plateau the opponent robot gets in the
way, and triggers a touch sensor Groucho would begin its
behavior activated when reaching the opposing wall
• Solution: techniques for error detection and recovery
– E.g.: “Knowing” that it had struck the opponent
![Page 7: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/7.jpg)
CS 491/691(X) - Lecture 7 7
Exit Conditions
• Going from position 4 to 5:
– Traverses light/dark edge across the field
– Check for touch sensor to continue
• Problem:
– Only way to exit is if one of the touch sensors is pressed
• Solution:
– Allow the subroutine to time out
– After a predetermined period of time has elapsed, the subroutine
exits even if a touch sensor was not pressed
– Inform the higher level control program of abnormal exit by
returning a value indicating: normal termination (with a touch
sensor press) or abnormal termination (because of a timeout)
- Timeouts
![Page 8: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/8.jpg)
CS 491/691(X) - Lecture 7 8
Exit Conditions
• Going from position 4 to 5:
– Traverses light/dark edge across the field
– Check for touch sensor to continue
• Problem: – While traversing the edge the other robot comes in the way
– The routine finishes in too little time
• Solution: – Use a “too-long” and a “too-short” timeout
– If elapsed time is less than TOO-SHORT procedure
returns an EARLY error result
- Timeouts
![Page 9: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/9.jpg)
CS 491/691(X) - Lecture 7 9
Exit Conditions – Premature Exits
• Edge-following section
– Veer left, go straight, going right
• Problem:– Robot shouldn’t stay in any of these modes for very long
• Solution: monitor the transitions between the different modes
of the feedback loop
– Parameters representing longest time that Groucho may spend
continuously in any given state
– State variables: last_mode and last_time
– Return codes to represent the states: stuck veering
left/right/straight
![Page 10: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/10.jpg)
CS 491/691(X) - Lecture 7 10
Exit Conditions – Taking Action
• What action to take after learning that a problem has occurred?
• Robot gets stuck following the edge (position 4 to 5)– Robot has run into the opponent robot
– Robot has mistracked the median edge
– Something else has gone wrong
• Solution– After an error re-examine all other sensors to asses the situation (e.g.
detecting the opponent robot)
• Difficult to design appropriate reactions to any possible situation
• A single recovery behavior would suffice for many circumstances– For Groucho: heading downhill until hitting the bottom wall and then
proceeding with the cornering routine
![Page 11: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/11.jpg)
CS 491/691(X) - Lecture 7 11
Control Architectures
• Feedback control is very good for doing one thing
– Wall following, obstacle avoidance
• Most non-trivial tasks require that robots do multiple
things at the same time
• How can we put multiple feedback controllers together?– What is needed
– With what priority
• Find guiding principles for robot programming
![Page 12: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/12.jpg)
CS 491/691(X) - Lecture 7 12
Control Architecture
• A robot control architecture provides the guiding
principles for organizing a robot’s control system
• It allows the designer to produce the desired overall
behavior
• The term architecture is used similarly as
“computer architecture”
– Set of principles for designing computers from a collection of well-understood building blocks
• The building-blocks in robotics are dependent on
the underlying control architecture
![Page 13: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/13.jpg)
CS 491/691(X) - Lecture 7 13
Software/Hardware Control
• Robot control involves hardware, signal processing
and computation
• Controllers may be implemented:
– In hardware: programmable logic arrays
– In software: conventional program running on a processor
• The more complex the controller, the more likely it
will be implemented in software
• In general, robot control refers to software control
![Page 14: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/14.jpg)
CS 491/691(X) - Lecture 7 14
Languages for Robot Programming
• Control architectures may be implemented in various
programming languages
• Turing universality: a programming language is
Turing universal if it has the following capabilities:
– Sequencing: a then b then c
– Conditional branching: if a then b else c
– Iteration: for a = 1 to 10 do something
• With these one can compute the entire class of
computable functions
• All major programming languages are Turing
Universal
![Page 15: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/15.jpg)
CS 491/691(X) - Lecture 7 15
Computability
• Architectures are all equivalent in computational expressiveness– If an architecture is implemented in a Turing Universal
programming language, it is fully expressive
– No architecture can compute more than another
• The level of abstraction may be different
• Architectures, like languages are better suited to a
particular domain
![Page 16: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/16.jpg)
CS 491/691(X) - Lecture 7 16
Organizing Principles
• Architectures are built from components, specific for
the particular architecture
• The ways in which these building blocks are
connected facilitate certain types of robotic design
• Architectures do greatly affect and constrain the
structure of the robot controller (e.g., behavior
representation, granularity, time scale…)
• Control architectures do not constrain expressiveness
– Any language can compute any computable function the
architecture on top of it cannot further limit it
![Page 17: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/17.jpg)
CS 491/691(X) - Lecture 7 17
Uses of Programming Languages
• Programming languages are designed for specific
uses
– Web programming
– Games
– Robots
• A control architecture may be implemented in any
programming language
• Some languages are better suited then others
– Standard: Lisp, C, C++
– Specialized: Behavior-Language, Subsumption Language
![Page 18: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/18.jpg)
CS 491/691(X) - Lecture 7 18
Specialized Languages for Robot Control
• Why not use always a language that is readily
available (C, Java)?
• Specialized languages facilitate the implementation
of the guiding principles of a control architecture
– Coordination between modules
– Communication between modules
– Prioritization
– Etc.
![Page 19: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/19.jpg)
CS 491/691(X) - Lecture 7 19
Robot Control Architectures
• There are infinitely many ways to program a robot,
but there are only few types of robot control:
– Deliberative control (no longer in use)
– Reactive control
– Hybrid control
– Behavior-based control
• Numerous “architectures” are developed,
specifically designed for a particular control problem
• However, they all fit into one of the categories above
![Page 20: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/20.jpg)
CS 491/691(X) - Lecture 7 20
Architecture Selection Criteria
• Support for parallelism:
The ability to execute concurrent
processes/behaviors at the same time
• Hardware targetability:
How well an architecture can be mapped to robot
sensors and effectors; how well the computation can
be mapped onto real processing elements
(microprocessors, PLAs, etc.)
![Page 21: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/21.jpg)
CS 491/691(X) - Lecture 7 21
Architecture Selection Criteria
• Niche targetability
How well the architecture allows the robot to deal
with its environment
• Support for modularity
How is encapsulation of control handled, how does
it treat abstraction? What methods are available for
encapsulating behavioral abstractions, and at what
levels? Does it allow software reusability?
![Page 22: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/22.jpg)
CS 491/691(X) - Lecture 7 22
Architecture Selection Criteria
• Robustness
Ability to perform in the case of failing components.
What mechanisms are available for fault tolerance?
• Run time flexibility
How can the system be adjusted or reconfigured at
runtime? Is learning and adaptation possible or
facilitated?
![Page 23: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/23.jpg)
CS 491/691(X) - Lecture 7 23
Architecture Selection Criteria
• Ease of development
What tools are available for development and how
easy are they to use?
• Performance
How well does the robot perform the intended task?
How well does it meet the deadlines, or fulfils its
quantitative metrics (energy consumption, minimum
travel etc.)?
![Page 24: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/24.jpg)
CS 491/691(X) - Lecture 7 24
Comparing Architectures
• The previous criteria help us to compare and
evaluate different architectures relative to specific
robot designs, tasks, and environments
• There is no perfect recipe for finding the right control
architecture
• Architectures can be classified by the way in which
they treat:
– Time-scale (looking ahead)
– Modularity
– Representation
![Page 25: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/25.jpg)
CS 491/691(X) - Lecture 7 25
Time-Scale and Looking Ahead
• How fast does the system react? Does it look into the future?
• Deliberative control– Look into the future (plan) then execute long time scale
• Reactive control– Do not look ahead, simply react short time scale
• Hybrid control– Look ahead (deliberative layer) but also react quickly
(reactive layer)
• Behavior-based: – Look ahead while acting
![Page 26: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/26.jpg)
CS 491/691(X) - Lecture 7 26
Modularity
• Refers to the way the control system is broken into
components
• Deliberative control– Sensing (perception), planning and acting
• Reactive control– Multiple modules running in parallel
• Hybrid control– Deliberative, reactive, middle layer
• Behavior-based: – Multiple modules running in parallel
![Page 27: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/27.jpg)
CS 491/691(X) - Lecture 7 27
Representation
• Representation is the form in which the control system internally stores information– Internal state
– Internal representations
– Internal models
– History
• What is represented and how it is represented has a major impact on robot control
• State refers to the "status" of the system itself, whereas "representation" refers to arbitrary information that the robot stores
![Page 28: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/28.jpg)
CS 491/691(X) - Lecture 7 28
An Example
• Consider a robot that moves in a maze: what does
the robot need to know to navigate?
• Store the path taken to the end of the maze
– Straight 1m, left 90 degrees, straight 2m, right 45 degrees
– Odometric path
• Store a sequence of moves it has made at particular
landmark in the environment
– Left at first junction, right at the second, left at the third
– Landmark-based path
![Page 29: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/29.jpg)
CS 491/691(X) - Lecture 7 29
Topological Map
• Store what to do at each landmark in the maze
– Landmark-based map• The map can be stored (represented) in different forms
– Store all possible paths and use the shortest one
– Topological map: describes the connections among the landmarks
– Metric map: global map of the maze with exact lengths of corridors and distances between walls, free and blocked paths: very general!
• The robot can use this map to find new paths through the maze
• Such a map is a world model, a representation of the environment
![Page 30: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/30.jpg)
CS 491/691(X) - Lecture 7 30
World Models
• Numerous aspects of the world can be represented
– self/ego: stored proprioception, self-limits, goals,
intentions, plans
– space: metric or topological (maps, navigable spaces,
structures)
– objects, people, other robots: detectable things in the
world
– actions: outcomes of specific actions in the environment
– tasks: what needs to be done, in what order, by when
• Ways of representation
– Abstractions of a robot’s state & other information
![Page 31: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/31.jpg)
CS 491/691(X) - Lecture 7 31
Model Complexity
• Some models are very elaborate
– They take a long time to construct
– These are kept around for a long time throughout the
lifetime of the robot
– E.g.: a detailed metric map
• Other models are simple
– Can be quickly constructed
– In general they are transient and can be discarded after use
– E.g.: information related to the immediate goals of the
robot (avoiding an obstacle, opening of a door, etc.)
![Page 32: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/32.jpg)
CS 491/691(X) - Lecture 7 32
Models and Computation
• Using models require significant amount of computation
• Construction: the more complex the model, the more computation is needed to construct the model
• Maintenance: models need to be updated and kept up-to-date, or they become useless
• Use of representations: complexity directly affects the type and amount of computation required for using the model
• Different architectures have different ways of handling representations
![Page 33: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/33.jpg)
CS 491/691(X) - Lecture 7 33
An Example
• Consider a metric map
• Construction:– Requires exploring and measuring the environment and
intense computation
• Maintenance:– Continuously update the map if doors are open or closed
• Using the map:– Finding a path to a goal involves planning: find
free/navigational spaces, search through those to find the
shortest, or easiest path
![Page 34: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/34.jpg)
CS 491/691(X) - Lecture 7 34
Simultaneous Mapping and Localization
![Page 35: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/35.jpg)
CS 491/691(X) - Lecture 7 35
Cooperative Mapping and Localization
![Page 36: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/36.jpg)
CS 491/691(X) - Lecture 7 36
Reactive Control
• Reactive control is based on tight (feedback) loops
connecting a robot's sensors with its effectors
• Purely reactive systems do not use any internal representations of the environment, and do not look ahead– They work on a short time-scale and react to the current
sensory information
• Reactive systems use minimal, if any, state
information
![Page 37: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/37.jpg)
CS 491/691(X) - Lecture 7 37
Collections of Rules
• Reactive systems consist of collections of reactive rules that map specific situations to
specific actions
• Analog to stimulus-response, reflexes– Bypassing the “brain” allows reflexes to be very fast
• Rules are running concurrently and in parallel
• Situations
– Are extracted directly from sensory input
• Actions
– Are the responses of the system (behaviors)
![Page 38: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/38.jpg)
CS 491/691(X) - Lecture 7 38
Mutually Exclusive Situations
• If the set of situations is mutually exclusive:
only one situation can be met at a given
time
only one action can be activated
• Often is difficult to split up the situations this way
• To have mutually exclusive situations the controller must encode rules for all possible sensory combinations, from all sensors
• This space grows exponentially with the number of
sensors
![Page 39: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/39.jpg)
CS 491/691(X) - Lecture 7 39
Complete Control Space
• The entire state space of the robot consists of all possible combinations of the internal and external states
• A complete mapping from these states to actions is needed such that the robot can respond to all possibilities
• This is would be a tedious job and would result in a very large look-up table that takes a long time to search
• Reactive systems use parallel concurrent reactive rules parallel architecture, multi-tasking
![Page 40: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/40.jpg)
CS 491/691(X) - Lecture 7 40
Incomplete Mappings
• In general, complete mappings are not used in hand-
designed reactive systems
• The most important situations are trigger the appropriate reactions
• Default responses are used to cover all other cases
• E.g.: a reactive safe-navigation controller
If left whisker bent then turn right
If right whisker bent then turn left
If both whiskers bent then back up and turn left
Otherwise, keep going
![Page 41: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/41.jpg)
CS 491/691(X) - Lecture 7 41
Example – Safe Navigation
• A robot with 12 sonar sensors, all around the robot
• Divide the sonar range into two zones
– Danger zone: things too close
– Safe zone: reasonable distance to objects
if minimum sonars 1, 2, 3, 12 < danger-zone and not-stopped
then stop
if minimum sonars 1, 2, 3, 12 < danger-zone and stopped
then move backward
otherwise
move forward
• This controller does not look at the side sonars
1 2
3
4
5
6
78
9
10
11
12
![Page 42: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/42.jpg)
CS 491/691(X) - Lecture 7 42
Example – Safe Navigation
• For dynamic environments, add another layer
if sonar 11 or 12 < safe-zone and
sonar 1 or 2 < safe-zone
then turn right
if sonar 3 or 4 < safe-zone
then turn left
• The robot turns away from the obstacles before getting
too close
• The combinations of the two controllers above
collision-free wandering behavior
• Above we had mutually-exclusive conditions
1 2
3
4
5
6
78
9
10
11
12
![Page 43: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/43.jpg)
CS 491/691(X) - Lecture 7 43
Arbitration
• If the rules are not triggered by unique mutually-exclusive conditions, more than one rule can be triggered at the same time
Two or more different commands are sent to the actuators
• Deciding which action to take is called action selection
• Arbitration: decide among multiple actions or behaviors
• Fusion: combine multiple actions to produce a single command
![Page 44: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/44.jpg)
CS 491/691(X) - Lecture 7 44
Arbitration
• There are many different types of arbitration
• Arbitration can be done based on:
• a fixed priority hierarchy
– rules have pre-assigned priorities
• a dynamic hierarchy
– rules priorities change at run-time
• learning
– rule priorities may be initialized and are learned at run-
time, once or continuously
![Page 45: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/45.jpg)
CS 491/691(X) - Lecture 7 45
Multi-Tasking• Arbitration decides which one action to execute
• To respond to any rule that might become triggered all rules have to be monitored in parallel, and concurrentlyIf no obstacle in front move forward
If obstacle in front stop and turn away
Wait for 30 seconds, then turn in a random direction
• Monitoring sensors in sequence may lead to missing important events, or failing to react in real time
• Reactive systems must support parallelism– The underlying programming language must have multi-
tasking abilities
![Page 46: Topics: Introduction to Robotics CS 491/691(X) Lecture 7 Instructor: Monica Nicolescu](https://reader035.vdocuments.mx/reader035/viewer/2022062300/56649d595503460f94a39cea/html5/thumbnails/46.jpg)
CS 491/691(X) - Lecture 7 46
Readings
• M. Matarić: Chapters 11, 12, 14