SlideShare une entreprise Scribd logo
1  sur  25
Télécharger pour lire hors ligne
On the perception of software quality
       requirements during the project lifecycle

                                   Neil A. Ernst, John Mylopoulos
                                  {nernst,jm}@cs.toronto.edu
                                            University of Toronto


                                              July 1, 2010




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   1 / 16
Motivation

   On the perception of software quality requirements during the project
   lifecycle
           Throughout the lifecycle
           Understand software quality requirements using an empirical,
           data mining approach
           Quality requirements as universal requirements
           Dataset: 8 Gnome OSS projects
           Data / code available at
           http://github.com/neilernst/gnome-quality-mining




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   2 / 16
Specific research questions:


       1       Test Lehman’s 7th Law1 : system quality will appear to be
               declining unless rigorously maintained and adapted to
               environmental changes
       2       Are high-level quality requirements (e.g., efficiency) of equal
               concern in different projects?
       3       Is this a viable mechanism for understanding the treatment of
               quality requirements?




           1
        Lehman, M.M., et al.: Metrics and laws of software evolution – the nineties view. In: International Software Metrics
   Symposium pp. 20–32. Albuquerque, NM (1997)
Ernst, Mylopoulos (University of Toronto)           Perception of quality req.                            July 1, 2010         3 / 16
Specific research questions:


       1       Test Lehman’s 7th Law1 : system quality will appear to be
               declining unless rigorously maintained and adapted to
               environmental changes
       2       Are high-level quality requirements (e.g., efficiency) of equal
               concern in different projects?
       3       Is this a viable mechanism for understanding the treatment of
               quality requirements?




           1
        Lehman, M.M., et al.: Metrics and laws of software evolution – the nineties view. In: International Software Metrics
   Symposium pp. 20–32. Albuquerque, NM (1997)
Ernst, Mylopoulos (University of Toronto)           Perception of quality req.                            July 1, 2010         3 / 16
Specific research questions:


       1       Test Lehman’s 7th Law1 : system quality will appear to be
               declining unless rigorously maintained and adapted to
               environmental changes
       2       Are high-level quality requirements (e.g., efficiency) of equal
               concern in different projects?
       3       Is this a viable mechanism for understanding the treatment of
               quality requirements?




           1
        Lehman, M.M., et al.: Metrics and laws of software evolution – the nineties view. In: International Software Metrics
   Symposium pp. 20–32. Albuquerque, NM (1997)
Ernst, Mylopoulos (University of Toronto)           Perception of quality req.                            July 1, 2010         3 / 16
Methodology

                                                 ISO9126,
       Gnome projects:
                                                 Wordnet, Boehm,
       commits, bugs,
                                                 McCall, KDE
       mail


                                             Create                                      end
              Generate                                                Query
                                            signifiers
              corpora                                                corpora
                                            (WN,ext)




            start                                                                  Plot
                               Precision/recall                      Error      outcomes
                               on random                            analysis   and calculate
                               events                                              stats




Ernst, Mylopoulos (University of Toronto)        Perception of quality req.      July 1, 2010   4 / 16
Datasets


      Product             Language Size (ksloc)                     Age (years)       Type
     Evolution                C                  313                     10.75       Mail
     Nautilus                 C                  108                     10.75     File mgr
     Metacity                 C                  66                       7.5     Window mgr
      Ekiga                  C++                 54                        7         VOIP
      Totem                   C                  49                      6.33       Media
     Deskbar                Python               21                       3.2     Widgets/UI
      Evince                  C                  66                      9.75     Doc viewer
     Empathy                  C                  55                       1.5         IM




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.             July 1, 2010   5 / 16
Signifiers and quality requirements
           Cross-project comparisons using a standardized taxonomy – ISO
           9126.
           Find quality concepts in project artifacts as signifier occurrences.
           Corpora: emails, bug reports, commit messages.
           Database of 900k ‘messages’ (total, all projects).

                                              This menu is
                                              barely usable!




                                                         email
Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   6 / 16
Signifiers
           Detect the appearance of quality concepts in the messages.
           Created signifier lists, a representative signifier thesaurus.
           Two lists: one based on Wordnet and ISO9126, the other
           extended with domain knowledge (ext). E.g.,
             Quality               Signifiers
             Maintainability       testability changeability analyzability stability maintainability
                                   maintain maintainable modularity modifiability understandabil-
                                   ity
             Functionality         security compliance accuracy interoperability suitability func-
                                   tional practicality functionality
             Portability           conformance adaptability replaceability installability portable
                                   movableness movability portability
             Efficiency              “resource behaviour” “time behaviour” efficient efficiency
             Usability             operability understandability learnability useable usable ser-
                                   viceable usefulness utility useableness usableness serviceable-
                                   ness serviceability usability
             Reliability           “fault tolerance” recoverability maturity reliable dependable
                                   responsibleness responsibility reliableness reliability dependable-
                                   ness dependability

Ernst, Mylopoulos (University of Toronto)       Perception of quality req.                  July 1, 2010   7 / 16
Observations
       1   Search for events
       2   Normalize for message volume
       3   Group by week
           Event                                                         Quality
           ...By upgrading to a newer version of GNOME you               None
           could receive bug fixes and new functionality.
           There should be a feature added that allows you to            Functionality
           keep the current functionality for those on work-
           stations (automatic hot-sync) and then another
           option that allows you to manually initiate .
           Steps to reproduce the crash: 1. Can’t reproduce              Reliability,
           with accuracy. Seemingly random. ....                         Functionality
           These calls are just a waste of time for client               Efficiency
           and server, and the Nautilus online storage view
           is slowed down by this wastefulness.
Ernst, Mylopoulos (University of Toronto)   Perception of quality req.       July 1, 2010   8 / 16
Error analysis
       1   Pick random messages; manually classify
       2   Compare manual classification to machine classification
       3   Precision: 80%, Recall: 51% (extended), 6% Wordnet


                      Signified quality Precision ext Precision WN
                         Usability                    0.47               0.22
                        Portability                   0.11               0.20
                       Maintainability                0.22               0.31
                        Reliability                   0.15               0.19
                       Functionality                  0.14               0.18
                         Efficiency                     0.16               0.07
                          Mean                        0.21               0.20


Ernst, Mylopoulos (University of Toronto)   Perception of quality req.          July 1, 2010   9 / 16
Error analysis
       1   Pick random messages; manually classify
       2   Compare manual classification to machine classification
       3   Precision: 80%, Recall: 51% (extended), 6% Wordnet


                      Signified quality Precision ext Precision WN
                         Usability                    0.47               0.22
                        Portability                   0.11               0.20
                       Maintainability                0.22               0.31
                        Reliability                   0.15               0.19
                       Functionality                  0.14               0.18
                         Efficiency                     0.16               0.07
                          Mean                        0.21               0.20


Ernst, Mylopoulos (University of Toronto)   Perception of quality req.          July 1, 2010   9 / 16
Observations



   RQ1: Lehman’s law
      Is there a relation between events and project lifespan?
      Looked at three possible explanations:
                   Overall lifespan
                   Project release windows
                   Key external events




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   10 / 16
Occurrences (normalized)

                                                             0         100            200               300           400




                                                   1998
                                                                                                                 Gnome 1.0




Ernst, Mylopoulos (University of Toronto)
                                                                                                               Gnome 1.2




                                                   2000
                                                                                                               Gnome 1.4




                                                   2002
                                                                                                               Gnome 2.0
                                                                                                               Gnome 2.2
                                                                                                               Gnome 2.4




                                            Year
                                                                                                               Gnome 2.6




                                                   2004
                                                                                                               Gnome 2.8




Perception of quality req.
                                                          Gnome 2.10                                          Gnome 2.10
                                                                                                              Gnome 2.12
                                                                                                                             Evolution -- Usability (R2 = 18%)




                                                   2006
                                                                                                              Gnome 2.16


                                                                                                              Gnome 2.20
                                                   2008




                                                                                                              Gnome 2.24
July 1, 2010
11 / 16
Results



           Correlation coefficient very low in both cases - no relationship
           Analyzing peaks seems useful - external events are driving
           frequencies
           “... I know this was discussed a few weeks ago ... could it be
           implemented as an advanced option that has to be turned on
           and is off by default?”




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   12 / 16
Observations (2)
   RQ2: Are qualities treated the same in different projects?
      Examine normalized occurrences per week for extended signifiers

                                  Quality        Project             Occurrences
                                Efficiency       Evolution                  0.012
                                               Nautilus                   0.026
                                 Usability     Evolution                  0.192
                                               Nautilus                   0.285
                               Portability Evolution                      0.010
                                           Nautilus                       0.011



Ernst, Mylopoulos (University of Toronto)    Perception of quality req.            July 1, 2010   13 / 16
Threats to validity


       1   How valid are word lists?
       2   Domain-dependent quality models
       3   Other sources of project discussions (IRC/F2F/Skype)
       4   Open source projects may not generalize
       5   No sense of ‘attitudes’ to requirements
       6   Statistics




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   14 / 16
Threats to validity


       1   How valid are word lists?
       2   Domain-dependent quality models
       3   Other sources of project discussions (IRC/F2F/Skype)
       4   Open source projects may not generalize
       5   No sense of ‘attitudes’ to requirements
       6   Statistics




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   14 / 16
Threats to validity


       1   How valid are word lists?
       2   Domain-dependent quality models
       3   Other sources of project discussions (IRC/F2F/Skype)
       4   Open source projects may not generalize
       5   No sense of ‘attitudes’ to requirements
       6   Statistics




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   14 / 16
Threats to validity


       1   How valid are word lists?
       2   Domain-dependent quality models
       3   Other sources of project discussions (IRC/F2F/Skype)
       4   Open source projects may not generalize
       5   No sense of ‘attitudes’ to requirements
       6   Statistics




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   14 / 16
Threats to validity


       1   How valid are word lists?
       2   Domain-dependent quality models
       3   Other sources of project discussions (IRC/F2F/Skype)
       4   Open source projects may not generalize
       5   No sense of ‘attitudes’ to requirements
       6   Statistics




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   14 / 16
Threats to validity


       1   How valid are word lists?
       2   Domain-dependent quality models
       3   Other sources of project discussions (IRC/F2F/Skype)
       4   Open source projects may not generalize
       5   No sense of ‘attitudes’ to requirements
       6   Statistics




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   14 / 16
Threats to validity


       1   How valid are word lists?
       2   Domain-dependent quality models
       3   Other sources of project discussions (IRC/F2F/Skype)
       4   Open source projects may not generalize
       5   No sense of ‘attitudes’ to requirements
       6   Statistics




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   14 / 16
Future work: agenda

   RQ3: Usefulness: Technique worked, but:
    1 Leverage other machine learning techniques like multi-label
      learning
    2 Understand inter-project variations and usefulness of global
      taxonomies of quality
    3 Use techniques to understand requirements evolution in software
      projects
    4 Tie experimental data to ethnographic data2




        2
          Aranda, J. and Venolia, G.: The secret life of bugs: Going past the errors and omissions in software repositories. In
   International Conference on Software Engineering, pp 298-308 (2009).
Ernst, Mylopoulos (University of Toronto)             Perception of quality req.                            July 1, 2010          15 / 16
Happy Canada Day!




Ernst, Mylopoulos (University of Toronto)   Perception of quality req.   July 1, 2010   16 / 16

Contenu connexe

Similaire à Perception of Software Quality Requirements

Not Only Statements: The Role of Textual Analysis in Software Quality
Not Only Statements: The Role of Textual Analysis in Software QualityNot Only Statements: The Role of Textual Analysis in Software Quality
Not Only Statements: The Role of Textual Analysis in Software QualityRocco Oliveto
 
GATE, HLT and Machine Learning, Sheffield, July 2003
GATE, HLT and Machine Learning, Sheffield, July 2003GATE, HLT and Machine Learning, Sheffield, July 2003
GATE, HLT and Machine Learning, Sheffield, July 2003butest
 
Luciano pr 08-849_ontology_evaluation_methods_metrics
Luciano pr 08-849_ontology_evaluation_methods_metricsLuciano pr 08-849_ontology_evaluation_methods_metrics
Luciano pr 08-849_ontology_evaluation_methods_metricsJoanne Luciano
 
Luciano pr 08-849_ontology_evaluation_methods_metrics
Luciano pr 08-849_ontology_evaluation_methods_metricsLuciano pr 08-849_ontology_evaluation_methods_metrics
Luciano pr 08-849_ontology_evaluation_methods_metricsJoanne Luciano
 
Read Between The Lines: an Annotation Tool for Multimodal Data
Read Between The Lines: an Annotation Tool for Multimodal DataRead Between The Lines: an Annotation Tool for Multimodal Data
Read Between The Lines: an Annotation Tool for Multimodal DataDaniele Di Mitri
 
On the Globalization of Modeling Languages (June 8th, 2015)
On the Globalization of Modeling Languages (June 8th, 2015)On the Globalization of Modeling Languages (June 8th, 2015)
On the Globalization of Modeling Languages (June 8th, 2015)Benoit Combemale
 
Kuchinsky_Cytoscape_BOSC2009
Kuchinsky_Cytoscape_BOSC2009Kuchinsky_Cytoscape_BOSC2009
Kuchinsky_Cytoscape_BOSC2009bosc
 
A PNML extension for the HCI design
A PNML extension for the HCI designA PNML extension for the HCI design
A PNML extension for the HCI designWaqas Tariq
 
8 ontology integration and interoperability (onto i op)
8 ontology integration and interoperability (onto i op)8 ontology integration and interoperability (onto i op)
8 ontology integration and interoperability (onto i op)AEGIS-ACCESSIBLE Projects
 
(Structural) Feature Interactions for Variability-Intensive Systems Testing
(Structural) Feature Interactions for Variability-Intensive Systems Testing (Structural) Feature Interactions for Variability-Intensive Systems Testing
(Structural) Feature Interactions for Variability-Intensive Systems Testing Gilles Perrouin
 
Non Functional Requirements in Requirement Engineering.pdf
Non Functional Requirements in Requirement Engineering.pdfNon Functional Requirements in Requirement Engineering.pdf
Non Functional Requirements in Requirement Engineering.pdfJeevaPadmini
 
SENTIMENT ANALYSIS IN MYANMAR LANGUAGE USING CONVOLUTIONAL LSTM NEURAL NETWORK
SENTIMENT ANALYSIS IN MYANMAR LANGUAGE USING CONVOLUTIONAL LSTM NEURAL NETWORKSENTIMENT ANALYSIS IN MYANMAR LANGUAGE USING CONVOLUTIONAL LSTM NEURAL NETWORK
SENTIMENT ANALYSIS IN MYANMAR LANGUAGE USING CONVOLUTIONAL LSTM NEURAL NETWORKijnlc
 
Sentiment Analysis In Myanmar Language Using Convolutional Lstm Neural Network
Sentiment Analysis In Myanmar Language Using Convolutional Lstm Neural NetworkSentiment Analysis In Myanmar Language Using Convolutional Lstm Neural Network
Sentiment Analysis In Myanmar Language Using Convolutional Lstm Neural Networkkevig
 
Bibliography (Microsoft Word, 61k)
Bibliography (Microsoft Word, 61k)Bibliography (Microsoft Word, 61k)
Bibliography (Microsoft Word, 61k)butest
 
From Bugs to Decision Support - Selected Research Highlights
From Bugs to Decision Support - Selected Research HighlightsFrom Bugs to Decision Support - Selected Research Highlights
From Bugs to Decision Support - Selected Research HighlightsMarkus Borg
 
Dynamic V&V in Language-Oriented Modeling
Dynamic V&V in Language-Oriented ModelingDynamic V&V in Language-Oriented Modeling
Dynamic V&V in Language-Oriented ModelingBenoit Combemale
 
Making Heterogeneous Ontologies Interoperable Through Standardisation
Making Heterogeneous Ontologies Interoperable Through StandardisationMaking Heterogeneous Ontologies Interoperable Through Standardisation
Making Heterogeneous Ontologies Interoperable Through StandardisationChristoph Lange
 

Similaire à Perception of Software Quality Requirements (20)

Not Only Statements: The Role of Textual Analysis in Software Quality
Not Only Statements: The Role of Textual Analysis in Software QualityNot Only Statements: The Role of Textual Analysis in Software Quality
Not Only Statements: The Role of Textual Analysis in Software Quality
 
GATE, HLT and Machine Learning, Sheffield, July 2003
GATE, HLT and Machine Learning, Sheffield, July 2003GATE, HLT and Machine Learning, Sheffield, July 2003
GATE, HLT and Machine Learning, Sheffield, July 2003
 
Luciano pr 08-849_ontology_evaluation_methods_metrics
Luciano pr 08-849_ontology_evaluation_methods_metricsLuciano pr 08-849_ontology_evaluation_methods_metrics
Luciano pr 08-849_ontology_evaluation_methods_metrics
 
Luciano pr 08-849_ontology_evaluation_methods_metrics
Luciano pr 08-849_ontology_evaluation_methods_metricsLuciano pr 08-849_ontology_evaluation_methods_metrics
Luciano pr 08-849_ontology_evaluation_methods_metrics
 
Read Between The Lines: an Annotation Tool for Multimodal Data
Read Between The Lines: an Annotation Tool for Multimodal DataRead Between The Lines: an Annotation Tool for Multimodal Data
Read Between The Lines: an Annotation Tool for Multimodal Data
 
Semantic annotation of biomedical data
Semantic annotation of biomedical dataSemantic annotation of biomedical data
Semantic annotation of biomedical data
 
On the Globalization of Modeling Languages (June 8th, 2015)
On the Globalization of Modeling Languages (June 8th, 2015)On the Globalization of Modeling Languages (June 8th, 2015)
On the Globalization of Modeling Languages (June 8th, 2015)
 
Kuchinsky_Cytoscape_BOSC2009
Kuchinsky_Cytoscape_BOSC2009Kuchinsky_Cytoscape_BOSC2009
Kuchinsky_Cytoscape_BOSC2009
 
CRC Final Report
CRC Final ReportCRC Final Report
CRC Final Report
 
A PNML extension for the HCI design
A PNML extension for the HCI designA PNML extension for the HCI design
A PNML extension for the HCI design
 
8 ontology integration and interoperability (onto i op)
8 ontology integration and interoperability (onto i op)8 ontology integration and interoperability (onto i op)
8 ontology integration and interoperability (onto i op)
 
(Structural) Feature Interactions for Variability-Intensive Systems Testing
(Structural) Feature Interactions for Variability-Intensive Systems Testing (Structural) Feature Interactions for Variability-Intensive Systems Testing
(Structural) Feature Interactions for Variability-Intensive Systems Testing
 
Lopez
LopezLopez
Lopez
 
Non Functional Requirements in Requirement Engineering.pdf
Non Functional Requirements in Requirement Engineering.pdfNon Functional Requirements in Requirement Engineering.pdf
Non Functional Requirements in Requirement Engineering.pdf
 
SENTIMENT ANALYSIS IN MYANMAR LANGUAGE USING CONVOLUTIONAL LSTM NEURAL NETWORK
SENTIMENT ANALYSIS IN MYANMAR LANGUAGE USING CONVOLUTIONAL LSTM NEURAL NETWORKSENTIMENT ANALYSIS IN MYANMAR LANGUAGE USING CONVOLUTIONAL LSTM NEURAL NETWORK
SENTIMENT ANALYSIS IN MYANMAR LANGUAGE USING CONVOLUTIONAL LSTM NEURAL NETWORK
 
Sentiment Analysis In Myanmar Language Using Convolutional Lstm Neural Network
Sentiment Analysis In Myanmar Language Using Convolutional Lstm Neural NetworkSentiment Analysis In Myanmar Language Using Convolutional Lstm Neural Network
Sentiment Analysis In Myanmar Language Using Convolutional Lstm Neural Network
 
Bibliography (Microsoft Word, 61k)
Bibliography (Microsoft Word, 61k)Bibliography (Microsoft Word, 61k)
Bibliography (Microsoft Word, 61k)
 
From Bugs to Decision Support - Selected Research Highlights
From Bugs to Decision Support - Selected Research HighlightsFrom Bugs to Decision Support - Selected Research Highlights
From Bugs to Decision Support - Selected Research Highlights
 
Dynamic V&V in Language-Oriented Modeling
Dynamic V&V in Language-Oriented ModelingDynamic V&V in Language-Oriented Modeling
Dynamic V&V in Language-Oriented Modeling
 
Making Heterogeneous Ontologies Interoperable Through Standardisation
Making Heterogeneous Ontologies Interoperable Through StandardisationMaking Heterogeneous Ontologies Interoperable Through Standardisation
Making Heterogeneous Ontologies Interoperable Through Standardisation
 

Plus de Neil Ernst

Measure It, Manage It, Ignore It - Software Practitioners and Technical Debt
Measure It, Manage It, Ignore It - Software Practitioners and Technical Debt Measure It, Manage It, Ignore It - Software Practitioners and Technical Debt
Measure It, Manage It, Ignore It - Software Practitioners and Technical Debt Neil Ernst
 
Critical Research Review at EmpiRE 2015
Critical Research Review at EmpiRE 2015Critical Research Review at EmpiRE 2015
Critical Research Review at EmpiRE 2015Neil Ernst
 
Using AI to Model Quality Attribute Tradeoffs
Using AI to Model Quality Attribute TradeoffsUsing AI to Model Quality Attribute Tradeoffs
Using AI to Model Quality Attribute TradeoffsNeil Ernst
 
Technical Debt and Requirements
Technical Debt and RequirementsTechnical Debt and Requirements
Technical Debt and RequirementsNeil Ernst
 
Requirements Evolution Drives Software Evolution
Requirements Evolution Drives Software EvolutionRequirements Evolution Drives Software Evolution
Requirements Evolution Drives Software EvolutionNeil Ernst
 
Adoption-Centric Knowledge Engineering
Adoption-Centric Knowledge EngineeringAdoption-Centric Knowledge Engineering
Adoption-Centric Knowledge EngineeringNeil Ernst
 
Introduction for CCASR
Introduction for CCASRIntroduction for CCASR
Introduction for CCASRNeil Ernst
 

Plus de Neil Ernst (7)

Measure It, Manage It, Ignore It - Software Practitioners and Technical Debt
Measure It, Manage It, Ignore It - Software Practitioners and Technical Debt Measure It, Manage It, Ignore It - Software Practitioners and Technical Debt
Measure It, Manage It, Ignore It - Software Practitioners and Technical Debt
 
Critical Research Review at EmpiRE 2015
Critical Research Review at EmpiRE 2015Critical Research Review at EmpiRE 2015
Critical Research Review at EmpiRE 2015
 
Using AI to Model Quality Attribute Tradeoffs
Using AI to Model Quality Attribute TradeoffsUsing AI to Model Quality Attribute Tradeoffs
Using AI to Model Quality Attribute Tradeoffs
 
Technical Debt and Requirements
Technical Debt and RequirementsTechnical Debt and Requirements
Technical Debt and Requirements
 
Requirements Evolution Drives Software Evolution
Requirements Evolution Drives Software EvolutionRequirements Evolution Drives Software Evolution
Requirements Evolution Drives Software Evolution
 
Adoption-Centric Knowledge Engineering
Adoption-Centric Knowledge EngineeringAdoption-Centric Knowledge Engineering
Adoption-Centric Knowledge Engineering
 
Introduction for CCASR
Introduction for CCASRIntroduction for CCASR
Introduction for CCASR
 

Dernier

Ensuring Technical Readiness For Copilot in Microsoft 365
Ensuring Technical Readiness For Copilot in Microsoft 365Ensuring Technical Readiness For Copilot in Microsoft 365
Ensuring Technical Readiness For Copilot in Microsoft 3652toLead Limited
 
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptx
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptxMerck Moving Beyond Passwords: FIDO Paris Seminar.pptx
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptxLoriGlavin3
 
Take control of your SAP testing with UiPath Test Suite
Take control of your SAP testing with UiPath Test SuiteTake control of your SAP testing with UiPath Test Suite
Take control of your SAP testing with UiPath Test SuiteDianaGray10
 
Hyperautomation and AI/ML: A Strategy for Digital Transformation Success.pdf
Hyperautomation and AI/ML: A Strategy for Digital Transformation Success.pdfHyperautomation and AI/ML: A Strategy for Digital Transformation Success.pdf
Hyperautomation and AI/ML: A Strategy for Digital Transformation Success.pdfPrecisely
 
Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Enterprise Knowledge
 
The Ultimate Guide to Choosing WordPress Pros and Cons
The Ultimate Guide to Choosing WordPress Pros and ConsThe Ultimate Guide to Choosing WordPress Pros and Cons
The Ultimate Guide to Choosing WordPress Pros and ConsPixlogix Infotech
 
H2O.ai CEO/Founder: Sri Ambati Keynote at Wells Fargo Day
H2O.ai CEO/Founder: Sri Ambati Keynote at Wells Fargo DayH2O.ai CEO/Founder: Sri Ambati Keynote at Wells Fargo Day
H2O.ai CEO/Founder: Sri Ambati Keynote at Wells Fargo DaySri Ambati
 
DevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache MavenDevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache MavenHervé Boutemy
 
Anypoint Exchange: It’s Not Just a Repo!
Anypoint Exchange: It’s Not Just a Repo!Anypoint Exchange: It’s Not Just a Repo!
Anypoint Exchange: It’s Not Just a Repo!Manik S Magar
 
How to write a Business Continuity Plan
How to write a Business Continuity PlanHow to write a Business Continuity Plan
How to write a Business Continuity PlanDatabarracks
 
Commit 2024 - Secret Management made easy
Commit 2024 - Secret Management made easyCommit 2024 - Secret Management made easy
Commit 2024 - Secret Management made easyAlfredo García Lavilla
 
From Family Reminiscence to Scholarly Archive .
From Family Reminiscence to Scholarly Archive .From Family Reminiscence to Scholarly Archive .
From Family Reminiscence to Scholarly Archive .Alan Dix
 
Artificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptxArtificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptxhariprasad279825
 
Human Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsHuman Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsMark Billinghurst
 
TeamStation AI System Report LATAM IT Salaries 2024
TeamStation AI System Report LATAM IT Salaries 2024TeamStation AI System Report LATAM IT Salaries 2024
TeamStation AI System Report LATAM IT Salaries 2024Lonnie McRorey
 
"LLMs for Python Engineers: Advanced Data Analysis and Semantic Kernel",Oleks...
"LLMs for Python Engineers: Advanced Data Analysis and Semantic Kernel",Oleks..."LLMs for Python Engineers: Advanced Data Analysis and Semantic Kernel",Oleks...
"LLMs for Python Engineers: Advanced Data Analysis and Semantic Kernel",Oleks...Fwdays
 
Unleash Your Potential - Namagunga Girls Coding Club
Unleash Your Potential - Namagunga Girls Coding ClubUnleash Your Potential - Namagunga Girls Coding Club
Unleash Your Potential - Namagunga Girls Coding ClubKalema Edgar
 
SAP Build Work Zone - Overview L2-L3.pptx
SAP Build Work Zone - Overview L2-L3.pptxSAP Build Work Zone - Overview L2-L3.pptx
SAP Build Work Zone - Overview L2-L3.pptxNavinnSomaal
 
"Debugging python applications inside k8s environment", Andrii Soldatenko
"Debugging python applications inside k8s environment", Andrii Soldatenko"Debugging python applications inside k8s environment", Andrii Soldatenko
"Debugging python applications inside k8s environment", Andrii SoldatenkoFwdays
 
Nell’iperspazio con Rocket: il Framework Web di Rust!
Nell’iperspazio con Rocket: il Framework Web di Rust!Nell’iperspazio con Rocket: il Framework Web di Rust!
Nell’iperspazio con Rocket: il Framework Web di Rust!Commit University
 

Dernier (20)

Ensuring Technical Readiness For Copilot in Microsoft 365
Ensuring Technical Readiness For Copilot in Microsoft 365Ensuring Technical Readiness For Copilot in Microsoft 365
Ensuring Technical Readiness For Copilot in Microsoft 365
 
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptx
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptxMerck Moving Beyond Passwords: FIDO Paris Seminar.pptx
Merck Moving Beyond Passwords: FIDO Paris Seminar.pptx
 
Take control of your SAP testing with UiPath Test Suite
Take control of your SAP testing with UiPath Test SuiteTake control of your SAP testing with UiPath Test Suite
Take control of your SAP testing with UiPath Test Suite
 
Hyperautomation and AI/ML: A Strategy for Digital Transformation Success.pdf
Hyperautomation and AI/ML: A Strategy for Digital Transformation Success.pdfHyperautomation and AI/ML: A Strategy for Digital Transformation Success.pdf
Hyperautomation and AI/ML: A Strategy for Digital Transformation Success.pdf
 
Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024Designing IA for AI - Information Architecture Conference 2024
Designing IA for AI - Information Architecture Conference 2024
 
The Ultimate Guide to Choosing WordPress Pros and Cons
The Ultimate Guide to Choosing WordPress Pros and ConsThe Ultimate Guide to Choosing WordPress Pros and Cons
The Ultimate Guide to Choosing WordPress Pros and Cons
 
H2O.ai CEO/Founder: Sri Ambati Keynote at Wells Fargo Day
H2O.ai CEO/Founder: Sri Ambati Keynote at Wells Fargo DayH2O.ai CEO/Founder: Sri Ambati Keynote at Wells Fargo Day
H2O.ai CEO/Founder: Sri Ambati Keynote at Wells Fargo Day
 
DevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache MavenDevoxxFR 2024 Reproducible Builds with Apache Maven
DevoxxFR 2024 Reproducible Builds with Apache Maven
 
Anypoint Exchange: It’s Not Just a Repo!
Anypoint Exchange: It’s Not Just a Repo!Anypoint Exchange: It’s Not Just a Repo!
Anypoint Exchange: It’s Not Just a Repo!
 
How to write a Business Continuity Plan
How to write a Business Continuity PlanHow to write a Business Continuity Plan
How to write a Business Continuity Plan
 
Commit 2024 - Secret Management made easy
Commit 2024 - Secret Management made easyCommit 2024 - Secret Management made easy
Commit 2024 - Secret Management made easy
 
From Family Reminiscence to Scholarly Archive .
From Family Reminiscence to Scholarly Archive .From Family Reminiscence to Scholarly Archive .
From Family Reminiscence to Scholarly Archive .
 
Artificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptxArtificial intelligence in cctv survelliance.pptx
Artificial intelligence in cctv survelliance.pptx
 
Human Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR SystemsHuman Factors of XR: Using Human Factors to Design XR Systems
Human Factors of XR: Using Human Factors to Design XR Systems
 
TeamStation AI System Report LATAM IT Salaries 2024
TeamStation AI System Report LATAM IT Salaries 2024TeamStation AI System Report LATAM IT Salaries 2024
TeamStation AI System Report LATAM IT Salaries 2024
 
"LLMs for Python Engineers: Advanced Data Analysis and Semantic Kernel",Oleks...
"LLMs for Python Engineers: Advanced Data Analysis and Semantic Kernel",Oleks..."LLMs for Python Engineers: Advanced Data Analysis and Semantic Kernel",Oleks...
"LLMs for Python Engineers: Advanced Data Analysis and Semantic Kernel",Oleks...
 
Unleash Your Potential - Namagunga Girls Coding Club
Unleash Your Potential - Namagunga Girls Coding ClubUnleash Your Potential - Namagunga Girls Coding Club
Unleash Your Potential - Namagunga Girls Coding Club
 
SAP Build Work Zone - Overview L2-L3.pptx
SAP Build Work Zone - Overview L2-L3.pptxSAP Build Work Zone - Overview L2-L3.pptx
SAP Build Work Zone - Overview L2-L3.pptx
 
"Debugging python applications inside k8s environment", Andrii Soldatenko
"Debugging python applications inside k8s environment", Andrii Soldatenko"Debugging python applications inside k8s environment", Andrii Soldatenko
"Debugging python applications inside k8s environment", Andrii Soldatenko
 
Nell’iperspazio con Rocket: il Framework Web di Rust!
Nell’iperspazio con Rocket: il Framework Web di Rust!Nell’iperspazio con Rocket: il Framework Web di Rust!
Nell’iperspazio con Rocket: il Framework Web di Rust!
 

Perception of Software Quality Requirements

  • 1. On the perception of software quality requirements during the project lifecycle Neil A. Ernst, John Mylopoulos {nernst,jm}@cs.toronto.edu University of Toronto July 1, 2010 Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 1 / 16
  • 2. Motivation On the perception of software quality requirements during the project lifecycle Throughout the lifecycle Understand software quality requirements using an empirical, data mining approach Quality requirements as universal requirements Dataset: 8 Gnome OSS projects Data / code available at http://github.com/neilernst/gnome-quality-mining Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 2 / 16
  • 3. Specific research questions: 1 Test Lehman’s 7th Law1 : system quality will appear to be declining unless rigorously maintained and adapted to environmental changes 2 Are high-level quality requirements (e.g., efficiency) of equal concern in different projects? 3 Is this a viable mechanism for understanding the treatment of quality requirements? 1 Lehman, M.M., et al.: Metrics and laws of software evolution – the nineties view. In: International Software Metrics Symposium pp. 20–32. Albuquerque, NM (1997) Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 3 / 16
  • 4. Specific research questions: 1 Test Lehman’s 7th Law1 : system quality will appear to be declining unless rigorously maintained and adapted to environmental changes 2 Are high-level quality requirements (e.g., efficiency) of equal concern in different projects? 3 Is this a viable mechanism for understanding the treatment of quality requirements? 1 Lehman, M.M., et al.: Metrics and laws of software evolution – the nineties view. In: International Software Metrics Symposium pp. 20–32. Albuquerque, NM (1997) Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 3 / 16
  • 5. Specific research questions: 1 Test Lehman’s 7th Law1 : system quality will appear to be declining unless rigorously maintained and adapted to environmental changes 2 Are high-level quality requirements (e.g., efficiency) of equal concern in different projects? 3 Is this a viable mechanism for understanding the treatment of quality requirements? 1 Lehman, M.M., et al.: Metrics and laws of software evolution – the nineties view. In: International Software Metrics Symposium pp. 20–32. Albuquerque, NM (1997) Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 3 / 16
  • 6. Methodology ISO9126, Gnome projects: Wordnet, Boehm, commits, bugs, McCall, KDE mail Create end Generate Query signifiers corpora corpora (WN,ext) start Plot Precision/recall Error outcomes on random analysis and calculate events stats Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 4 / 16
  • 7. Datasets Product Language Size (ksloc) Age (years) Type Evolution C 313 10.75 Mail Nautilus C 108 10.75 File mgr Metacity C 66 7.5 Window mgr Ekiga C++ 54 7 VOIP Totem C 49 6.33 Media Deskbar Python 21 3.2 Widgets/UI Evince C 66 9.75 Doc viewer Empathy C 55 1.5 IM Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 5 / 16
  • 8. Signifiers and quality requirements Cross-project comparisons using a standardized taxonomy – ISO 9126. Find quality concepts in project artifacts as signifier occurrences. Corpora: emails, bug reports, commit messages. Database of 900k ‘messages’ (total, all projects). This menu is barely usable! email Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 6 / 16
  • 9. Signifiers Detect the appearance of quality concepts in the messages. Created signifier lists, a representative signifier thesaurus. Two lists: one based on Wordnet and ISO9126, the other extended with domain knowledge (ext). E.g., Quality Signifiers Maintainability testability changeability analyzability stability maintainability maintain maintainable modularity modifiability understandabil- ity Functionality security compliance accuracy interoperability suitability func- tional practicality functionality Portability conformance adaptability replaceability installability portable movableness movability portability Efficiency “resource behaviour” “time behaviour” efficient efficiency Usability operability understandability learnability useable usable ser- viceable usefulness utility useableness usableness serviceable- ness serviceability usability Reliability “fault tolerance” recoverability maturity reliable dependable responsibleness responsibility reliableness reliability dependable- ness dependability Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 7 / 16
  • 10. Observations 1 Search for events 2 Normalize for message volume 3 Group by week Event Quality ...By upgrading to a newer version of GNOME you None could receive bug fixes and new functionality. There should be a feature added that allows you to Functionality keep the current functionality for those on work- stations (automatic hot-sync) and then another option that allows you to manually initiate . Steps to reproduce the crash: 1. Can’t reproduce Reliability, with accuracy. Seemingly random. .... Functionality These calls are just a waste of time for client Efficiency and server, and the Nautilus online storage view is slowed down by this wastefulness. Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 8 / 16
  • 11. Error analysis 1 Pick random messages; manually classify 2 Compare manual classification to machine classification 3 Precision: 80%, Recall: 51% (extended), 6% Wordnet Signified quality Precision ext Precision WN Usability 0.47 0.22 Portability 0.11 0.20 Maintainability 0.22 0.31 Reliability 0.15 0.19 Functionality 0.14 0.18 Efficiency 0.16 0.07 Mean 0.21 0.20 Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 9 / 16
  • 12. Error analysis 1 Pick random messages; manually classify 2 Compare manual classification to machine classification 3 Precision: 80%, Recall: 51% (extended), 6% Wordnet Signified quality Precision ext Precision WN Usability 0.47 0.22 Portability 0.11 0.20 Maintainability 0.22 0.31 Reliability 0.15 0.19 Functionality 0.14 0.18 Efficiency 0.16 0.07 Mean 0.21 0.20 Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 9 / 16
  • 13. Observations RQ1: Lehman’s law Is there a relation between events and project lifespan? Looked at three possible explanations: Overall lifespan Project release windows Key external events Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 10 / 16
  • 14. Occurrences (normalized) 0 100 200 300 400 1998 Gnome 1.0 Ernst, Mylopoulos (University of Toronto) Gnome 1.2 2000 Gnome 1.4 2002 Gnome 2.0 Gnome 2.2 Gnome 2.4 Year Gnome 2.6 2004 Gnome 2.8 Perception of quality req. Gnome 2.10 Gnome 2.10 Gnome 2.12 Evolution -- Usability (R2 = 18%) 2006 Gnome 2.16 Gnome 2.20 2008 Gnome 2.24 July 1, 2010 11 / 16
  • 15. Results Correlation coefficient very low in both cases - no relationship Analyzing peaks seems useful - external events are driving frequencies “... I know this was discussed a few weeks ago ... could it be implemented as an advanced option that has to be turned on and is off by default?” Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 12 / 16
  • 16. Observations (2) RQ2: Are qualities treated the same in different projects? Examine normalized occurrences per week for extended signifiers Quality Project Occurrences Efficiency Evolution 0.012 Nautilus 0.026 Usability Evolution 0.192 Nautilus 0.285 Portability Evolution 0.010 Nautilus 0.011 Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 13 / 16
  • 17. Threats to validity 1 How valid are word lists? 2 Domain-dependent quality models 3 Other sources of project discussions (IRC/F2F/Skype) 4 Open source projects may not generalize 5 No sense of ‘attitudes’ to requirements 6 Statistics Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 14 / 16
  • 18. Threats to validity 1 How valid are word lists? 2 Domain-dependent quality models 3 Other sources of project discussions (IRC/F2F/Skype) 4 Open source projects may not generalize 5 No sense of ‘attitudes’ to requirements 6 Statistics Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 14 / 16
  • 19. Threats to validity 1 How valid are word lists? 2 Domain-dependent quality models 3 Other sources of project discussions (IRC/F2F/Skype) 4 Open source projects may not generalize 5 No sense of ‘attitudes’ to requirements 6 Statistics Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 14 / 16
  • 20. Threats to validity 1 How valid are word lists? 2 Domain-dependent quality models 3 Other sources of project discussions (IRC/F2F/Skype) 4 Open source projects may not generalize 5 No sense of ‘attitudes’ to requirements 6 Statistics Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 14 / 16
  • 21. Threats to validity 1 How valid are word lists? 2 Domain-dependent quality models 3 Other sources of project discussions (IRC/F2F/Skype) 4 Open source projects may not generalize 5 No sense of ‘attitudes’ to requirements 6 Statistics Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 14 / 16
  • 22. Threats to validity 1 How valid are word lists? 2 Domain-dependent quality models 3 Other sources of project discussions (IRC/F2F/Skype) 4 Open source projects may not generalize 5 No sense of ‘attitudes’ to requirements 6 Statistics Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 14 / 16
  • 23. Threats to validity 1 How valid are word lists? 2 Domain-dependent quality models 3 Other sources of project discussions (IRC/F2F/Skype) 4 Open source projects may not generalize 5 No sense of ‘attitudes’ to requirements 6 Statistics Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 14 / 16
  • 24. Future work: agenda RQ3: Usefulness: Technique worked, but: 1 Leverage other machine learning techniques like multi-label learning 2 Understand inter-project variations and usefulness of global taxonomies of quality 3 Use techniques to understand requirements evolution in software projects 4 Tie experimental data to ethnographic data2 2 Aranda, J. and Venolia, G.: The secret life of bugs: Going past the errors and omissions in software repositories. In International Conference on Software Engineering, pp 298-308 (2009). Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 15 / 16
  • 25. Happy Canada Day! Ernst, Mylopoulos (University of Toronto) Perception of quality req. July 1, 2010 16 / 16