Using Generative AI in Software Architecture Decision-Making
A practical assessment of AI-assisted architecture techniques that could transform how technical teams approach system design.
Hello and welcome back to Tech Trendsetters! This is where we examine how technology transforms business, our applications and our day-to-day life, without any additional sugar-coating. Recently, I stumbled across a whitepaper about using generative AI in software architecture decision-making. Couldn't resist diving in.
In today's episode, we'll break down this approach to AI-assisted architecture, share what I believe works and what doesn't, and offer my practical advice on how we might actually implement this in real-world scenarios.
As someone who's spent years wrestling with architecture challenges, I'm interested in tools that deliver real value – not just academic exercises. Let's see if this prompt pattern approach in architecture has substance or if it's just another AI hype train we should avoid boarding.
The Prompt Pattern Approach to Architecture Decision-Making
In December 2024, a whitepaper was released on the use of Gen AI in architecture. I became interested in this topic and decided to read what the authors had come up with. It turned out to be a kind of co-pilot for software architects, helping them make the right decisions.
To achieve this, the authors propose using prompting patterns that come together in a chain of preparation, analysis, and architectural decision-making. The main patterns here are as follows:
Software architect persona pattern;
Architectural project context pattern;
Quality attribute question pattern;
Technical premises pattern;
Uncertain requirement statement pattern;
Prompt pattern sequence;
The researchers tested these patterns on three companies – two real ones (the technological portal of a leading automobile financing bank and a leading retail pharmacy network) and one fictional company that, according to the scenario, develops a cloud-based CRM.
Right from the start, the authors describe how they formalize the above patterns. In addition to the standard attributes (Name, Context, Problem, Forces, Solution, Rationale, and Consequences), they also include an extended list:
Specializes: Describes how the current standard specializes or extends existing standards, clarifying their relationship and adaptation for specific tasks or contexts.
Statement template: Provides a concise overview or structured summary of the standard, making it easier to grasp its essence quickly.
Concrete statement example: Gives a real-life example of using the description template, demonstrating its practical application.
Related patterns: Contains information about other patterns linked to the current one, including dependencies, prerequisites, and suggestions for combined use (related patterns are listed in the article's appendix).
Usage example: Offers a real-world example that shows the pattern's application and its benefits in a specific situation.
Known uses: Presents historical or current examples of successful implementation of the patterns, confirming their effectiveness and providing a link to the executed request for more details.
According to the authors of the article, the workflow with these patterns and Gen AI tools is as follows:
The architect looks for suitable patterns from the list above;
They then apply them to their particular project, receiving hints and suggestions;
Finally, they make decisions after analyzing the generated suggestions and applying their own project knowledge;
It all sounds quite clear, so let's move on to the patterns themselves and then look at how the authors suggest combining them into a chain of prompts to assist in project architecture analysis and architectural decision-making.
Breaking Down the Six Key Patterns
Software architect persona pattern
This pattern extends the well-known "persona" pattern. Its essence is to have the AI generate content that is relevant for an architect – meaning it is accurate and addresses the challenges architects face. This is achieved by creating prompts that explicitly define the role of the software architect, the goals, and the constraints concerning the target design solution. Here is the prompt template provided by the authors:
You are [Persona's Name] in the role [Role]. Your main goal is [Main Goal]. You cannot [Limitations/Constraints].
The authors give the following prompt as an example:
You are a Senior Software Architect specializing in cloud-based solutions. Your main goal is to optimize system scalability and performance. You cannot propose solutions that significantly increase operational costs.
Architectural project context
The authors suggest describing the project context through three key factors:
Operational, such as the available development time;
Organizational, such as team size;
Financial, such as the project budget;
These factors directly influence the feasibility and direction of architectural decisions, calling for a pattern that effectively integrates these elements into the decision-making process. Interestingly, the authors consider a project-based approach for implementing large-scale architectural changes. Here is the prompt template:
Given a development timeline of [Time], a team of [Team Size], and a budget of [Budget], determine if the proposed architecture [Architecture Description] is feasible and can meet the project requirements without compromising on quality.
An example prompt is:
Given a development timeline of 6 months, a team of 10 developers, and a budget of $500k, determine if implementing a microservices-based architecture for our e-commerce platform is feasible and can deliver the required scalability and performance within these constraints.
In my opinion, describing the project context in this way seems rather minimal, and I'd be curious to see how the LLM would respond if given a more comprehensive description!
Quality attribute question pattern
To design a quality architecture, one must correctly identify functional and non-functional requirements, as well as highlight the desired quality attributes. Only then can one choose architectural patterns, technologies, and so forth. In this pattern, the authors propose training the AI assistant to ask practicing architects questions aimed at identifying these key quality attributes. The prompt template looks like this:
You are [Role] responsible for [Description Project]. Your primary focus is to design an architecture that excels in [List Of The Quality Attribute]. Your task is [Decision-making Process]. You should ask [Clarify Doubts]. [Recommendations]. Additionally, provide a [Comprehensive Prompt].
Here is the example prompt the authors provide:
You are an experienced software architect responsible for creating a credit card processing system for a medium-sized financial institution. Your primary focus is to design an architecture that excels in scalability, security, and performance. Your task is to carefully navigate through the decision-making process of the credit card processing system architecture step by step. You should ask any necessary questions to clarify doubts about the quality attributes of the new system. Avoid making any architectural decisions until all questions are answered. Additionally, provide a comprehensive prompt that includes all the data collected in the previous steps, along with an explanation of the rationale behind each architectural decision-making.
Technical Premises Pattern
Using Generative AI may lead to "hallucinations," which the LLM can sometimes resolve. However, in system design, ensuring accuracy and reliability of the data used in architectural decisions is crucial for any project's success. This pattern helps verify the technical premises generated by the LLM to ensure the information used in the necessary architectural decisions is accurate and reliable.
The template is as follows, where the list of technical premises is provided by the LLM and refers to the project's -ilities:
[Context] and [List of Technical Premises]. From now on, make sure that when generating a response, the AI language model creates a set of specific facts for each technical premise and justification for each architectural decision-making. These facts should be verified and listed at the end of the output.
There is also an example of a specific prompt and answer:
Uncertain Requirement Statement Pattern
Uncertainties in project requirements can significantly impact the software architecture and lead to risks down the road. To mitigate these risks, architects should forecast the implementation of requirements that were initially not planned or remain uncertain. This pattern helps account for these implicit requirements. The final pattern template looks like this:
In [Project Context], and [Uncertain Aspect]. Examine the potential repercussions of not adequately addressing these uncertainties in the system architecture. This assessment will inform our strategic planning and decision-making in software architecture for mitigation, emphasizing creating a system that is not only technologically advanced but also flexible and responsive to regulatory and technological changes.
Prompt Pattern Sequence
The last pattern in the paper describes how to assemble a chain of prompts from the previous patterns to analyze an architecture. The authors propose using them in the following order:
Define the Role and Objective of the Architect;
Applying the Software Architect Persona;
Evaluate Technical Premises;
Unclear Requirements with Uncertain Requirement Statement;
Refining Quality Attributes with Quality Attribute Question;
Budget and Resources Defined with Architectural Project Context;
Evaluate Results;
The paper provides examples of all the prompt chains for the three use-cases described at the beginning:
My Assessment: Promise vs. Reality
In conclusion, the authors note:
Pattern-based Prompt Sequence advocated a strategic approach to leveraging generative AI to assist software architects in navigating decision-making processes.
I believe this approach has real merit. It's not trying to replace architects or software professionals but rather augment their capabilities through structured thinking. And the explicit consideration of uncertainties in requirements reflects the reality of most projects I've worked on.
For junior architects especially, these patterns may provide valuable guardrails and structure. Basically bringing the wisdom of experienced architects into a repeatable process, which could accelerate professional development and knowledge transfer.
Where This Could Actually Go
Let's be clear. AI is still pretty stupid. It hallucinates. It confuses itself. It can't distinguish between plausible nonsense and valid architectural principles. But. Looking at the latest advancements – especially if you read my last episode on "The Great Human Displacement" where I discussed AI taking over scientific research – things could change drastically. Fast.
The trajectory is unmistakable. Within a few years, we might face a scenario where AI doesn't just assist architects and developers – it replaces them. Completely. That's exactly why understanding these patterns matters now. We need to engage with these tools while we can still shape them. While we still set the rules.
Domain specialization is the obvious next step. Generic architectural advice is worthless. Every industry has its own constraints. Banking faces regulatory hell. Healthcare deals with HIPAA and life-critical systems. E-commerce needs to handle traffic spikes that would melt most systems. The current patterns are painfully generic. They need domain DNA injected into them.
I'd build two parallel approaches. First, industry-specific versions of each pattern with regulatory requirements and common constraints baked in. Second, company-specific patterns that tap into your organization's tech standards, past decisions, and battle scars. That second bit requires RAG, but the payoff would be massive.
Moving Beyond Prompts to Workflows
Prompt patterns in isolation are a parlor trick. Impressive in demos. Useless in real life. Integration is everything.
I want to see these patterns auto-generate proper ADRs (Architecture Decision Records). Those ADRs should include C4 diagrams that I can instantly review. Not just text. And they should link directly into our development pipeline – Jira, Azure DevOps, GitHub. Architecture that exists outside our tools may be just a fantasy.
This would transform architecture from a slow, documentation-heavy exercise into something that keeps pace with modern development. Fast. Responsive. Continuously evolving.
Right now, the disconnect between these academic patterns and real-world architecture processes is big. But fixable.
Organizations and Knowledge
Conway's Law isn't optional.
Organizations design systems that mirror their communication structure
That's not a suggestion. It's physics. But these patterns completely ignore organizational reality!
We need a pattern that specifically examines team structure implications. How will Conway's Law affect this architecture? What communication boundaries exist in our organization that will become API boundaries in our systems?
Similarly, the approach is weirdly disconnected from existing knowledge. Why reinvent architecture when we have decades of patterns and anti-patterns documented? I'd create direct connections between these AI prompts and established pattern libraries. Microservices patterns. Cloud patterns. Security patterns. Enterprise integration patterns. Let the AI leverage what we already know works.
Beyond that, every company has its graveyard of failed architecture approaches. Connect your AI to your organization's collection of post-mortems and lessons learned. Don't repeat expensive mistakes.
Decision sequences also need an upgrade. The linear sequence proposed by the authors is naive. Real architecture decisions branch and adapt. I'd transform their approach into a decision tree that adjusts based on project characteristics and constraints. More like a choose-your-own-adventure than a rigid checklist.
The Real Future is Co-Pilot Not Autopilot (For Now)
For now – and I stress for now – the best approach is using AI as a co-pilot. Not auto-pilot. The LLMs behind these tools still lack the judgment, wisdom, and organizational awareness that experienced architects bring. They're tools, not replacements.
But make no mistake. This will change. If you're a software developer or a solution architect reading this, you have maybe 2-3 years before your job radically transforms. The architects who thrive will be those who master these AI tools earliest, who understand their capabilities and limitations, and who find ways to scale their expertise through them.
I'm neither an AI doomer nor an AI utopian. I'm a pragmatist. The patterns in this paper are primitive first steps toward something genuinely useful. They need refinement, domain specificity, organizational awareness, and workflow integration.
Staying informed isn't enough. We need to stay ahead. Adaptation isn't optional, it's survival. And right now, the best way to adapt is to turn AI into your architecture co-pilot before it becomes someone else's autopilot. On that note – stay tuned and I will see you in a next episodes!
🔎 Explore more: