Search papers, labs, and topics across Lattice.
The paper introduces PriCoder, a method to improve LLMs' ability to generate code using APIs from private libraries by automatically synthesizing training data. PriCoder uses a graph-based approach with progressive graph evolution for data diversity and multidimensional graph pruning for data quality. Experiments on three mainstream LLMs demonstrate that PriCoder significantly improves performance on private-library-oriented code generation benchmarks, achieving over 20% gains in pass@1, without impacting general code generation.
LLMs struggle to effectively use private library APIs even when given the correct documentation, but PriCoder's data synthesis approach boosts performance by over 20%.
Large Language Models (LLMs) have shown strong potential for code generation, yet they remain limited in private-library-oriented code generation, where the goal is to generate code using APIs from private libraries. Existing approaches mainly rely on retrieving private-library API documentation and injecting relevant knowledge into the context at inference time. However, our study shows that this is insufficient: even given accurate required knowledge, LLMs still struggle to invoke private-library APIs effectively. To address this limitation, we propose PriCoder, an approach that teaches LLMs to invoke private-library APIs through automatically synthesized data. Specifically, PriCoder models private-library data synthesis as the construction of a graph, and alternates between two graph operators: (1) Progressive Graph Evolution, which improves data diversity by progressively synthesizing more diverse training samples from basic ones, and (2) Multidimensional Graph Pruning, which improves data quality through a rigorous filtering pipeline. To support rigorous evaluation, we construct two new benchmarks based on recently released libraries that are unfamiliar to the tested models. Experiments on three mainstream LLMs show that PriCoder substantially improves private-library-oriented code generation, yielding gains of over 20% in pass@1 in many settings, while causing negligible impact on general code generation capability. Our code and benchmarks are publicly available at https://github.com/contact-eniacode/PriCoder.