Waterfall model

The waterfall model is a breakdown of developmental activities into linear sequential phases, meaning that each phase is passed down onto each other, where each phase depends on the deliverables of the previous one and corresponds to a specialization of tasks.[1] This 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 Systems Development Life Cycle (SDLC) approach 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 the 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, Benington republished his paper with a foreword 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 coming from a 1970 article by Winston W. Royce.[8][9][10] However, he commented that it had major flaws stemming from how testing only happened at the end of the process, which he described as being "risky and [inviting] 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 include returning to the previous cycle after flaws are found downstream, or returning to the design phase if downstream phases are 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. With the project organization needing 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 supporting 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 and new teams should be able to familiarise themselves to the project 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, often being used as a beginning example of a development model in many software engineering texts and courses.[20]

Similarly, simulation can play a valuable role within the waterfall model. [21] 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 the exact requirements before they see working software and thus change their requirements further on, leading to redesign, redevelopment, and retesting, and increased costs.[22]

Designers may not be aware of future difficulties when designing a new software product or feature, in which case revising the design initially can increase efficiency in comparison to a design not built to account for newly discovered constraints, requirements, or problems.[23]

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,[24] as implementing any non-trivial system will often expose issues and edge cases that the systems analyst did not consider.

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

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

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).[citation needed] 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 the following:

  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. Dordrecht, The Netherlands: Springer. pp. 2343–2344. doi:10.1007/978-1-4020-8265-8_200285. ISBN 978-1-4020-8264-1. {{cite book}}: |journal= ignored (help)
  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 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. ^ Saravanos, Antonios; Curinga, Matthew X. (December 2023). "Simulating the Software Development Lifecycle: The Waterfall Model". Applied System Innovation. 6 (6): 108. doi:10.3390/asi6060108. ISSN 2571-5577.
  22. ^ 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.
  23. ^ McConnell, Steve (2004). Code Complete, 2nd edition. Microsoft Press. ISBN 1-55615-484-4.
  24. ^ Ensmenger, Nathan (2010). The Computer Boys Take Over. MIT Press. p. 42. ISBN 978-0-262-05093-7.
  25. ^ 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.
  26. ^ "Methodology:design methods".

Read other articles:

JSPEkstensi berkas.jsp, .jspx, .jspfRilis pertama1999; 25 tahun lalu (1999)Rilis terbaru3.1 / 31 April 2022; 21 bulan lalu (2022-04-31)Jenis formatHalaman web dinamisStandarJSR 245Situs webprojects.eclipse.org/projects/ee4j.jsp Jakarta Server Pages (sebelumnya: JavaServer Pages) ialah teknologi untuk mengontrol isi atau tampilan halaman Web melalui penggunaan servlet, program kecil yang dijalankan di server Web. Sun Microsystem, pembuat Java, mengacu kepada tekno...

 

Beram Kayal Kayal bersama klub Celtic pada 2013Informasi pribadiNama lengkap Beram KayalTanggal lahir 2 Mei 1988 (umur 35)Tempat lahir Jadeidi, IsraelTinggi 178 m (584 ft 0 in)Posisi bermain Gelandang TengahInformasi klubKlub saat ini Hapoel Bnei SakhninNomor 7Karier junior2002–2006 Maccabi HaifaKarier senior*Tahun Tim Tampil (Gol)2006–2010 Maccabi Haifa 92 (6)2010–2015 Celtic 86 (2)2015–2020 Brighton & Hove Albion 120 (4)2019 → Charlton Athletic (pinjaman) ...

 

Artikel ini membutuhkan rujukan tambahan agar kualitasnya dapat dipastikan. Mohon bantu kami mengembangkan artikel ini dengan cara menambahkan rujukan ke sumber tepercaya. Pernyataan tak bersumber bisa saja dipertentangkan dan dihapus.Cari sumber: Eilat – berita · surat kabar · buku · cendekiawan · JSTOR (November 2023)Eilat אילתإيلاتKotaTeluk Aqabah di pesisir Eilat. BenderaLogo EilatEilatTampilkan peta Kawasan Negev Selatan, IsraelEilatTampi...

Artikel ini tidak memiliki referensi atau sumber tepercaya sehingga isinya tidak bisa dipastikan. Tolong bantu perbaiki artikel ini dengan menambahkan referensi yang layak. Tulisan tanpa sumber dapat dipertanyakan dan dihapus sewaktu-waktu.Cari sumber: Ivan nama – berita · surat kabar · buku · cendekiawan · JSTOR IvanJenis kelaminLaki-lakiAsal usulKataSlaviaAlternatifNama terkaitJohn Ivan (Bulgaria, Rusia, Macedonia: Иван, Serbia: Иван, Uk...

 

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

 

この項目では、球技について説明しています。その他の用法については「クリケット (曖昧さ回避)」をご覧ください。 クリケット クリケットの試合風景 ベージュ色の線がピッチ。右側で黒いズボンを着用しているのが審判。統括団体 国際クリケット評議会起源 16世紀前半 イングランド特徴身体接触 無選手数 グラウンド上:11人男女混合 男女別カテゴリ チーム競技、�...

Samut Songkhram สมุทรสงครามProvinsi BenderaJulukan: Mae KlongPeta Thailand memperlihatkan Provinsi Samut SongkhramNegaraThailandIbukotaSamut SongkhramPemerintahan • GubernurKhanchat Tansathian (sejak Oktober 2016)Luas • Total416,7 km2 (1,609 sq mi)Peringkatke-76Populasi (2017) • Total193.902 • Peringkatke-75 • Kepadatan0,047/km2 (0,12/sq mi) • Peringkat kepadatanke-...

 

Historic district in Illinois, United States This article is about the historic district of Chicago, United States. For other uses, see Gold Coast. United States historic placeGold Coast Historic DistrictU.S. National Register of Historic PlacesU.S. Historic district Gold Coast's Oak Street BeachShow map of Chicago metropolitan areaShow map of IllinoisShow map of the United StatesLocationRoughly bounded by North Ave., Lake Shore Dr., Clark and Oak Sts., Chicago, IllinoisCoordinates41°54′21...

 

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. (June 2012) This article includes a list of general references, but it lacks sufficient corresponding inline citations. Please help to improve this ...

Neodymium(II) iodide Names IUPAC name Diiodoneodymium Other names Neodymium diiodide Identifiers CAS Number 61393-36-0 3D model (JSmol) Interactive image ECHA InfoCard 100.150.931 EC Number 622-142-8 PubChem CID 57351516 CompTox Dashboard (EPA) DTXSID30722364 InChI InChI=1S/2HI.Nd/h2*1H;/p-2Key: XKFMXEILCPYOQT-UHFFFAOYSA-L SMILES [I-].[I-].[Nd+2] Properties Chemical formula NdI2 Molar mass 398.05 Appearance dark violet solid[1] Structure[2] Crystal str...

 

Pour les articles homonymes, voir Cassel et Crochon. Vincent CasselVincent Cassel au festival de Cannes 2018.BiographieNaissance 23 novembre 1966 (57 ans)15e arrondissement de ParisNom dans la langue maternelle Vincent CrochonNom de naissance Vincent Georges Pierre CrochonNationalité françaiseDomiciles Itacaré (depuis 2012), Rio de JaneiroActivités Acteur, réalisateur, producteur de cinéma, scénaristePériode d'activité depuis 1987Père Jean-Pierre CasselFratrie Rockin' SquatCé...

 

Hôpital San SalvadourGéographiePays  FranceDivision territoriale française France métropolitaineRégion Provence-Alpes-Côte d'AzurDépartement français VarPartie de Assistance publique – Hôpitaux de Paris, structures de soin de l'AP-HP (hors GH) (d)Coordonnées 43° 05′ 05″ N, 6° 06′ 34″ EFonctionnementStatut HôpitalIdentifiantsSite web www.aphp.fr/contenu/hopital-san-salvadour-2modifier - modifier le code - modifier Wikidata L'hôpital Sa...

2017 studio album by FergieDouble DutchessStudio album by FergieReleasedSeptember 22, 2017Recorded2014–2017StudioLos Angeles, California (The Village Recorder, Record Plant, Roccage, Eightsevenfourteen, Kite Music, Chalice, Conway, WindmarkThe FutureHQ)Santa Monica, California (No Excuses, Interscope)Virginia Beach, Virginia (Mixstar)London, UK (AIR)Genre Pop[1] hip hop[2] R&B[3] Length56:54Label Dutchess Retrofuture BMG Producer Alesso DJ Ammo Philip DJ...

 

Radio station in Huntington, West VirginiaWVHUHuntington, West VirginiaBroadcast areaHuntington, West VirginiaFrequency800 kHzBrandingNews Radio 800ProgrammingFormatNews/talkAffiliationsFox News RadioCompass Media NetworksPremiere NetworksOwnershipOwneriHeartMedia, Inc.(iHM Licenses, LLC)Sister stationsWAMX, WBVB, WKEE-FM, WTCR-FM, WZWBHistoryFirst air dateJuly 1947 (1947-07)Former call signsWHTN (1947–1959)WKEE (1959–1979)WHTN (1979–1983)Call sign meaningWest Virginia Hunting...

 

Iglesia de San Sebastián Mártir Tipo iglesiaLocalización Madrid (España)Coordenadas 40°22′48″N 3°44′28″O / 40.380097222222, -3.7410166666667Culto Iglesia católicaNombrado por Sebastián de Milán [editar datos en Wikidata] La iglesia de San Sebastián Mártir es un templo católico del distrito de Carabanchel de la ciudad española de Madrid. Está ubicada en el barrio de Puerta Bonita, en la plaza de la Parroquia, junto a la plaza de Carabanchel y la ...

Eustache Le Sueur Die Darbringung der Jungfrau im Tempel Die Musen Klio, Euterpe und Thalia Eustache Le Sueur oder Lesueur [øsˈtaʃ ləˈsɥœʀ] (* 19. November 1616 in Paris; † 30. April 1655 ebenda) war ein französischer Maler. Leben Le Sueur war ein Schüler von Simon Vouet und bildete sich daneben nach italienischen Gemälden, die nach Paris kamen. Von 1645 bis 1648 malte er die berühmten 22 Bilder aus dem Leben des hl. Bruno im Kleinen Kartäuserkloster zu Paris (jetzt i...

 

一中同表,是台灣处理海峡两岸关系问题的一种主張,認為中华人民共和国與中華民國皆是“整個中國”的一部份,二者因為兩岸現狀,在各自领域有完整的管辖权,互不隶属,同时主張,二者合作便可以搁置对“整个中國”的主权的争议,共同承認雙方皆是中國的一部份,在此基礎上走向終極統一。最早是在2004年由台灣大學政治学教授張亞中所提出,希望兩岸由一中各表�...

 

Chemical compound PNU-282,987Identifiers IUPAC name N-[(3'R)-1'-azabicyclo[2.2.2]oct-3'-yl]-4-chlorobenzamide CAS Number123464-89-1PubChem CID9795278ChemSpider7971045UNII810P1694K2ChEMBLChEMBL177611 YCompTox Dashboard (EPA)DTXSID801017103 Chemical and physical dataFormulaC14H17ClN2OMolar mass264.75 g·mol−13D model (JSmol)Interactive image SMILES C1CN2CCC1[C@H](C2)NC(=O)C3=CC=C(C=C3)Cl InChI InChI=1S/C14H17ClN2O/c15-12-3-1-11(2-4-12)14(18)16-13-9-17-7-5-10(13)6-8-17/h1-4,10,13H,5-...

Voce principale: Italia. «[...] il trasporto costituisce una componente necessaria ma non sufficiente per lo sviluppo del reddito.» (prof. Ing. Vincenzo Leuzzi, Direttore dell'Istituto dei Trasporti dell'Università La Sapienza, I trasporti in Italia in Ambiente e informatica: problemi nuovi della società contemporanea. Vol. 16. Servizio studi, legislazione e inchieste parlamentari, 1974.) La rete dei trasporti in Italia comprende le seguenti infrastrutture: 156 porti, una rete ferroviari...

 

Hotel ShillaNama asli신라호텔IndustriPenyantunanDidirikanMaret 1979KantorpusatSeoul, Korea SelatanCabang15 Hotel & Resort (Juli 2020)Wilayah operasiKoreaVietnamTiongkokTokohkunciLee Boo-jin, Manajer Umum & CEOProdukHotelIndukSamsungSitus webwww.shilla.net/kr Hotel Shilla (Hangul: 신라호텔) adalah sebuah operator hotel mewah dan toko bebas bea asal Korea Selatan. Hotel Shilla merupakan salah satu anggota dari The Leading Hotels of the World. Lee Boo-jin adalah manajer umum dan ...