The cleanroom software engineering process is a software development process intended to produce software with a certifiable level of reliability. The central principles are software development based on formal methods, incremental implementation under statistical quality control, and statistically sound testing.

History

edit

The cleanroom process was originally developed by Harlan Mills and several of his colleagues including Alan Hevner at IBM.[1]

The cleanroom process first saw use in the mid to late 1980s. Demonstration projects within the military began in the early 1990s.[2] Recent work on the cleanroom process has examined fusing cleanroom with the automated verification capabilities provided by specifications expressed in CSP.[3]

Philosophy

edit

The focus of the cleanroom process is on defect prevention rather than defect removal. The name "cleanroom" was chosen to evoke the cleanrooms used in the electronics industry to prevent the introduction of defects during the fabrication of semiconductors.

Central principles

edit

The basic principles of the cleanroom process are

Software development based on formal methods
Software tool support based on some mathematical formalism includes model checking, process algebras, and Petri nets. The Box Structure Method might be one such means of specifying and designing a software product.[4] Verification that the design correctly implements the specification is performed through team review, often with software tool support.
Incremental implementation under statistical quality control
Cleanroom development uses an iterative approach, in which the product is developed in increments that gradually increase the implemented functionality. The quality of each increment is measured against pre-established standards to verify that the development process is proceeding acceptably. A failure to meet quality standards results in the cessation of testing for the current increment and a return to the design phase.
Statistically sound testing
Software testing in the cleanroom process is carried out as a statistical experiment. Based on the formal specification, a representative subset of software input/output trajectories is selected and tested. This sample is then statistically analyzed to produce an estimate of the reliability of the software and a level of confidence in that estimate.

References

edit
  1. ^ Mills, H.; M. Dyer; R. Linger (September 1987). "Cleanroom Software Engineering" (PDF). IEEE Software. 4 (5): 19–25. Bibcode:1987ISoft...4e..19M. doi:10.1109/MS.1987.231413. S2CID 383170.
  2. ^ Foreman, John (2005). "Cleanroom Software Engineering Reference". Software Technology Roadmap. Software Engineering Institute (SEI). Retrieved 2006-04-27.
  3. ^ Broadfoot, Guy H.; Hopcroft, P. J. (2005). "Introducing formal methods into industry using Cleanroom and CSP". Dedicated Systems e-Magazine. S2CID 14066854.
  4. ^ Linger, R. (April 1994). "Cleanroom Process Model". IEEE Software. 11 (2): 50–58. Bibcode:1994ISoft..11b..50L. CiteSeerX 10.1.1.130.8642. doi:10.1109/52.268956. S2CID 206447346.

Further reading

edit
  • Stavely, Allan (1999). Toward Zero-Defect Programming. Addison-Wesley.
  • Prowell, Stacy J.; Trammell, Carmen; Linger, Richard C.; Poore, Jesse H. (1999). Cleanroom Software Engineering: Technology and Process. Addison-Wesley.
  • Poore, Jesse H.; Trammell, Carmen J. (1996). Cleanroom Software Engineering: A Reader. NCC Blackwell.
edit

📚 Artikel Terkait di Wikipedia

Clean room (disambiguation)

standards for operating in a cleanroom Cleanroom software engineering, software development process intended to produce software with a certifiable level

Glossary of computer science

cleanroom software engineering A software development process intended to produce software with a certifiable level of reliability. The cleanroom process

Software testing

Software testing is the act of checking whether software meets its intended objectives and satisfies expectations. Software testing can provide objective

Software architecture

into software architecture knowledge management. There is no sharp distinction between software architecture versus design and requirements engineering (see

Outline of software development

Uninstaller Product retirement Software maintenance Aspect-oriented software development Cleanroom Software Engineering Iterative and incremental development

Software engineering

Software engineering is a branch of both computer science and engineering focused on designing, developing, testing, and maintaining software applications

Outline of software engineering

outline is provided as an overview of and topical guide to software engineering: Software engineering – application of a systematic, disciplined, quantifiable

Software development process

of software engineering Program lifecycle phase Software development effort estimation Software documentation Software project management Software release