Critical Review of Extended Waterfall Model

Total Page:16

File Type:pdf, Size:1020Kb

Critical Review of Extended Waterfall Model International Journal of Scientific & Engineering Research, Volume 6, Issue 11, November-2015 425 ISSN 2229-5518 Critical Review of Extended Waterfall Model Rajesh H. Kulkarni, P.Padmanabham, K.K.Baseer Abstract—Software product quality improvement is a desired attribute and a strenuous effort is required to achieve that.Usability is also a desired attribute as it helps in identifying how effectively user achieves product goals.Concrete efforts to integrate Software Engineering and Human Computer Interaction exist in the form of models by many researchers. Better user experience is an oft expressed and desired quality of the products designed nowadays.Many efforts in this regard lead to various proposals of smooth integration of SE (software engineering) processes with HCI (human computer integration) for product development. One such effort is extended waterfall process model. This paper presents a critical review of extended waterfall model. It also suggests means to bring nearer the two diverse communities of SE and HCI. Index Terms— Usability, SE, HCI, Extended Waterfall Process Model. —————————— —————————— 1 INTRODUCTION He model of waterfall process refer Figure 1 in the field of T software engineering [1] has been playing a chief role Waterfall model is classic SDLC model. This model is also from the past. This model was put forth in 1950s and later, called as a heavyweight process. The lifecycle is long say six it has turned out to be a renowned model in 1970s. Its struc- months. This classic model consists of the phases: Require- ture takes the form of a cascade involving phases and it can be ment, Design, Analyze, Code, Test,and Maintain. There are viewed that the output from one phase serves as the input to other models such as Agile and RUP. In Agile Development the subsequent phase. If a single phase is considered, there the lifecycle is very small say two weeks. Requirements are will be a group of actions that several people may carry out in freezed. A scrum call is issued for not more than fifteen a simultaneous manner. The idea behind the waterfall process minutes where what today’s tasks to be done are discussed constitutes the following. (i) A linear and sequential path may and scrum master takes the onus for that. It is also called as a exist between the consecutive phases, (ii) The standards may light weight process because of shorter span of lifecycle.In be maintained at places, where the outputs or deliverables practice none of the models are followed to the tee. Every pro- could be generated or (iii) Few techniques, which aim to ject in itself is an experience. If bracketed each project is a rep- achieve the necessary output, may be suggested. The waterfall resentative of its own unique model. The reason being Re- model imparts numerous benefits.One such benefit is that it quirements are given yesterday night and the deadline for could legibly recognize the number of related phases through deliverable is within a week. It is a chaotic scenario. Most of which a process in software development should traverse. the time is spent on negotiations between client and vendor.As per Carroll et al. “Human-computer interaction (HCI) is an These phases may own varyingIJSER arrangements along with few area of research and practice that emerged in the early 1980s, changes in the scope as well as the significance and hence, initially as a specialty area in computer science embracing there is a possibility for these phases to occur in more than one cognitive science and human factors engineering. HCI has process models. Moreover, the phases involve the following: expanded rapidly and steadily for three decades, attracting (1) drawing out the requirements for specifying how the sys- professionals from many other disciplines and incorporating tem should look like at the end, (2) examining the require- diverse concepts and approaches. To a considerable extent, ments for sorting it out into functionality group and non- HCI now aggregates a collection of semi-autonomous fields of functionality group (for instance, the features), (iii) making an research and practice in human-centered informatics.”[18, 19]. architectural design for the system as well its corresponding elements, (iv) programming and executing the system, (v) The implementation and the functioning of a system will substantiating the performance of the system and its associat- be unfeasible without an integrated software engineering ed elements and (vi) subjecting the system to work in an oper- environment, which is capable of offering stability to han- ational background [2]. dle the process as well as the product. There are three lay- ers, namely, the collaboration layer, the information layer and the operational layer. The collaboration layer relies on ———————————————— the process management techniques for assisting the com- • Rajesh H. Kulkarni is currently pursuing Phd degree program in computer bined task. The information layer is one among the three engineering inJ.N.T University, Huderabad and working in JSPM NTC layers supporting the ASP system. Yet, the traditional Pune,India. E-mail: [email protected] product management systems have their centre of attrac- • P.Padmanabham is currently Director Academics in BIETin J.N.T. Uni- versityHyderabad,India,. E-mail: [email protected] tion towards the source codes or else on excellently orga- • K.K. Baseer is Phd Scholar in JNIAS-JNTUA, Anantapuramu, India, nized design details like, the transition diagrams and the India data flow diagrams. The operation layer acts as the ASP E-mail: [email protected] system’s infrastructure. IJSER © 2015 http://www.ijser.org International Journal of Scientific & Engineering Research, Volume 6, Issue 11, November-2015 426 ISSN 2229-5518 2 BACKGROUND that it still defers integration of code and testing until it is very late and when problems are harder to resolve, and hence is poor at managing risks (Kroll, et al., 2003 pp. 6, 50). The domain of software development has undergone a • SE is relatively immature in the requirements area (Suitcliffe, tremendous progress in the past forty years of research. In 2005). 1970, Winston Royce’s has granted a popular publication on • Language for communication is an issue. Improved communi- the present day waterfall scheme [3].It is this approach that cation is possible through prototypes, sketches, mock-ups, has brought about the transformation in the area of software simulations, and scenarios er (Gulliksen, et al., 2003). • development, in which the software development is imagined Communication techniques are basic. The oft-used phrase “re- quirements gathering” conjures an image in the mind’s eye to be extremely complicated and user-specific that a number that requirements are like flowers fallen overnight under a pa- of shortcomings may arise with improper arrangement.The rijatak tree, and one needs to only gather them for the morning waterfall process model serves as the conventional and typical pooja . means for developing the software.In the Waterfall process • Instead of asking users what they want and putting it into the model, the significant phases taking part are Communication, design blindly, it is much better to directly watch what users Planning, Modeling, Construction and Deployment.Further, do, identify design problems and opportunities and then design this model comprises of iterations in the form of system de- a system that solves the problems and realises the opportuni- velopment life cycle (SDLC) phases.The software developers ties. are rendered with plenty of benefits from the waterfall mod- • Conscious design decisions can be taken during communica- el.The first benefit is that the staged development cycle impos- tion phase following HCI design process. • es control because a phase will definitely have a beginning SE literature does not acknowledge that that requirements specifications already specify HCI design decisions. and ending, which allows the vendor as well as the clients to • HCI aspects are considered superficial and SE literature does fix goals to determine the advancements in a decisive way.The not mention or demonstrate the importance of considering al- time spent and the effort applied gets degraded because the ternative HCI designs. requirements and design are demanded prior to the execution • There are major gaps of communication between the HCI and of a single line of code, thus deviation from the schedule is SE fields: the architectures, processes, methods, and vocabu- prohibited.Acquiring the requirements and design at the ini- lary being used in each community are often foreign to the tial stage grants several benefits. One such is the enrichment other community.” (IFIP WG 2.7/13.4 on User Interface Engi- gained in the quality. In addition, the flaws that are likely to neering, 2004).. There is a need to have shared processes, occur can be disclosed and rectified in the design phase itself. common techniques, nomenclature, checkpoints, and measures Hence, performing flaw detection and correction in the testing for success (Jerome, et al., 2005). • phase, where the entire number of elements have undergone The HCI practitioners must have SE process support before they can deliver good quality usable software. integration and locating certain errors can be difficult, are • There is a deep- rooted myth that usability is not a central topic eliminated. The two phases in the beginning result in a formal of SE. specification and thus, the function of waterfall model is to • SE and HCI practitioners rarely collaborate and speak different assist in conveying the knowledge to the team members dis- language. tributed in various places. TheIJSER application of waterfall process • is feasible, if and only if the complete requirements exist for re-engineering the presently available SW. The commercial Critic of Waterfall model derived from [11]: projects cannot use this model practically due to the presence of iterations among the phases. Moreover, the price and dura- • Time and cost estimation is extremely difficult tion spent for system advancement and implementation is also • Upfront requirement capture and design is not realistic and large.
Recommended publications
  • Software Company Edition
    Data Sheet Software Company Edition NetSuite Software Company Edition offers the industry’s first and only: NetSuite—The One Integrated Application To Manage Your Software Business • Integrated revenue recognition and advanced billing With NetSuite, your software company can manage its entire front-office and back-office • Role-based, customizable dashboards operations with a single, flexible, powerful business application — integrating customer relation- • Integrated CRM, Accounting/ERP, ecommerce ship management, customer service, financials, inventory management, ecommerce, and more. NetSuite Software Company Edition Hundreds of software companies run their business on NetSuite — and we do too. Here’s why features include: NetSuite is the best application for software companies. • Customer Relationship Management - Sales Force Automation Advanced Financials with Revenue Management and Revenue Recognition - Marketing Automation Financials are complex in any industry, and they are arguably the most complex in the software - Customer Support and Service industry. The stumbling block for most software companies is managing revenue recognition - Incentive Management* - Offline Sales Client* and billing schedules—and ensuring compliance. Few financial packages provide these tools, - Issue Management* forcing companies to manage these complexities offline in spreadsheets or in third party stand- - Partner Relationship Management alone packages. With NetSuite you have one financial system that manages accounting, complex billing and revenue recognition—so there’s no more double entry. • Accounting/ERP - Revenue Recognition NetSuite supports AICPA, FASB and SEC regulations (including SOP 81-1, SAB 101, and EITF - Advanced Billing 00-21). NetSuite also accommodates the requirements specified in SOP 97-2 & 98-9 relating - General Ledger to Vendor Specific Objective Evidence or VSOE, including the accommodation of the Residual - Accounts Receivable, Accounts Payable Method and a separate VSOE price for every item.
    [Show full text]
  • Software Developers Working from Home During the COVID-19 Pandemic
    A Tale of Two Cities: Software Developers Working from Home During the COVID-19 Pandemic DENAE FORD, Microsoft Research MARGARET-ANNE STOREY, University of Victoria, Canada THOMAS ZIMMERMANN, Microsoft Research CHRISTIAN BIRD, Microsoft Research SONIA JAFFE, Microsoft Corp. CHANDRA MADDILA, Microsoft Research JENNA L. BUTLER, Microsoft Research BRIAN HOUCK, Microsoft Corp. NACHIAPPAN NAGAPPAN, Facebook The COVID-19 pandemic has shaken the world to its core and has provoked an overnight exodus of developers that normally worked in an office setting to working from home. The magnitude of this shift and the factors that have accompanied this new unplanned work setting go beyond what the software engineering community has previously understood to be remote work. To find out how developers and their productivity were affected, we distributed two surveys (with a combined total of 3,634 responses that answered all required questions) —weeks apart to understand the presence and prevalence of the benefits, challenges, and opportunities to improve this special circumstance of remote work. From our thematic qualitative analysis and statistical quantitative analysis, we find that there isa dichotomy of developer experiences influenced by many different factors (that for some are a benefit, while for others a challenge). For example, a benefit for some wasbeing close to family members but for others having family members share their working space and interrupting their focus, was a challenge. Our surveys led to powerful narratives from respondents
    [Show full text]
  • Proven Business Value of the Borland® Application Lifecycle Management (ALM) Solution
    Proven Business Value of the Borland® Application Lifecycle Management (ALM) Solution A Consynity white paper Principal, Terry Theisen www.consynity.com Proven Business Value of the Borland® Application Lifecycle Management (ALM) Solution Proven Business Value of the Borland® Application Lifecycle Management (ALM) Solution Introduction 3 Challenges and Opportunities in Application Development and Deployment 4 The Borland ALM Solution 5 Borland ALM Value Proposition 5 Application Lifecycle Quantified Benefits 5 Define Design Develop Test Deploy Manage Borland ALM Customer Results 8 Case Study #1: Deployment Across Large Enterprise 8 Implementation Details Case Study Findings ROI Analysis Case Study #2: Standardizing on Common Solution 10 Implementation Details Case Study Findings Case Study #3: Migration to Borland ALM Solution 11 Implementation Details Case Study Findings ROI Analysis Benefits of an Integrated Suite of Solutions 12 Conclusion: Dramatic ROI with Borland ALM 14 2 2003 Consynity All Rights Reserved Proven Business Value of the Borland® Application Lifecycle Management (ALM) Solution Introduction In an extremely competitive global economy where advantage is short-lived, companies in all industries continually strive for an edge over the competition. One way for companies to achieve that edge is to deliver better software, faster – software applications that strengthen customer relationships, software that increases operational efficiency, software that creates market leaders. Increasingly companies develop new applications on Java™ systems and Microsoft® .NET platforms, requiring development environments that support both as well as other platforms. Gartner’s “Leading Programming Languages for IT Portfolio Planning” report of September 2002 forecasts that by 2005, over 4.5 million programmers will use Java and .NET languages to build software applications.
    [Show full text]
  • Emerging Trends in Management, IT and Education ISBN No.: 978-87-941751-2-4
    Emerging Trends in Management, IT and Education ISBN No.: 978-87-941751-2-4 Paper 12 IMPLEMENTING PRODUCT DIVERSIFICATION STRATEGIES FOR THE SUSTAINABILITY OF A TECHNOLOGY COMPANY - A CASE OF MICROSOFT CORPORATION Vinayachandra1 & Krishna Prasad K2 1Research Scholar, College of Computer Science and Information Science, Srinivas University, Mangalore, India 2 College of Computer Science and Information Science, Srinivas University, Mangalore, India E-mail : [email protected] Abstract Started in 1975, with a view to develop and vend BASIC interpreter, today, Microsoft develop, produce, license, support and sell worldwide software, user-level electronics, personal computers, and allied services. The company is world-famous because of its best software products Windows operating systems, Office suits, IE and Edge. The company’s notable hardware pieces are Xbox and Microsoft Surface family touch-screen computers. The company is listed as the top software company by Forbes Global for many years. From its inception to date, the company is maintaining top ranking technology-wise, product-wise, service-wise, revenue-wise, and growth-wise. It is possible for the company to sustain growth because of the integration and implementation of product diversification strategy. Over the years the company transformed from just a developer and seller of interpreter to producer & marketer of wide variety of software-hardware products. This paper analyses the strategies the company adopted and incorporated in diversifying product and services lineup to sustain growth and maintain market stability. It also analyses the relevance and acceptability of different Microsoft products, its customer base, and software market share and near future strategies. Keywords: Microsoft, strategies, product diversification, Windows, generic, intensive.
    [Show full text]
  • Agile Software Development Processes
    Agile Software Development Jinjin Li Technische Universitt Berlin Berlin, Germany E-mail:[email protected] Abstract—With the further development of computer technol- customer requirements in the process, in the process people ogy, the software development process has some new goals and will invest resources and then convert it to outputs of project. requirements. In order to adapt to these changes, people has Before the 1960s, computers had just put into practical use, optimized and improved the previous method. At the same time, some of the traditional software development methods have been the software design was often only for a particular application unable to adapt to the requirements of people. Therefore, in re- in the specified design and preparation. The scale of software cent years there have been some new lightweight software process was relative small and usually didn’t have documentation, development methods, That is agile software development, which rarely use a systematic metohd to development. Design and is widely used and promoted. In this paper the author will firstly programming was often equated. introduces the background and development about agile software development, as well as comparison to the traditional software In mid-1960s, large capacity, high speed computers have development. Then the second chapter gives the definition of agile enabled the rapid expansion of computer applications, the software development and characteristics, principles and values. quantity of software development has increased dramatically. In the third chapter the author will highlight several different The Appearance of High-level programming language and agile software development methods, and characteristics of each operating system, causing of changes in the way of computer method.
    [Show full text]
  • How to Become a Programmer Everything (Non-Technical) You Need to Know to Start Making Money Writing Code Rob Walling V1.0
    How to Become a Programmer Everything (Non-Technical) You Need to Know to Start Making Money Writing Code www.SoftwareByRob.com Rob Walling v1.0 Contents Introduction .................................................................................................................................... 4 What is Computer Programming? .................................................................................................. 5 Why Should I Become a Programmer? ........................................................................................... 7 What Are Some Reasons Not to Become a Programmer? ........................................................... 10 What are the Different “Worlds” of Programming? ..................................................................... 11 What Programming Language Should I Learn? ............................................................................ 13 Where Do I Start?.......................................................................................................................... 16 I’ve Built a Project and Decided I Like Programming, What Next? .............................................. 18 I Just Graduated from School, How Can I Get Experience? .......................................................... 20 How Can I Become a Programmer Without Going to College? .................................................... 22 What About Offshoring – Will I have a Job in 5 years? ................................................................ 23 Do I Have to Know Math to be a Programmer?
    [Show full text]
  • Software Development a Practical Approach!
    Software Development A Practical Approach! Hans-Petter Halvorsen https://www.halvorsen.blog https://halvorsen.blog Software Development A Practical Approach! Hans-Petter Halvorsen Software Development A Practical Approach! Hans-Petter Halvorsen Copyright © 2020 ISBN: 978-82-691106-0-9 Publisher Identifier: 978-82-691106 https://halvorsen.blog ii Preface The main goal with this document: • To give you an overview of what software engineering is • To take you beyond programming to engineering software What is Software Development? It is a complex process to develop modern and professional software today. This document tries to give a brief overview of Software Development. This document tries to focus on a practical approach regarding Software Development. So why do we need System Engineering? Here are some key factors: • Understand Customer Requirements o What does the customer needs (because they may not know it!) o Transform Customer requirements into working software • Planning o How do we reach our goals? o Will we finish within deadline? o Resources o What can go wrong? • Implementation o What kind of platforms and architecture should be used? o Split your work into manageable pieces iii • Quality and Performance o Make sure the software fulfills the customers’ needs We will learn how to build good (i.e. high quality) software, which includes: • Requirements Specification • Technical Design • Good User Experience (UX) • Improved Code Quality and Implementation • Testing • System Documentation • User Documentation • etc. You will find additional resources on this web page: http://www.halvorsen.blog/documents/programming/software_engineering/ iv Information about the author: Hans-Petter Halvorsen The author currently works at the University of South-Eastern Norway.
    [Show full text]
  • Interviewing Software Testing Job Candidates
    KANER.COM Cem Kaner, Ph.D., J.D. [email protected] P.O. Box 1200 408-244-7000 (Voice) Santa Clara, CA 95052 www.kaner.com 408-244-2181 (FAX) RECRUITING SOFTWARE TESTERS INTERNATIONAL QUALITY WEEK SAN JOSE, CA, JUNE, 1999 This paper is a work in progress. Eventually, it will become a chapter in the 3rd Edition of Testing Computer Software (under development by Cem Kaner, Bob Johnson, Brian Lawrence, Jack Falk, & Hung Quoc Nguyen. This is a multi-year project. Please don't ask me when it will be done. It certainly won't be done in 1999.) I'd appreciate comments and suggestions. (Send them to [email protected].) I don't claim to be an expert on recruiting, but I have been reasonably successful at recruiting testers (and other software workers) over the last 15 years, have made a lot of mistakes, and learned a few lessons. This paper collects some of those lessons. Managers get work done through other people. The people that a manager chooses are the people who will achieve, or fail to achieve, the mission of the group and the tasks assigned by the manager. Recruiting staff is one of the hardest jobs for any manager. Hiring the wrong staff is, I believe, the worst mistake that a manager can make. A good treatment of recruiting would consider the following issues: . A behavioral approach to gathering information . Legal issues . Consensus-driven hiring . A strategy for gathering information . Characteristics of the person you're seeking . Defining the position and characteristics needed for it .
    [Show full text]
  • Why Software Firms Build Hardware – and What Microsoft Is Doing About It
    Why Software Firms Build Hardware – And What Microsoft Is Doing About It by Ryan M. Shaffer B.S. Electrical Engineering Grove City College, 2008 M.S. Computer Science Boston University, 2011 SUBMITTED TO THE SYSTEM DESIGN AND MANAGEMENT PROGRAM IN PARTIAL FULFILLMENT OF THE REQUIREMENTS FOR THE DEGREE OF MASTER OF SCIENCE IN ENGINEERING AND MANAGEMENT AT THE MASSACHUSETTS INSTITUTE OF TECHNOLOGY FEBRUARY 2015 © Ryan M. Shaffer. All rights reserved. The author hereby grants to MIT permission to reproduce and to distribute publicly paper and electronic copies of this thesis document in whole or in part in any medium now known or hereafter created. Signature of Author: _____________________________________________________ System Design and Management Program January 9, 2015 Certified by: ____________________________________________________________ Michael Cusumano Sloan Management Review Professor in Management Thesis Supervisor Accepted by: ___________________________________________________________ Patrick Hale Director, System Design and Management Fellows Program Why Software Firms Build Hardware – And What Microsoft Is Doing About It by Ryan M. Shaffer Submitted to the System Design and Management Program on January 9, 2015 in Partial Fulfillment of the Requirements for the Degree of Master of Science in Engineering and Management ABSTRACT Many software companies build first-party hardware products due to the trend toward smaller, more highly-integrated devices, along with the fast pace of innovation in the technology industry. Building hardware products does not always lead to success and actually creates a financial risk for the company by significantly reducing profit margins as compared to the traditional profit margins to which large software companies are accustomed. Three specific strategies are observed which firms have used successfully in this area.
    [Show full text]
  • Agile Software Development: a Case Study in a Software Company
    Agile Software Development: A Case Study in a Software Company L. Ashkenazi*, A. Shmilovici**, I. Ben-Gal* *Dept. of Industrial Engineering, Tel-Aviv University **Dept. of Information Systems Engineering, Ben-Gurion University In this case study we accompanied a software development project which was performed using the Agile SCRUM method for software development. Subjective parameters of the design and code quality were collected and analyzed and a comparison was performed to an equivalent non-Agile project. We analyzed the software development process from the following aspects: Initial Effort Estimation process compared to the Effort Estimation given for the project by the COCOMO-II model; Control and management process compared to the one suggested by the PERT/CPM and Critical Chain methods. Results and conclusions: The COCOMO II model showed the smallest deviation in its effort estimation from the real required effort; The PERT/CPM method is not recommended as in most cases the real result was out of the PERT/ CPM allowed variance. 1. Introduction and Goals Software development is though from a project management point of view: too many software development projects overrun their schedules, their budgets, and deliver a low quality product. Scrum is an iterative incremental process of software development that focuses on a subset of project management and requirements management. It is one of the new Agile methods for software development [1, 2]. In this case study we accompanied a software development project which was performed using the Scrum method. Subjective and objective parameters of the design and code quality were collected and analyzed and a comparison was performed to an equivalent non-agile project.
    [Show full text]
  • Assessing Application Lifecycle Management Potentials: an Exploratory Industrial Case Study
    ASSESSING APPLICATION LIFECYCLE MANAGEMENT POTENTIALS: AN EXPLORATORY INDUSTRIAL CASE STUDY A THESIS SUBMITTED TO THE GRADUATE SCHOOL OF NATURAL AND APPLIED SCIENCES OF ÇANKAYA UNIVERSITY BY ZÜLEYHA AKGÜN IN PARTIAL FULFILLMENT OF THE REQUIREMENTS FOR THE DEGREE OF MASTER OF SCIENCE IN THE DEPARTMENT OF COMPUTER ENGINEERING JANUARY 2019 iii ABSTRACT ASSESSING APPLICATION LIFECYCLE MANAGEMENT POTENTIALS: AN EXPLORATORY INDUSTRIAL CASE STUDY AKGÜN, Züleyha M.Sc., Department of Computer Engineering Supervisor: Dr. Instructor Murat YILMAZ January 2019 Software projects require a good management system to achieve a successful result because they are risky and often spread over a long period. The most important element of a good management is controlled planning. Within the scope of the project, all necessary stages of the software development life cycle need to be accurately and consistently planned and documented to complete the requirements, analysis, design, development process, estimations, risk and change control methods, test and maintenance processes in a complete and accurate manner. The notion of software lifecycle management requires the incorporation of effective software engineering processes that encompass not only development but also deployment and maintenance. Although new methodologies for software engineering continue to emerge, still software development continues to experience a significant amount of failure rates. To overcome the complexities of modern software development, agile development philosophy suggests that software developers should remain involved with the application and working continuously with stakeholders to make required changes incrementally by tracking application changes. Application Lifecycle Management (ALM) is an emerging trend that reflects a novel attitude towards software development also expressed as the DevOps, which blends the tasks performed by a firm’s software development and systems operations teams, monitor software artifacts from inception to completion while changes are noted.
    [Show full text]
  • What Predicts Software Developers' Productivity?
    1 What Predicts Software Developers’ Productivity? Emerson Murphy-Hill, Ciera Jaspan, Caitlin Sadowski, David Shepherd, Michael Phillips, Collin Winter, Andrea Knight, Edward Smith and Matthew Jorde Abstract—Organizations have a variety of options to help their software developers become their most productive selves, from modifying office layouts, to investing in better tools, to cleaning up the source code. But which options will have the biggest impact? Drawing from the literature in software engineering and industrial/organizational psychology to identify factors that correlate with productivity, we designed a survey that asked 622 developers across 3 companies about these productivity factors and about self-rated productivity. Our results suggest that the factors that most strongly correlate with self-rated productivity were non-technical factors, such as job enthusiasm, peer support for new ideas, and receiving useful feedback about job performance. Compared to other knowledge workers, our results also suggest that software developers’ self-rated productivity is more strongly related to task variety and ability to work remotely. Index Terms—Productivity factors, software engineers, knowledge workers F 1 Introduction Improving productivity of software developers is impor- generalize and do not generalize, we adapted and deployed tant. By definition, developers who have completed their tasks the survey at two other companies in different industries. To can spend their freed-up time on other useful tasks, such as answer the third question, which helps explain what differen- implementing new features or on new verification and valida- tiates software developers from other groups, we adapted and tion activities. But what causes developers to be more pro- deployed the survey with non-developer knowledge workers, ductive? and compared the results to that of software developers.
    [Show full text]