The V-Model (or VEE model) is a systems development model designed to simplify the understanding of the complexity associated with developing systems.[2][3][4] In systems engineering it is used to define a uniform procedure for product or project development.
Overview
The V-model is a graphical representation of the systems development lifecycle. It summarizes the main steps to be taken in conjunction with the corresponding deliverables within computerized system validation framework.
The VEE is a process that represents the sequence of steps in a project life cycle development. It describes the activities and results that have to be produced during product development. The left side of the VEE represents the decomposition of requirements, and creation of system specifications. The right side of the V represents integration of parts and their verification.[3][4][5][6][7] V stands for "Verification and Validation"
It is similar to the Classic Waterfall model as it is quite rigid and contains many iterations.
Objectives
The V-Model provides guidance for the planning and realization of projects. The following objectives are intended to be achieved by a project execution:
- Minimization of Project Risks: The V-Model improves project transparency and project control by specifying standardized approaches and describing the corresponding results and responsible roles. It permits an early recognition of planning deviations and risks and improves process management, thus reducing the project risk.
- Improvement and Guarantee of Quality: As a standardized process model, the V-Model ensures that the results to be provided are complete and have the desired quality. Defined interim results can be checked at an early stage. Uniform product contents will improve readability, understandability and verifiability.
- Reduction of Total Cost over the Entire Project and System Life Cycle: The effort for the development, production, operation and maintenance of a system can be calculated, estimated and controlled in a transparent manner by applying a standardized process model. The results obtained are uniform and easily retraced. This reduces the acquirers dependency on the supplier and the effort for subsequent activities and projects.
- Improvement of Communication between all Stakeholders: The standardized and uniform description of all relevant elements and terms is the basis for the mutual understanding between all stakeholders. Thus, the frictional loss between user, acquirer, supplier and developer is reduced.
V Model topics
Systems Engineering and verification
The Systems Engineering Process (SEP) provides a path for improving the cost effectiveness of complex systems as experienced by the system owner over the entire life of the system, from conception to retirement.[1]
It involved early and comprehensive identification of goals, a concept of operations that describes user needs and the operating environment, thorough and testable system requirements, detailed design, implementation, rigorous acceptance testing of the implemented system to ensure it meets the stated requirements (system verification), measuring its effectiveness in addressing goals (system validation), on-going operation and maintenance, system upgrades over time, and eventual retirement.[1][3][4][7]
The process emphasizes requirements-driven design and testing. All design elements and acceptance tests must be traceable to one or more system requirements and every requirement must be addressed by at least one design element and acceptance test. Such rigor ensures nothing is done unnecessarily and everything that is necessary is accomplished.[1][3]
The specification stream
The specification stream mainly consists of:
- User Requirement Specifications
- Functional Requirement Specifications
- Design Specifications
The testing stream generally consists of:
- Installation Qualification (IQ)
- Operational Qualification (OQ)
- Performance Qualification (PQ)
The development stream can consist (depending on the system type and the development scope) of customization, configuration or coding.
Applications
The V-model is used to regulate the software development process within the German federal administration. Nowadays it is still the standard for German federal administration and defense projects, as well as software developers within in the region.
The concept of the V-Model was developed simultaneously, but independently, in Germany and in the United States in the late 1980s:
- The German V-Model was originally developed by IABG in Ottobrunn, near Munich, in cooperation with the Federal Office for Defence Technology and Procurement in Koblenz, for the Federal Ministry of Defence. It was taken over by the Federal Ministry of the Interior for the civilian public authorities domain in summer 1992.[9]
- The US V-Model, as documented in the 1991 proceedings for the National Council on Systems Engineering (NCOSE; now INCOSE as of 1995),[7] was developed for satellite systems involving hardware, software, and human interaction.
- The V-Model first appeared at Hughes Aircraft circa 1982 as part of the pre-proposal effort for the FAA Advanced Automation System (AAS) program. It eventually formed the test strategy for the Hughes AAS Design Competition Phase (DCP) proposal. It was created to show the test and integration approach which was driven by new challenges to surface latent defects in the software. The need for this new level of latent defect detection was driven by the goal to start automating the thinking and planning processes of the air traffic controller as envisioned by the Automated Enroute Air Traffic Control (AERA) program. The reason the V is so powerful comes from the Hughes culture of coupling all text and analysis to multi dimensional images. It was the foundation of Sequential Thematic Organization of Publications (STOP) [10] created by Hughes in 1963 and used until Hughes was divested by the Howard Hughes Medical Institute in 1985.[11]
It has now found widespread application in commercial as well as defence programs. Its primary use is in Project Management[3][4] and throughout the project lifecycle.
One fundamental characteristic of the US V-Model is that time and maturity move from left to right and one cannot move back in time. All iteration is along a vertical line to higher or lower levels in the system hierarchy, as shown in the figure.[3][4][7] This has proven to be an important aspect of the model. The expansion of the model to a dual-Vee concept is treated in reference.[3]
As the V-model is publicly available many companies also use it. In project management it is a method comparable to PRINCE2 and describes methods for project management as well as methods for system development. The V-Model while rigid in process, can be very flexible in application, especially as it pertains to the scope outside of the realm of the System Development Lifecycle normal parameters.
Advantages
These are the advantages V-Model offers in front of other systems development models:
- The users of The V-Model participate in the development and maintenance of The V-Model. A change control board publicly maintains the V-Model. The change control board meets once a year and processes all received change requests on The V-Model.[12]
- At each project start, the V-Model can be tailored into a specific project V-Model, this being possible because the V-Model is organization and project independent.[13]
- The V-Model provides concrete assistance on how to implement an activity and its work steps, defining explicitly the events needed to complete a work step: each activity schema contains instructions, recommendations and detailed explanations of the activity.[14]
Limits
The following aspects are not covered by the V-Model, they must be regulated in addition, or the V-Model must be adapted accordingly [15][16]:
- The placing of contracts for services is not regulated.
- The organization and execution of operation, maintenance, repair and disposal of the system are not covered by the V-Model. However, planning and preparation of a concept for these tasks are regulated in the V-Model.
- The V-Model addresses software development within a project rather than a whole organization.
No comments:
Post a Comment