150 likes | 180 Views
GQM – an example from Fjellanger - Widerøe. Hans J. Lied Tor Stålhane IDI / NTNU. Environment. Medium sized company making tailor-made software systems Fixed price projects with little room for rework caused by introduction of errors
E N D
GQM – an example from Fjellanger - Widerøe Hans J. Lied Tor Stålhane IDI / NTNU
Environment • Medium sized company making tailor-made software systems • Fixed price projects with little room for rework caused by introduction of errors • Two development projects, same project team and process model. • Project 1: standard with a given requirements specification • Project 2: prototyping without requirements specification
The projects • Project 1 had • structure given from the start • customer-defined quality assurance requirements • requirements specification from the customer • Project 2 • depended on prototyping. • started with an idea from the customer • the requirements specification was a co-production between customer and developers.
Methods We used a combination of three methods: • GQM, to decide what and how to measure • Pareto with a robustness analysis, to analyse and assess collected data • RCA: brainstorming and Ishikawa diagrams to identify root causes
GQM method – 1 GQM abstraction sheet without the lower part
GQM method – 2 The GQM abstraction sheet was used to: • manage and structure the brainstorming sessions • identify problem areas for the RCA • benefit from its focus on developer participation to get a set of basic root causes to analyse
GQM method – 3 The GQM method helps us to obtain: • reliable data. The developers are more interested in obtaining correct data if they feel that they have ownership to the goal and purpose of the data collection • more interest in the results. Involving the developers from day one => • create interest • keep the improvement program alive.
GQM - process • Two hour workshop to introduce the method • Establishing the GQM goal: • Analyse the reported failures in order to understand causes for failures seen from the developers in the X project. • Produced a GQM abstraction sheet, which was converted to a data collection form
Pareto – 1 • The 20/80 distribution, known as Pareto’s Law, is applicable in software development • Pareto diagrams used to visualise the main problem areas • We used Pareto analysis on our data to identify main areas of improvement
Pareto – 2 Pareto identified the following main problem areas: • Project1 – standard project: • Incorrect use of language features (3) • Incorrect use of library components (4) • Wrong code logic (14) • Project2 – prototyping : • Incomplete or insufficiently detailed req. spec. (13) • Errors in HW-SW communication (15) • Wrong code logic (14)
RCA - Brainstorm We presented the development team with the results from the Pareto analysis and introduced them to RCA. We made an Ishikawa diagram, using the categoriesfrom the data collection form as a starting point. The strong point of a brain-storming sessionis that it maximises the use of available knowledge
RCA - Results Improvement actions identified from this session: • The need for sharing competence internally • Checklist on Intranet • Common routines/solutions for standard tasks (best practice experience) • Common dynamic document templates • Start the planning, design and development of an experience database
Conclusions • Measurements gave knowledge of how things really are in the company • Common understanding of what we learned from this knowledge • Explicit shared knowledge about the process that the company can reuse