System and Solution Architect/Engineering

Image

Engineering is a great profession. There is the satisfaction of watching a figment of the imagination emerge through the aid of science to a plan on paper. Then it moves to realization in stone or metal or energy. Then it brings homes to men or women. Then it elevates the standard of living and adds to the comforts of life. This is the engineer’s high privilege.

Herbert Hoover

The System and Solution Architect/Engineering role is filled by an individual or small team that defines a shared technical and architectural vision for the Solution under development. These people participate in determining the system, subsystems, and interfaces; validate technology assumptions; and evaluate alternatives; all while working closely with the Agile Release Train (ARTs) and Solution Train.

These individuals, or cross-disciplinary teams, take a ‘systems view’ of solution development (SAFe Lean-Agile Principle #2). They participate in defining the higher-level functional and Nonfunctional Requirements (NFRs) by analyzing technical trade-offs, determining the primary components and subsystems, and identifying the interfaces and collaborations between them. They understand the Solution Context and work with the teams, Customers, and Suppliers to help ensure fitness for purpose.

Collaborating with Solution and Product Management, Architect/Engineers play a critical role in aligning teams in a shared technical direction geared toward the accomplishment of the Vision and Roadmap. And, of course, Architect/Engineers are Lean-Agile Leaders who understand the complexities of large-scale solution development and apply SAFe Lean-Agile principles and practices to address them.

Details

Architect/Engineering personnel support solution development by providing, communicating, and evolving the broader technology and architectural view of the solution.

Architect/Engineering teams are found at both the Program and Large Solution Levels. System Architect/Engineering operates mainly in the context of the ART, where these personnel work with Agile Teams and provide technical enablement concerning subsystems and capability areas for an ART. Solution Architect/Engineering teams provide technical leadership for evolving architectural capabilities of the entire solution.

Both roles engage in close collaboration with business stakeholders, teams, customers, suppliers, and third-party stakeholders to define the technology infrastructure, decompose it into components and subsystems, and define interfaces between subsystems and between the solution and solution context.

While providing a general view of solution architecture, Architect/Engineering enables those who implement value by empowering them to make local decisions, thereby allowing a faster flow of work and better economics.

Responsibilities

Architect/Engineering teams are Lean-Agile Leaders who typically have the following responsibilities:

The Origin of the Roles in SAFe

Role of the System Architect

Architects routinely participate in software development efforts, and this function is part of SAFe. Architects work at the program and large solution levels, with their role often extending beyond the software domain to include responsibilities that enable value delivery in a technically diverse and heterogeneous multi-domain solution environment.

Role of Systems Engineering

Enterprises building cyber-physical systems (e.g., embedded systems) also rely on systems engineering—which typically encompasses multiple disciplines, including hardware, electrical and electronic, mechanical, hydraulic, and optical, as well as the software elements. The International Council on Systems Engineering defines systems engineering as follows [1]:

… an interdisciplinary approach and means to enable the realization of successful systems. It focuses on defining customer needs and required functionality early in the development cycle, documenting requirements, then proceeding with design synthesis and system validation while considering the complete problem, including operations, performance, test, manufacturing, cost and schedule, training and support, and disposal. Systems engineering integrates all the disciplines and specialty groups into a team effort, forming a structured development process that proceeds from concept to production to operation. Systems engineering considers both the business and the technical needs of all customers with the goal of providing a quality product that meets the user needs.

A Leaner Approach

It is impossible to reason about how to build complex solutions without including the roles of software architecture and systems engineering. However, a significant note of caution is warranted. The dominant, traditional methods for both strongly favor phase-gated, point-solution Big Design Upfront (BDUF) approaches. This preference is understandable because these solutions are big systems and someone has to know how to go about building them—and the BDUF model has the best available one in the past.

As noted in the SAFe Lean-Agile Principles, the BDUF approach is not supportive of product development flow, and it doesn’t produce the optimal economic outcomes. SAFe, by comparison, views software architecture and systems engineering as enabling functions for continuous product development flow. In the Lean-Agile Mindset, these roles focus on cross-disciplinary collaboration, building systems incrementally through fast, feedback-driven learning cycles, understanding and leveraging the inherent variability of the product development process, and decentralizing control.

The Compliance chapter in Part 7 elaborates on the shift from traditional phase-gated governance models to a Lean-Agile process that enables flow while still meeting regulatory and compliance concerns.

Decentralized Decision-Making

Design decisions vary significantly regarding their impact, urgency, and frequency of occurrence. This diversity suggests a need to balance centralized and decentralized decision-making (see Principle #9, Decentralize decision-making). In terms of system design, this has two implications:

Frequent collaboration supports system design, whether in the form of informal and continuous face-to-face discussions or, more regularly, in PI planning, system, and solution demos, I&A workshops, and specification workshops.

In any case, Architect/Engineers exhibit the traits of Lean-Agile Leaders:

An Empirical Approach

The success of any solution development program also depends on the organization’s ability to embrace the learnings from empirical evidence. This paradigm can challenge the traditional mindsets that support detailed, committed, early design based on reasoned but unverified hypotheses and implementation strategies. In the case where contrary evidence exists, those responsible for the initial design tend to defend the solution and ignore the evidence.

The Lean-Agile Architect/Engineering mindset relies on the firm belief that if a problem arises with the design, the problem does not lie with the people who created it. No one could have anticipated the new learnings—it’s research and development, after all. Everyone learns together. This belief is further fostered by:

LEARN MORE

[1] International Council on Systems Engineering. “What Is Systems Engineering?” http://www.incose.org/AboutSE/WhatIsSE.

[2] Leffingwell, Dean. Agile Software Requirements: Lean Requirements Practices for Teams, Programs, and the Enterprise. Addison-Wesley, 2011.