Thursday, August 20, 2015

Business management software: solutions architecture and solution architects, part 1

My friend Viktor Lesiv from Arbela Techologies and I are presenting these days two sessions for the Association of Dynamics Professionals about who are solution architects and what they do on business management software implementation projects. Materials from these events will be posted on in near future. Here I will describe the main concept divided in two parts - fist one is based on our ADP session held on August 18, 2015 and another one will be based on the next session on September 9, 2015.

Implementing business software for many years we have found that a lot of our colleagues don't have a clear understanding of difference between solution architect role and other roles on a project. Sometimes a solution architect is considered just as a most experiences consultant in a team with the same duties as the others. During this presentations Viktor and I present our vision of what exactly a solution architect does, and what is the best utilization for this role. Slides for this article and for the first ADP session you can find on SlideShare .

Software architecture

There are a lot of definitions of software architecture and most of them are good enough for our purposes. Let me cite here ISO standard ISO/IEC/IEEE 42010 "Systems and software engineering - Architecture description":
Architecture is a fundamental concepts or properties of a system in its environment embodied in its elements, relationships, and in the principles of its design and evolution

I can just add to this that the difference between terms 'software' and 'solution' here is that term 'solution' in our business also includes how our software are to be used, i.e. the process of solution architecture design includes a feature selection step and solution architect not only designs what is needed to cover existing requirements, but also participates in a process of designing what will be the final list of requirements and the scope of a project.

The role of a solution architect

To define and to describe the architecture of a solution is not the main goal for a solution architect. Moreover in most cases it's not a goal for solution architect at all. The role of a solution architect is to to predict and to solve architectural problems, to avoid architectural risks and to give to project managers, executives, subject matter experts and all the other parties involved in a project enough information to ensure that they can properly plan their own activities regarding best ways to use and to implement the solution.

We can divide the duties of a solution architect into three main parts.

Up-front design

Some features should be designed before we develop and implement them to insure that we won't provide several answers for a single question and that all our decisions are concordant.


In many cases architect can develop some standards for a project - what to use and what shouldn't be used. Standards simplify a solution and can make it less expensive and less buggy.


In general planning of resources and deliverables is not a solution architect's responsibility but a solution architect should participate in planning activities and take responsibility for their technology part. Solution architect provides team with estimations and information on dependencies between features, skills, technologies and so on.

Planning process

Two good examples of involvement of a solution architect info a planning process are feature selection and development of a project roadmap.

The purpose of feature selection process is to get the maximum effect for the customer with the minimum effort for both parties.

The typical feature selection process includes the next steps:
  • Describe the main purpose of a solution and collect initial list of business requirements related to this purpose or to a potential solution. All the business requirements should be written down using only business terms, nothing about specific software to be scored from a business point of view. There can be a dozen of main business requirements for a single project, maybe less
  • Break each business requirement into main, 'epic' features. Epics should be described in terms what software should be able to do when a business requirement says what the business should get. Epic is a place where the value will meet costs, so if the purpose of business requirements is to get a perfect assessment of a planned value, the purpose of creation of a list of epics is to define the result provided directly by the implementation team
  • Break each epic feature into technical features for estimation purposes. Architect don't have to define here each feature in detail, the goal is only to estimate the cost of each epic. So we can say that to craft some functionality we should create two journals, several usual tables and a couple of reports and it will take three man-weeks to make it
  • Define main constrains, dependencies and missed opportunities
  • The most interesting part - the feature selection itself, that should be performed together with the sales team and with the customer. The result will be a project scope and a list criteria of success for the project. Also all the parties will get a list of features that will be used to plane all the next activities
When we know what and how (in general) will be done on the project we can create a roadmap to precise when we will get the main parts. But maybe now you can ask a good question: "Sorry, are we talking about an agile? In this case our plans for the second half of the project can be changed many times during the first half! It's not agile to create plans long before we start to execute them!". And you'll be right. On any project we try to be as agile as we can end to deliver every single part of a solution as fast as we can and not to invest in those parts we are not doing right now. But when we do anything we should give the name and imagine the scope of our final aim. So the goal for a project scope and for a project roadmap is to give names and to define a shape.

Project roadmap is a description of main milestones - names, dates, and lists of activities external to the project that are linked to a certain milestone. We should include there planned changes for customer's business, our planned marketing activities, planned team changes and so on to ensure that every part of our solution will be used upon release and the we are ready to deliver the solution in a planned timeframe.

In the second part of this series we will describe some techniques usually used by solution architects in their work - estimation, technology mapping and working with feature changes and with risks. Your feedback here in comments, on slideshare or to Viktor's and mine emails will be greatly appreciated.


  1. You've made some decent points there. I looked on the net for more info about the issue and found most people will go along with your views on this site. Project Management Software

  2. Breaking down information about the present condition of your stocks is one of the conventions of exchanging and can be entirely troublesome for beginners to take after and figure out how to accomplish for themselves.navigate to this website

  3. There are a lot of such services that you can afford directly from the internet. These institutes can provide you with the training as per the working environment of the Revit Structure 2015

  4. When designing a building, Cedar Rapids architects are able to help their customers achieve their goals. Whether someone is looking for a spacious kitchen or a small office, they can count on an architect to help them achieve this while staying within their budget. They are able to help with interior and exterior designing of many different kinds of near me

  5. We studied your blog. We found it interesting.
    We generally works with Project Management Software to make a plan of constructing and designing projects. Visit our page for more information.

  6. Thank you so much for sharing this informative blog. Your technical information is really useful for me. Keep update your blog.
    Amazon Web Services Training in Chennai | Amazon Web Services Training Institute in Chennai

  7. Your Task Management Tool must be easy to set up and run free trouble. The last thing you want is a new level of technical problems or a system that requires a dedicated technical person to perform.

  8. Needed to compose you a very little word to thank you yet again regarding the nice suggestions you’ve contributed here.

    aws training in chennai

    advanced aws training in chennai

  9. Great Post! Thank you such a great amount for sharing.
    best project management software

  10. I found so many interesting stuff in your blog especially its discussion. Really its great article. Keep it up. martyn pattie

  11. For many go!! today, there are many challenges that come along inhibiting success. It is, therefore, important to know the pitfalls that one can run into and the possible solutions.

  12. As more and more people become interested in adopting a whole foods lifestyle it is very important that people understand why whole foods are better for them as opposed to the foods that most people consume every day. Eating whole foods is not a diet but actually a decision that is made by an individual to only consume the foods that are the healthiest for their bodies. Whole foods are not processed and they do not contain a lot of different substances that a person can barely pronounce. How to Calculate Depreciation Expense

  13. This comment has been removed by the author.

  14. This information is meaningful and magnificent which you have shared here about the small business. I am impressed by the details that you have shared in this post and It reveals how nicely you understand this subject. I would like to thanks for sharing this article here. Unexpected Death of a Business Owner


  15. Thank you for this brief explanation and very nice information. Well, got good knowledge.
    Best graphic design company chennai

  16. Fast personal loans can be availed easily online. Simply go online and research for the lenders offering these loans at competitive rates. Payday Loans Chattanooga

  17. No matter how professional or for how long the software development company has been operating, the planning is not an easy phase to follow.Open Source Crowdfunding Software

  18. In talking with many different friends, colleagues, and various martial artists turned instructors on Facebook; I have come to find that there's a lot of people that don't have any idea how to begin their business. I was talking with my wife the other day really wanted to write some things down to help those starting a business get a good footing and a reference point to start from. I am going to attempt to make this a multi part series to help all of you interested.

  19. thanks for this usefull article, waiting for this article like this again. תפקידו של יחצ

  20. The popularity of video games has led to the expansion of the industry and technology advances. Today, there are many different How To Get Discord Nitro For Free types and the genre is still expanding rapidly. One video game differs from another by its gameplay, category and interaction.

  21. General information on putting a business plan together, groups that free Minecraft pocket edition polish rough draft plans and funding sources to consider once your plan is done. This includes marketing, legal basics, expenditure lists, etc.

  22. This design is spectacular! You obviously know how to keep a reader amused. Between your wit and your videos, I was almost moved to start my own blog (well, almost…HaHa!) Fantastic job. I really enjoyed what you had to say, and more than that, how you presented it. Too cool! free cash app money

  23. I just loved your article on the beginners guide to starting a blog.If somebody take this blog article seriously in their life, he/she can earn his living by doing blogging.thank you for thizs article. best devops online training

  24. A very awesome blog post. We are really grateful for your blog post. You will find a lot of approaches after visiting your post. Bitcoin Trader