Print

Except for the most risk-sensitive industries, it’s my assertion that any sizable organization should evolve to the point where it is generally either an Early Adopter or Early Majority user of technology.  Furthermore, an organization should strategically chose certain technology domains that are key points of competitive differentiation where they are Innovators. Consistently and correctly selecting when to be an early adopter is a great indication of organizational maturity and the ability to adapt competently.

Organizations struggling to adapt have a tendency to be insular, that is, they predominantly look inside and not outside for solutions. Unaware of industry offerings until late in the game, innovations eventually get brought in-house and can be touted as novel when for industry they are not. From personal experience, a 5 year lag in the uptake of new technologies is not uncommon.

An organization on the path to being a competitive software provider must instill in its culture the value of adaptability, cultivating it across all facets of the business. An intentional culture of adaptability provides the framework for transformation. Never is this more important to follow than when recruiting, developing, and retaining employees.

 

 

Employee Mismatch with the Emerging Organization

An organization embarking on the journey to become a software company is likely not composed of the right type of employees. The more pervasive this problem, the more difficult the transformation journey. From past experience, the alignment of the employee with the emerging organization can be categorized by employee state:

Given that employees are the lifeblood of change, it is important for an organization to know the personal qualities of their next generation employees and to seek out such people. Without being overly prescriptive, successful software companies for the modern era will have employees that are:

Immature Software Engineering Practices

For non-trivial sized organizations, robust software engineering practices and their systematic application to deliver software products consistently requires years of maturation. Each wave of technology advancement necessitates software engineering practice improvement.

Experience suggests that even before building out practices for new technology advancements, organizations typically must first strengthen their existing software practices. For example, in the days of SOA, organizations I worked with did not have strong enough design practices to build out the SOA variations of those practices. For an organization becoming a software company, the gaps of existing practices can be non-trivial inhibitors that must be identified when coming-up with a realistic improvement plan.

With a plan in place, an organization becoming a software company must diligently mature its software engineering practice, remediating gaps and obtaining legitimate mastery of the new practices of the day. For example, if the organization is rolling out an Agile practice, it needs to doggedly pursue competency until it is excellent. This is very much the organization becoming a software specialist at the enterprise level, which is easier said than done. Lacking a baseline of mature software engineering practices coupled with not having an employee pool with technical depth can cause the transforming organization to not master the practices of the day, disadvantaging the organization for the next wave of practice adoption. Imagine the problems that would result if building a house from the ground up where first the property lot is only partially prepared, and then the foundation is built only half right, and then the flooring is added but not up to code, etc. Under analogous circumstances, the organization becoming a software company will not likely resemble best-in-industry competitors and pervasive organizational problems will likely drive problems into developed products.

For the transforming organization, there are no shortcuts to maturation. The organization must plot a realistic course and achieve excellence at each step of its journey.

Substandard Software Development Infrastructure

Just as with software engineering practices, the development infrastructure to build and run software is established over time as a software organization matures. Industry leading software companies have a rich set of tools and runtimes. From a continuous integration and continuous delivery pipeline to reusable libraries and everything in between, engineers are enabled to build software products as this infrastructure makes them efficient and the development process more enjoyable. Organizations becoming software companies will likely have to make an investment in infrastructure for several years to improve development execution. There seems to be a tendency for leaders not coming from a technology background to have difficulty accepting the necessity and/or size of this investment. Leaders growing-up in software companies readily understand that the value proposition, though indirect, is nonetheless strong. Good infrastructure makes software engineers efficient, reducing the friction of getting work done so that products inevitably get released faster. Just as important, it keeps software engineers happy and that has numerous benefits, including the retention of top talent.

Lack of Innovation

An organization can survive a long time by just developing the capacity to readily adopt new technologies and technical approaches that others in industry pioneer. This is the first bar that a non-technical organization should attempt to achieve and one that rewards nicely. This necessarily requires active participation in industry including conferences, standards bodies, online forums, and industry consortiums.

When you are a company that does not yet regularly produce industry-leading innovation but instead largely follow industry evolution, it indicates lack of engineering excellence, implicating engineer quality and likely quantity as well.

When you are a company that does not yet regularly produce industry-leading innovation but instead largely follow industry evolution, care must be taken to avoid ill-advised technology adoption. An organization transforming to a software company may not have the expertise to separate hype from new technologies that can deliver business value as purported — causing a lemming type following effect where the organization tends to adopt everything that is new without proper vetting. The organization needs to become a discerning adopter where employees can critically evaluate technologies, filtering out those that are not technically sound as well as those that are not a good fit for the specific needs of the business. This typically involves a shift from passive adoption after-the-fact to proactively seeking out new technologies that are a good fit for problems the business needs to solve.

Employees that are used to following and not innovating technology may feel uncomfortable with novel solution proposals, not trusting internal innovations due to an over-reliance on industry players telling them what is right. This will slow down the journey to becoming an innovative company and may frustrate newly acquired employees brought in to help transform the organization.

Inevitably, the transforming organization needs to raise the bar and become consistently innovative. There is a lot to say on how to achieve this but it starts with hiring technically creative people, establishing an organizational culture that supports risk taking, and intentionally providing opportunities for innovation to occur. These are yet more areas that necessitate transformation where challenges must be overcome.

The Reality

It’s not really that easy for an organization to become a software company if that is not its roots. Some degree of transformation is certainly possible and may be sufficient to compete in industry. Can an organization transform to the point that it is indistinguishable from an organization that started out as a software company? From what I have seen so far, no. Perhaps that level of transformation requires many years in the making.

 

It’s hard to believe that software is even more critical to business success than a few years ago, but it’s a reality that the livelihood of many historically non-technical corporations now depends on growing a software development competency that is the foothold of their competitive advantage and/or their ability to execute — like it or not. Ready or not.

Over the years, I’ve seen and helped drive new technology and approach adoption, typically hired into organizations that did not have requisite expertise in-house; serving as a catalyst for change, an arbitrator, and necessarily an internal educator. The fundamental software transformations of the last decade or so have included for me: Service Oriented Architecture, Agile, REST, Microservices, and the Cloud. Take a look at A Decade of Evolution in Architecting Reusable Software for a synopsis of the technical evolution driven by these transformations.

Having lived through multiple waves of technology adoption while working at a diverse set of organizations has been an eye-opening experience, giving me an appreciation for the challenges that non-technical organizations face to become software companies. The largest and most likely impediments to transformation are shared below. While this story is anecdotal in nature, trends observed across transformational initiatives over the years provide some substantiation for the patterns of challenge discussed.

Lack of Organizational Adaptability

The single-most important factor of transformational success is if change is a key competency of the organization where this is not only an explicitly stated precept but also pervasively supported and pursued across the enterprise. If it is, the organization has likely got several transformations under its belt and is poised for the next wave of change. If it’s not, then people, process, and tooling are likely not up to the task of change, or at least of changing efficiently.

A key quality of an organization is its technical adaptability — a measure of how readily it can adopt new technologies and technical approaches for competitive advantage. Organizations born in the software industry are accustomed to and able to perform in cadence with the Silicon Valley pace of innovation. For corporations used to competing in slower industries, it can be quite a challenge for them to keep up. Moore’s Technology Adoption Curve provides a good framework for categorizing an organization’s adaptability.