tag 标签: defects

相关博文
  • 热度 26
    2015-8-14 19:51
    1477 次阅读|
    1 个评论
    Capers Jones is one of the most prolific software researchers around. He has a vast collection of metrics from many thousands of real-world projects. His book The Economics of Software Quality is rather dry but full of fun facts. He’s careful to point out that the data has huge standard deviations, but it does paint some interesting pictures about the nature of software engineering.   Chapter 2 is called “Estimating and Measuring Software Quality.” Though all of the numbers are interesting those for requirements are especially so.   Mr. Jones is adamant that we shouldn’t use lines of code (LOC, or KLOC for thousands of lines of code) as a metric. He prefers function points. While it’s hard to dispute his arguments in favor of function points, few practicing developers understand them, which makes the metric a barrier to communication. Most sources figure one function point is around 100-120 lines of C code, so here I’ve converted his numbers to C code using 100 LOC = 1 function point.   Let’s look at his numbers for the size of requirements. For an application of 10 KLOC developers typically get 115 pages of requirements, which are 95% complete. That’s roughly a page per 100 LOC, or something like one line per two LOC. Of course, some percentage of those requirements would be graphical, but his numbers suggest that 75% of requirements are text. Does that mirror your experience? That’s a lot of text for a couple of lines of code.   But it gets worse as applications grow in size. At 100 KLOC figure on 750 pages of requirements, which will only be 80% complete. At 1 million lines of code there will be 6,000 pages of, probably dreary, conflicting, and poorly-specified requirements, comprising just 60% of what is expected to be delivered. In other words, those 6K pages specify just about half of the desired functionality. No wonder big systems are delivered so late. Mr. Jones makes the scary point that at 5 million LOC it would be impossible for a single person to read the requirements in one lifetime!   Small systems don’t experience much requirements churn; for projects of 10 KLOC figure on 1% growth/month, or about 225 LOC change over the duration of the project. At 1 million LOC that bumps to 1.25% growth/month resulting in an extra almost 300 KLOC.   What about requirements defects? A 10 KLOC system will have 75 of those, of which 8 are typically delivered to the customer. At 1 million LOC that jumps to over 10,000 of those kinds of defects, 2000 of which will wind up in the user’s hands.   Now, these numbers are for all sorts of software projects. He points out that embedded projects experience only 20% of the defects of the numbers he presents. That’s still 400 delivered requirements defects for a big project. Of course, there will be plenty of other bugs in the final project from other phases of development, but those numbers are fodder for a different column.   One of the rationales for agile methods is, as Kent Beck puts it, everything changes all of the time. One can’t know, it’s reasoned, what the customer wants so it makes sense to deliver early and incrementally. I’ve always agreed with the conclusion, but not necessarily with the thesis. Though there are exceptions, in my experience most embedded projects can get a decent, if imperfect, set of requirements early in the project. Admittedly, it can be hard to elicit them, but “hard” is no excuse for abdicating our responsibility to work diligently to clarify our goals.   Given that firmware has only 20% of the requirements defects experienced by other sorts of software, two things jump out. First, we’re doing a heck of a job! Second, the notion of using agile to elicit requirements probably doesn’t make sense in this space (though implementation may benefit from agile ideas). Traditional approaches seem to be working pretty well, and to determine requirements in an agile, incremental, manner demands an awful lot of customer participation. eXtreme Programming practitioners require an on-site customer; in recent years some have suggested than an entire customer team be co-located with the developers to wring out desired product functionality. That’s unrealistic for many projects.   As regular readers know I think careful engineering requires the use of metrics to understand both what we’re building, as well as how we’re building it. Do you track anything about requirements, like size, churn or defects?
  • 热度 10
    2011-7-6 00:09
    1532 次阅读|
    0 个评论
    Based a story on Internet.com's eCRM Guide , a content management system called Drupal has previously had serious delivery delays due to bug infestations. Developers then promise that there will never be more than 15 critical bugs at a time for the latest version. This is so they can " do timely releases because we know at most the release is only 15 critical bugs away from being ready ." Capers Jones studied 4000 late software projects and discovered that bugs are the biggest cause of late deliveries. For this and other reasons, I advocate – in general—getting rid of the bug list. Don't accumulate defects; fix them when they appear. No one knows how long it'll take to fix a problem, so a substantial bug list means there is no schedule. We've known for a generation that bugs are schedule-killers, so I find it interesting that the Drupal developers had to discover this fact through the agony of failure, rather than from research, book learning, or the wisdom passed down through mentors. Though I congratulate them on learning from their own mistakes, the process reminds me of raising teenagers. The most frustrating part of guiding young 'uns through those tough years is that they are utterly unable to learn anything from someone else's experience (unless it's an incorrect lesson garnered from an equally-misinformed friend). Eventually, though, they do grow up and realize that the old fogies do know a thing or two. As Mark Twain said, " When I was a boy of fourteen, my father was so ignorant I could hardly stand to have the old man around. But when I got to be twenty-one, I was astonished by how much he'd learned in seven years. " Maybe we software people are teenagers! Is it even worse than that? I find very few firmware groups make any effort to systematically learn from even their own experiences. The retrospective (AKA postmortem) is well-developed and widely taught, but rarely practiced. The idea is to take a little time at the end of a project and try to understand what went wrong, and then invent solutions. One would think that we engineers, who love problem solving, would find this a natural and compelling thing to do. But we don't. Most groups don't even make much of an attempt to codify knowledge, say via the disciplined use of a wiki. Since we were late, the next project is already behind schedule, so there's no time to think about ways to improve. We're bailing as the boat sinks, instead of plugging the leak. She's going down, folks—it's just a matter of when.
相关资源
  • 所需E币: 5
    时间: 2019-12-24 22:11
    大小: 104.55KB
    上传者: 238112554_qq
    Abstract:TheStatisticalProcessControlCalculator(SPCC)aidsinthepredictionandanalysisofprocessyield.ThecalculatorcanbeusedwithanHP®50gcalculatororafreePCemulator.Maxim>DesignSupport>AppNotes>A/DandD/AConversion/SamplingCircuits>APP5063Maxim>DesignSupport>AppNotes>AutomaticTestEquipment(ATE)>APP5063Maxim>DesignSupport>AppNotes>DigitalPotentiometers>APP5063Keywords:statisticalprocesscontrol,yielddefects,Gaussiandistribution,SixSigma,predictionyieldanalysis,defectopportunitypermillion,DOPM,normaldistributioncurve,SPCC,SPCAug18,2011APPLICATIONNOTE5063StatisticalProcessControlCalculatorTutorialBy:BillLaumeister,StrategicApplicationsEngineerAbstract:TheStatisticalProcessControlCalculator(SPCC)aidsinthepredictionandanalysisofprocessyi……
  • 所需E币: 4
    时间: 2019-12-24 17:09
    大小: 104.55KB
    上传者: 978461154_qq
    摘要:统计过程控制计算器(斯佩克)艾滋病的过程中产量的预测和分析。惠普®50G计算器或免费的PC模拟器可以使用计算器。Maxim>DesignSupport>AppNotes>A/DandD/AConversion/SamplingCircuits>APP5063Maxim>DesignSupport>AppNotes>AutomaticTestEquipment(ATE)>APP5063Maxim>DesignSupport>AppNotes>DigitalPotentiometers>APP5063Keywords:statisticalprocesscontrol,yielddefects,Gaussiandistribution,SixSigma,predictionyieldanalysis,defectopportunitypermillion,DOPM,normaldistributioncurve,SPCC,SPCAug18,2011APPLICATIONNOTE5063StatisticalProcessControlCalculatorTutorialBy:BillLaumeister,StrategicApplicationsEngineerAbstract:TheStatisticalProcessControlCalculator(SPCC)aidsinthepredictionandanalysisofprocessyi……