Software Quality Assurance in Neuroinformatics H Jeremy Bockholt 20080630 NITRC Grantee Meeting.

Slides:



Advertisements
Similar presentations
Kyle Hartmann. RAD was created in response to long lead times and low flexibility Focuses on communication Quicker and better requirements interpretation.
Advertisements

Test Automation Success: Choosing the Right People & Process
Chapter 2 Modeling the Process and Life Cycle Shari L. Pfleeger
Software Engineering CSE470: Process 15 Software Engineering Phases Definition: What? Development: How? Maintenance: Managing change Umbrella Activities:
Alternate Software Development Methodologies
Copyright © 2012 Pearson Education, Inc. Publishing as Prentice Hall B.1.
Software Life Cycles ECE 417/617: Elements of Software Engineering
Stepan Potiyenko ISS Sr.SW Developer.
Software Development Process Models. The Waterfall Development Model.
Software Quality Metrics
R R R CSE870: Advanced Software Engineering (Cheng): Intro to Software Engineering1 Advanced Software Engineering Dr. Cheng Overview of Software Engineering.
1 Software Testing and Quality Assurance Lecture 15 - Planning for Testing (Chapter 3, A Practical Guide to Testing Object- Oriented Software)
Computer Engineering 203 R Smith Agile Development 1/ Agile Methods What are Agile Methods? – Extreme Programming is the best known example – SCRUM.
Chapter 6 Systems Development.
SE 450 Software Processes & Product Metrics 1 Defect Removal.
1 Software Engineering II Presentation Software Maintenance.
Chapter 30 Agile Requirements Methods. Mitigating Requirements Risk  The entire requirements discipline within the software lifecycle exists for only.
Planning and Tracking Software Quality Yordan Dimitrov Telerik Corporation
User Experience Design Goes Agile in Lean Transformation – A Case Study (2012 Agile Conference) Minna Isomursu, Andrey Sirotkin (VTT Technical Research.
Software Engineering Institute Capability Maturity Model (CMM)
Michael Solomon Tugboat Software Managing the Software Development Process.
Chapter 30 Agile Requirements Methods. Mitigating Requirements Risk  The entire requirements discipline within the software lifecycle exists for only.
This chapter is extracted from Sommerville’s slides. Text book chapter
Chapter : Software Process
COMPARISON STUDY BETWEEN AGILEFANT AND XPLANNER PLUS Professor Daniel Amyot Ruijun Fan Badr Alsubaihi Submitted to Professor Daniel Amyot.
System Implementation. System Implementation and Seven major activities Coding Testing Installation Documentation Training Support Purpose To convert.
Chapter 3 – Agile Software Development 1Chapter 3 Agile software development.
Dillon: CSE470: SE, Process1 Software Engineering Phases l Definition: What? l Development: How? l Maintenance: Managing change l Umbrella Activities:
Page 1 MODEL TEST in the small GENERALIZE PROGRAM PROCESS allocated maintenance changes management documents initial requirement project infrastructure.
Planning and Tracking Software Quality.  What Is Software Quality?  Causes of Software Defects  What is Quality Assurance?  Improving the Software.
Rational Unified Process Fundamentals Module 4: Disciplines II.
1 Chapter 2 The Process. 2 Process  What is it?  Who does it?  Why is it important?  What are the steps?  What is the work product?  How to ensure.
Software Project Failure Software Project Failure Night Two, Part One CSCI 521 Software Project Management.
What is a life cycle model? Framework under which a software product is going to be developed. – Defines the phases that the product under development.
These courseware materials are to be used in conjunction with Software Engineering: A Practitioner’s Approach, 6/e and are provided with permission by.
 To explain the importance of software configuration management (CM)  To describe key CM activities namely CM planning, change management, version management.
EMI INFSO-RI SA2 - Quality Assurance Alberto Aimar (CERN) SA2 Leader EMI First EC Review 22 June 2011, Brussels.
Creator: ACSession No: 16 Slide No: 1Reviewer: SS CSE300Advanced Software EngineeringFebruary 2006 (Software Quality) Configuration Management CSE300 Advanced.
1 Software Process Models-ii Presented By; Mehwish Shafiq.
William Schroeder, Ph.D. §, Andy Cedilnik §, Sebastien Barré, Ph.D. §, William Lorensen ‡, James Miller, Ph.D. ‡, Daniel Blezek, Ph.D. ‡ § Kitware Inc.,
Lucian Voinea Visualizing the Evolution of Code The Visual Code Navigator (VCN) Nunspeet,
University of Toronto at Scarborough © Kersti Wain-Bantin CSCC40 other methodologies 1 Method/Process = step-by-step description of the steps involved.
Using UML, Patterns, and Java Object-Oriented Software Engineering Chapter 16, Methodologies: Putting it all together.
Cmpe 589 Spring 2006 Lecture 2. Software Engineering Definition –A strategy for producing high quality software.
A Metrics Program. Advantages of Collecting Software Quality Metrics Objective assessments as to whether quality requirements are being met can be made.
Lecture 4 – XP and Agile 17/9/15. Plan-driven and agile development Plan-driven development A plan-driven approach to software engineering is based around.
Connecting with Computer Science2 Objectives Learn how software engineering is used to create applications Learn some of the different software engineering.
1 Software Engineering and Security DJPS April 12, 2005 Professor Richard Sinn CMPE 297: Software Security Technologies.
Agile Software Development Jeff Sutherland, one of the developers started it In February 2001, 17 Tools: continuous integration, automated or xUnit test,
Software Engineering Lecture # 1.
1 Educational Technology Electronic Teaching Portfolio Based on the ISTE/NCATE Foundation Standards for all educators. All candidates in teacher preparation.
Copyright © 2009 Pearson Education, Inc. Publishing as Prentice Hall Appendix B Agile Methodologies B.1.
System Maintenance Modifications or corrections made to an information system after it has been released to its customers Changing an information system.
Concept Mapping: A Graphical System for Understanding the Relationship between Concepts. ERIC Digest.
1 Chapter 12 Configuration management This chapter is extracted from Sommerville’s slides. Text book chapter 29 1.
Process Asad Ur Rehman Chief Technology Officer Feditec Enterprise.
Software Engineering (CSI 321) Software Process: A Generic View 1.
High Risk 1. Ensure productive use of GRID computing through participation of biologists to shape the development of the GRID. 2. Develop user-friendly.
CS223: Software Engineering Lecture 18: The XP. Recap Introduction to Agile Methodology Customer centric approach Issues of Agile methodology Where to.
by: Er. Manu Bansal Deptt of IT Software Quality Assurance.
Software Development. The Software Life Cycle Encompasses all activities from initial analysis until obsolescence Analysis of problem or request Analysis.
Software Development Life Cycle. The Software Life Cycle  Encompasses all activities from initial analysis until end of work  Formal process for software.
Advanced Software Engineering Dr. Cheng
Software Development.
Chapter 7: Software Engineering
Software Quality Assurance (SQA)
Introducing ISTQB Agile Foundation Extending the ISTQB Program’s Support Further Presented by Rex Black, CTAL Copyright © 2014 ASTQB 1.
Agile software development
UML Design for an Automated Registration System
Presentation transcript:

Software Quality Assurance in Neuroinformatics H Jeremy Bockholt NITRC Grantee Meeting

Outline Background and Examples Software Process Software Quality Assurance Recommendations

Background Neuroinformatics is an emerging discipline which attempts to integrate neuroscientific information from the level of the genome to the level of human behavior. Neuroinformatics produces digital capabilities for a web-based information management system in the form of interoperable databases and associated data management tools. Neuroinformatics tools include: –software for querying and data mining, data manipulation and analysis, scientific visualization, biological modeling and simulation, and electronic communication and collaboration

Examples of Neuroinformatics Tools MRN has over 5500 human subjects, with 6500 scanning sessions using MR, EEG, MEG –We are now actively sequencing 1,000,000 SNPs arrays on subjects as well as collecting vast amounts of clinical, neuropsychological, behavioral, and physiological data –Using MRN tools, over 200 users at 7 sites collaborate on 150 active research studies with access to nearly 200 TB of data and growing… BIRN has a vast set of multisite tools with even larger user base, set of data and tools and has adopted a federated model XNAT multi-site tool for collaborative research data management Analysis tools such as Slicer, FSL, AFNI, SPM, BRAINS, Freesurfer, etc.

Goal Just like we are converging on standards and recommendations for data storage, data exchange, data access, we should explore the possibility of having recommendations for software process and software quality assurance for the field of neuroinformatics

Software Process What tools and set of procedures and policies should be followed to create software. –Source Code Revision Control –Compilation –Testing –Documentation –Enhancement Tracking –Project Management –Communication and Collaboration

Software Process Challenges The largest challenge in neuroinformatics is that usually there is a resistant to following a software process as the perception is that it take too much time It is common for developers and users can be at separate sites Many of our neuroinformatics developers are not software engineers Time constraints and funding constraints sometimes limit neuroinformatics tool development just to functional prototypes that have limited or no testing or documentation associated with them

The NA-MIC Software Process NA-MIC has a publication on software process and follows an excellent example of a software process optimized for Neuroinformatics –Adaptation of the distributed, open source software process –Targeted to the data-driven approach. –Utilize eXtreme Programming techniques generating user stories, using simple design, writing tests first, refactoring, using continuous integration, and using coding standards are employed some aspects such as having on-site customers, and pair- programming are not used –Suggests using CVS, DART, DOXYGEN, Bugzilla, Cmake, to support software development process –Encourages software developers to share code and tools and encourages participation in two programming weeks per year to permit face to face time for rapid development

Software Quality Assurance The purpose of a software quality assurance plan is to define the formal processes and procedures for software development, a release review process, software development standards, and testing standards for a organization to follow across all software projects. The plan should formally define communication strategies, Software Testing Plan, Software Measurements (calibration and user satisfaction), Risk Assessment, Corrective action process, and Training for developers Software Quality should be measured and tracked at each development iteration

Software Quality Challenges Most Neuroinformatics software development is for users at multiple sites, much of the software is deployed into multi-site research consortia Most Neuroinformatics software development occurs under limited resources, shortened development cycles, large time constraints A formal quality plan seems to be rarely followed, Documentation, training, and thorough testing are typically cut or truncated to meet the constraints of budget and time While the field is starting to share tools and source code (thanks to NITRC), we’re not sharing software process and strategies for maintaining quality

A Software Quality Plan for Neuroinformatics We have developed a software quality plan that has been optimized to avoid some of the challenges found in the field of neuroinformatics. Some of the highlights are using DART and Bugzilla to automatically perform and track software quality metrics –programmer productivity (bugs/module) –module defect density (code size/programming time) –requirements stability (number of initial requirements / total number of requirements) –system spoilage (effort fixing bugs / total project effort) Conduct user satisfaction surveys at the onset and during use of each software product release We have also generated recommendations on software development standards (IEEE) and specifically recommend following General Principles of Software Validation (US FDA, 2002) for neuroinformatics tools

Future Work How can a software process be shared? How can a software quality plan be shared? Can the community decide on a preferred software process and software quality plan We should publish a lessons learned manuscript on software quality in multi-site neuroinformatics

Conclusions NITRC is a well-positioned to guide the field on software process and software quality Having tool developers share their software process and quality plans would assist adopters of the tools better assess tools for integration with other components