There is some concern among design engineers that if
organizations actually achieve CMMI Level 5 in their Systems Engineering
processes the organizations can replace their design engineers with
computers. It is possible that among the
managers that think about such esoteric things there may be some who actually
want this to happen.
A Correspondence in the INCOSE Journal, Systems
Engineering, appears to indicate that there will always be a need for
design engineers for the really interesting problems. William L. Chapman, Jerzy Rozenbilt, and A.
Terry Bahill, in “System Design Is an NP-Complete Problem,” SE, Vol. 4,
No. 3, 2001, map the Knapsack Problem to the System Design Problem. The Knapsack Problem has been known to be
“NP-Complete” for over 30 years. The
technical implication of this is that “designing optimal systems with
deterministic, polynomial time procedures is not possible.” The article states, “This is the primary
reason why engineers do not try to produce optimal systems: They merely produce designs that are good
enough.”
I think this sort of says that you can have Requirements
Driven Systems Design for a limited domain.
You can have requirements driven design for “special-purpose systems.” However, for general-purpose systems, the
best you can do is verification that the requirements are met. The design is selected to meet the
requirements and the design process is “aided” by the requirements but it is
not driven by the requirements.
The closing paragraph of the INCOSE article touches all the
bases, it states that philosophers have pondered the type of problems that are
solvable: They System Design Problem seems to be solvable. Theoreticians have worried about how long it
might take to find solutions for certain classes of problems: Because the
System Design Problem is NP-complete, finding an optimal solution could take an
infinite amount of time. Behaviorists
have shown that humans seek satisficing rather than optimal solutions. And, academicians have proven that “the job
of a systems engineer is hard, in fact, NP-hard.”
The reader is encouraged to figure out how to explain to the
customer that he (the customer) should not require optimal solutions and also
how to explain to the customer that the main reason for not requiring an
optimal solution is that the design problem is “NP-hard” rather than because
our design processes are “immature. “