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

Instruction Tuning for Secure Code Generation

About

Modern language models (LMs) have gained widespread acceptance in everyday and professional contexts, particularly in programming. An essential procedure enabling this adoption is instruction tuning, which substantially enhances LMs' practical utility by training them to follow user instructions and human preferences. However, existing instruction tuning schemes overlook a crucial aspect: the security of generated code. As a result, even the state-of-the-art instruction-tuned LMs frequently produce unsafe code, posing significant security risks. In this work, we introduce SafeCoder to address this gap. SafeCoder performs security-centric fine-tuning using a diverse and high-quality dataset that we collected using an automated pipeline. We integrate the security fine-tuning with standard instruction tuning, to facilitate a joint optimization of both security and utility. Despite its simplicity, we show that SafeCoder is effective across a variety of popular LMs and datasets. It is able to drastically improve security (by about 30%), while preserving utility.

Jingxuan He, Mark Vero, Gabriela Krasnopolska, Martin Vechev• 2024

Related benchmarks

TaskDatasetResultRank
Code GenerationHumanEval+
Pass@162.07
189
Code GenerationMBPP+
Pass@154.18
122
Secure Code GenerationCyberSecEval SCG
Safety79.06
17
Secure Code GenerationCWEval
Safety21.01
17
Secure Code GenerationSecure Code Average
Safety Score50.04
12
Showing 5 of 5 rows

Other info

Follow for update