fbpx
Wikipedia

Waterfall model

The waterfall model is a breakdown of development activities into linear sequential phases, meaning they are passed down onto each other, where each phase depends on the deliverables of the previous one and corresponds to a specialization of tasks.[1] The approach is typical for certain areas of engineering design. In software development,[1] it tends to be among the less iterative and flexible approaches, as progress flows in largely one direction ("downwards" like a waterfall) through the phases of conception, initiation, analysis, design, construction, testing, deployment and maintenance.[2][better source needed] The waterfall model is the earliest SDLC approach that was used in software development.[citation needed]

The waterfall development model originated in the manufacturing and construction industries,[citation needed] where the highly structured physical environments meant that design changes became prohibitively expensive much sooner in the development process.[citation needed] When first adopted for software development, there were no recognized alternatives for knowledge-based creative work.[3][better source needed]

History edit

The first known presentation describing use of such phases in software engineering was held by Herbert D. Benington at the Symposium on Advanced Programming Methods for Digital Computers on 29 June 1956.[4] This presentation was about the development of software for SAGE. In 1983 the paper was republished with a foreword by Benington explaining that the phases were on purpose organized according to the specialization of tasks, and pointing out that the process was not in fact performed in a strict top-down fashion, but depended on a prototype.[3]

Although the term "waterfall" is not used in the paper, the first formal detailed diagram of the process later known as the "waterfall model" is often[citation needed] cited as a 1970 article by Winston W. Royce.[5][6][7] However he also felt it had major flaws stemming from the fact that testing only happened at the end of the process, which he described as being "risky and invites failure".[5] The rest of his paper introduced five steps which he felt were necessary to "eliminate most of the development risks" associated with the unaltered waterfall approach.[5]

Royce's five additional steps (which included writing complete documentation at various stages of development) never took mainstream hold, but his diagram of what he considered a flawed process became the starting point when describing a "waterfall" approach.[8][better source needed]

The earliest use of the term "waterfall" may have been in a 1976 paper by Bell and Thayer.[9][better source needed]

In 1985, the United States Department of Defense captured this approach in DOD-STD-2167A[citation needed], their standards for working with software development contractors, which stated that "the contractor shall implement a software development cycle that includes the following six phases: Software Requirement Analysis, Preliminary Design, Detailed Design, Coding and Unit Testing, Integration, and Testing".[10]

Model edit

Although Royce never recommended nor described a waterfall model[citation needed], rigid adherence to the following phases are criticized by him:

  1. System and software requirements: captured in a product requirements document
  2. Analysis: resulting in models, schema, and business rules
  3. Design: resulting in the software architecture
  4. Coding: the development, proving, and integration of software
  5. Testing: the systematic discovery and debugging of defects
  6. Operations: the installation, migration, support, and maintenance of complete systems

Thus the waterfall model maintains that one should move to a phase only when its preceding phase is reviewed and verified.

Various modified waterfall models (including Royce's final model), however, can include slight or major variations on this process.[5] These variations included returning to the previous cycle after flaws were found downstream, or returning all the way to the design phase if downstream phases deemed insufficient.

Supporting arguments edit

Time spent early in the software production cycle can reduce costs at later stages. For example, a problem found in the early stages (such as requirements specification) is cheaper to fix than the same bug found later on in the process (by a factor of 50 to 200).[11]

In common practice, waterfall methodologies result in a project schedule with 20–40% of the time invested for the first two phases, 30–40% of the time to coding, and the rest dedicated to testing and implementation. The actual project organization needs to be highly structured. Most medium and large projects will include a detailed set of procedures and controls, which regulate every process on the project.[12][failed verification]

A further argument for the waterfall model is that it places emphasis on documentation (such as requirements documents and design documents) as well as source code.[citation needed] In less thoroughly designed and documented methodologies, knowledge is lost if team members leave before the project is completed, and it may be difficult for a project to recover from the loss. If a fully working design document is present (as is the intent of Big Design Up Front and the waterfall model), new team members or even entirely new teams should be able to familiarise themselves by reading the documents.[13]

The waterfall model provides a structured approach; the model itself progresses linearly through discrete, easily understandable and explainable phases and thus is easy to understand; it also provides easily identifiable milestones in the development process. It is perhaps for this reason that the waterfall model is used as a beginning example of a development model in many software engineering texts and courses.[14]

Simulation can play a valuable role within the waterfall model. By creating computerized or mathematical simulations of the system being developed, teams can gain insights into how the system will perform before proceeding to the next phase. Simulations allow for testing and refining the design, identifying potential issues or bottlenecks, and making informed decisions about the system's functionality and performance.

Criticism edit

Clients may not know exactly what their requirements are before they see working software and so change their requirements, leading to redesign, redevelopment, and retesting, and increased costs.[15]

Designers may not be aware of future difficulties when designing a new software product or feature, in which case it is better to revise the design than persist in a design that does not account for any newly discovered constraints, requirements, or problems.[16]

Organisations may attempt to deal with a lack of concrete requirements from clients by employing systems analysts to examine existing manual systems and analyse what they do and how they might be replaced. However, in practice, it is difficult to sustain a strict separation between systems analysis and programming.[17] This is because implementing any non-trivial system will almost inevitably expose issues and edge cases that the systems analyst did not consider.

In response to the perceived problems with the pure waterfall model, modified waterfall models were introduced, such as "Sashimi (Waterfall with Overlapping Phases), Waterfall with Subprojects, and Waterfall with Risk Reduction".[11]

Some organisations, such as the United States Department of Defense, now have a stated preference against waterfall-type methodologies, starting with MIL-STD-498 released in 1994, which encourages evolutionary acquisition and Iterative and Incremental Development.[18]

Modified waterfall models edit

In response to the perceived problems with the "pure" waterfall model, many 'modified waterfall models' have been introduced. These models may address some or all of the criticisms of the "pure" waterfall model.

These include the Rapid Development models that Steve McConnell calls "modified waterfalls":[11] Peter DeGrace's "sashimi model" (waterfall with overlapping phases), waterfall with subprojects, and waterfall with risk reduction. Other software development model combinations such as "incremental waterfall model" also exist.[19]

Royce's final model edit

 
Royce final model

Winston W. Royce's final model, his intended improvement upon his initial "waterfall model", illustrated that feedback could (should, and often would) lead from code testing to design (as testing of code uncovered flaws in the design) and from design back to requirements specification (as design problems may necessitate the removal of conflicting or otherwise unsatisfiable/undesignable requirements). In the same paper Royce also advocated large quantities of documentation, doing the job "twice if possible" (a sentiment similar to that of Fred Brooks, famous for writing the Mythical Man Month, an influential book in software project management, who advocated planning to "throw one away"), and involving the customer as much as possible (a sentiment similar to that of extreme programming).

Royce notes on the final model are:

  1. Complete program design before analysis and coding begins
  2. Documentation must be current and complete
  3. Do the job twice if possible
  4. Testing must be planned, controlled, and monitored
  5. Involve the customer

See also edit

References edit

  1. ^ a b Petersen, Kai; Wohlin, Claes; Baca, Dejan (2009). "The Waterfall Model in Large-Scale Development". In Bomarius, Frank; Oivo, Markku; Jaring, Päivi; Abrahamsson, Pekka (eds.). Product-Focused Software Process Improvement. Lecture Notes in Business Information Processing. Vol. 32. Berlin, Heidelberg: Springer. pp. 386–400. Bibcode:2009pfsp.book..386P. doi:10.1007/978-3-642-02152-7_29. ISBN 978-3-642-02152-7.
  2. ^ "The Traditional Waterfall Approach". www.umsl.edu. Retrieved 2022-02-23.
  3. ^ a b Benington, Herbert D. (1 October 1983). "Production of Large Computer Programs" (PDF). IEEE Annals of the History of Computing. IEEE Educational Activities Department. 5 (4): 350–361. doi:10.1109/MAHC.1983.10102. S2CID 8632276. Retrieved 2011-03-21. July 18, 2011, at the Wayback Machine
  4. ^ United States, Navy Mathematical Computing Advisory Panel (29 June 1956), Symposium on advanced programming methods for digital computers, [Washington, D.C.]: Office of Naval Research, Dept. of the Navy, OCLC 10794738
  5. ^ a b c d Royce, Winston (1970), "Managing the Development of Large Software Systems" (PDF), Proceedings of IEEE WESCON, 26 (August): 1–9
  6. ^ "Waterfall". Bremen University - Mathematics and Computer Science.
  7. ^ Abbas, Noura; Gravell, Andrew M.; Wills, Gary B. (2008). "Historical Roots of Agile Methods: Where Did "Agile Thinking" Come From?". In Abrahamsson, Pekka; Baskerville, Richard; Conboy, Kieran; Fitzgerald, Brian; Morgan, Lorraine; Wang, Xiaofeng (eds.). Agile Processes in Software Engineering and Extreme Programming. Lecture Notes in Business Information Processing. Vol. 9. Berlin, Heidelberg: Springer. pp. 94–103. doi:10.1007/978-3-540-68255-4_10. ISBN 978-3-540-68255-4.
  8. ^ Conrad Weisert, Waterfall methodology: there's no such thing!
  9. ^ Bell, Thomas E., and T. A. Thayer. Software requirements: Are they really a problem? Proceedings of the 2nd international conference on Software engineering. IEEE Computer Society Press, 1976.
  10. ^ "Military Standard Defense System Software Development" (PDF).
  11. ^ a b c McConnell, Steve (1996). Rapid Development: Taming Wild Software Schedules. Microsoft Press. ISBN 1-55615-900-5.
  12. ^ "Waterfall Software Development Model". 5 February 2014. Retrieved 11 August 2014.
  13. ^ Arcisphere technologies (2012). "Tutorial: The Software Development Life Cycle (SDLC)" (PDF). Retrieved 2012-11-13.
  14. ^ Hughey, Douglas (2009). "Comparing Traditional Systems Analysis and Design with Agile Methodologies". University of Missouri – St. Louis. Retrieved 11 August 2014.
  15. ^ Parnas, David L.; Clements, Paul C. (1986). "A rational design process: How and why to fake it" (PDF). IEEE Transactions on Software Engineering (2): 251–257. doi:10.1109/TSE.1986.6312940. S2CID 5838439. Retrieved 2011-03-21.
  16. ^ McConnell, Steve (2004). Code Complete, 2nd edition. Microsoft Press. ISBN 1-55615-484-4.
  17. ^ Ensmenger, Nathan (2010). The Computer Boys Take Over. MIT Press. p. 42. ISBN 978-0-262-05093-7.
  18. ^ Larman, Craig; Basili, Victir (2003). "Iterative and Incremental Development: A Brief History". IEEE Computer (June ed.). 36 (6): 47–56. doi:10.1109/MC.2003.1204375. S2CID 9240477.
  19. ^ "Methodology:design methods".

External links edit

  • Understanding the pros and cons of the Waterfall Model of software development
  • Project lifecycle models: how they differ and when to use them
  • Going Over the Waterfall with the RUP by Philippe Kruchten
  • CSC and IBM Rational join to deliver C-RUP and support rapid business change
  • c2:WaterFall
  • [1]

waterfall, model, this, article, needs, updated, please, help, update, this, article, reflect, recent, events, newly, available, information, october, 2021, waterfall, model, breakdown, development, activities, into, linear, sequential, phases, meaning, they, . This article needs to be updated Please help update this article to reflect recent events or newly available information October 2021 The waterfall model is a breakdown of development activities into linear sequential phases meaning they are passed down onto each other where each phase depends on the deliverables of the previous one and corresponds to a specialization of tasks 1 The approach is typical for certain areas of engineering design In software development 1 it tends to be among the less iterative and flexible approaches as progress flows in largely one direction downwards like a waterfall through the phases of conception initiation analysis design construction testing deployment and maintenance 2 better source needed The waterfall model is the earliest SDLC approach that was used in software development citation needed The waterfall development model originated in the manufacturing and construction industries citation needed where the highly structured physical environments meant that design changes became prohibitively expensive much sooner in the development process citation needed When first adopted for software development there were no recognized alternatives for knowledge based creative work 3 better source needed Contents 1 History 2 Model 3 Supporting arguments 4 Criticism 5 Modified waterfall models 6 Royce s final model 7 See also 8 References 9 External linksHistory editThe first known presentation describing use of such phases in software engineering was held by Herbert D Benington at the Symposium on Advanced Programming Methods for Digital Computers on 29 June 1956 4 This presentation was about the development of software for SAGE In 1983 the paper was republished with a foreword by Benington explaining that the phases were on purpose organized according to the specialization of tasks and pointing out that the process was not in fact performed in a strict top down fashion but depended on a prototype 3 Although the term waterfall is not used in the paper the first formal detailed diagram of the process later known as the waterfall model is often citation needed cited as a 1970 article by Winston W Royce 5 6 7 However he also felt it had major flaws stemming from the fact that testing only happened at the end of the process which he described as being risky and invites failure 5 The rest of his paper introduced five steps which he felt were necessary to eliminate most of the development risks associated with the unaltered waterfall approach 5 Royce s five additional steps which included writing complete documentation at various stages of development never took mainstream hold but his diagram of what he considered a flawed process became the starting point when describing a waterfall approach 8 better source needed The earliest use of the term waterfall may have been in a 1976 paper by Bell and Thayer 9 better source needed In 1985 the United States Department of Defense captured this approach in DOD STD 2167A citation needed their standards for working with software development contractors which stated that the contractor shall implement a software development cycle that includes the following six phases Software Requirement Analysis Preliminary Design Detailed Design Coding and Unit Testing Integration and Testing 10 Model editAlthough Royce never recommended nor described a waterfall model citation needed rigid adherence to the following phases are criticized by him System and software requirements captured in a product requirements document Analysis resulting in models schema and business rules Design resulting in the software architecture Coding the development proving and integration of software Testing the systematic discovery and debugging of defects Operations the installation migration support and maintenance of complete systemsThus the waterfall model maintains that one should move to a phase only when its preceding phase is reviewed and verified Various modified waterfall models including Royce s final model however can include slight or major variations on this process 5 These variations included returning to the previous cycle after flaws were found downstream or returning all the way to the design phase if downstream phases deemed insufficient Supporting arguments editTime spent early in the software production cycle can reduce costs at later stages For example a problem found in the early stages such as requirements specification is cheaper to fix than the same bug found later on in the process by a factor of 50 to 200 11 In common practice waterfall methodologies result in a project schedule with 20 40 of the time invested for the first two phases 30 40 of the time to coding and the rest dedicated to testing and implementation The actual project organization needs to be highly structured Most medium and large projects will include a detailed set of procedures and controls which regulate every process on the project 12 failed verification A further argument for the waterfall model is that it places emphasis on documentation such as requirements documents and design documents as well as source code citation needed In less thoroughly designed and documented methodologies knowledge is lost if team members leave before the project is completed and it may be difficult for a project to recover from the loss If a fully working design document is present as is the intent of Big Design Up Front and the waterfall model new team members or even entirely new teams should be able to familiarise themselves by reading the documents 13 The waterfall model provides a structured approach the model itself progresses linearly through discrete easily understandable and explainable phases and thus is easy to understand it also provides easily identifiable milestones in the development process It is perhaps for this reason that the waterfall model is used as a beginning example of a development model in many software engineering texts and courses 14 Simulation can play a valuable role within the waterfall model By creating computerized or mathematical simulations of the system being developed teams can gain insights into how the system will perform before proceeding to the next phase Simulations allow for testing and refining the design identifying potential issues or bottlenecks and making informed decisions about the system s functionality and performance Criticism editClients may not know exactly what their requirements are before they see working software and so change their requirements leading to redesign redevelopment and retesting and increased costs 15 Designers may not be aware of future difficulties when designing a new software product or feature in which case it is better to revise the design than persist in a design that does not account for any newly discovered constraints requirements or problems 16 Organisations may attempt to deal with a lack of concrete requirements from clients by employing systems analysts to examine existing manual systems and analyse what they do and how they might be replaced However in practice it is difficult to sustain a strict separation between systems analysis and programming 17 This is because implementing any non trivial system will almost inevitably expose issues and edge cases that the systems analyst did not consider In response to the perceived problems with the pure waterfall model modified waterfall models were introduced such as Sashimi Waterfall with Overlapping Phases Waterfall with Subprojects and Waterfall with Risk Reduction 11 Some organisations such as the United States Department of Defense now have a stated preference against waterfall type methodologies starting with MIL STD 498 released in 1994 which encourages evolutionary acquisition and Iterative and Incremental Development 18 Modified waterfall models editIn response to the perceived problems with the pure waterfall model many modified waterfall models have been introduced These models may address some or all of the criticisms of the pure waterfall model These include the Rapid Development models that Steve McConnell calls modified waterfalls 11 Peter DeGrace s sashimi model waterfall with overlapping phases waterfall with subprojects and waterfall with risk reduction Other software development model combinations such as incremental waterfall model also exist 19 Royce s final model edit nbsp Royce final modelWinston W Royce s final model his intended improvement upon his initial waterfall model illustrated that feedback could should and often would lead from code testing to design as testing of code uncovered flaws in the design and from design back to requirements specification as design problems may necessitate the removal of conflicting or otherwise unsatisfiable undesignable requirements In the same paper Royce also advocated large quantities of documentation doing the job twice if possible a sentiment similar to that of Fred Brooks famous for writing the Mythical Man Month an influential book in software project management who advocated planning to throw one away and involving the customer as much as possible a sentiment similar to that of extreme programming Royce notes on the final model are Complete program design before analysis and coding begins Documentation must be current and complete Do the job twice if possible Testing must be planned controlled and monitored Involve the customerSee also editList of software development philosophies Agile software development Big Design Up Front Chaos model DevOps Iterative and incremental development Monitoring Maintenance Lifecycle Object oriented analysis and design Rapid application development Software development process Spiral model Structured Systems Analysis and Design Method SSADM System development methodology Traditional engineering V modelReferences edit a b Petersen Kai Wohlin Claes Baca Dejan 2009 The Waterfall Model in Large Scale Development In Bomarius Frank Oivo Markku Jaring Paivi Abrahamsson Pekka eds Product Focused Software Process Improvement Lecture Notes in Business Information Processing Vol 32 Berlin Heidelberg Springer pp 386 400 Bibcode 2009pfsp book 386P doi 10 1007 978 3 642 02152 7 29 ISBN 978 3 642 02152 7 The Traditional Waterfall Approach www umsl edu Retrieved 2022 02 23 a b Benington Herbert D 1 October 1983 Production of Large Computer Programs PDF IEEE Annals of the History of Computing IEEE Educational Activities Department 5 4 350 361 doi 10 1109 MAHC 1983 10102 S2CID 8632276 Retrieved 2011 03 21 Archived July 18 2011 at the Wayback Machine United States Navy Mathematical Computing Advisory Panel 29 June 1956 Symposium on advanced programming methods for digital computers Washington D C Office of Naval Research Dept of the Navy OCLC 10794738 a b c d Royce Winston 1970 Managing the Development of Large Software Systems PDF Proceedings of IEEE WESCON 26 August 1 9 Waterfall Bremen University Mathematics and Computer Science Abbas Noura Gravell Andrew M Wills Gary B 2008 Historical Roots of Agile Methods Where Did Agile Thinking Come From In Abrahamsson Pekka Baskerville Richard Conboy Kieran Fitzgerald Brian Morgan Lorraine Wang Xiaofeng eds Agile Processes in Software Engineering and Extreme Programming Lecture Notes in Business Information Processing Vol 9 Berlin Heidelberg Springer pp 94 103 doi 10 1007 978 3 540 68255 4 10 ISBN 978 3 540 68255 4 Conrad Weisert Waterfall methodology there s no such thing Bell Thomas E and T A Thayer Software requirements Are they really a problem Proceedings of the 2nd international conference on Software engineering IEEE Computer Society Press 1976 Military Standard Defense System Software Development PDF a b c McConnell Steve 1996 Rapid Development Taming Wild Software Schedules Microsoft Press ISBN 1 55615 900 5 Waterfall Software Development Model 5 February 2014 Retrieved 11 August 2014 Arcisphere technologies 2012 Tutorial The Software Development Life Cycle SDLC PDF Retrieved 2012 11 13 Hughey Douglas 2009 Comparing Traditional Systems Analysis and Design with Agile Methodologies University of Missouri St Louis Retrieved 11 August 2014 Parnas David L Clements Paul C 1986 A rational design process How and why to fake it PDF IEEE Transactions on Software Engineering 2 251 257 doi 10 1109 TSE 1986 6312940 S2CID 5838439 Retrieved 2011 03 21 McConnell Steve 2004 Code Complete 2nd edition Microsoft Press ISBN 1 55615 484 4 Ensmenger Nathan 2010 The Computer Boys Take Over MIT Press p 42 ISBN 978 0 262 05093 7 Larman Craig Basili Victir 2003 Iterative and Incremental Development A Brief History IEEE Computer June ed 36 6 47 56 doi 10 1109 MC 2003 1204375 S2CID 9240477 Methodology design methods External links edit nbsp Wikimedia Commons has media related to Waterfall models Understanding the pros and cons of the Waterfall Model of software development Project lifecycle models how they differ and when to use them Going Over the Waterfall with the RUP by Philippe Kruchten CSC and IBM Rational join to deliver C RUP and support rapid business change c2 WaterFall 1 Retrieved from https en wikipedia org w index php title Waterfall model amp oldid 1189939494, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.