390 likes | 409 Views
Learn why requirements are crucial for GIS success, how to evolve them, and their role in Waterfall vs. Agile approaches. Discover benefits and business types of requirements along with practical steps for implementation.
E N D
How to Collect and Manage Requirements for Successful GIS Projects Matt Harman Mirjam Stadelmann
Requirements Provide direction for program success
Why Requirements are Important? Early mistakes lead to costly fixes
Build for Value Requirements evolve over time Standish Group Study Reported at XP2002 by Jim Johnson, Chairman 20% - Often or Always 64% - Rarely or Never
Where do Requirements fit? Waterfall implementation Hours Months
Where do Requirements fit? Agile implementation
Where do Requirements fit? Source: Vikas Thange Blog
What Benefits? Increase Productivity Streamline Processes Reduce Costs Business Types of Requirements Meet Goals Derive Benefits Business, Functional/Technical, COTS Performance Usability Quality Operational Standards Infrastructure What NOT how Clear Define workflow Testable Functional Quality of Service “What?” “How Well?” “What Constraints?” Solution Concept Leverage COTS components
So how do you get there…. Prioritize workflows Assess business workflows Discuss similar industries Add Details Create a plan Conduct kickoff meeting Implementing an Enterprise GIS Project
Approach and Agenda Kickoff meeting Smaller working groups
Similar industries …what are the GIS Patterns that apply Location Enablement Constituent Engagement Decision Support Field Mobility Analytics Location Data Management Discover, use, make, and share maps at work -- anywhere, anytime Facilitate and manage communication with stakeholders Inform execs and management with maps and location intelligence Get authoritative information into and out of the field Describe, predict, and improve business performance Collect and organize location data about your assets and resources System of Engagement (Demand) System of Record (Supply) https://www.esri.com/~/media/Files/Pdfs/products/arcgis platform/architecting-the-arcgis-platform
GIS Solutions Meter Data Collection Air Pollution Analysis Campus Navigation Fire Hydrants Building Permit Management Air Quality Sensors Partner Award ARIA Technologies France Valarm California Cityworks Oklahoma GISi Washington SSP Innovations Tennessee CityView Canada Road Construction Planning Work Orders District Planning Wilson Pym May Philippines Isovist New Zealand Trimble Illinois
Next Steps – How to add details to your business requirements Evolutionary Refinement of Requirements Product Backlog • Requirements • Who is it for? • What is the result? • Why is it needed? Daily Review Sprint Cycle <30 Days Working Increment Tasks
User Story • Simple, brief descriptions of functionality • Primarily from a user (role) perspective • Sized for planning • Testable • Why?
Field Worker Public Citizen Real Estate Manager Data Provider Analyst
As a data provider I need to be able to upload my data to the client on a monthly basis, so that I can provide the most up-to-date data for analysis. As a real estate manager, I need to interact with a map to explore new locations. User Stories Simple and concise As an analyst, I need the ability to create a map with pop-ups to build easy-use-maps for management. As a public citizen, I need to interact with a map to see where new permits are allowed and potential site my new business. As a real estate manager, I need interactive map capability on my iPad so that I can travel minimalistic during site visits. As a real estate manager, I need to receive information by clicking on potential sites to better understand the property. As an analyst, I need to the ability to run hurricane models from Provider X and see the results on a map, so that I can better understand the impact on our book of business.
User stories facilitate a conversation with the team Development Lead Product Owner Hey! Something to look at, talk about, comment on, react to… The team Stakeholders
As an analyst, I need the ability to create a map with pop-ups to build easy-use-maps for management. User Stories As a real estate manager, I need to be able to see a pie chart of surrounding demographics so that I can match consumer demand with product. Progressively decompose your stories As a real estate manager, I need to interact with a map to explore new locations. As a real estate manager, I need to receive information by clicking on potential sites to better understand the property. As a real estate manager, I need interactive map capability on my iPad so that I can travel minimalistic during site visits.
Example – Leak Management – Isolation Trace Decomposing work into manageable pieces Most Detailed – Test Case Titles Use Cases Locate by address Locate Leak Locate with Map User Story As a Field Engineer I need to run an Isolation Trace to identify network leaks, and improve the quality of water service to all customers. Pick Trace Starting Point Select from map Configure Options Run Trace Execute Trace Save Trace Field Crew Launch Mobile App Locate Leak Run Isolation Trace Notify Customers Fix Leak Display Trace Results “Trace Map” Summary Report Detail Report
User Stories Consider grouping them into themes ~~~~~~~~~~~ ~~~~~~~~~~~~~ ~~~~~~~~ ~~~~~~~~~ ~~~~~~~~~~~ ~~~~~~~~~~~~~ ~~~~~~~~ ~~~~~~~~~ ~~~~~~~~~~~ ~~~~~~~~~~~~~ ~~~~~~~~ ~~~~~~~~~ ~~~~~~~~~~~ ~~~~~~~~~~~~~ ~~~~~~~~ ~~~~~~~~~ ~~~~~~~~~~~ ~~~~~~~~~~~~~ ~~~~~~~~ ~~~~~~~~~ ~~~~~~~~~~~ ~~~~~~~~~~~~~ ~~~~~~~~ ~~~~~~~~~ ~~~~~~~~~~~ ~~~~~~~~~~~~~ ~~~~~~~~ ~~~~~~~~~ ~~~~~~~~~~~ ~~~~~~~~~~~~~ ~~~~~~~~ ~~~~~~~~~
Not always about [a user] Capture key concepts As a user interface, I need to look like the following image so that I can be intuitive to use
Use Paper Cards Keep them simple and concise
Keep user stories visible Focus of daily meetings
Compare Requirement Management Tools Licensed and Open Source Microsoft Team Foundation Server (TFS) Waffle.io JIRA
Requirements Process Things to avoid • Avoid long lists of requirements • Do not be judgmental • Prepare for conflicting requirements • Avoid requirements that are ambiguous • Avoid requirements that describe HOW (unless you are using COTS approach) • Don’t forget to prioritize • Requirements must have a “reason”
Requirements THE most important part of a project • Solid requirements gathering leads to successful projects • Consider solution, COTS capabilities before collecting additional requirements • Involve the right people in the process • Pick a methodology that fits your project • Focus on the level of detail that is appropriate • Important to prioritize and allocate • Invest plenty of time to secure customer approval
References • Agile & Iterative Development: A Manager’s Guide by Criag Larman, Addison-Wesley ,2003 • Software Requirements (2nd Edition) by Karl Wiegers, Microsoft Press, 2003 • Use Case Driven Object Modeling with UML by Doug Rosenberg and Matt Stephens, Apress, 2008 • Writing Effective User Cases, A Cockburn, Addison-Wesley, 2001 • Agile Development with ICONIX Process by Doug Rosenberg, Matt Stephens, and Mark Collins, Apress, 2005
References www.agilemanifesto.org http://alistair.cockburn.us/ http://www.iconixsw.com/ http://www.pmi.org/default.aspx
Please take our Survey Your feedback allows us to help maintain high standards and to help presenters Find your event in the Esri Events App Find the session you want to review Scroll down to the bottom of the session Answer survey questions and submit