Downloads provided by UsageCounts
We present a static analysis for discovering differentiable or more generally smooth parts of a given probabilistic program, and show how the analysis can be used to improve the pathwise gradient estimator, one of the most popular methods for posterior inference and model learning. Our improvement increases the scope of the estimator from differentiable models to non-differentiable ones without requiring manual intervention of the user; the improved estimator automatically identifies differentiable parts of a given probabilistic program using our static analysis, and applies the pathwise gradient estimator to the identified parts while using a more general but less efficient estimator, called score estimator, for the rest of the program. Our analysis has a surprisingly subtle soundness argument, partly due to the misbehaviours of some target smoothness properties when viewed from the perspective of program analysis designers. For instance, some smoothness properties, such as partial differentiability and partial continuity, are not preserved by function composition, and this makes it difficult to analyse sequential composition soundly without heavily sacrificing precision. We formulate five assumptions on a target smoothness property, prove the soundness of our analysis under those assumptions, and show that our leading examples satisfy these assumptions. We also show that by using information from our analysis instantiated for differentiability, our improved gradient estimator computes the correct estimate on average, i.e., it returns an unbiased estimate. Our experiments with representative probabilistic programs in the Pyro language show that our static analysis is capable of identifying smooth parts of those programs accurately, and making our improved pathwise gradient estimator exploit all the opportunities for high performance in those programs. Artifact accompanying the article: "Smoothness Analysis for Probabilistic Programs with Application to Optimised Variational Inference" -------------------------------------------------------------------------------- Dear User, This artifact contains the following elements, described more in details below and in the companion files: (1) the sources of the Pyppai static analyzer (2) the data files used in the paper (3) information on how to reproduce the results reported in the paper (using scripts that allow to reproduce most results using a single command, and instruction to reproduce individual data-points) and to. See pyppai/README.txt for detailed instructions. About the virtual machine: - the virtual machine is based on the Ubuntu i386 distribution (18.04 LTS) - the default user account is "artifact": login: artifact password: artifact - user artifact can sudo (e.g., to install STHG, just do 'sudo apt-get install STHG' although this should not be necessary). - the analyser is written in OCaml; the virtual machine provides a local installation (in the artifact user directory) of the opam OCaml package manager, with the 4.14.0 OCaml compiler and all required libraries pre-installed (in particular, the analyser uses the pyml and pyast libraries for manipulating Python programs and the apron library of numerical abstract domain); no further installation should be necessary. (1) The content of the artifact is described briefly in Desktop/FILES.txt (2) The sources of the analyzer are available in the directory Desktop/pyppai They can be compiled locally in that directory (by simply typing "make").
| selected citations These citations are derived from selected sources. This is an alternative to the "Influence" indicator, which also reflects the overall/total impact of an article in the research community at large, based on the underlying citation network (diachronically). | 1 | |
| popularity This indicator reflects the "current" impact/attention (the "hype") of an article in the research community at large, based on the underlying citation network. | Average | |
| influence This indicator reflects the overall/total impact of an article in the research community at large, based on the underlying citation network (diachronically). | Average | |
| impulse This indicator reflects the initial momentum of an article directly after its publication, based on the underlying citation network. | Average |
| views | 5 | |
| downloads | 1 |

Views provided by UsageCounts
Downloads provided by UsageCounts