Software Engineering, Process Improvement, and Experience Management: Is the Nexus Productive? Clues from the Indian Giants

Software Engineering, Process Improvement, and Experience Management: Is the Nexus Productive? Clues from the Indian Giants

Neeraj Sharma, Kawaljeet Singh, D.P. Goyal
DOI: 10.4018/978-1-4666-2958-5.ch011
OnDemand:
(Individual Chapters)
Available
$37.50
No Current Special Offers
TOTAL SAVINGS: $37.50

Abstract

Software engineers have always been experimenting with various models in an endeavor to improve upon software processes. Recently, a new area of software process improvement through experience management has got attention of the software engineering community. Software developers are experimenting with experience management to improve software process. This chapter explores the role of experience management in mitigating the effects of software crisis and investigates the current state of EM in Indian software engineering environment. The chapter discusses the need and integration of knowledge and experience management practices in software engineering environments. The chapter begins with the discussion of the ills of software engineering, classically referred to as “software crisis,” like late delivery of the systems, ill-functionality, and cost overruns, and justifies how managing the knowledge and experience of software engineers and practitioners can ward off these evils. The chapter then discusses the models and methodologies for knowledge and experience management in software engineering. Finally, the chapter sheds light on the major works carried out in this area and suggests possible future research avenues in this domain.
Chapter Preview
Top

Introduction

Software has become ‘woven into the threads of our daily lives’ (Glass, 1996). It has become an inherent constituent of survival for almost all organisations as well as for individuals in today’s world of competition. May it be telecommunications, transportation, medical services or the defence of a nation, software is a critical component. With Internet and mobile technologies becoming omnipresent, and growing use of embedded software in consumer products, individuals are increasingly becoming dependent on software. For this ever increasing dependence over software, problems in developing software can have ravaging effects not only at individual and organisational levels but also at national and international levels. As a result, the improvement of software development processes has become the pressing area of concern for software engineering (SE) professionals and researchers.

Software engineering is a highly intricate, multi-stage process, usually involving teams of multi-domain experts and professionals working through different phases and activities, sometimes even beyond the boundaries of geographical space and time. Complexity in the field is further aggravated by continuous technology revisions and replacements. With the successful completion of every new project, new proportions in the SE knowledge are added. Even failures in the project execution lead to the generation of new experience that was not already known. Thus knowledge in SE is constantly growing, leading to another kind of problem – keeping track of what this knowledge is, where it is, or who owns it. Managing this knowledge in a systemic way and treating those who possess knowledge as valuable assets in an organisation, is the most potent solution to leverage the knowledge of individuals within the organisation.

Software engineering organisations qualify to be the perfect candidates for experience management initiative because of the knowledge-intensive nature of SE tasks (Birk et al., 1999; Rus and Lindvall, 2002). Understanding and balancing user requirements, applying the most appropriate development methodology, choosing suitable tools, and storing project related experience are some of the examples which justify the knowledge-intensive nature of the software engineering discipline. Software development, like any other design work, is not rigid mechanical manufacturing process. Rather, it has a strong creative component involving human and social interaction that cannot be totally pre-planned (Conradi and Fuggetta, 2002). That is why we develop software and not produce it. Every person involved in software development has to make a variety of decisions, each of them with several possible options, in contrast to a production process which is mostly structured and programmable. Choice of what software to develop, selection of the team-members to carry out the project, selection of technique of programming, finalization of design from among many available alternatives, selection of kinds of tests and test cases for testing the final product, ways of providing user-manuals or help are some of the examples of the cross-roads which every software engineer faces. What helps software engineers make the ‘right choice’ when in situation of doubt? Well, most of the time it is their personal experience, gut feeling and intuitions that guide the software engineers. But for bigger projects, involving large group of people, knowledge sharing among individuals in the team is indispensable. And this is where experience management comes into picture.

The major objective of the chapter is to study the use of experience management (EM) systems in software engineering environments. It is especially interesting to study this in a setting with people who are very skilled in using computers, like people developing software. The chapter also investigates the current EM practices followed by Indian software engineering organisations. For the purpose of this study, an exhaustive literature search has been carried out. For the empirical evidence of EM in Indian SE environment, five major SE companies in India were selected randomly. Primary data was collected through interviews and secondary data was collected from internal documentation and official websites of the companies.

Complete Chapter List

Search this Book:
Reset