What are Stakeholder Requirements?
Introduction
Recently I have seen much discussion around the term “stakeholder requirements”. To make sense of this I have looked into the origin of the term and the related terms “(stakeholder) needs” and “system requirements”. I am particularly concerned as the authors of the INCOSE?Needs and Requirements Manual?have chosen to interpret the stakeholder requirements in a way that is counter to all my experience in over thirty years of practice, consulting, and teaching.
Where do the terms come from?
Much of the terminology around requirements originated in the software world. One of the first lessons I learnt in writing specifications was to distinguish between the “user requirements”, which defined what users wanted, and the “functional specification”, which defined what the software (system) would do. Over time, these terms were replaced by “stakeholder requirements” as a way of recognizing that people and actors other than the users would have requirements on the system, and “system requirements” to recognize the importance of non-functional aspects1.
Moving on in time, the two major standards in our field are ISO 15288?Systems and software engineering — System life cycle processes?and ISO 29148?Systems and software engineering — Life cycle processes — Requirements engineering. Interestingly, neither of these standards explicitly defines “needs”, “stakeholder requirements”, or “system requirements”. Unless otherwise stated, the definitions here are from ISO 29148, though these are consistent with ISO 15288:
requirement
stakeholder requirements specification
Although neither standard explicitly defines stakeholder needs or stakeholder requirements, ISO 15288 includes this statement, which I have structured for consistency with other definitions:
Stakeholder needs
In terms of process, ISO 29148 states:
This implies that goals or objectives can be needs and is consistent with the definition extracted from ISO 15288.
So, what are Stakeholder Requirements? ISO 15288 defines the process of defining them as (in part):
Further, from this and the definition of stakeholder requirements specification in ISO 15288, we can infer the following definition:
stakeholder requirements
We also need to define system requirements. ISO 15288 states this:
system requirements specification
ISO 15288 further defines the System requirements definition process as:
It is then straightforward to infer the following definition:
system requirements
If we are to use the terms “stakeholder needs”, “stakeholder requirements”, and “system requirements” (and there is value in doing so), then it makes sense for them to mean different things. Defining stakeholder requirements as stakeholder-owned system requirements does not add any meaning, as you should be specifying the owner(s) as an attribute to each requirement anyway. Far better would be to separate them according to the definitions given above. We can use:
The definitions I use above are consistent with decades of practice, ISOISO 15288, and the 4th edition of the handbook. If INCOSE is now choosing to define stakeholder requirements as stakeholder-owned system requirements rather than as the problem definition, then it is taking a huge risk by removing an essential concept.
The controversy
There is nothing too controversial in the above. However, ISO 29148 states the following:
The authors of the INCOSE Needs and Requirements Manual chose to interpret this as follows:
To my mind, this interpretation is based on a fundamental misreading (or perhaps it would be kinder to call it an over-interpretation) of the quoted material from ISO 29148, as that document clearly uses the term “stakeholder-owned system requirements” in a very specific and limited way that definitely does?not?cover the full meaning generally ascribed to “stakeholder requirements”. Specifically, ISO 29148 does not state that the stakeholder needs and requirements identified at lower levels?are?system requirements. Indeed, the use of “stakeholder needs” clearly implies a transformation to stakeholder requirements following the stakeholder requirements process.
A reminder, as I wrote earlier, ISO 29148 also states:
The whole point of the statement is that stakeholder needs evolve to become stakeholder requirements. In other words, they are two clearly different things that effectively represent advances in the maturity of (information about) the system of interest. It is also clear from this that stakeholder requirements are not, as the NRM has it, a subset of system requirements. If they were, then the processes would be "Stakeholder needs definition process" and "Stakeholder and System [System/Software] Requirements definition process" instead of "Stakeholder needs and requirements definition process" and "System [System/Software] Requirements definition process".
The authors of the manual are using the term “stakeholder needs” to mean what has traditionally been called “stakeholder requirements” and using “stakeholder requirements” to define a specific subset of system requirements, again going against decades of usage. Such a drastic and unnecessary change in terminology, particularly changing the meaning of a well-understood term, is potentially catastrophic and one wonders how a profession that prides itself on removing ambiguity can have allowed this to happen.
Discussion
The following discussion is based on responses given by one of the authors of?Needs and Requirements Manual, Lou Wheatcraft, and me to posts on LinkedIn. I have annotated Lou Wheatcraft’s material with [LW] and mine with [KC]. I have used Lou’s material verbatim, but in some cases have edited mine for clarity.
[LW]: the phrase comes from ISO 29148.
[KC] I guess the phrase you are referring to is “stakeholder requirements”? ISO 29148 defines these as being at the business operational level, which is not the case for system requirements. It also states:
“The Stakeholder Requirements Specification (StRS) describes the organization’s motivation for why the system is being developed or changed, defines processes and policies/rules under which the system is used and documents the top-level requirements from the stakeholders’ perspective including expressing needs of users/operators/maintainers as derived from the context of use in a specific, precise and unambiguous manner. In the context described in the BRS, the StRS describes how the organization will utilize the system as a means to contribute to the business.”
In other words, Stakeholder Requirements state the problem and the context within which it must be solved. If stakeholder requirements were just system requirements owned by stakeholders, the standards would define them as such. But that is not the case. Neither ISO 15288 nor ISO 29148 define stakeholder requirements in that way. This definition is a clear misinterpretation of what ISO 29148 states.
The definitions I use are consistent with both ISO 29148 and ISO 15288.
[LW] My interpretation is not the same as yours. I do not find it useful for me to define and manage two sets of requirements communicating the same perspective when one is all that is needed.
[KC] Although you can consider needs and stakeholder requirements as addressing the same perspective, it is better to think of needs as the draft and stakeholder requirements as the published material. Same perspective, different degrees of maturity.
[LW] I must clearly define and understand the well-formed integrated set of needs and get them baselined and agreed to. This defines the scope of the project. Then I will transform those needs into a well-formed set of system design input requirements to which I will verify the design and realized SOI against. I will, or the customer will, then validate that the verified system meets the integrated set of needs.
[KC] I don’t disagree with this. But I do disagree with the use of well-understood terminology to mean something different from what most practitioners are used to. This would be like deciding to change the meaning of strain from force per unit area to force2?per unit area.
[LW] I am not trapped in the “That’s how we have always done it” argument. If I can find a more practical and effective way, I will do it, even if not per any outdated standards that may exist, especially when those standards are not accepted not practiced by all organizations involved in product development.
[KC] I agree with this, except the last clause. It is fair to say that very few standards are accepted and practised by all organizations involved in product development. However, although not all the hundreds of organizations I have worked with over the years have used the term “stakeholder requirements”,?none?of them has ever used it in the way the?Needs and Requirements Manual?does.
[LW] In advancing the state of art, we sometimes must be willing to move forward and not be held back by the past.
[KC] Also true, but this is a clear case of taking a sledgehammer and destroying a useful, nay, vital, piece of existing terminology for absolutely no benefit.
Conclusion
I cannot agree with the usage by the authors of the manual. If we accept that usage, then there is no difference between stakeholder requirements and system requirements except that the former are owned by stakeholders (and the latter have no defined owner). If this is the case, then there is no need to have separate processes to define them, yet both ISO 15288 and ISO 29148 do have distinct processes for each.
There is no valid reason to change the definition of a term that has been in use for decades. Such a change will only cause confusion and, in this case at least, provides no benefit whatsoever.
Keith: Good points. I would agree with other comments about many organizations not following ISO standards. Seems everybody wants to it their way. I would however, offer two observations: 1. The roles and responsibilities called out for a stakeholder usually requires a great of of involvement and understanding. In my experience, traditional "Stakeholders" are usually , so to speak, above the fray. they are the ones who show up at the quarterly review meetings and are asked to concur with the requirements list. That leads me to my 2nd point. 2. Years ago, when the term stakeholder first appeared, most understood it to be a senior leader group who could make corporate decisions, decide on major project changes, was probably was the the ultimate benefactor of the work, and controlled/impacted the funding. I think we need a clear distinction between the program/program leaders who gather/generate/interpret/implement the requirements and those leaders who maintain the global picture of what the effort is expected to produce and how it will impact the business'. The later will never see 15288 or 29148. So, should we end up with two sets of Stakeholder Requirements?
Requirements Engineer | Systems Engineer | Trainer | Mentor
2 年I missed this when I first wrote the article. I wrote "In terms of process, ISO 29148 states: Defining requirements begins with stakeholder needs (or goals, or objectives) that are refined and evolve before arriving as valid stakeholder requirements." I should have emphasized this point, which is that stakeholder needs evolve to become stakeholder requirements. In other words, they are two clearly different things that effectively represent advances in the maturity of (information about) the system of interest. It is also clear from this that stakeholder requirements are not, as the NRM has it, a subset of system requirements. If they were, then the processes would be "Stakeholder needs definition process" and "Stakeholder and System [System/Software] Requirements definition process" instead of "Stakeholder needs and requirements definition process" and "System [System/Software] Requirements definition process". I have edited the article to add this point.
Chief Engineer (Instruments and Mission Systems)
2 年Keith, I am not sure how we missed your inputs in the last few years as we have been sharing content from the Needs and Requirements Manual with INCOSE members frequently. You seem to have some strong opinions on this topic and I would love to see your examples of Stakeholder Requirements in real application to see how far apart we are in what we published and what you envision. As Chair of the Requirements Working Group I would certainly support trying to understand your perspective. Although posting an article on this forum was one way to get our attention, perhaps it is not as effective as working with us directly. Please reach out to continue the conversation directly, it might be more constructive than the LinkedIn comment forum. [email protected].
Senior Consultant, Managing Member at Wheatland Consulting, LLC.; Chair of the INCOSE Requirements Working Group (RWG).
2 年Not all organizations follow 15288 nor 29148 when developing products. There are organizations out there that are quite successful that have never heard of these standards. I have been exposed to a wide variety of approaches to product development and have seen all the different approaches. These different organizations have their own handbooks, standards, and regulations for how they will approach product development. NASA's SE HB first process is "Defining stakeholder Expectations". The FDA in Title 21 part 820, clearly define what they call as "user needs" against which medical devices are validated against. PMI, SEI (CMMI), IIBA, etc. all have their own approaches. As such, when there are multiple standards, there is no standard. Whichever approach best fits a specific domain, product, organization's needs, is what is followed. The RWG NRM has considered these different approaches and has defined a set of activities that organizations can tailor and use however they see that best meets their needs. We have received an overwhelming positive response to our products. I was just in a zoom meeting where it was stated that the NRM was life changing and is the bible they are using for product development.
Learning Facilitator: Lean Startup Method (LSM), Business Analysis, and Agile, for Needs and Capabilities Analysis (NACA)
2 年On November 5, 2022, I gave a Zoom Tutorial, "Using Lean Startup Method (LSM) and Agile in Eliciting System Initial Capabilities"; sponsored by the INCOSE Chesapeake Chapter. I've given this tutorial several times since December, 2015. As motivation, I use this excerpt from ISO/IEC/IEEE 15288-2015: "The purpose of the Stakeholder Needs and Requirements Definition process is to define the stakeholder requirements for a system that can provide the capabilities needed by users and other stakeholders in a defined environment." Since 2015 I've been proving out specific process steps to develop these, "needed capabilities", for any system solution project. I call these process steps, "Needs and Capabilities Engineering (NACE)". The primary objectives of NACE are: - Identification of, "Users and Other Stakeholders", - Identification of, "Defined Environments", and - Development of, "Needed Capabilities". In addition to tutorials, in 2017 and 2018 I facilitated three NACE workshops for the, "Micro-grid (uGrid) Reference Model (RM) MBSE Project", and three more NACE workshops for the ongoing, "Resilient Hospital Reference Model (RHRM) MBSE Project". The goal is for NACE outputs to always be actionable inputs for Requirements Engineering.