Chapter 12. Agile (Adaptive) Project Management
12.1 Introduction to Agile
In the 1980s and 1990s, software development teams started to have serious problems with developing and finishing their software projects, which were getting more complex with more computer power and digitalization of businesses and organizations[1]. Project managers and developers faced more problems using the traditional waterfall approach (Figure 12.1.3). The development of software necessitated more collaboration among the project manager, developers, testers, and users, as well as constant feedback from the users. Besides, new requirements were emerging while the software was being developed, and the client and end users were not always happy with the final product when they had the chance to see it after some time passed. Therefore, new methods emerged among software developers leading this type of project. The “Lean” methodology, created by Toyota for its production system and utilized by many manufacturers, inspired many software developers. In addition to the lean manufacturing process, the just-in-time process and total quality management movement were other influencers of agile project management[2]. Furthermore, Kanban, a process improvement method in manufacturing, was adapted to the software development life cycle.
As indicated above, new methods emerged in the 1980s, mostly in the 1990s, as a response to some of the challenges developers faced when using a waterfall approach. One of the first to become popular was Rapid Application Development (RAD). James Martin, an IT consultant, developed an approach through which he divided the process into four distinct phases, namely, (1) requirements planning phase, (2) user design phase, (3) construction phase, and (4) cutover phase[3]. It involved creating prototypes and using them to elicit requirements, validate designs, and evolve toward usable solutions (Figure 12.1.1). RAD itself led to the development of alternative approaches as well.
There has been a diversification of agile methods, called lightweight methods, compared to the heavyweight waterfall models. The most popular methods were Crystal methods (1992), Dynamic Systems Development Model (DSDM) (1995), Scrum (1995), Feature Driven Development (FDD) (1997), Extreme Programming (XP) (1999), and Adaptive Software Development (ASD) (2000). Through the 1990s, several alternative ways to organize and structure the development of software products emerged, as mentioned above, and they eventually were nested under “Agile” in 2001 with the “Agile Manifesto.”
12.1.1 Agile Manifesto
17 people, the pioneers of agile methods, met in 2001 at Snowbird Ski Resort in Utah to talk, ski, relax, and try to find common ground between their thoughts on software development[5]. They represented the leading thinkers from XP, Scrum, DSDM, ASD, Crystal, FDD, Pragmatic Programming, and others who wanted a viable alternative to traditional heavyweight and documentation-driven development processes. They published the “Agile Manifesto” that embodied the values they all believed in and a set of guiding principles (Figure 12.1.2)[6]. Thus, the Agile Alliance was born[7].
Twelve Agile Principles behind the Agile Manifesto are listed below[8]:
- Our highest priority is to satisfy the customer through early and continuous delivery of valuable software.
- Welcome changing requirements, even late in development. Agile processes harness change for the customer’s competitive advantage.
- Deliver working software frequently, from a couple of weeks to a couple of months, with a preference for the shorter timescale.
- Business people and developers must work together daily throughout the project.
- Build projects around motivated individuals. Give them the environment and support they need, and trust them to get the job done.
- The most efficient and effective method of conveying information to and within a development team is face-to-face conversation.
- Working software is the primary measure of progress.
- Agile processes promote sustainable development. The sponsors, developers and users should be able to maintain a constant pace indefinitely.
- Continuous attention to technical excellence and good design enhances agility.
- Simplicity – the art of maximizing the amount of work not done – is essential.
- The best architectures, requirements and designs, emerge from self-organizing teams.
- At regular intervals, the team reflects on how to become more effective, then tunes and adjusts its behavior accordingly.
12.1.2 Differences between Waterfall and Agile Methods
As shown in Figure 12.1.3, the process is linear and sequential in the waterfall (predictive, traditional) project management approach. Project teams should finish one stage to proceed with the following stage. As seen in Figure 12.1.4, the agile (adaptive) project management approach compresses the sequential phases in small timeboxes. Therefore, agile teams work on a limited number of requirements (i.e., user stories) at a time, and they can receive frequent stakeholder feedback at the end of each timebox when they create a partial working product.
The frequent interaction with the client and stakeholders offers an environment where the frustration level of stakeholders is minimized. Nevertheless, agile methods may not be appropriate for all projects. The waterfall project approach may work better when:
- Requirements are very well understood and can be fixed before the implementation begins.
- Expectations of clients or customers from the product are stable, and substantial changes can be avoided.
- The stakeholders understand the technology and the tools utilized very well, and changes that may affect the project’s progress are not expected.
- The duration of the project is relatively short.
- The uncertainty is at a low level.
- Resources are available and easy to acquire.
Therefore, we can implement a waterfall project when we expect low uncertainty and easily define the project scope, product scope, and project constraints with unambiguous procedures. The production domain and processes involved are usually well understood, and there are typically low levels of execution uncertainty and risk[9]. However, if we cannot define the product scope and the uncertainty level is high, an agile approach would be better to move gradually by clarifying the requirements and uncertainties with the active involvement of clients and stakeholders.
In agile projects, client and stakeholder involvement can be provided constantly since product owners are a part of the team, and the increments are reviewed by the product owner and the client frequently. In waterfall projects, the interaction with the client is deferred to the end of a phase, for instance, when the software coding and testing are complete. However, in real-life projects, teams often implement a hybrid approach, which blends the waterfall approach and some agile principles, such as client involvement and feedback.
Grocery LLC Decides on the Project Approach for the “Self-Checkout Stations Project”
As discussed in section 1.2, the grocery chain Grocery LLC is considering establishing self-checkout station areas in all fifty branches to find a solution to long lines in front of the current checkout stations where the cashiers work. The project selection committee discussed the solution and decided to implement this project. The business analysis team surveyed managers and employees and interviewed customers as part of requirements elicitation. Besides, the team visited the competitors’ markets and did market research to understand possible solutions in the market better. The team concluded that self-checkout has been increasingly deployed in many grocery store and pharmacy chains (e.g., Walmart, Target, CVS) across the United States, and the manufacturers and service providers are experienced. Therefore, the sponsor, project manager, and relevant departments met to discuss the project management approach. They decided to implement a waterfall approach supported by continuous stakeholder interaction, as with agile methods.
- Managers, employees, and customers conveyed their requirements. The analysis revealed that requirements are consistent with the current implementations and the research consultancy company’s report. Therefore, it was concluded that requirements are very well understood and can be fixed to a large extent before the implementation begins. However, to keep up with technological advancements and to be prepared for risks such as new waves of pandemic, it was decided to establish a continuous interaction and feedback system with the stakeholders.
- Experienced companies provide competitive prices to acquire systems. They have implemented numerous projects across the United States and have comprehensive knowledge of current and upcoming technologies.
- The duration of the project is eight months.
Grocery LLC Decides on the Project Approach for the “M-Commerce Project”.
As discussed in section 1.2, the grocery chain Grocery LLC considers having a better online presence by creating a mobile app and optimizing the website for mobile devices in particular due to the negative effects of pandemic on the number of in-store customers, hence significantly decreased revenue and profit. In the initiation stage, the project manager prepared a report justifying the need for conducting an agile methodology, i.e., Scrum, during this project to accelerate the pace and achieve the outcome in a relatively shorter time, receive constant and timely feedback from the employees and customers, keep a healthy interaction with the stakeholders, and adjust the specifications to the fast and unprecedented changing technologies and socioeconomic conditions. Since it was not easy for the project manager and the team to oversee the near future in a turbulent environment (e.g., COVID cases and hospitalizations rocketing to the peak in a very short time), the sponsor and the project steering committee supported the project manager’s decision to implement an agile method. The Scrum cycles (sprints) were set as two weeks so that a working app and mobile website could be developed gradually with some of the requirements and functions at each sprint’s end, allowing frequent end-user feedback and interaction.
- Rothman, J. (2017). Create Your Successful Agile Project: Collaborate, Measure, Estimate, Deliver. Pragmatic Bookshelf. ↵
- Cobb, C. G. (2015). The project manager's guide to mastering Agile: Principles and practices for an adaptive approach. John Wiley & Sons. ↵
- Martin, J. (1991). Rapid application development. Macmillan Publishing Co., Inc. ↵
- Adapted from Martin, J. (1991). Rapid application development. Macmillan Publishing Co., Inc. ↵
- . Retrieved from https://agilemanifesto.org/history.html. ↵
- Retrieved from https://agilemanifesto.org/. ↵
- Visit https://www.agilealliance.org/ for more information. ↵
- Retrieved from https://agilemanifesto.org/principles.html. ↵
- Project Management Institute. (2017). Agile Practice Guide. Project Management Institute. ↵