Publication | Closed Access
Alattin: Mining Alternative Patterns for Detecting Neglected Conditions
108
Citations
20
References
2009
Year
Unknown Venue
EngineeringSoftware SystemsVerificationPattern DiscoverySoftware EngineeringSource Code AnalysisPattern MiningMining MethodsSoftware AnalysisFormal VerificationAlattin ApproachInformation RetrievalData ScienceData MiningMining Alternative PatternsStatisticsSoftware MiningSource CodePredictive AnalyticsKnowledge DiscoveryProgram Source CodeComputer ScienceStatic Program AnalysisFrequent Pattern MiningProgram AnalysisFormal Methods
To improve software quality, static or dynamic verification tools accept programming rules as input and detect their violations in software as defects. As these programming rules are often not well documented in practice, previous work developed various approaches that mine programming rules as frequent patterns from program source code. Then these approaches use static defect-detection techniques to detect pattern violations in source code under analysis. These existing approaches often produce many false positives due to various factors. To reduce false positives produced by these mining approaches, we develop a novel approach, called Alattin, that includes a new mining algorithm and a technique for detecting neglected conditions based on our mining algorithm. Our new mining algorithm mines alternative patterns in example form "P <sub xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">1</sub> or P <sub xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">2</sub> ", where P <sub xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">1</sub> and P <sub xmlns:mml="http://www.w3.org/1998/Math/MathML" xmlns:xlink="http://www.w3.org/1999/xlink">2</sub> are alternative rules such as condition checks on method arguments or return values related to the same API method. We conduct two evaluations to show the effectiveness of our Alattin approach. Our evaluation results show that (1) alternative patterns reach more than 40% of all mined patterns for APIs provided by six open source libraries; (2) the mining of alternative patterns helps reduce nearly 28% of false positives among detected violations.
| Year | Citations | |
|---|---|---|
Page 1
Page 1