Our new X account is live! Follow @wizwand_team for updates
WorkDL logo mark

VulScribeR: Exploring RAG-based Vulnerability Augmentation with LLMs

About

Detecting vulnerabilities is vital for software security, yet deep learning-based vulnerability detectors (DLVD) face a data shortage, which limits their effectiveness. Data augmentation can potentially alleviate the data shortage, but augmenting vulnerable code is challenging and requires a generative solution that maintains vulnerability. Previous works have only focused on generating samples that contain single statements or specific types of vulnerabilities. Recently, large language models (LLMs) have been used to solve various code generation and comprehension tasks with inspiring results, especially when fused with retrieval augmented generation (RAG). Therefore, we propose VulScribeR, a novel LLM-based solution that leverages carefully curated prompt templates to augment vulnerable datasets. More specifically, we explore three strategies to augment both single and multi-statement vulnerabilities, with LLMs, namely Mutation, Injection, and Extension. Our extensive evaluation across four vulnerability datasets and DLVD models, using three LLMs, show that our approach beats two SOTA methods Vulgen and VGX, and Random Oversampling (ROS) by 27.48%, 27.93%, and 15.41% in f1-score with 5K generated vulnerable samples on average, and 53.84%, 54.10%, 69.90%, and 40.93% with 15K generated vulnerable samples. Our approach demonstrates its feasibility for large-scale data augmentation by generating 1K samples at as cheap as US$ 1.88.

Seyed Shayan Daneshvar, Yu Nong, Xu Yang, Shaowei Wang, Haipeng Cai• 2024

Related benchmarks

TaskDatasetResultRank
Vulnerability DetectionReveal (test)
Precision20.65
42
Vulnerability DetectionPrimeVul (test)
F1 Score23.22
38
Vulnerability DetectionBigvul (test)
Precision19.03
30
Vulnerability DetectionBigVul Seed: Devign (test)
Precision11.64
24
Vulnerability DetectionPrimeVul Seed: PrimeVul Train (test)
Precision20.26
24
Vulnerability InjectionMajor Vulnerability Datasets Injection
Accuracy82
8
Showing 6 of 6 rows

Other info

Code

Follow for update