Difference between revisions of "Planningsspel voor ontwikkelprojecten"
Line 1: | Line 1: | ||
Het {{pattern|planningsspel}} - plannen met kaartjes (versie voor klant en leverancier) | |||
Neem een set indexkaarten, de klant vertelt een wens in de vorm van een verhaaltje (in het engels: user story) ({{pattern|klant schrijft verhaaltje}}). De titel van dit verhaaltje komt bovenop de indexkaart te staan. In het midden van de indexkaart kan eventueel een zin met wat meer detail staan, of een tekening die beschrijft wat de klant wil (in het geval van software kan het een schets van een scherm of webpagina zijn). Acherop het kaartje kunnen eventueel {{pattern|acceptatietests}} of {{pattern|acceptatiecriteria}} geschreven worden. Als klanten en ontwikkelaars beter op elkaar ingespeeld zijn volstaat vaak de titel van het verhaaltje, in combinatie met het volgende: | |||
Een verhaaltje is een belofte voor verdere communicatie tijdens de uitvoering van het werk. Het is dus geen volledige specificatie van het werk dat gedaan moet worden. We gaan ervanuit dat het realiseren van een verhaaltje een spel van samenwerken en uitvinden is. Het is dus de bedoeling dat klant en leverancier {{pattern|samen werken}}, in plaats van tegen over elkaar gezet te worden (zoals met een {{pattern|programma van eisen}} nog wel eens wil gebeuren).Klanten en leverancier zijn {{pattern|gezamenlijk eigenaar}} van het resultaat – deze manier van werken is dus {{pattern|resultaat gericht}}. | |||
(je kunt het project zien als een tijdelijke {{pattern|cooperatie}} tussen klanten en ontwikkelaars) | |||
De {{pattern|ontwikkelaars adviseren de klant}}, maar nemen geen beslissingen. De {{pattern|klant bepaalt waarde}}. Adviseren gebeurt voornamelijk door vragen (bijvoorbeeld door de {{pattern|socratische methode}} toe te passen), soms door uit te leggen wat er mogelijk is – liever nog door {{pattern|laat zien wat kan}} (show, don't tell). Hier zit een spanningsveld tussen {{pattern|klantgericht werken}} en {{pattern|technologische innovatie}} – aan de ene kant wil je doen wat de klant wil, maar de klant weet niet altijd wat er mogelijk is (tegen welke kosten). Als het goed loopt, lost dit planningsproces het vanzelf op, omdat gaandeweg de klant een beter gevoel krijgt voor wat er mogelijk is, en de ontwikkelaars een beter gevoel krijgen voor wat de klant wil en wat de klant echt nodig heeft. | |||
Als de klant een aantal verhaaltjes heeft vertelt, en de titels op kaartjes heeft geschreven, is het tijd voor {{pattern|ontwikkelaars bepalen complexiteit}}. De gedachte achter deze stap is dat plannen eenvoudiger is in termen van relatieve complexiteit of moeilijkheid. De eenvoudigste manier om dit te doen is de {{pattern|verhalen}} op volgorde van moeite te leggen. Het eenvoudigste verhaal gaat bovenaan, en zo verder naar beneden. {{pattern|verhalen}} die even complex zijn kunnen naast elkaar gelegd worden. | |||
Nadat {{pattern|verhalen in volgorde van complexiteit}} zijn gelegd, kunnen er {{pattern|gummiberen}} op geschreven worden. {{pattern|gummiberen}} zijn een aantal 'punten' voor {{pattern|verhalen}}. Een verhaal met een lager aantal {{pattern|gummiberen}} is eenvoudiger dan een verhaal met een groter aantal {{pattern|gummiberen}}. | |||
Hoeveel {{pattern|gummiberen}} schrijf je op een verhaal? Er zit hier een verschil tussen de eerste keer dat je het {{pattern|planningsspel}} speelt en latere keren – de eerste keer moet je vanaf niets bepalen hoe veel {{pattern|gummiberen}} te geven aan een verhaal. Een eenvoudige manier om dit te doen is de eenvoudigste story 20 punten te geven, en daarna met 30,40 etc. verder te nummeren. | |||
De tweede en volgende keren kun je kijken naar {{pattern|verhalen van de vorige ronde}} en {{pattern|relatieve complexiteit}} bepalen door verhalen van deze {{pattern|ronde}} te leggen naast die van de vorige. | |||
Na {{pattern|ontwikkelaars bepalen complexiteit}} is het tijd voor {{pattern|klant bepaalt waarde}}. Hiervoor doen de klanten voor waarde hetzelfde als de ontwikkelaars voor complexiteit – kaartjes op volgorde leggen. In dit geval komen de meest waardevolle {{pattern|verhalen}} bovenaan. | |||
Ook hier is het mogelijk om soortgelijk als aan {{pattern|gummiberen}} punten op de kaartjes te schrijven, in dit geval {{pattern|waardepunten}} geheten. Heel soms is het mogelijk voor klanten om waarde in {{pattern|euros}} op te geven. Meest voorkomend is de {{pattern|verhalen}} in volgorde {{pattern|aan de muur hangen}}, of bij voorbeeld in een {{pattern|wiki}} of een {{pattern|online verhalenverzamelbak}} te zetten. | |||
Na deze stap geven de ontwikkelaars een schatting over hoeveel {{pattern|verhalen}} ze in de komende {{pattern|ronde}} kunnen doen. Voor de eerste {{pattern|ronde}} is dit een gokje, voor volgende {{pattern|ronde}}s kan de {{pattern|snelheid}} van de vorige {{pattern|ronde}} gebruikt worden. {{pattern|snelheid}} is eenvoudigweg het aantal {{pattern|gummiberen}} per {{pattern|ronde}}. | |||
De lijst van verhalen, op volgorde van waarde gelegd noemen we een {{pattern|restpuntenlijst}}. | |||
context | |||
Zie {{pattern| | Zie {{pattern|gummiberen}} voor een alternatieve manier om nummering te bepalen (fibonacci reeksen). |
Revision as of 13:34, 29 November 2006
Het planningsspel - plannen met kaartjes (versie voor klant en leverancier)
Neem een set indexkaarten, de klant vertelt een wens in de vorm van een verhaaltje (in het engels: user story) (klant schrijft verhaaltje). De titel van dit verhaaltje komt bovenop de indexkaart te staan. In het midden van de indexkaart kan eventueel een zin met wat meer detail staan, of een tekening die beschrijft wat de klant wil (in het geval van software kan het een schets van een scherm of webpagina zijn). Acherop het kaartje kunnen eventueel acceptatietests of acceptatiecriteria geschreven worden. Als klanten en ontwikkelaars beter op elkaar ingespeeld zijn volstaat vaak de titel van het verhaaltje, in combinatie met het volgende:
Een verhaaltje is een belofte voor verdere communicatie tijdens de uitvoering van het werk. Het is dus geen volledige specificatie van het werk dat gedaan moet worden. We gaan ervanuit dat het realiseren van een verhaaltje een spel van samenwerken en uitvinden is. Het is dus de bedoeling dat klant en leverancier samen werken, in plaats van tegen over elkaar gezet te worden (zoals met een programma van eisen nog wel eens wil gebeuren).Klanten en leverancier zijn gezamenlijk eigenaar van het resultaat – deze manier van werken is dus resultaat gericht.
(je kunt het project zien als een tijdelijke cooperatie tussen klanten en ontwikkelaars) De ontwikkelaars adviseren de klant, maar nemen geen beslissingen. De klant bepaalt waarde. Adviseren gebeurt voornamelijk door vragen (bijvoorbeeld door de socratische methode toe te passen), soms door uit te leggen wat er mogelijk is – liever nog door laat zien wat kan (show, don't tell). Hier zit een spanningsveld tussen klantgericht werken en technologische innovatie – aan de ene kant wil je doen wat de klant wil, maar de klant weet niet altijd wat er mogelijk is (tegen welke kosten). Als het goed loopt, lost dit planningsproces het vanzelf op, omdat gaandeweg de klant een beter gevoel krijgt voor wat er mogelijk is, en de ontwikkelaars een beter gevoel krijgen voor wat de klant wil en wat de klant echt nodig heeft.
Als de klant een aantal verhaaltjes heeft vertelt, en de titels op kaartjes heeft geschreven, is het tijd voor ontwikkelaars bepalen complexiteit. De gedachte achter deze stap is dat plannen eenvoudiger is in termen van relatieve complexiteit of moeilijkheid. De eenvoudigste manier om dit te doen is de verhalen op volgorde van moeite te leggen. Het eenvoudigste verhaal gaat bovenaan, en zo verder naar beneden. verhalen die even complex zijn kunnen naast elkaar gelegd worden.
Nadat verhalen in volgorde van complexiteit zijn gelegd, kunnen er gummiberen op geschreven worden. gummiberen zijn een aantal 'punten' voor verhalen. Een verhaal met een lager aantal gummiberen is eenvoudiger dan een verhaal met een groter aantal gummiberen.
Hoeveel gummiberen schrijf je op een verhaal? Er zit hier een verschil tussen de eerste keer dat je het planningsspel speelt en latere keren – de eerste keer moet je vanaf niets bepalen hoe veel gummiberen te geven aan een verhaal. Een eenvoudige manier om dit te doen is de eenvoudigste story 20 punten te geven, en daarna met 30,40 etc. verder te nummeren.
De tweede en volgende keren kun je kijken naar verhalen van de vorige ronde en relatieve complexiteit bepalen door verhalen van deze ronde te leggen naast die van de vorige.
Na ontwikkelaars bepalen complexiteit is het tijd voor klant bepaalt waarde. Hiervoor doen de klanten voor waarde hetzelfde als de ontwikkelaars voor complexiteit – kaartjes op volgorde leggen. In dit geval komen de meest waardevolle verhalen bovenaan.
Ook hier is het mogelijk om soortgelijk als aan gummiberen punten op de kaartjes te schrijven, in dit geval waardepunten geheten. Heel soms is het mogelijk voor klanten om waarde in euros op te geven. Meest voorkomend is de verhalen in volgorde aan de muur hangen, of bij voorbeeld in een wiki of een online verhalenverzamelbak te zetten.
Na deze stap geven de ontwikkelaars een schatting over hoeveel verhalen ze in de komende ronde kunnen doen. Voor de eerste ronde is dit een gokje, voor volgende rondes kan de snelheid van de vorige ronde gebruikt worden. snelheid is eenvoudigweg het aantal gummiberen per ronde.
De lijst van verhalen, op volgorde van waarde gelegd noemen we een restpuntenlijst.
context
Zie gummiberen voor een alternatieve manier om nummering te bepalen (fibonacci reeksen).