A distributed development project is a
research and development
Research and development (R&D or R+D), known in Europe as research and technological development (RTD), is the set of innovative activities undertaken by corporations or governments in developing new services or products, and improving existi ...
(R&D) project that is done across multiple business worksites or locations. It is a form of R&D where the project members may not see each other face to face, but they are all working collaboratively toward the outcome of the project. Often this is done through
email, the
Internet and other forms of quick long-distance communication.
Mitch Kapor
Mitchell David Kapor ( ; born November 1, 1950) is an American entrepreneur best known for his work as an application developer in the early days of the personal computer software industry, later founding Lotus, where he was instrumental in deve ...
,
How to Build a Successful Company
', lecture to Stanford University
Stanford University, officially Leland Stanford Junior University, is a private research university in Stanford, California. The campus occupies , among the largest in the United States, and enrolls over 17,000 students. Stanford is consider ...
entrepreneurship students, 2008-01-16. Distributed development was largely pioneered by the
open-source software community.
It is different from
outsourcing
Outsourcing is an agreement in which one company hires another company to be responsible for a planned or existing activity which otherwise is or could be carried out internally, i.e. in-house, and sometimes involves transferring employees and ...
because all of the organizations are working together on an equal level, instead of one organization
subcontracting
A subcontractor is an individual or (in many cases) a business that signs a contract to perform part or all of the obligations of another's contract.
Put simply the role of a subcontractor is to execute the job they are hired by the contractor ...
the work to another. It is similar to a
virtual team but with a research element.
Characteristics of distributed development
Developers are distributed across multiple locations and work on the same project or product. The reasons for the distributions do not matter, they might include the availability of resources in different locations, closeness to certain clusters, proximity to customers or cost advantages.
People might specialize in a distributed development environment, but they actively collaborate to achieve the common goal. There must be a program lead or project manager somewhere in the project management mix. In a distributed environment, project members share ideas, information and resources. One key requirement is that all communication must be open to all involved, and not limited to those in the same office building. This is usually achieved by using internet-based collaboration. Communication tools commonly used include
GitHub, and
wikis.
Distributed development is one of the highest forms of collaboration in any
engineering or
scientific R&D environment. It is typically not a barrier to business success, but it can range from being somewhat of a burden to difficult to achieve, since it requires high management capabilities, an excellent communication environment, a politically free environment, a highly efficient infrastructure, a well-developed organization chart, and frequent interaction. Most important, management needs to believe in the set-up and put measures in place to reward compliance, as well as be very strict with those who do not comply. According to
entrepreneur Mitch Kapor
Mitchell David Kapor ( ; born November 1, 1950) is an American entrepreneur best known for his work as an application developer in the early days of the personal computer software industry, later founding Lotus, where he was instrumental in deve ...
, many companies are doing distributed development successfully.
Success factors
There are several disadvantages to distributed development. Studies have shown that employees that all work in the same office are better at coordinating their work and more productive. Similarly, software applications that are tightly-integrated can be very difficult to develop using distributed development. For these reasons, many large companies, including Facebook, require all employees to work in the same office.
Despite this, there are several advantages to distributed development for a business. It allows companies to hire a more diverse workforce, including employees that wish to work at home or don't wish to move long distances. It allows companies to hire quality workers for a lower cost, as opposed to the very high wages in Silicon Valley. Distributed development is often more suitable for modular software, where different parts of the program can be developed separately.
There are three main success factors for a distributed development project:
#Select and/or recruit good, strong, highly skilled people.
#Spend some money for face-to-face meetings, especially at the beginning of each major project.
[ Daniel Ek, A Playlist for Entrepreneurs, lecture to ]Stanford University
Stanford University, officially Leland Stanford Junior University, is a private research university in Stanford, California. The campus occupies , among the largest in the United States, and enrolls over 17,000 students. Stanford is consider ...
entrepreneurship students, 2012-05-16.
#Build an organizational design that supports working in a distributed development, including the right incentive systems.
By doing these three actions, one may obtain advantages beyond pure outsourcing or
offshoring
Offshoring is the relocation of a business process from one country to another—typically an operational process, such as manufacturing, or supporting processes, such as accounting. Usually this refers to a company business, although state gover ...
, namely much higher motivated employees in all parts of the distributed network, higher retention and certainly one gains from the diversity of the network.
Applications
Globally Distributed Software Engineering
Global Distributed Software Engineering (GDSE) is the enterprise application for a distributed development process. Companies can work in a distributed environment due to teams working in different places, or because of
Outsourcing
Outsourcing is an agreement in which one company hires another company to be responsible for a planned or existing activity which otherwise is or could be carried out internally, i.e. in-house, and sometimes involves transferring employees and ...
or
Offshoring
Offshoring is the relocation of a business process from one country to another—typically an operational process, such as manufacturing, or supporting processes, such as accounting. Usually this refers to a company business, although state gover ...
. A popular approach to distributed software engineering is
Distributed Agile Software Development.
In the past, almost all software development was accomplished by teams in which all members: the team leader, designers, developers and testers, worked together in close physical proximity.
Over the years the companies started to grow in size and complexity, which forced them to develop software globally.
Furthermore, other forces had their impact as well, for example, economic forces and
globalization started to turn national markets into global markets, which also brought more competition.
As explained earlier on
Success factors
SAP SuccessFactors is an American multinational company headquartered in South San Francisco, California, providing cloud-based software for human capital management using the Software as a service (SaaS) model.
Competitors include Workday, ...
, developing software in a distributed environment brings several advantages, which is also a factor for companies starting to develop software globally, such as:
*Lower development costs due to, for example, lower salaries in other regions of the world
*Time-effectiveness, increase the number of daily working hours
*Access to a larger skilled labor pool
*Closer proximity to a company's market and customers
Globally Distributed Software Engineering features many challenges in terms of communication. The area of study of
Communication in Distributed Software Development addresses these challenges and focuses on helping enterprises in having reliable communication channels without misunderstandings.
References
{{Reflist
Organizational theory
Information technology management