Agile/Scrum
for Dummies Roboticists
A methodology created for small, cross-functional teams
Main characteristics
- Deliver value to your customers
- Use iterative development
- Adapt to change
The infamous "project triangle"
data:image/s3,"s3://crabby-images/8d639/8d6391bcfe513b1d2212acb33ac4af98caefc9a3" alt=""
Davide's tip: contrariwise to what other say, the area or the triangle in not constant
Waterfall
Project management "de toda la vida"
data:image/s3,"s3://crabby-images/3096f/3096fb871eaa9f86b643bfbb8e4ac31ad003267c" alt=""
Waterfall
The analog version
data:image/s3,"s3://crabby-images/786e9/786e988ee10a28fc94d2a52c4945272cf8abdff0" alt=""
Davide's tip: this model is still the best for some kind of projects
The "agile triangle"
data:image/s3,"s3://crabby-images/a3c4a/a3c4a3f56281c265d141b11a0af18368db5fdadb" alt=""
Deliver value
data:image/s3,"s3://crabby-images/217ae/217aed13895a37b8b843eea4f6ccef3f2191a10f" alt=""
Davide's tip: value is the happiness of the stackeholders,
including the team itself
data:image/s3,"s3://crabby-images/c35ac/c35aca2c85dedec479a5696985729cca1b8982fe" alt=""
Incremental value
Any iteration should deliver incremental value
data:image/s3,"s3://crabby-images/217bc/217bcda025486d01749b2da43b72a8ca79e721d4" alt=""
data:image/s3,"s3://crabby-images/9e4c6/9e4c6a9ba49cb9f65f6e4f8557b8769ed2e6c0e1" alt=""
How does it work?
data:image/s3,"s3://crabby-images/78b95/78b9550948cc2c1334a9b2ccf05890c99ce867d1" alt=""
Step 1: define the project requirements and intermediate deadlines
Known as "project backlog"
"AS A [type of user],
I WANT TO [do this thing],
SO THAT I CAN [accomplish this goal]."
Davide's tip: Try to decompose them hierarchically
"THE ROBOT,
CAN NAVIGATE AUTONOMOUSLY
TO A GIVEN POINT OF THE SEWER"
Step 2: split an intermediate deadline into small tasks
Davide's tip: if the unit is days, never more than 5
Each task has an estimated "effort"...
use fibonacci number to take uncertaincy into account
1 / 2 / 3 / 5 / 8 / 13 / ...
data:image/s3,"s3://crabby-images/aa1a5/aa1a5627a6c496eef075bc3f76f6f6b9835b9887" alt=""
Beware useless work!
Step 3: arrange tasks into sprints
- Any sprint should have a high level goal and a deliverable.
- Sprint shall always have a review phase.
- Team members pull tasks form the backlog.
data:image/s3,"s3://crabby-images/45280/45280533cc693951b198b26408cc0da1fc1f7f27" alt=""
Daily stand-up meeting
data:image/s3,"s3://crabby-images/21719/21719d74f4afab6f2e635ba429bf014288a3f03d" alt=""
- What did I do yesterday that helped our team meet the sprint goal?
- What will I do today to help our team meet the sprint goal?
- Do I see any impediments that prevent me from meeting the sprint goal?
How do we define
data:image/s3,"s3://crabby-images/64406/644067ec00246291f003ecf0bea90be11d6fb4b1" alt=""
?
data:image/s3,"s3://crabby-images/13d13/13d13820b614e58d1bf64fc1eecc44d47b2507a3" alt=""
Step 4: retrospective
- Define what was achieved.
- Find opportunities for improvements.
- Add/remove tasks to the backlog
data:image/s3,"s3://crabby-images/31d9f/31d9f3c2efb2de6d0c6fcfe9ef986ac390aab405" alt=""
Keep
Iterating
data:image/s3,"s3://crabby-images/9f3d8/9f3d8b4279c7ae098b537a33da62c52fc7b597b9" alt=""
Agile for roboticists
By Davide Faconti
Agile for roboticists
- 668