A distributed development project is a research and development (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.[1] Distributed development was largely pioneered by the open-source software community.[2]
It is different from outsourcing because all of the organizations are working together on an equal level, instead of one organization subcontracting the work to another. It is similar to a virtual team but with a research element.
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, many companies are doing distributed development successfully.
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:
By doing these three actions, one may obtain advantages beyond pure outsourcing or offshoring, namely much higher motivated employees in all parts of the distributed network, higher retention and certainly one gains from the diversity of the network.
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 or Offshoring.[4] 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.[5] Over the years the companies started to grow in size and complexity, which forced them to develop software globally.[6] 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.[6]
As explained earlier on Success factors, developing software in a distributed environment brings several advantages, which is also a factor for companies starting to develop software globally, such as:[7]
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.[8]