GQM and data analysis Example from a Norwegian company Tor Stålhane IDI / NTNU
The Problem The company in question develops hardware and software. They have two software groups, each with circa 15 developers. Part of the system is developed in SDL. In order to focus their V&V work better they needed to know which SDL module characteristics that caused errors. Possible candidates were number of module states, number of input signals etc.
What to measure? In order to get a consistent and efficient data collection and analysis, we started with a GQM process. A half-day basic course in GQM. A half-day workshop where they identified – the questions that needed answers. – which metrics they needed in order to answer these questions.
The Metrics Some of the metrics collected for each SDL module: Number of errors found. Subjective - perceived - complexity. Number of pages of SDL description. Number of SDL states Number of signals in Number of signals out
Qc – block complexity When we defined the Qc question, we decided to use a Kiviat diagram to display the metrics included in this question. We show the following data: Non-modified metrics. Just to show that it is not a good idea Normalized metrics values Mean metrics values for each complexity class
Non-modified metrics The large value of M6b reduces everything else to “noise”
Normalized metrics values – 1 M5 PMECDM52 PMECOM56 CAMCON32 HPOTBL21 TAMCON25 TAMTST10 TTRMOT6 TTRTST3 M5 PMECDM0,93 PMECOM1,00 CAMCON0,57 HPOTBL0,38 TAMCON0,45 TAMTST0,18 TTRMOT0,11 TTRTST0,05
Normalized metrics values – 2 High complexity Low complexity Be ware different scales on the axis in the two diagrams
Mean metrics values – 1 Be ware different scales on the axis in the three diagrams
Mean metrics values – 2
What makes it complex - 1 We went through all the hypothesis put forward by the developers during the GQM session. We will look at three of them: Number of states - M5 Number of signals out - M9 Number of pages in the SDL description - M10
What makes it complex - 2 The data for the three metrics M5, M9 and M10 were sorted according to the complexity scores (High, Medium and Low). An ANOVA analyses was then performed for each data set. We decided to require a p-value better than 10%
ANOVA results - 1 Number of states – M5: Source of VariationSS df MS P-value Between Group 1190, ,02 0,25 Within Groups 1631, ,37 Number of states does not contribute significantly to the complexity as perceived by the developers.
ANOVA results - 2 Number of signals out – M9: Source of VariationSS df MS P-value Between Group 2779, ,521 0,098 Within Groups 1813, ,77 Number of signals out contribute significantly to the complexity as perceived by the developers
ANOVA results - 3 Number of pages in the SDL description – M10: Source of VariationSS df MS P-value Between Groups 5586, ,02 0,04 Within Groups 2133, ,77 Number of pages in the SDL description contribute significantly to the complexity as perceived by the developers
Summary - 1 SDL module complexity as perceived by the developers depends on two factors: Number of signals out Number of pages in the SDL description The other suspected factors identified during the GQM process did not give a significant contribution.
What about Errors We now have some ideas on what makes a module look complex to the developers. The next step is to see if there is any connection between module complexity and the number of errors in the modules. The ANOVA can give us an answer.
Complexity and Errors - 1 Errors and complexity Source of Variation SS dfMS P-value Between Groups 1646, ,42 0,06 Within Groups 770, ,13 It is reasonable to assume that complex modules have more errors.
Complexity and Errors - 2 If we look at the ANOVA summary table, we see that the differences are quite large: GroupsCount Sum AverageVariance Column Column ,33 41,33 Column Due to few observations for each complexity level, the variances are large. Thus, we should not be too categorical in our conclusions.
Conclusions With all the necessary caveats in mind the company decided as follows: In order to reduce the number of errors we need to single out modules with : Large descriptions - more than 35 pages of SDL description. Many signals out - more than 30. The limiting values are the average values from the ANOVA summary tables.