SELGPLFeb 28, 2023

Safe-DS: A Domain Specific Language to Make Data Science Safe

arXiv:2302.14548v26 citationsh-index: 2
AI Analysis

This addresses the issue of reliability and development costs for data scientists using Python, though it is incremental as it builds on existing static analysis concepts.

The paper tackles the problem of costly programming mistakes in data science pipelines due to Python's lack of static type checking, by introducing Safe-DS, a domain-specific language that catches type, range, data manipulation, and call order errors, and integrates Python libraries via automated stub generation and a graphical representation.

Due to the long runtime of Data Science (DS) pipelines, even small programming mistakes can be very costly, if they are not detected statically. However, even basic static type checking of DS pipelines is difficult because most are written in Python. Static typing is available in Python only via external linters. These require static type annotations for parameters or results of functions, which many DS libraries do not provide. In this paper, we show how the wealth of Python DS libraries can be used in a statically safe way via Safe-DS, a domain specific language (DSL) for DS. Safe-DS catches conventional type errors plus errors related to range restrictions, data manipulation, and call order of functions, going well beyond the abilities of current Python linters. Python libraries are integrated into Safe-DS via a stub language for specifying the interface of its declarations, and an API-Editor that is able to extract type information from the code and documentation of Python libraries, and automatically generate suitable stubs. Moreover, Safe-DS complements textual DS pipelines with a graphical representation that eases safe development by preventing syntax errors. The seamless synchronization of textual and graphic view lets developers always choose the one best suited for their skills and current task. We think that Safe-DS can make DS development easier, faster, and more reliable, significantly reducing development costs.

Code Implementations1 repo
Foundations

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

Your Notes