Software Engineering in Robotics - Lecture 1
Software Engineering in Robotics - Lecture 1
OUTLINE
Welcome Objectives of the course Structure of the course Material for the course Wrap-Up
WELCOME
Highlight some of the special issues for robotics Discuss a broad set of methods as used in robotics Design of a small system for robot navigation Practical experience using software engineering with Microsoft Robotics Developer Studio (RDS)
Software Engineering
Systematic approach to analysis, development, operations and maintenance Most systems are highly complex Expectations are often poorly defined Quality is often a major challenge Essential to consider all aspects up-front
Motivation
Requirements analysis Systems Modeling Functional Modeling Implementation Evaluation Deployment Maintenance Documentation
Waterfall Model Prototyping Model Iterative Enhancement Model Spiral Life Cycle Model Agile Software Development Object Oriented Model
Determination of system requirements Design of the system / architecture Development of the software Testing and Evaluation Implementation and Maintenance Error Distribution / Version Management
Waterfall Model
Pros
Cons
Easy to explain Clearly staged Easy to plan and schedule Clear Deliverables / milestones
Assumes a linear project progression All requirements up-front Iterations are only implicit
Pros
Cons
Direct user involvement Good fit to user expectations Errors detected early Solution as user buy in
Pro
Cons
User buy-in with clear deliverables Clearly defined phases / team efficiency
Pro
Cons
Phases
Philosophy
Model Implementation incl unit testing Perform objective testing Transition Deployment Version Management Context
System Analysis System Design Object Design Implementation Evaluation and Benchmarking A little more details in lecture 3 (stay tuned)
Considerations/Comparison
Agility Driven
Plan Driven
Formal Design
Low criticality Experienced sw team Dynamic requirements Small team Highly dynamic environment
High criticality Junior sw team Mostly stable requirements Large team Structured process
Extremely critical Experienced sw team Limited features Features can be modeled Extreme quality
Creates disparate requirements in a systems engineering Emergent behavior Multi-threaded execution / complexity
Internet to Robotics Motivation/Background Software Engineering Tools Introduction to Robotics Developer Studio Use of simulation for system development Process / System Models Inter Process Communications Data Flow Models Common Control Structures Hardware Integration Issues Reference Architectures Packaging and Deployment of Systems Integration of legacy code and use of libraries Systems Evaluation and Benchmarking Outlook and Summary
Exercises
Design of a robot navigation system Architecture of the system? Simulation of the system using off-the-shelf components Service Design and Implementation
Computer running Windows XP / 7 Microsoft Visual Studio 2008/2010 Express Microsoft Robotics Developer Studio R3 Surveyor SRV-1 Robot (or similar) Slides for all lectures available at CodePlex site Example C# code available at CodePlex site
Summary
Introduction to the course A need to actively design a system Exploration of software engineering for robotics
Coverage of most aspects Discussion of methods Objective to provide a sound basis for design A basis for efficient use design of systems Exploration of use of RDS for robot systems
Acknowledgement
This series of lectures has been developed with the generous support from the Microsoft Corporation under the project Software Engineering in Robotics Contract # 113873. The support is gratefully acknowledged.