SHERLOCK: A Deep Learning Approach To Detect Software Vulnerabilities
By: Saadh Jawwadh, Guhanathan Poravi
Potential Business Impact:
Finds hidden computer bugs better than before.
The increasing reliance on software in various applications has made the problem of software vulnerability detection more critical. Software vulnerabilities can lead to security breaches, data theft, and other negative outcomes. Traditional software vulnerability detection techniques, such as static and dynamic analysis, have been shown to be ineffective at detecting multiple vulnerabilities. To address this issue, this study employed a deep learning approach, specifically Convolutional Neural Networks (CNN), to solve the software vulnerability detection problem. A 5-split cross-validation approach was used to train and evaluate the CNN model, which takes tokenized source code as input. The findings indicated that Sherlock successfully detected multiple vulnerabilities at the function level, and its performance was particularly strong for CWE-199, CWE-120, and CWE-Other, with an overall high accuracy rate and significant true positive and true negative values. However, the performance was less reliable for some vulnerabilities due to the lack of a standardized dataset which will be a future research direction. The results suggest that compared to current techniques, the proposed deep learning approach has the potential to substantially enhance the accuracy of software vulnerability detection.
Similar Papers
Deep Learning Aided Software Vulnerability Detection: A Survey
Software Engineering
Finds hidden computer bugs before hackers do.
When Machine Learning Meets Vulnerability Discovery: Challenges and Lessons Learned
Cryptography and Security
Finds computer bugs faster using smart programs.
AI-Based Software Vulnerability Detection: A Systematic Literature Review
Software Engineering
Finds computer bugs faster using smart programs.