Calculating Mean Time to Defect
MTTD is Mean Time to Defect. Basically, it means the average time between defects (mean is the statistical term for average). A related term is MTTF, or Mean Time to Failure. It is usually meant as the average time between encountering a defect serious enough to cause the system to fail.
Is MTTD hard to compute? Does it require difficult metrics collection? Some people I have spoken to think so. Some texts think so, too. For example:
Gathering data about time between failures is very expensive. It requires recording the occurrence time of each software failure. It is sometimes quite difficult to record the time for all the failures observed during testing or operation. To be useful, time between failures data also requires a high degree of accuracy. This is perhaps the reason the MTTF metric is not widely used by commercial developers.
But this is not really true. The MTTD or MTTF can be computed from basic defect metrics. All you need is:
- the total number of defects or failures and
- the total number of months, weeks, days, or hours during which the system was running or being tested and metrics were recorded. You do not need the exact time of each defect.
Here is an example. I will compute MTTD and MTTF two ways to demonstrate that the results are identical. This table contains defect metrics for first three days of operation of a system that runs 24 hours a day, five days a week: