SlideShare a Scribd company logo
1 of 20
Download to read offline
Improving Agile Development
        Through Tetrisยฎ
         Mark Daggett




                          Copyright ยฉ 2011 Mark Daggett. Some Rights Reserved

Saturday, March 5, 2011
Can learning Tetris improve the
          quality of your software
           development process?




                                         2

Saturday, March 5, 2011
You know Tetris




                  Photo Credit: fraskedesigns.blogspot.com   3

Saturday, March 5, 2011
Tetris is Crack for the OCD




                                          4

Saturday, March 5, 2011
Tetris Is Serious; Seriously
          Developed by Alexey Pajitnov to test
          arti๏ฌcial intelligence algorithms
          Can be used to measure conceptual skills
          of task analysis and resource management
          in players
          Can also measure a playerโ€™s visceral
          decision making process under pressure


                                                     5

Saturday, March 5, 2011
Agile Development Reasoning
          Greater awareness of development costs
          [resource management]
          Tighter integration between developers
          and stakeholders [task analysis]
          Ability to quickly change course on
          projects [response to pressure]




                                                   6

Saturday, March 5, 2011
1. Donโ€™t Get Too Clever

                          Tetris rewards players for clearing
                          more than one row at a time.
                          This creates a chain of serial
                          dependencies that need to happen
                          in the right order to succeed.
                          Serial dependencies cost your
                          project time and resources as you
                          wait for the right piece to arrive.




                                                                9
                                                                7

Saturday, March 5, 2011
1. Donโ€™t Get Too Clever

                          Serial dependencies can easily turn
                          into a FAIL as other resources, such
                          as time, run out.




                                                            10
                                                             8

Saturday, March 5, 2011
1. Donโ€™t Get Too Clever

                          Your chances of success are greatly
                          increased when you work towards
                          solutions that can be completed in
                          many different ways.




                                                           11
                                                            9

Saturday, March 5, 2011
2. Stay Low
                          As your stack of uncleared rows
                          increases, your time to make
                          decisions decreases. This means you
                          are more likely to make a poor
                          decision in the future.
                          The more time you give yourself the
                          more likely your future steps will be
                          well-reasoned
                          In Tetris and in development cycles
                          if you are forced to just react to
                          impending deadlines you drastically
                          reduce your ability to succeed.


                                                            10

Saturday, March 5, 2011
3. Maximize the Work You Are Not
     Doing
      Tetris pieces can be rotated clockwise and counterclockwise.
      Ef๏ฌciency is knowing the fastest direction to rotate the piece
      to ๏ฌt your stack.
                   Rotating Left   Desired Orientation    Rotating Right




                                   3x as long to rotate

                                                                           13
                                                                           11

Saturday, March 5, 2011
3. Maximize the Work You Are Not
     Doing

          Many agile teams take pride in the amount of automation
          they bring to their development process, through testing,
          deploying or documenting.
          Any process that can be done a faster way (without
          sacri๏ฌcing quality) should be.
          Developers need to know the strengths and weaknesses
          of their technology stack.




                                                                14
                                                                12

Saturday, March 5, 2011
4. Know Your Goal

          In Tetris it is easy to focus on your score, as a
          measurement for progress but thatโ€™s a red herring.
          Tetris by design is a game that doesnโ€™t end so you canโ€™t
          โ€œwinโ€.
          You donโ€™t win your application by deploying it - you just
          clear your stack




                                                                     15
                                                                     13

Saturday, March 5, 2011
5. Fix Mistakes NOW!
                          A common problem in Tetris among
                          players is to try to bury their
                          mistakes
                          Ignoring mistakes means players
                          have less space remaining to work
                          with, and therefore a higher
                          likelihood of making similar mistakes
                          in the future.
                          Agile development focuses on
                          refactoring code, getting rid of
                          duplication, baroqueness and silos
                          of code.
                          A.B.R. (Always Be Refactoring)
                                                           16
                                                           14

Saturday, March 5, 2011
6. Fail Early And Often
                          Tetris is to agile
                          development as
                          โ€œPITFALL!โ€ is to the
                          Waterfall method.




                          Ironic Name I Know
                                           17
                                           15

Saturday, March 5, 2011
6. Fail Early And Often




         START OVER HERE




                           DIE HERE
Level map of PITFALL!                 16

Saturday, March 5, 2011
6. Fail Early And Often
     โ€œPitfall!โ€ requires you to start back at the beginning of the
     level each time you die. This is like the waterfall method,
     which reboots the development cycle for every
     requirement change.

     Tetris lets you fail quickly and let you restart where you left
     off. You can improve your technique and understanding of
     the game at any point of the play cycle.

     Agile development focuses on test driven development,
     and writing tests to fail ๏ฌrst. This ensures that you work
     directly on the feature in question and not any of the
     ancillary systems.

                                                                   19
                                                                   17

Saturday, March 5, 2011
7. Embrace Change

          In Tetris the player only knows which piece is coming
          next.
          Agile development says the developer should embrace
          change, be it shifting requirements, or deadlines.
          Just as the player is constantly scanning the game board
          the agile developer should be reevaluating previous
          design decisions looking for ways to refactor code and
          reduce complexity.




                                                                  20
                                                                  18

Saturday, March 5, 2011
8. Thereโ€™s an โ€œIโ€ in Tetris but not Team

          Tetris is a single player unless you are competing against
          another player.
          This is unlike programming, which at some fundamental
          level is a process of building off the work of others.
          The Tetris metaphor works only so far. The biggest factor
          in success or failure in an agile environment is how the
          team works together.




                                                                   21
                                                                   19

Saturday, March 5, 2011
THANKS!
      Mark Daggett
      Application Architect
      Humansized Inc.

      @heavysixer
      mark@humansized.com
      http://www.humansized.com




  Tetris ยฎ is a registered trademark of The Tetris Company
  PITFALL! ยฎ is a registered trademark of Activision
                                                             22
                                                             20

Saturday, March 5, 2011

More Related Content

Similar to Learn Agile Development Through Tetris

Social improvements in monitoring
Social improvements in monitoringSocial improvements in monitoring
Social improvements in monitoring
Theo Schlossnagle
ย 
Kill bottlenecks with gearman, sphinx, and memcached, Confoo 2011
Kill bottlenecks with gearman, sphinx, and memcached, Confoo 2011Kill bottlenecks with gearman, sphinx, and memcached, Confoo 2011
Kill bottlenecks with gearman, sphinx, and memcached, Confoo 2011
Bachkoutou Toutou
ย 
LISA 2011 Keynote: The DevOps Transformation
LISA 2011 Keynote: The DevOps TransformationLISA 2011 Keynote: The DevOps Transformation
LISA 2011 Keynote: The DevOps Transformation
benrockwood
ย 
Monitoring is easy, why are we so bad at it presentation
Monitoring is easy, why are we so bad at it  presentationMonitoring is easy, why are we so bad at it  presentation
Monitoring is easy, why are we so bad at it presentation
Theo Schlossnagle
ย 
P&P Notes 2nd Day
P&P Notes 2nd DayP&P Notes 2nd Day
P&P Notes 2nd Day
Tiago Forjaz
ย 

Similar to Learn Agile Development Through Tetris (13)

Put Some SRE in Your Shipped Software
Put Some SRE in Your Shipped SoftwarePut Some SRE in Your Shipped Software
Put Some SRE in Your Shipped Software
ย 
Social improvements in monitoring
Social improvements in monitoringSocial improvements in monitoring
Social improvements in monitoring
ย 
Negative Sentiment (or "Sentiment Analysis is Sh*te")
Negative Sentiment (or "Sentiment Analysis is Sh*te")Negative Sentiment (or "Sentiment Analysis is Sh*te")
Negative Sentiment (or "Sentiment Analysis is Sh*te")
ย 
Kill bottlenecks with gearman, sphinx, and memcached, Confoo 2011
Kill bottlenecks with gearman, sphinx, and memcached, Confoo 2011Kill bottlenecks with gearman, sphinx, and memcached, Confoo 2011
Kill bottlenecks with gearman, sphinx, and memcached, Confoo 2011
ย 
When Tdd Goes Awry
When Tdd Goes AwryWhen Tdd Goes Awry
When Tdd Goes Awry
ย 
Engineering Software Engineering Teams - SSE 2011
Engineering Software Engineering Teams - SSE 2011Engineering Software Engineering Teams - SSE 2011
Engineering Software Engineering Teams - SSE 2011
ย 
LISA 2011 Keynote: The DevOps Transformation
LISA 2011 Keynote: The DevOps TransformationLISA 2011 Keynote: The DevOps Transformation
LISA 2011 Keynote: The DevOps Transformation
ย 
Pair Programming in Theory and Practice By Garrick West
Pair Programming in Theory and Practice By Garrick WestPair Programming in Theory and Practice By Garrick West
Pair Programming in Theory and Practice By Garrick West
ย 
The perfectionists bathroom
The perfectionists bathroomThe perfectionists bathroom
The perfectionists bathroom
ย 
Monitoring is easy, why are we so bad at it presentation
Monitoring is easy, why are we so bad at it  presentationMonitoring is easy, why are we so bad at it  presentation
Monitoring is easy, why are we so bad at it presentation
ย 
P&P Notes 2nd Day
P&P Notes 2nd DayP&P Notes 2nd Day
P&P Notes 2nd Day
ย 
PHP World DC 2015 - What Can Go Wrong with Agile Development and How to Fix It
PHP World DC 2015 - What Can Go Wrong with Agile Development and How to Fix ItPHP World DC 2015 - What Can Go Wrong with Agile Development and How to Fix It
PHP World DC 2015 - What Can Go Wrong with Agile Development and How to Fix It
ย 
Extending rails
Extending railsExtending rails
Extending rails
ย 

Recently uploaded

๐“€คCall On 6297143586 ๐“€ค Ultadanga Call Girls In All Kolkata 24/7 Provide Call W...
๐“€คCall On 6297143586 ๐“€ค Ultadanga Call Girls In All Kolkata 24/7 Provide Call W...๐“€คCall On 6297143586 ๐“€ค Ultadanga Call Girls In All Kolkata 24/7 Provide Call W...
๐“€คCall On 6297143586 ๐“€ค Ultadanga Call Girls In All Kolkata 24/7 Provide Call W...
rahim quresi
ย 
Jodhpur Park ( Call Girls ) Kolkata โœ” 6297143586 โœ” Hot Model With Sexy Bhabi ...
Jodhpur Park ( Call Girls ) Kolkata โœ” 6297143586 โœ” Hot Model With Sexy Bhabi ...Jodhpur Park ( Call Girls ) Kolkata โœ” 6297143586 โœ” Hot Model With Sexy Bhabi ...
Jodhpur Park ( Call Girls ) Kolkata โœ” 6297143586 โœ” Hot Model With Sexy Bhabi ...
ritikasharma
ย 
Model Call Girls In Ariyalur WhatsApp Booking 7427069034 call girl service 24...
Model Call Girls In Ariyalur WhatsApp Booking 7427069034 call girl service 24...Model Call Girls In Ariyalur WhatsApp Booking 7427069034 call girl service 24...
Model Call Girls In Ariyalur WhatsApp Booking 7427069034 call girl service 24...
Shivani Pandey
ย 
Low Rate Call Girls Dhakuria (8005736733) 100% GENUINE ESCORT SERVICE & HOTEL...
Low Rate Call Girls Dhakuria (8005736733) 100% GENUINE ESCORT SERVICE & HOTEL...Low Rate Call Girls Dhakuria (8005736733) 100% GENUINE ESCORT SERVICE & HOTEL...
Low Rate Call Girls Dhakuria (8005736733) 100% GENUINE ESCORT SERVICE & HOTEL...
Shivani Pandey
ย 
Mumbai ] Call Girls Service Mumbai โ‚น7.5k Pick Up & Drop With Cash Payment 983...
Mumbai ] Call Girls Service Mumbai โ‚น7.5k Pick Up & Drop With Cash Payment 983...Mumbai ] Call Girls Service Mumbai โ‚น7.5k Pick Up & Drop With Cash Payment 983...
Mumbai ] Call Girls Service Mumbai โ‚น7.5k Pick Up & Drop With Cash Payment 983...
hotbabesbook
ย 
Model VVIP Call Girls In Porur ๐Ÿ‘‰ Chennai ๐Ÿฌ 7427069034 Escort Service & Hotel ...
Model VVIP Call Girls In Porur ๐Ÿ‘‰ Chennai ๐Ÿฌ 7427069034 Escort Service & Hotel ...Model VVIP Call Girls In Porur ๐Ÿ‘‰ Chennai ๐Ÿฌ 7427069034 Escort Service & Hotel ...
Model VVIP Call Girls In Porur ๐Ÿ‘‰ Chennai ๐Ÿฌ 7427069034 Escort Service & Hotel ...
hotbabesbook
ย 
Zirakpur Call Girls๐Ÿ‘ง Book Now๐Ÿ“ฑ8146719683 ๐Ÿ“ž๐Ÿ‘‰Mohali Call Girl Service No Advanc...
Zirakpur Call Girls๐Ÿ‘ง Book Now๐Ÿ“ฑ8146719683 ๐Ÿ“ž๐Ÿ‘‰Mohali Call Girl Service No Advanc...Zirakpur Call Girls๐Ÿ‘ง Book Now๐Ÿ“ฑ8146719683 ๐Ÿ“ž๐Ÿ‘‰Mohali Call Girl Service No Advanc...
Zirakpur Call Girls๐Ÿ‘ง Book Now๐Ÿ“ฑ8146719683 ๐Ÿ“ž๐Ÿ‘‰Mohali Call Girl Service No Advanc...
rajveermohali2022
ย 
VIP Model Call Girls Budhwar Peth ( Pune ) Call ON 8005736733 Starting From 5...
VIP Model Call Girls Budhwar Peth ( Pune ) Call ON 8005736733 Starting From 5...VIP Model Call Girls Budhwar Peth ( Pune ) Call ON 8005736733 Starting From 5...
VIP Model Call Girls Budhwar Peth ( Pune ) Call ON 8005736733 Starting From 5...
SUHANI PANDEY
ย 
Mira Road | Call Girls Service Mumbai | โ‚น,9500 Pay Cash 9833325238 Free Home ...
Mira Road | Call Girls Service Mumbai | โ‚น,9500 Pay Cash 9833325238 Free Home ...Mira Road | Call Girls Service Mumbai | โ‚น,9500 Pay Cash 9833325238 Free Home ...
Mira Road | Call Girls Service Mumbai | โ‚น,9500 Pay Cash 9833325238 Free Home ...
hotbabesbook
ย 
๐“€คCall On 6297143586 ๐“€ค Park Street Call Girls In All Kolkata 24/7 Provide Call...
๐“€คCall On 6297143586 ๐“€ค Park Street Call Girls In All Kolkata 24/7 Provide Call...๐“€คCall On 6297143586 ๐“€ค Park Street Call Girls In All Kolkata 24/7 Provide Call...
๐“€คCall On 6297143586 ๐“€ค Park Street Call Girls In All Kolkata 24/7 Provide Call...
rahim quresi
ย 

Recently uploaded (20)

๐“€คCall On 6297143586 ๐“€ค Ultadanga Call Girls In All Kolkata 24/7 Provide Call W...
๐“€คCall On 6297143586 ๐“€ค Ultadanga Call Girls In All Kolkata 24/7 Provide Call W...๐“€คCall On 6297143586 ๐“€ค Ultadanga Call Girls In All Kolkata 24/7 Provide Call W...
๐“€คCall On 6297143586 ๐“€ค Ultadanga Call Girls In All Kolkata 24/7 Provide Call W...
ย 
Bhimtal โคCALL GIRL 8617697112 โคCALL GIRLS IN Bhimtal ESCORT SERVICEโคCALL GIRL
Bhimtal โคCALL GIRL 8617697112 โคCALL GIRLS IN Bhimtal ESCORT SERVICEโคCALL GIRLBhimtal โคCALL GIRL 8617697112 โคCALL GIRLS IN Bhimtal ESCORT SERVICEโคCALL GIRL
Bhimtal โคCALL GIRL 8617697112 โคCALL GIRLS IN Bhimtal ESCORT SERVICEโคCALL GIRL
ย 
Jodhpur Park ( Call Girls ) Kolkata โœ” 6297143586 โœ” Hot Model With Sexy Bhabi ...
Jodhpur Park ( Call Girls ) Kolkata โœ” 6297143586 โœ” Hot Model With Sexy Bhabi ...Jodhpur Park ( Call Girls ) Kolkata โœ” 6297143586 โœ” Hot Model With Sexy Bhabi ...
Jodhpur Park ( Call Girls ) Kolkata โœ” 6297143586 โœ” Hot Model With Sexy Bhabi ...
ย 
Call Girls Panaji Just Call 8617370543 Top Class Call Girl Service Available
Call Girls Panaji Just Call 8617370543 Top Class Call Girl Service AvailableCall Girls Panaji Just Call 8617370543 Top Class Call Girl Service Available
Call Girls Panaji Just Call 8617370543 Top Class Call Girl Service Available
ย 
Model Call Girls In Ariyalur WhatsApp Booking 7427069034 call girl service 24...
Model Call Girls In Ariyalur WhatsApp Booking 7427069034 call girl service 24...Model Call Girls In Ariyalur WhatsApp Booking 7427069034 call girl service 24...
Model Call Girls In Ariyalur WhatsApp Booking 7427069034 call girl service 24...
ย 
Almora call girls ๐Ÿ“ž 8617697112 At Low Cost Cash Payment Booking
Almora call girls ๐Ÿ“ž 8617697112 At Low Cost Cash Payment BookingAlmora call girls ๐Ÿ“ž 8617697112 At Low Cost Cash Payment Booking
Almora call girls ๐Ÿ“ž 8617697112 At Low Cost Cash Payment Booking
ย 
Low Rate Call Girls Dhakuria (8005736733) 100% GENUINE ESCORT SERVICE & HOTEL...
Low Rate Call Girls Dhakuria (8005736733) 100% GENUINE ESCORT SERVICE & HOTEL...Low Rate Call Girls Dhakuria (8005736733) 100% GENUINE ESCORT SERVICE & HOTEL...
Low Rate Call Girls Dhakuria (8005736733) 100% GENUINE ESCORT SERVICE & HOTEL...
ย 
โคPersonal Whatsapp Number Keylong Call Girls 8617697112 ๐Ÿ’ฆโœ….
โคPersonal Whatsapp Number Keylong Call Girls 8617697112 ๐Ÿ’ฆโœ….โคPersonal Whatsapp Number Keylong Call Girls 8617697112 ๐Ÿ’ฆโœ….
โคPersonal Whatsapp Number Keylong Call Girls 8617697112 ๐Ÿ’ฆโœ….
ย 
WhatsApp Chat: ๐Ÿ“ž 8617697112 Hire Call Girls Raiganj For a Sensual Sex Experience
WhatsApp Chat: ๐Ÿ“ž 8617697112 Hire Call Girls Raiganj For a Sensual Sex ExperienceWhatsApp Chat: ๐Ÿ“ž 8617697112 Hire Call Girls Raiganj For a Sensual Sex Experience
WhatsApp Chat: ๐Ÿ“ž 8617697112 Hire Call Girls Raiganj For a Sensual Sex Experience
ย 
Hire ๐Ÿ’• 8617697112 North Sikkim Call Girls Service Call Girls Agency
Hire ๐Ÿ’• 8617697112 North Sikkim Call Girls Service Call Girls AgencyHire ๐Ÿ’• 8617697112 North Sikkim Call Girls Service Call Girls Agency
Hire ๐Ÿ’• 8617697112 North Sikkim Call Girls Service Call Girls Agency
ย 
Mumbai ] Call Girls Service Mumbai โ‚น7.5k Pick Up & Drop With Cash Payment 983...
Mumbai ] Call Girls Service Mumbai โ‚น7.5k Pick Up & Drop With Cash Payment 983...Mumbai ] Call Girls Service Mumbai โ‚น7.5k Pick Up & Drop With Cash Payment 983...
Mumbai ] Call Girls Service Mumbai โ‚น7.5k Pick Up & Drop With Cash Payment 983...
ย 
Model VVIP Call Girls In Porur ๐Ÿ‘‰ Chennai ๐Ÿฌ 7427069034 Escort Service & Hotel ...
Model VVIP Call Girls In Porur ๐Ÿ‘‰ Chennai ๐Ÿฌ 7427069034 Escort Service & Hotel ...Model VVIP Call Girls In Porur ๐Ÿ‘‰ Chennai ๐Ÿฌ 7427069034 Escort Service & Hotel ...
Model VVIP Call Girls In Porur ๐Ÿ‘‰ Chennai ๐Ÿฌ 7427069034 Escort Service & Hotel ...
ย 
Zirakpur Call Girls๐Ÿ‘ง Book Now๐Ÿ“ฑ8146719683 ๐Ÿ“ž๐Ÿ‘‰Mohali Call Girl Service No Advanc...
Zirakpur Call Girls๐Ÿ‘ง Book Now๐Ÿ“ฑ8146719683 ๐Ÿ“ž๐Ÿ‘‰Mohali Call Girl Service No Advanc...Zirakpur Call Girls๐Ÿ‘ง Book Now๐Ÿ“ฑ8146719683 ๐Ÿ“ž๐Ÿ‘‰Mohali Call Girl Service No Advanc...
Zirakpur Call Girls๐Ÿ‘ง Book Now๐Ÿ“ฑ8146719683 ๐Ÿ“ž๐Ÿ‘‰Mohali Call Girl Service No Advanc...
ย 
Call Girls Manjri Call Me 7737669865 Budget Friendly No Advance Booking
Call Girls Manjri Call Me 7737669865 Budget Friendly No Advance BookingCall Girls Manjri Call Me 7737669865 Budget Friendly No Advance Booking
Call Girls Manjri Call Me 7737669865 Budget Friendly No Advance Booking
ย 
VIP Model Call Girls Budhwar Peth ( Pune ) Call ON 8005736733 Starting From 5...
VIP Model Call Girls Budhwar Peth ( Pune ) Call ON 8005736733 Starting From 5...VIP Model Call Girls Budhwar Peth ( Pune ) Call ON 8005736733 Starting From 5...
VIP Model Call Girls Budhwar Peth ( Pune ) Call ON 8005736733 Starting From 5...
ย 
Call Girls Bhandara Just Call 8617697112 Top Class Call Girl Service Available
Call Girls Bhandara Just Call 8617697112 Top Class Call Girl Service AvailableCall Girls Bhandara Just Call 8617697112 Top Class Call Girl Service Available
Call Girls Bhandara Just Call 8617697112 Top Class Call Girl Service Available
ย 
๐Ÿ“ž Contact Number 8617697112 VIP East Sikkim Call Girls
๐Ÿ“ž Contact Number 8617697112 VIP East Sikkim Call Girls๐Ÿ“ž Contact Number 8617697112 VIP East Sikkim Call Girls
๐Ÿ“ž Contact Number 8617697112 VIP East Sikkim Call Girls
ย 
Mira Road | Call Girls Service Mumbai | โ‚น,9500 Pay Cash 9833325238 Free Home ...
Mira Road | Call Girls Service Mumbai | โ‚น,9500 Pay Cash 9833325238 Free Home ...Mira Road | Call Girls Service Mumbai | โ‚น,9500 Pay Cash 9833325238 Free Home ...
Mira Road | Call Girls Service Mumbai | โ‚น,9500 Pay Cash 9833325238 Free Home ...
ย 
Navi Mumbai Call Girls -๐Ÿ“ž9833754194-Call Girls Number Vashi-Nerul Call Girls ...
Navi Mumbai Call Girls -๐Ÿ“ž9833754194-Call Girls Number Vashi-Nerul Call Girls ...Navi Mumbai Call Girls -๐Ÿ“ž9833754194-Call Girls Number Vashi-Nerul Call Girls ...
Navi Mumbai Call Girls -๐Ÿ“ž9833754194-Call Girls Number Vashi-Nerul Call Girls ...
ย 
๐“€คCall On 6297143586 ๐“€ค Park Street Call Girls In All Kolkata 24/7 Provide Call...
๐“€คCall On 6297143586 ๐“€ค Park Street Call Girls In All Kolkata 24/7 Provide Call...๐“€คCall On 6297143586 ๐“€ค Park Street Call Girls In All Kolkata 24/7 Provide Call...
๐“€คCall On 6297143586 ๐“€ค Park Street Call Girls In All Kolkata 24/7 Provide Call...
ย 

Learn Agile Development Through Tetris

  • 1. Improving Agile Development Through Tetrisยฎ Mark Daggett Copyright ยฉ 2011 Mark Daggett. Some Rights Reserved Saturday, March 5, 2011
  • 2. Can learning Tetris improve the quality of your software development process? 2 Saturday, March 5, 2011
  • 3. You know Tetris Photo Credit: fraskedesigns.blogspot.com 3 Saturday, March 5, 2011
  • 4. Tetris is Crack for the OCD 4 Saturday, March 5, 2011
  • 5. Tetris Is Serious; Seriously Developed by Alexey Pajitnov to test arti๏ฌcial intelligence algorithms Can be used to measure conceptual skills of task analysis and resource management in players Can also measure a playerโ€™s visceral decision making process under pressure 5 Saturday, March 5, 2011
  • 6. Agile Development Reasoning Greater awareness of development costs [resource management] Tighter integration between developers and stakeholders [task analysis] Ability to quickly change course on projects [response to pressure] 6 Saturday, March 5, 2011
  • 7. 1. Donโ€™t Get Too Clever Tetris rewards players for clearing more than one row at a time. This creates a chain of serial dependencies that need to happen in the right order to succeed. Serial dependencies cost your project time and resources as you wait for the right piece to arrive. 9 7 Saturday, March 5, 2011
  • 8. 1. Donโ€™t Get Too Clever Serial dependencies can easily turn into a FAIL as other resources, such as time, run out. 10 8 Saturday, March 5, 2011
  • 9. 1. Donโ€™t Get Too Clever Your chances of success are greatly increased when you work towards solutions that can be completed in many different ways. 11 9 Saturday, March 5, 2011
  • 10. 2. Stay Low As your stack of uncleared rows increases, your time to make decisions decreases. This means you are more likely to make a poor decision in the future. The more time you give yourself the more likely your future steps will be well-reasoned In Tetris and in development cycles if you are forced to just react to impending deadlines you drastically reduce your ability to succeed. 10 Saturday, March 5, 2011
  • 11. 3. Maximize the Work You Are Not Doing Tetris pieces can be rotated clockwise and counterclockwise. Ef๏ฌciency is knowing the fastest direction to rotate the piece to ๏ฌt your stack. Rotating Left Desired Orientation Rotating Right 3x as long to rotate 13 11 Saturday, March 5, 2011
  • 12. 3. Maximize the Work You Are Not Doing Many agile teams take pride in the amount of automation they bring to their development process, through testing, deploying or documenting. Any process that can be done a faster way (without sacri๏ฌcing quality) should be. Developers need to know the strengths and weaknesses of their technology stack. 14 12 Saturday, March 5, 2011
  • 13. 4. Know Your Goal In Tetris it is easy to focus on your score, as a measurement for progress but thatโ€™s a red herring. Tetris by design is a game that doesnโ€™t end so you canโ€™t โ€œwinโ€. You donโ€™t win your application by deploying it - you just clear your stack 15 13 Saturday, March 5, 2011
  • 14. 5. Fix Mistakes NOW! A common problem in Tetris among players is to try to bury their mistakes Ignoring mistakes means players have less space remaining to work with, and therefore a higher likelihood of making similar mistakes in the future. Agile development focuses on refactoring code, getting rid of duplication, baroqueness and silos of code. A.B.R. (Always Be Refactoring) 16 14 Saturday, March 5, 2011
  • 15. 6. Fail Early And Often Tetris is to agile development as โ€œPITFALL!โ€ is to the Waterfall method. Ironic Name I Know 17 15 Saturday, March 5, 2011
  • 16. 6. Fail Early And Often START OVER HERE DIE HERE Level map of PITFALL! 16 Saturday, March 5, 2011
  • 17. 6. Fail Early And Often โ€œPitfall!โ€ requires you to start back at the beginning of the level each time you die. This is like the waterfall method, which reboots the development cycle for every requirement change. Tetris lets you fail quickly and let you restart where you left off. You can improve your technique and understanding of the game at any point of the play cycle. Agile development focuses on test driven development, and writing tests to fail ๏ฌrst. This ensures that you work directly on the feature in question and not any of the ancillary systems. 19 17 Saturday, March 5, 2011
  • 18. 7. Embrace Change In Tetris the player only knows which piece is coming next. Agile development says the developer should embrace change, be it shifting requirements, or deadlines. Just as the player is constantly scanning the game board the agile developer should be reevaluating previous design decisions looking for ways to refactor code and reduce complexity. 20 18 Saturday, March 5, 2011
  • 19. 8. Thereโ€™s an โ€œIโ€ in Tetris but not Team Tetris is a single player unless you are competing against another player. This is unlike programming, which at some fundamental level is a process of building off the work of others. The Tetris metaphor works only so far. The biggest factor in success or failure in an agile environment is how the team works together. 21 19 Saturday, March 5, 2011
  • 20. THANKS! Mark Daggett Application Architect Humansized Inc. @heavysixer mark@humansized.com http://www.humansized.com Tetris ยฎ is a registered trademark of The Tetris Company PITFALL! ยฎ is a registered trademark of Activision 22 20 Saturday, March 5, 2011