Share to: share facebook share twitter share wa share telegram print page

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] The waterfall model is the earliest SDLC approach that was used in software development.[3]

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 it was first adopted for software development, there were no recognized alternatives for knowledge-based creative work.[4]

History

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.[5] 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.[6][better source needed]

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[7] cited as a 1970 article by Winston W. Royce.[8][9][10] 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".[8] 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.[8]

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.[11] [12]

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

In 1985, the United States Department of Defense adopted the waterfall model in the DOD-STD-2167 standard for working with software development contractors. This standard referred for iterations of a software development[14] to "the sequential phases of a software development cycle" and 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".[14][15]

Model

Although Royce never recommended nor described a waterfall model,[16] 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.[8] 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

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).[17]

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.[18][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.[19]

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.[20]

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

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.[21]

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.[22]

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.[23] 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."[17]

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.[24]

Modified waterfall models

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":[17] 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.[25]

Royce's final model

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

References

  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. ^ Tom Gilb. "Evolutionary Delivery versus the 'waterfall model'". ACM SIGSOFT Software Engineering Notes. 10 (3): 49–61. doi:10.1145/1012483.1012490. Open access icon
  3. ^ Linda Sherrell (2013). "Waterfall Model". Encyclopedia of Sciences and Religions (A.L.C. Runehov; L. Oviedo (Eds.)). Dordrecht, The Netherlands: Springer: 2343–2344. doi:10.1007/978-1-4020-8265-8_200285. ISBN 978-1-4020-8264-1.
  4. ^ Andreas P. Schmidt; Christine Kunzmann (September 16, 2014). Designing for knowledge maturing: from knowledge-driven software to supporting the facilitation of knowledge development. i-KNOW '14: Proceedings of the 14th International Conference on Knowledge Technologies and Data-driven Business. ACM. pp. 1–7. doi:10.1145/2637748.2638421.
  5. ^ 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
  6. ^ Benington, Herbert D. (1 October 1983). "Production of Large Computer Programs" (PDF). IEEE Annals of the History of Computing. 5 (4). IEEE Educational Activities Department: 350–361. doi:10.1109/MAHC.1983.10102. S2CID 8632276. Retrieved 2011-03-21. Archived July 18, 2011, at the Wayback Machine
  7. ^ Larman, Craig; Basili, Victor (June 2003). "Iterative and Incremental Development: A Brief History" (PDF). Computer. 36 (6): 47–56. doi:10.1109/MC.2003.1204375.
  8. ^ a b c d Royce, Winston (1970), "Managing the Development of Large Software Systems" (PDF), Proceedings of IEEE WESCON, 26 (August): 1–9
  9. ^ "Waterfall". Bremen University - Mathematics and Computer Science.
  10. ^ Abbas, Noura; Gravell, Andrew M.; Wills, Gary B. (2008). "Historical Roots of Agile Methods: Where Did "Agile Thinking" Come From?" (PDF). 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.
  11. ^ Conrad Weisert, Waterfall methodology: there's no such thing!
  12. ^ Lineberger, Rob (Apr 25, 2024). Inheriting Agile: The IT Practitioner's Guide to Managing Software Development in a Post-Agile World. Durham, NC: Sandprint Press. p. 36. ISBN 9798989149605.
  13. ^ 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.
  14. ^ a b DOD-STD-2167 - Military Standard : Defence System Software Development". Department of Defence, United States of America. 1985-06-04. p. 11.
  15. ^ "Military Standard Defense System Software Development" (PDF).
  16. ^ Lineberger, Rob (Apr 25, 2024). Inheriting Agile: The IT Practitioner's Guide to Managing Software Development in a Post-Agile World. Durham, NC: Sandprint Press. p. 37. ISBN 9798989149605.
  17. ^ a b c McConnell, Steve (1996). Rapid Development: Taming Wild Software Schedules. Microsoft Press. ISBN 1-55615-900-5.
  18. ^ "Waterfall Software Development Model". 5 February 2014. Retrieved 11 August 2014.
  19. ^ Arcisphere technologies (2012). "Tutorial: The Software Development Life Cycle (SDLC)" (PDF). Retrieved 2012-11-13.
  20. ^ Hughey, Douglas (2009). "Comparing Traditional Systems Analysis and Design with Agile Methodologies". University of Missouri – St. Louis. Retrieved 11 August 2014.
  21. ^ 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.
  22. ^ McConnell, Steve (2004). Code Complete, 2nd edition. Microsoft Press. ISBN 1-55615-484-4.
  23. ^ Ensmenger, Nathan (2010). The Computer Boys Take Over. MIT Press. p. 42. ISBN 978-0-262-05093-7.
  24. ^ Larman, Craig; Basili, Victir (2003). "Iterative and Incremental Development: A Brief History". IEEE Computer. 36 (6) (June ed.): 47–56. doi:10.1109/MC.2003.1204375. S2CID 9240477.
  25. ^ "Methodology:design methods".

waterpoor;design

Read other articles:

This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these template messages) This article's lead section may be too short to adequately summarize the key points. Please consider expanding the lead to provide an accessible overview of all important aspects of the article. (July 2014) This biography of a living person includes a list of general references, but it lacks sufficient corresponding inline citations. Content...

العلاقات الإيرانية المولدوفية إيران مولدوفا   إيران   مولدوفا تعديل مصدري - تعديل   العلاقات الإيرانية المولدوفية هي العلاقات الثنائية التي تجمع بين إيران ومولدوفا.[1][2][3][4][5] مقارنة بين البلدين هذه مقارنة عامة ومرجعية للدولتين: وجه المقار...

Neighborhood of Manhattan in New York City Neighborhood in New York CityEast VillageNeighborhoodSecond Avenue and 6th Street, facing south.Location in New York CityCoordinates: 40°43′41″N 73°59′10″W / 40.728°N 73.986°W / 40.728; -73.986Country United StatesState New YorkCityNew York CityBoroughManhattanCommunity DistrictManhattan 3[1]Named1960s[2]Area[3] • Total1.99 km2 (0.768 sq mi)Population...

Universitas Nasional AustraliaAustralian National UniversityMotoNaturam Primum Cognoscere Rerum (First to learn the nature of things) Menjadi yang pertama dalam mempelajari sesuatuJenisSemi SwastaDidirikan1946KanselirJulie BishopWakil KanselirBrian Schmidt ACStaf administrasi3.753 (2014)Sarjana10.052 (2014)Magister10.840 (2014)LokasiCanberra, AustraliaSitus webwww.anu.edu.au Universitas Nasional Australia (Australian National University; disingkat ANU) adalah sebuah universitas yang terletak ...

New Zealand rugby league footballer, coach and administrator Sir Graham LoweKNZM QSMLowe in 2019Personal informationFull nameGraham Michael LoweBorn (1946-10-02) 2 October 1946 (age 77)[citation needed]New ZealandRugby league careerPlaying information Club Years Team Pld T G FG P Otahuhu Coaching information Club Years Team Gms W D L W% 1973–78 Otahuhu 1979–82 Northern Suburbs 80 38 0 42 48 1986–89 Wigan 128 104 3 21 81 1990–92 Manly-Warringah 70 ...

هذه المقالة يتيمة إذ تصل إليها مقالات أخرى قليلة جدًا. فضلًا، ساعد بإضافة وصلة إليها في مقالات متعلقة بها. (مايو 2014) بليناتوموماب ضد وحيد النسيلة نوع Bi-specific T-cell engager الهدف CD19، CD3 اعتبارات علاجية معرّفات CAS 853426-35-4 ك ع ت None درغ بنك 09052  كيم سبايدر NA المكون الفريد 4FR53SIF3A Y كيوتو...

Герой Соціалістичної ПраціГерой Социалистического Труда Країна СРСРТип орден, медаль, грамотаСистема highest honors of the USSRdПідстава за працюСтатус не вручається Нагородження Засновано: 27 грудня 1938Перше: 20 грудня 1939Останнє: 1991Нагороджено: більш 19 000Нагороджені: Категорія:Геро...

Bahasa Arab Yordania اللهجة الأردنية Dituturkan diYordaniaPenutur6,24 juta (2016)[1]Rumpun bahasaAfroasiatik SemitSemit TengahArabArab SyamArab Syam SelatanArab Yordania DialekFellahi (perdesaan) Madani (perkotaan) Sistem penulisanAbjad ArabKode bahasaISO 639-3Mencakup:avl – Syam Badawiajp – Syam SelatanGlottologsout3123[2]east2690[3]Lokasi penuturan  Syam Selatan   Syam BadawiPeta bahasa lain Artikel ...

التهاب البربخ 1: البربخ2: رأس البربخ3: فصيصات البربخ4: جسم البربخ5: ذيل البربخ6: قناة البربخ7: الوعاء الناقل (القناتين الدافقتين)1: البربخ2: رأس البربخ3: فصيصات البربخ4: جسم البربخ5: ذيل البربخ6: قناة البربخ7: الوعاء الناقل (القناتين الدافقتين) معلومات عامة الاختصاص طب الجهاز البولي&...

Sports stadium in Frisco, Texas, U.S. Comerica CenterComerica CenterLocation within TexasShow map of TexasComerica CenterLocation within the United StatesShow map of the United StatesFormer namesDeja Blue Arena (2003–2008)Dr Pepper Arena (2009–2019)Address2601 Avenue of the StarsLocationFrisco, TexasCoordinates33°06′04″N 96°49′11″W / 33.101026°N 96.819624°W / 33.101026; -96.819624OwnerCity of FriscoOperatorDallas StarsExecutive suites12CapacityI...

Esta biografia de uma pessoa viva cita fontes, mas que não cobrem todo o conteúdo. Ajude a inserir fontes confiáveis e independentes. Material controverso que esteja sem fontes deve ser imediatamente removido, especialmente se for de natureza difamatória.—Encontre fontes: ABW  • CAPES  • Google (N • L • A) (Janeiro de 2019) Tim Tim (músico)Tim, vocalista dos Xutos & Pontapés Informação geral Nome completo António Man...

KertosariKelurahanPeta lokasi Kelurahan KertosariNegara IndonesiaProvinsiJawa TimurKabupatenBanyuwangiKecamatanBanyuwangiKodepos68418Kode Kemendagri35.10.16.1006 Kode BPS3510180006 Luas... km2Jumlah penduduk... jiwaKepadatan... jiwa/km2 Untuk tempat lain yang bernama sama, lihat Kertosari. Makam Datuk Daeng Ruyung Kelurahan Kertosari merupakan salah satu kelurahan yang terletak di bagian timur kecamatan Banyuwangi, Kabupaten Banyuwangi, Provinsi Jawa Timur, Indonesia. Pembagian Wilayah K...

قرية السرب  - قرية -  تقسيم إداري البلد  اليمن المحافظة محافظة المحويت المديرية مديرية ملحان العزلة عزلة القبلة السكان التعداد السكاني 2004 السكان 471   • الذكور 251   • الإناث 220   • عدد الأسر 77   • عدد المساكن 83 معلومات أخرى التوقيت توقيت اليمن (+3 غرينيتش) ...

Ne pas confondre avec l'équipe de république d'Irlande ou l'équipe d'Irlande du Nord Équipe d'Irlande Généralités Confédération Aucune Couleurs vert et blanc Personnalités Plus sélectionné Elisha Scott : 31 Meilleur buteur Billy Gillespie, Joe Bambrick : 12 Rencontres officielles historiques Premier match 18 février 1882(0-13 Angleterre) Dernier match 8 mars 1950(0-0, Pays de Galles) Plus large victoire 7-0, Pays de Galles (1er février 1930) Plus large défaite 0-13, A...

2006 translation of L'Immaculée conception The Immaculate Conception First edition coverAuthorGaétan SoucyOriginal titleL'Immaculée conceptionTranslatorLazer LederhendlerCountryCanadaLanguageEnglish translation of original FrenchGenrePsychological novelPublisherHouse of Anansi PressPublication dateApril 28, 2006Media typePrint (Paperback)Pages320 ppISBN0-88784-736-6OCLC60798019Dewey Decimal843/.914 22LC ClassPQ3919.2.S655 I4613 2005 The Immaculate Conception is the English t...

Природне відслонення Новомосковського горизонтуз стародавньою фауною Виходи Новомосковського горизонту з викопними рештками стародавньої сарматської фауниВиходи Новомосковського горизонту з викопними рештками стародавньої сарматської фауни 48°48′33″ пн. ш. 35°1...

American college football season 1970 Washington Huskies footballConferencePacific-8Record6–4 (4–3 Pac-8)Head coachJim Owens (14th season)Assistant coaches Mel Thompson Otto Kofler John Goodwin Bob Schloredt Jim LambrightMarv WeetmanJerry Cheek Captains Bo Cornell (RB) Tom Failla (DT) Home stadiumHusky StadiumSeasons← 19691971 → 1970 Pacific-8 Conference football standings vte Conf Overall Team W   L   T W   L   T No. 8 Stanford $ 6 R...

Beautiful days嵐的歌曲收录于专辑《1999-2009 完全精選!》A面Beautiful daysB面我就是我的一切難以忘懷发行日期2008年11月5日格式唱片录制时间2008年类型J-Pop时长初回:9分26秒通常:61分43秒唱片公司J Storm制作人Julie K.排行榜最高名次 週榜第1位(Oricon) 2008年11月度月榜第1位(Oricon) 2008年度年榜第10位(Oricon) 销量认证 ダブル・プラチナ(日本レコード協会) 嵐单曲年表 truth/前往...

1990 television film directed by Wes Craven Night VisionsGenreMysteryThrillerWritten byWes CravenThomas BaumDirected byWes CravenStarringLoryn LocklinJames RemarMusic byBrad FiedelOriginal languageEnglishProductionExecutive producerWes CravenProducersThomas BaumMarianne MaddalenaRick NathansonCinematographyPeter SteinEditorsJames CoblentzMark MelnickRunning time92 minutesProduction companiesWes Craven FilmsMGM TelecommunicationsOriginal releaseNetworkNBCReleaseNovember 30, 1990 ...

Area of scholarly activity Example of a textual analysis program being used to study a novel, with Jane Austen's Pride and Prejudice in Voyant Tools Digital humanities (DH) is an area of scholarly activity at the intersection of computing or digital technologies and the disciplines of the humanities. It includes the systematic use of digital resources in the humanities, as well as the analysis of their application.[1][2] DH can be defined as new ways of doing scholarship that ...

Kembali kehalaman sebelumnya