Extreme Programming and Agile Software Development Methodologies

Total Page:16

File Type:pdf, Size:1020Kb

Extreme Programming and Agile Software Development Methodologies Extreme Programming and Agile Software Development Methodologies Lowell Lindstrom, Object Mentor, Inc., [email protected] Ron Jeffries, xprogramming.com, [email protected] ____________________________________________________________________________ As a stakeholder of a software project, how does this sound to you? You can have releases as often as you like. The small number of defects is unprecedented. All of the features in the system are the most valuable ones to your business. At anytime, you have access to complete, accurate information as the status of any feature and of the quality of the system as a whole. The team developing your project works in an energized space with constant communication about the project. You are not dependent on any one or even two programmers for the continued success of the project. If your needs change, the development team welcomes the change of direction. As a developer of a software project, how does this sound to you? No one estimates your tasks but you, period! You always have access to a customer to clarify details about the features you are implementing. You are free (and required) to clean up the code whenever necessary. You complete a project every two weeks. You can work in any part of the system that you wish. You can pick who will help you on any given task. You are not required to work constantly long hours. Does this sound to good to be true? Teams are achieving these advantages using a relatively new set of software methodologies. Collectively, they are referred to as Agile Software Development Methodologies. The most pervasive is Extreme Programming. This chapter will introduce you to these exciting, popular, yet controversial new approaches to software development. ____________________________________________________________________________ BACKGROUND as the current economic downturn limits capital investment, innovators and Trends In Software Development entrepreneurs are pushing the limits in areas of biotechnology and nanotechnology. The last half-century has seen a dizzying progression of technical advancement in the Supporting all of these advances is software areas of computer, software, and running on some kind of computer. From communications technology. With each the spreadsheets to anti-lock brakes to advance came rapid changes in the way phones to toys, logic that was once society works and lives. The impact of implemented in mechanics, circuitry, or technology is increasingly pervasive. Even pencil and paper, is now a set of instructions Copyright 2003 © Lowell Lindstrom and Ron Jeffries Copyright 2003 © CRC Press LLC controlling one or many computers. These computers communicate with each other Despite these delivery problems, strong over networks ignorant to the limits of demand seems to hold steady. Reports still geography and even wires. The notion of a suggest a shortage of software professionals program running on a computer is largely a and college graduates, despite the implosion memory as the emergence of distributed of the Internet industry slowing the growth computing models, most recently Web of demand and the emergence of offshore Services, allow many different computers to programming market increasing supply. participate in the “running” of a program or system to yield a given output. Improvement Remains Elusive Efforts to improve the success rate of In this explosive environment, software software projects have since the first bug professionals have the challenge to deliver a was detected. Recently, these efforts have seemingly infinite backlog of software focused on four distinct part of the software projects, while keeping abreast with the development process: requirements latest advances. The results are debatable at gathering, designing and developing the best. Survey after survey continues to software, testing the results, and overall confirm that most software projects fail project management. Formal requirements against some measure of success. Most definition and analysis addressed the software developers have many more stories problem of requirements that were of failure than of success. Given the friction incomplete or did not reflect the needs of the and finger pointing that accompanies the end customer. Formal design before of a failed project, it is difficult to research implementation addressed the goals of reuse, the causes of software failures. However, consistency of operation, and reducing typically, projects fail for the one of more of rework. Testing catches defects before they the following: reach the users. Project Management ? Requirements that are not clearly addressed the problem of coordinating the communicated efforts of multi-department teams. These ? Requirements that do not solve the areas of focus follow a logical approach to business problem process improvement: improve the quality ? Requirements that change prior to of the inputs (requirements), improve the the completion of the project quality of the output (designing and ? Software (code) that has not been developing, project management), and tested improve the detection and elimination of ? Software that has not been tested as defects prior to shipping (testing). Methods the user will use it and tools focusing on these four distinct ? Software developed such that it is areas of software development have hard to modify. proliferated. ? Software that is used for functions for which it was not intended For some projects, these efforts have been ? Projects not staffed with the effective. For others, it yielded silos of resources required in the project plan responsibility, with poor communication between the groups and distributed ? Schedule and scope commitments are made prior to fully understanding ownership and accountability. If a project is late, it is easy for the programmers to blame of the requirements or the technical risks. the requirements gatherers and vice versa. If Want to learn more? See www.oobeyagroup.com or www.xprogramming.com 2 the users detect defects, finger pointing ensues between developers and testers. A few people started to author papers about Project Management techniques try to better these disciplined, yet lighter approaches to coordinate the activities of the multiple software development. They called them groups involved in delivering the project, Extreme Programming, SCRUM, Crystal, but add yet another silo and area of Adaptive, etc. Different authors emphasized accountability. The most popular project different aspects of software development. management techniques focus on developing Some focused on approaches to planning a plan and sticking to the plan. This and requirements, some focused on ways to improves coordination, but reduces the write software that could be changed more ability of the project to adapt to new easily. Some focused on the people information regarding the requirements or interactions that allow software developers the implementation details. to more easily adapt to their customers’ changing needs. These various efforts Emergence Of Agile Methods created a focal point for a community that furthered the set of practices that succeed The additional process steps, roles, and without many of the activities and artifacts artifacts helped many teams to enjoy higher required by more defined methodologies. success rates and more satisfied customers. Unfortunately, many projects failed In the fall of 1999, Extreme Programming, attempting to use the same techniques. Embrace Change1, was published and the Some projects got lost in the documents and trend had found its catalyst. In early 2001, never implemented any code, missing the the different innovators that were creating window of opportunity for the software. different agile methodologies held a retreat Others did not leave enough time at the end and scribed the Agile Manifesto for for implementation and test, and delivered Software Development.2 By the spring of systems inconsistent with the documents and 2002, Computerworld.com ran the following designs on which most of the project time headline: "More than two-thirds of all was spent. corporate IT organizations will use some form of ‘agile’ software development At the same time, numerous projects were process within 18 months, Giga Information very successful that did not follow methods Group predicted this week at its application with binders of documents, detailed designs, development conference here."3 and project plans. Many experienced programmers were having great success AGILE METHODOLOGIES without all of these extra steps. The At the retreat in early 2001, a number of determining factor of project success leaders of the agile software development seemed more and more to be the people on movement held a retreat to discuss their the project, not the technology or the approaches and to explore the methods that were being used. After all, commonalities and differences. What people end up writing the software at some emerged was the Agile Manifesto for point. To some, the developers that did not Software Development. The manifesto embrace the new methodologies appeared to articulates core values and principles that be undisciplined and indifferent to quality, guide agile methodologies. despite their successes at delivering quality software that people wanted to use. Want to learn more? See www.oobeyagroup.com or www.xprogramming.com 3 Agile Manifesto ? Working software is the primary We are uncovering better ways of measure of progress. developing software by doing it and ? Agile processes promote
Recommended publications
  • Xp Project Management
    University of Montana ScholarWorks at University of Montana Graduate Student Theses, Dissertations, & Professional Papers Graduate School 2007 XP PROJECT MANAGEMENT Craig William Macholz The University of Montana Follow this and additional works at: https://scholarworks.umt.edu/etd Let us know how access to this document benefits ou.y Recommended Citation Macholz, Craig William, "XP PROJECT MANAGEMENT" (2007). Graduate Student Theses, Dissertations, & Professional Papers. 1201. https://scholarworks.umt.edu/etd/1201 This Thesis is brought to you for free and open access by the Graduate School at ScholarWorks at University of Montana. It has been accepted for inclusion in Graduate Student Theses, Dissertations, & Professional Papers by an authorized administrator of ScholarWorks at University of Montana. For more information, please contact [email protected]. XP PROJECT MANAGEMENT By Craig William Macholz BS in Business Administration, The University of Montana, Missoula, MT, 1997 Thesis presented in partial fulfillment of the requirements for the degree of Master of Science in Computer Science The University of Montana Missoula, MT Autumn 2007 Approved by: Dr. David A. Strobel, Dean Graduate School Dr. Joel Henry Computer Science Dr. Yolanda Reimer Computer Science Dr. Shawn Clouse Business Administration i Macholz, Craig, M.S., December 2007 Computer Science Extreme Programming Project Management Chairperson: Dr. Joel Henry Extreme programming project management examines software development theory, the extreme programming process, and the essentials of standard project management as applied to software projects. The goal of this thesis is to integrate standard software project management practices, where possible, into the extreme programming process. Thus creating a management framework for extreme programming project management that gives the extreme programming managers the management activities and tools to utilize the extreme programming process within a wider range of commercial computing organizations, relationships, and development projects.
    [Show full text]
  • The Timeboxing Process Model for Iterative Software Development
    The Timeboxing Process Model for Iterative Software Development Pankaj Jalote Department of Computer Science and Engineering Indian Institute of Technology Kanpur – 208016; India Aveejeet Palit, Priya Kurien Infosys Technologies Limited Electronics City Bangalore – 561 229; India Contact: [email protected] ABSTRACT In today’s business where speed is of essence, an iterative development approach that allows the functionality to be delivered in parts has become a necessity and an effective way to manage risks. In an iterative process, the development of a software system is done in increments, each increment forming of an iteration and resulting in a working system. A common iterative approach is to decide what should be developed in an iteration and then plan the iteration accordingly. A somewhat different iterative is approach is to time box different iterations. In this approach, the length of an iteration is fixed and what should be developed in an iteration is adjusted to fit the time box. Generally, the time boxed iterations are executed in sequence, with some overlap where feasible. In this paper we propose the timeboxing process model that takes the concept of time boxed iterations further by adding pipelining concepts to it for permitting overlapped execution of different iterations. In the timeboxing process model, each time boxed iteration is divided into equal length stages, each stage having a defined function and resulting in a clear work product that is handed over to the next stage. With this division into stages, pipelining concepts are employed to have multiple time boxes executing concurrently, leading to a reduction in the delivery time for product releases.
    [Show full text]
  • Agile Software Development and Im- Plementation of Scrumban
    Joachim Grotenfelt Agile Software Development and Im- plementation of Scrumban Metropolia University of Applied Sciences Bachelor of Engineering Mobile Solutions Bachelor’s Thesis 30 May 2021 Abstrakt Författare Joachim Grotenfelt Titel Agile software utveckling och Implementation av Scrumban Antal Sidor 31 sidor Datum 30.05.2021 Grad Igenjör YH Utbildningsprogram Mobile Solutions Huvudämne Informations- och kommunikationsteknologi Instruktörer Mikael Lindblad, Projektledare Peter Hjort, Lektor Målet med avhandlingen var att studera agila metoder, hur de används i mjukvaruföretag och hur de påverkar arbetet i ett programvaruutvecklingsteam. Ett annat mål med avhandlingen var att studera bakgrunden till den agila metoden, hur den togs i bruk och hur den påverkar kundnöjdhet. I denna avhandling förklaras några existerande agila metoder, verktygen för hur agila metoder används, samt hur de påverkar programvaruutvecklingsteamet. Avhandlingen fokuserar sig på två agila metoder, Scrum och Kanban, eftersom de ofta används i olika företag. Ett av syftena med denna avhandling var att skapa förståelse för hur Scrumban metoden tas i bruk. Detta projekt granskar fördelarna med att ha ett mjukvaruutvecklingsteam som arbetar med agila processer. Projektet lyckades bra och en arbetsmiljö som använder agila metoder skapades. Fördelen blev att utvecklarteamet kunde göra förändringar när sådana behövdes. Nyckelord Agile, Scrum, Kanban, Scrumban Abstract Joachim Grotenfelt Author Basics of Agile Software Development and Implementation of Title Scrumban Number of Pages 31 pages Date 30.05.2021 Degree Bachelor of Engineering Degree Program Mobile Solutions Professional Major Information- and Communications Technology Instructors Mikael Lindblad, Project Manager Peter Hjort, Senior Lecturer The goal of the thesis is to study the Agile methods and how they affect the work of a soft- ware development team.
    [Show full text]
  • Information Technology and Software Development
    Course Title: Information Technology and Software Development NATIONAL OPEN UNIVERSITY OF NIGERIA SCHOOL OF SCIENCE AND TECHNOLOGY COURSE CODE: CIT 703 COURSE TITLE: Information Technology and Software Development National Open University of Nigeria, Victoria Island, Lagos Page 1 Course Title: Information Technology and Software Development Course Code Course Title Information Technology and Software Development Course Developer/Writer Eze, Festus Chux Department of Computer Science Ebonyi State University Abakaliki Course Editor Programme Leader Course Coordinator National Open University of Nigeria, Victoria Island, Lagos Page 2 Course Title: Information Technology and Software Development Introduction Information Technology and Software Development is a three credit load course for all the students offering Post Graduate Diploma (PGD) in Computer Science, Information Technology and other allied courses. Software Development is a major branch in computing and information Technology. A software development professional oversees the processes of software development, the management of software development project, the maintenance of the installed software in an organisation. For sometime the field has been dominated with what is the definitive process of software development. Furthermore there has been the running battle between professionals and managers on who should control a software development project. There is an attempt to classify it as any other project that an organisation handles hence anybody could manage it. Whereas others see it as a highly professional issue that requires high precision in design, management and implementation. However, software development is all involving. It involves the user (client) whose interest is paramount. The developing organisation and her professionals ( team)are of great importance. Therefore a successful exercise can only take place when all these variegated interests are harmonised.
    [Show full text]
  • Extreme Programming Considered Harmful for Reliable Software Development
    AVOCA GmbH Extreme Programming Considered Harmful for Reliable Software Development Status: Approved Author(s): Gerold Keefer Version: 1.0 Last change: 06.02.02 21:17 Project phase: Implementation Document file name: ExtremeProgramming.doc Approval Authority: Gerold Keefer Distribution: Public Security Classification: None Number of pages: 1 Extreme Programming Considered Harmful for Reliable Software Development AVOCA GmbH 1 MOTIVATION ................................................................................................................................... 3 2BIAS................................................................................................................................................. 4 3 BENEFITS ........................................................................................................................................ 4 4 DUBIOUS VALUES AND PRACTICES........................................................................................... 5 5 C3 REVISITED ................................................................................................................................. 7 6 MISSING ANSWERS ....................................................................................................................... 7 7 ALTERNATIVES .............................................................................................................................. 8 8 CONCLUSIONS ............................................................................................................................
    [Show full text]
  • Empirical Studies of Agile Software Development: a Systematic Review
    Available online at www.sciencedirect.com Information and Software Technology 50 (2008) 833–859 www.elsevier.com/locate/infsof Empirical studies of agile software development: A systematic review Tore Dyba˚ *, Torgeir Dingsøyr SINTEF ICT, S.P. Andersensv. 15B, NO-7465 Trondheim, Norway Received 22 October 2007; received in revised form 22 January 2008; accepted 24 January 2008 Available online 2 February 2008 Abstract Agile software development represents a major departure from traditional, plan-based approaches to software engineering. A system- atic review of empirical studies of agile software development up to and including 2005 was conducted. The search strategy identified 1996 studies, of which 36 were identified as empirical studies. The studies were grouped into four themes: introduction and adoption, human and social factors, perceptions on agile methods, and comparative studies. The review investigates what is currently known about the benefits and limitations of, and the strength of evidence for, agile methods. Implications for research and practice are presented. The main implication for research is a need for more and better empirical studies of agile software development within a common research agenda. For the industrial readership, the review provides a map of findings, according to topic, that can be compared for relevance to their own settings and situations. Ó 2008 Elsevier B.V. All rights reserved. Keywords: Empirical software engineering; Evidence-based software engineering; Systematic review; Research synthesis; Agile software development; XP; Extreme programming; Scrum Contents 1. Introduction . 834 2. Background – agile software development . 834 2.1. The field of agile software development. 834 2.2. Summary of previous reviews .
    [Show full text]
  • Emerging Themes in Agile Software Development: Introduction to the Special Section on Continuous Value Delivery
    ARTICLE IN PRESS JID: INFSOF [m5G; May 14, 2016;7:8 ] Information and Software Technology 0 0 0 (2016) 1–5 Contents lists available at ScienceDirect Information and Software Technology journal homepage: www.elsevier.com/locate/infsof Emerging themes in agile software development: Introduction to the special section on continuous value delivery ∗ Torgeir Dingsøyr a,b, , Casper Lassenius c a SINTEF, Trondheim, Norway b Department of Computer and Information Science, Norwegian University of Science and Technology, Trondheim, Norway c Department of Computer Science and Engineering, Aalto University, Helsinki, Finland a r t i c l e i n f o a b s t r a c t Article history: The relationship between customers and suppliers remains a challenge in agile software development. Received 19 April 2016 Two trends seek to improve this relationship, the increased focus on value and the move towards con- Revised 26 April 2016 tinuous deployment. In this special section on continuous value delivery, we describe these emerging Accepted 27 April 2016 research themes and show the increasing interest in these topics over time. Further, we discuss implica- Available online xxx tions for future research. Keywords: ©2016 The Authors. Published by Elsevier B.V. Agile software development This is an open access article under the CC BY-NC-ND license Software process improvement ( http://creativecommons.org/licenses/by-nc-nd/4.0/ ). Value-based software engineering Requirements engineering Continuous deployment Lean startup Scrum Extreme programming 1. Introduction ous deployment of new features. We describe these two trends as a focus on continuous value delivery. This is a challenging topic.
    [Show full text]
  • A Survey of Agile Development Methodologies
    A Survey of Agile Development Methodologies Agile development methodologies are emerging in the software industry. In this chapter, we provide an introduction to agile development methodologies and an overview of four specific methodologies: • Extreme Programming • Crystal Methods • Scrum • Feature Driven Development Plan-driven methods work best when developers can determine the requirements in advance . and when the requirements remain relatively stable, with change rates on the order of one percent per month. -- Barry Boehm [11] Plan-driven methods are those that begin with the solicitation and documentation of a set of requirements that is as complete as possible. Based on these requirements, one can then formulate a plan of development. Usually, the more complete the requirements, the better the plan. Some examples of plan-driven methods are various waterfall approaches and others such as the Personal Software Process (PSP) [28] and the Rational Unified Process (RUP) [30, 31]. An underlying assumption in plan-driven processes is that the requirements are relatively static. On the other hand, iterative methods, such as spiral- model based approaches [12, 14], evolutionary processes described in [5, 22, 32, 33], and recently agile approaches [45] count on change and recognize that the only constant is change. The question is only of the degree and the impact of the change. Beginning in the mid-1990’s, practitioners began finding the rate of change in software requirements increasing well beyond the capabilities of classical development methodologies [11, 27]. The software industry, software technology, and customers expectations were moving very quickly and the customers were becoming increasingly less able to fully state their needs up front.
    [Show full text]
  • Evaluating Effectiveness of Pair Programming As a Teaching Tool in Programming Courses
    Information Systems Education Journal (ISEDJ) 12 (6) ISSN: 1545-679X November 2014 Evaluating Effectiveness of Pair Programming as a Teaching Tool in Programming Courses Silvana Faja [email protected] School of Accountancy and Computer Information Systems, University of Central Missouri, Warrensburg, Missouri, 64093, USA Abstract This study investigates the effectiveness of pair programming on student learning and satisfaction in introductory programming courses. Pair programming, used in the industry as a practice of an agile development method, can be adopted in classroom settings to encourage peer learning, increase students’ social skills, and enhance student achievement. This study explored students’ perceptions on effectiveness of pair programming and the influence of student’s level of experience with this activity and perceived partner involvement on effectiveness outcomes. Findings suggest that the more students are involved in this activity, the more they enjoy it and the more they learn by collaborating with their partners. When comparing different effectiveness measures, their perceived learning, quality of work, and enjoyment during pair programming was found to be at a higher level than increased productivity outcome. Keywords: Pair Programming, Teamwork, Collaborative Learning, Programming Course. 1. INTRODUCTION information systems courses. It discusses what was learned about the impact of this type of Software development is typically a process that collaborative activity on students’ attitudes and requires the coordinated efforts of the members learning. The following section provides a of one or more teams. As such, it is important review of existing research on pair that computer programming courses provide programming, collaborative learning and students not only with technical knowledge, but research questions and hypotheses.
    [Show full text]
  • Agile Methodology: Hybrid Approach Scrum and XP Farrukh Musa, Muhammad Ali Tariq
    International Journal of Scientific & Engineering Research, Volume 8, Issue 4, April-2017 1405 ISSN 2229-5518 Agile Methodology: Hybrid Approach Scrum and XP Farrukh Musa, Muhammad Ali Tariq Abstract— Nowadays, agile is the most usable process model in IT industry. There are plenty of agile methodologies in the market but all of them have some drawbacks that must be solved. Most commonly used agile methodologies are scrum, extreme programming (XP), lean development etc. This research paper is basically to introduce the new agile methodology i-e hybrid of scrum and XP that overcome the drawback and issues we face in previous agile methodologies. Further there is detail that how it works and when to use along with some advantages. Index Terms— hybrid software engineering methodology, agile approach, Scrum, XP, extreme programming, Scrum with XP. —————————— —————————— 1 INTRODUCTION GILE methodology is now becoming most popular and rapid prototype etc. agile process model requires very limited A usable process model in IT Development industry. In this planning to get started with the project. Changes and en- methodology we discuss certain models such as by nature its hancement can be discussed and implement later on as per Incremental because in this software is developed in incre- client demand to get more efficient and better results. mental, rapid cycle. Results builds in small incremental release The paper is distributed in some major sections; section II will and each release is thoroughly tested to ensure the software be comprised of related work on the different agile method- quality maintainability [1, 2]. In it we invest lesser time on ologies which are already existing and up to date, while Sec- analysis and design phase as compare to other because here tion III deals with the proposed methodology.
    [Show full text]
  • The Continuous Refinement of Extreme Programming
    The Continuous Refinement of Extreme Programming Ken Auer RoleModel Software, Inc. [email protected] http://rolemodelsoftware.com Copyright © 2003-04, RoleModel Software, Inc. Requirements Documents* • Documentation is not Understanding (tacit) – One Study of Typical Requirements Documents (Source: Elemer Magaziner): • 15% Complete, • 7% Correct, Not cost effective to increase • Formality is not Discipline • Process is not Skill • Initial Requirements define a fuzzy view of a point on the horizon * Some slide content supplied by Jim Highsmith, —Adaptive Software Development“ Copyright © 2003, RoleModel Software, Inc. Dichotomies Pragmatic Technical Business Academic Copyright © 2003, RoleModel Software, Inc. Perceptions Pragmatic Technical Business Academic Copyright © 2003, RoleModel Software, Inc. Charicatures Pragmatic – Making computers do something useful without actually thinking critically Technical Business Academic – critical thinking about how computers work without actually doing anything useful Copyright © 2003, RoleModel Software, Inc. Charicatures Pragmatic – Making computers do something useful without actually thinking critically Technical – understanding how Business – wanting to make things work, wanting things to work without someone to pay them to any desire to understand how play and gain more understanding or paying for someone who does Academic – critical thinking about how computers work without actually doing anything useful Copyright © 2003, RoleModel Software, Inc. The Pragmatic/Business Dialog Pragmatic Technical Business Academic Copyright © 2003, RoleModel Software, Inc. The Technical/Academic Dialog Pragmatic Technical Business Academic Copyright © 2003, RoleModel Software, Inc. The Essential Dialog Pragmatic Iron sharpens iron, Technical Business So one man sharpens another. (Prov 27:17) Academic Copyright © 2003, RoleModel Software, Inc. Cost of Communication* * Alistair Cockburn, “Agile Software Development”, Addison-Wesley 2002 Copyright © 2003, RoleModel Software, Inc.
    [Show full text]
  • The Role of Customers in Extreme Programming Projects
    View metadata, citation and similar papers at core.ac.uk brought to you by CORE provided by ResearchArchive at Victoria University of Wellington THE ROLE OF CUSTOMERS IN EXTREME PROGRAMMING PROJECTS By Angela Michelle Martin A thesis submitted to the Victoria University of Wellington in fulfilment of the requirements for the degree of Doctor of Philosophy In Computer Science Victoria University of Wellington 2009i The Role of Customers in Extreme Programming Projects ABSTRACT eXtreme programming (XP) is one of a new breed of methods, collectively known as the agile methods, that are challenging conventional wisdom regarding systems development processes and practices. Practitioners specifically designed the agile methods to meet the business problems and challenges we face building software today. As such, these methods are receiving significant attention in practitioner literature. In order to operate effectively in the world of vague and changing requirements, XP moves the emphasis away from document-centric processes into practices that enable people. The Customer is the primary organisational facing role in eXtreme Programming (XP). The Customer's explicit responsibilities are to drive the project, providing project requirements (user stories) and quality control (acceptance testing). Unfortunately the customer must also shoulder a number of implicit responsibilities including liaison with external project stakeholders, especially project funders, clients, and end users, while maintaining the trust of both the development team and the wider business. This thesis presents a grounded theory of XP software development requirements elicitation, communication, and acceptance, which was guided by three major research questions. What is the experience of being an XP Customer? We found that teams agree that the on-site customer practice is a drastic improvement to the traditional document-centric approaches.
    [Show full text]