SEAIIRSep 10, 2022

Code Compliance Assessment as a Learning Problem

arXiv:2209.04602v12 citationsh-index: 8
Originality Incremental advance
AI Analysis

This addresses the scalability issue in verifying coding policies for software developers, though it is incremental as it builds on existing embedding methods.

The paper tackles the problem of scaling code compliance assessment by formulating it as a machine learning task that predicts compliance based on natural language policies and code, achieving classification accuracies of 59% and 71% on CWE and CBP benchmarks, with a user study showing 24% acceptance for their tool compared to 7% for a baseline.

Manual code reviews and static code analyzers are the traditional mechanisms to verify if source code complies with coding policies. However, these mechanisms are hard to scale. We formulate code compliance assessment as a machine learning (ML) problem, to take as input a natural language policy and code, and generate a prediction on the code's compliance, non-compliance, or irrelevance. This can help scale compliance classification and search for policies not covered by traditional mechanisms. We explore key research questions on ML model formulation, training data, and evaluation setup. The core idea is to obtain a joint code-text embedding space which preserves compliance relationships via the vector distance of code and policy embeddings. As there is no task-specific data, we re-interpret and filter commonly available software datasets with additional pre-training and pre-finetuning tasks that reduce the semantic gap. We benchmarked our approach on two listings of coding policies (CWE and CBP). This is a zero-shot evaluation as none of the policies occur in the training set. On CWE and CBP respectively, our tool Policy2Code achieves classification accuracies of (59%, 71%) and search MRR of (0.05, 0.21) compared to CodeBERT with classification accuracies of (37%, 54%) and MRR of (0.02, 0.02). In a user study, 24% Policy2Code detections were accepted compared to 7% for CodeBERT.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes