ISO/IEC 12207 explained

ISO/IEC/IEEE 12207 Systems and software engineering – Software life cycle processes[1] is an international standard for software lifecycle processes. First introduced in 1995, it aims to be a primary standard that defines all the processes required for developing and maintaining software systems, including the outcomes and/or activities of each process.

Revision history

ISO/IEC/IEEE 12207:2017 is the newest version, published in November 2017. The IEEE Computer Society joined directly with ISO/IEC JTC 1/SC 7/WG 7 in the editing process for this version. A significant change is that it adopts a process model identical to the ISO/IEC/IEEE 15288:2015 process model (there is one name change, the 15288 "System Requirements Definition" process is renamed to the "System/Software Requirements Definition" process). This harmonization of the two standards led to the removal of separate software development and software reuse processes, bringing the total number of 43 processes from 12207 down to the 30 processes defined in 15288. It also caused changes to the quality management and quality assurance process activities and outcomes. Additionally, the definition of "audit" and related audit activities were updated.[2] [3] [4] Annex I of ISO/IEC/IEEE 12207:2017 provides a process mapping between the 2017 version and the previous version, including the primary process alignments between the two versions; this is intended to enable traceability and ease transition for users of the previous version.

Prior versions include:

IEEE versions

Prior to the IEEE Computer Society formally joining the editing process (becoming a major stakeholder) for the 2017 release, the IEEE maintained its own versions of ISO/IEC 12207, initially with modifications made jointly with the Electronic Industries Alliance (EIA).[10] [11] [12] With the 2008 update came a "shared strategy of ISO/IEC JTC 1/SC 7 and the IEEE to harmonize their respective collections of standards," resulting in identical standards thereon, but with slightly different names. Those IEEE versions included:

It's also worth noting that IEEE/EIA 12207 officially replaced MIL-STD-498 (released in December 1994) for the development of DoD software systems on May 27, 1998.

Processes not stages

The standard establishes a set of processes for managing the lifecycle of software. The standard "does not prescribe a specific software life cycle model, development methodology, method, modelling approach, or technique.". Instead, the standard (as well as ISO/IEC/IEEE 15288) distinguishes between a "stage" and "process" as follows:

Stages (aka phases) are not the same as processes, and this standard only defines specific processes - it does not define any particular stages. Instead, the standard acknowledges that software life cycles vary, and may be divided into stages (also called phases) that represent major life cycle periods and give rise to primary decision gates. No particular set of stages is normative, but it does mention two examples:

The life cycle processes the standard defines are not aligned to any specific stage in a software life cycle. Indeed, the life cycle processes that involve planning, performance, and evaluation "should be considered for use at every stage". In practice, processes occur whenever they are needed within any stage.

Processes

ISO/IEC/IEEE 12207:2017 divides software life cycle processes into four main process groups: agreement, organizational project-enabling, technical management, and technical processes. Under each of those four process groups are a variety of sub-categories, including the primary activities of acquisition and supply (agreement); configuration (technical management); and operation, maintenance, and disposal (technical).[16]

Agreement processes

Here ISO/IEC/IEEE 12207:2017 includes the acquisition and supply processes, which are activities related to establishing an agreement between a supplier and acquirer. Acquisition covers all the activities involved in initiating a project. The acquisition phase can be divided into different activities and deliverables that are completed chronologically. During the supply phase a project management plan is developed. This plan contains information about the project such as different milestones that need to be reached.

Organizational project-enabling processes

Detailed here are life cycle model management, infrastructure management, portfolio management, human resource management, quality management, and knowledge management processes. These processes help a business or organization enable, control, and support the system life cycle and related projects. Life cycle model management helps ensure acquisition and supply efforts are supported, while infrastructure and portfolio management supports business and project-specific initiatives during the entire system life cycle. The rest ensure the necessary resources and quality controls are in place to support the business' project and system endeavors. If an organization does not have an appropriate set of organizational processes, a project executed by the organization may apply those processes directly to the project instead.

Technical management processes

ISO/IEC/IEEE 12207:2017 places eight different processes here:

These processes deal with planning, assessment, and control of software and other projects during the life cycle, ensuring quality along the way.

Technical processes

The technical processes of ISO/IEC/IEEE 12207:2017 encompass 14 different processes, some of which came from the old software-specific processes that were phased out from the 2008 version.

The full list includes:

These processes involve technical activities and personnel (information technology, troubleshooters, software specialists, etc.) during pre-, post- and during operation. The analysis and definition processes early on set the stage for how software and projects are implemented. Additional processes of integration, verification, transition, and validation help ensure quality and readiness. The operation and maintenance phases occur simultaneously, with the operation phase consisting of activities like assisting users in working with the implemented software product, and the maintenance phase consisting of maintenance tasks to keep the product up and running. The disposal process describes how the system/project will be retired and cleaned up, if necessary.

Conformance

Clause 4 describes the document's intended use and conformance requirements. It is expected that particular projects "may not need to use all of the processes provided by this document." In practice, conforming to this standard normally involves selecting and declaring the set of suitable processes. This can be done through either "full conformance" or "tailored conformance".

"Full conformance" can be claimed in one of two ways. "Full conformance to tasks" can be claimed if all requirements of the declared processes' activities and tasks are met. "Full conformance to outcomes" can be claimed if all required outcomes of the declared processes are met. The latter permits more variation.

"Tailored conformance" may be declared when specific clauses are selected or modified through the tailoring process also defined in the document.

See also

Notes and References

  1. Web site: ISO/IEC/IEEE 12207:2017 . Standards catalogue . International Organization for Standardization . November 2017 . 21 June 2018.
  2. Web site: New or Improved! Software Engineering Standards for Quality . Reilly, A. . American Society for Quality . 27 June 2017 . 21 June 2018.
  3. Web site: ISO/IEC 12207 Updated and Renumbered as ISO/IEC/IEEE 12207 . Bach, C. . Standards Forum . Document Center, Inc . 12 December 2017 . 22 June 2018.
  4. Web site: INCITS/SSE - Software and Systems Engineering Annual Report - April 2017 to March 2018 . Reilly, A. . INCITS . March 2018 . The cornerstone standards of ISO/IEC JTC 1/SC 7, ISO/IEC/IEEE 12207:2017 and ISO/IEC/IEEE 15288:2015, have recently completed revision to reflect a unified model set of acquisition, organizational, technical management, and technical processes for systems and software. . 22 June 2018 . 9 August 2020 . https://web.archive.org/web/20200809000646/https://www.incits.org/symposium/annual-report/INCITS-SSE.pdf . dead .
  5. Web site: ISO/IEC 12207:2008 . Standards catalogue . International Organization for Standardization . February 2008 . 21 June 2018.
  6. Web site: ISO/IEC 12207:1995/Amd 2:2004 . Standards catalogue . International Organization for Standardization . November 2004 . 21 June 2018.
  7. Web site: ISO/IEC 12207:1995/Amd 1:2002 . Standards catalogue . International Organization for Standardization . May 2002 . 21 June 2018.
  8. Web site: ISO/IEC 12207:1995 . Standards catalogue . International Organization for Standardization . July 1995 . 21 June 2018.
  9. Web site: Overview of IEEE/EIA 12207: Standard for Information Technology . https://web.archive.org/web/20081230123134/http://sepo.spawar.navy.mil/12207.doc . SSC San Diego Process Asset Library . 30 July 1998 . 30 December 2008 . 22 June 2018.
  10. Web site: IEEE 12207.0-1996 - Standard for Information Technology - Software Life Cycle Processes . IEEE Standards Association . March 1998 . 22 June 2018 . 29 June 2018 . https://web.archive.org/web/20180629105033/http://standards.ieee.org/findstds/standard/12207.0-1996.html . dead .
  11. Web site: ISO/IEC 12207:2008, IEEE Std 12207-2008 Systems and Software Engineering — Software Life Cycle Processes . https://web.archive.org/web/20180622205208/https://pdfs.semanticscholar.org/presentation/1806/1ac358b6dff0d58422fa6eaa781e0283f351.pdf . dead . 22 June 2018 . 7 December 2009 . 22 June 2018.
  12. Web site: 1SO/IEC 12207:2008(en) Systems and software engineering — Software life cycle processes: IEEE Introduction . Online Browsing Platform . International Organization for Standardization . February 2008 . 22 June 2018.
  13. Web site: IEEE Std. 12207-2008 - Systems and software engineering -- Software life cycle processes . IEEE Standards Association . January 2008 . 22 June 2018.
  14. Web site: IEEE 12207.2-1997 - Guide for Information Technology - Software Life Cycle Processes - Implementation Considerations . IEEE Standards Association . April 1998 . 22 June 2018 . 22 June 2018 . https://web.archive.org/web/20180622203023/https://standards.ieee.org/findstds/standard/12207.2-1997.html . dead .
  15. Web site: IEEE 12207.1-1997 - Guide for Information Technology - Software Life Cycle Processes - Life Cycle Data . IEEE Standards Association . April 1998 . 22 June 2018 . 22 June 2018 . https://web.archive.org/web/20180622202735/https://standards.ieee.org/findstds/standard/12207.1-1997.html . dead .
  16. Web site: Proceso: Ingeniería de Software I . Peñalvo, F.J. . Holgado, A.G. . Universidad de Salamanca . 2017 . 39 . 21 June 2018.