Renaissance man in the Knowledge Age Achieving more with less

Monday 4 June 2007

Technical Practice

We have already talked at a high level what a Software Architect is and we have covered the three keys areas of practice. Here we will attempt to drill down on the technical aspects to provide an inventory of the necessary skills and experience the Architect needs to carry with him.

When we talk about technical skills, we are talking about Technology Competencies. I shall describe these in terms of three classifications, the first being the bear minimum that is expected, the second being representative of someone with satisfactory skills and the third being the required to be a leader or innovator in the field.

A. As a minimum:

  1. Has been a specialist in a given technology and has worked with that technology on a day to day basis.
  2. Currently can be considered a generalist with a very broad understanding of technologies from a vendor neutral viewpoint.
  3. Is respected by developers on a technical basis.
  4. Has current skills that allows them experiment with technologies and prototype ideas.
  5. Can contribute to the development of a system.
  6. Has an detail understanding of the application domain.
  7. Has had ownership of at least a part of an application design.
  8. Can deal with technical problems that are not clear or clouded by a number of factors.
  9. Understands the concept of abstraction and is comfortable with creating abstractions to solve problems.

B. In addition to (A) above the person with satisfactory skills would:

  1. Has a broad and deep knowledge of a number of technologies.
  2. Is able to assess the maturity of a technology against a business's requirements.
  3. Is abreast of the latest technology developments and research.
  4. Has had experience managing a commercial application development.
  5. Ability to work closely with developers to understand key elements of critical technologies.
  6. Does not work at a code level day to day.
  7. Has designed a commercial mission critical application.
  8. Can handle high amounts of ambiguity and movable goal post.
  9. Can proceed at an abstract level but has the ability to drill down to detailed technical level as required.

C. In addition to (A) & (B) above, the person can be considered a technology leader or innovator:

  1. Can easily integrate key principles with new technologies.
  2. Can invent new technologies or apply existing technologies in new innovative ways.
  3. Can see market opportunities associated with new technologies.
  4. Has had extensive developer experience over a industries and situations.
  5. Has implemented and integrated opposing architectures in a complex organisational setting.
  6. Has worked if not in all then many of the roles within a development team and understand the challenges that face people in those roles.
  7. Understands the market offering of the organisations it's business model and its tactical and strategic advantages.
  8. Is able to resolve ambiguity and uncertain situations.
  9. Outstanding at working an abstract level across the organisation in a manner that can be directly linked back to technical details.

So as you can see the required skills go beyond coding ability and in may way coding is a cake walk compared to the other issues.

Blog Archive

"It is not all about me"

View Ray King's profile on LinkedIn Add to Technorati Favorites Creative Commons License
This work is licensed under a Creative Commons Attribution-Share Alike 3.0 License.