Bayesian synthesis of probabilistic programs for automatic data modeling. Saad, F. A., Cusumano-Towner, M. F., Schaechtle, U., Rinard, M. C., & Mansinghka, V. K. Proceedings of the ACM on Programming Languages, 3(POPL):37:1–37:32, ACM, January, 2019.
Bayesian synthesis of probabilistic programs for automatic data modeling [link]Paper  Bayesian synthesis of probabilistic programs for automatic data modeling [link]Link  Bayesian synthesis of probabilistic programs for automatic data modeling [link]Video  Bayesian synthesis of probabilistic programs for automatic data modeling [link]Mit news  Bayesian synthesis of probabilistic programs for automatic data modeling [link]Zdnet news  abstract   bibtex   
We present new techniques for automatically constructing probabilistic programs for data analysis, interpretation, and prediction. These techniques work with probabilistic domain-specific data modeling languages that capture key properties of a broad class of data generating processes, using Bayesian inference to synthesize probabilistic programs in these modeling languages given observed data. We provide a precise formulation of Bayesian synthesis for automatic data modeling that identifies sufficient conditions for the resulting synthesis procedure to be sound. We also derive a general class of synthesis algorithms for domain-specific languages specified by probabilistic context-free grammars and establish the soundness of our approach for these languages. We apply the techniques to automatically synthesize probabilistic programs for time series data and multivariate tabular data. We show how to analyze the structure of the synthesized programs to compute, for key qualitative properties of interest, the probability that the underlying data generating process exhibits each of these properties. Second, we translate probabilistic programs in the domain-specific language into probabilistic programs in Venture, a general-purpose probabilistic programming system. The translated Venture programs are then executed to obtain predictions of new time series data and new multivariate data records. Experimental results show that our techniques can accurately infer qualitative structure in multiple real-world data sets and outperform standard data analysis methods in forecasting and predicting new data.
@article{saad2019bayesian,
title                 = {Bayesian synthesis of probabilistic programs for automatic data modeling},
author                = {Saad, Feras A. and Cusumano-Towner, Marco F. and Schaechtle, Ulrich and Rinard, Martin C. and Mansinghka, Vikash K.},
journal               = {Proceedings of the ACM on Programming Languages},
volume                = 3,
number                = {POPL},
month                 = jan,
year                  = 2019,
pages                 = {37:1--37:32},
articleno             = {37},
numpages              = {29},
publisher             = {ACM},
url_paper             = {https://dl.acm.org/doi/pdf/10.1145/3290350},
url_link              = {https://doi.org/10.1145/3290350},
url_video             = {https://www.youtube.com/watch?v=T5fdUmYJsjM},
url_MIT_News          = {https://news.mit.edu/2019/nonprogrammers-data-science-0115},
url_ZDNet_News        = {https://www.zdnet.com/article/mit-aims-to-help-data-scientists-by-having-ai-do-the-heavy-lifting/},
abstract              = {We present new techniques for automatically constructing probabilistic programs for data analysis, interpretation, and prediction. These techniques work with probabilistic domain-specific data modeling languages that capture key properties of a broad class of data generating processes, using Bayesian inference to synthesize probabilistic programs in these modeling languages given observed data. We provide a precise formulation of Bayesian synthesis for automatic data modeling that identifies sufficient conditions for the resulting synthesis procedure to be sound. We also derive a general class of synthesis algorithms for domain-specific languages specified by probabilistic context-free grammars and establish the soundness of our approach for these languages. We apply the techniques to automatically synthesize probabilistic programs for time series data and multivariate tabular data. We show how to analyze the structure of the synthesized programs to compute, for key qualitative properties of interest, the probability that the underlying data generating process exhibits each of these properties. Second, we translate probabilistic programs in the domain-specific language into probabilistic programs in Venture, a general-purpose probabilistic programming system. The translated Venture programs are then executed to obtain predictions of new time series data and new multivariate data records. Experimental results show that our techniques can accurately infer qualitative structure in multiple real-world data sets and outperform standard data analysis methods in forecasting and predicting new data.},
}

Downloads: 0