Skip to content

OCaml Library and PPX rewriter for abductive programming

Notifications You must be signed in to change notification settings

reubenrowe/ocaml-decml

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

57 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DecML: A Library and PPX Extension for Abductive Decoupling

DecML is an OCaml library and PPX preprocessor for building and optimising numerical models. DecML allows models to be written as OCaml functions in which parameters are explicitly indicated. The model can then be decoupled from its parameters to obtain the collection of parameters used in the model and a parameterised function for instantiating the model with a given collection of parameters.

The DecML library contains functions for optimising a collection of parameters for a given model with respect to a particular data set.

For example, the following code creates a linear regression model and then fits it to a given data set using DecML's built-in gradient descent:

open Decml
open   Model
open   Optimise

let%model linear x = ([%pc 1] *. x) +. [%pc 0]

let model =
  let%decouple (model, params) = linear in
  let params =
    grad_desc ~loss_f:mse ~rate:0.00001 ~threshold:1.0 ~epochs:50000 ~model
      params data in
  rebind model params

Some more examples of DecML syntax can be found in the EXAMPLES.md file. Some working examples programs can be found in then examples subdirectory.

DecML makes building supervised learning models simple because it handles model parameters automatically when combining models. Moreover, it uses OCaml's type system to ensure that parameterised models can only be rebound with the parameter collections from which they were decoupled.

Depedencies

DecML depends on the following OCaml packages:

  • ocaml-migrate-parsetree
  • dune
  • containers
  • csv (only needed for running examples)
  • gnuplot (only needed for running examples)
  • opam-installer (if installing the package via OPAM)

The PPX preprocessor is written using the ocaml-migrate-parsetree package, and so it should be portable across compiler versions from 4.02.x upwards which themselves support the dependencies listed above.

Building and Installing

DecML is compiled using dune.

For convenience, a Makefile is provided. The library, PPX rewriter, and the examples and tests can be built by running:

make all

The library and PPX rewriter can be installed in your OPAM by:

opam pin add decml /path/to/decml

This installs two packages, decml (the library) and decml.ppx (the PPX rewriter), which can then be used by your programs in the usual way by specifying these packages as dependencies.

Viewing the Output of the PPX Rewriter

Once the PPX package is installed in your OPAM environment, you can view the output produced by the PPX rewriter for a given file using:

$(ocamlfind query decml.ppx)/ppx.exe <file>

After compiling the source, you can run the PPX rewriter directly by using the dune exec command from the top-level source directory.

$(dune exec ocamlfind query decml.ppx)/ppx.exe <file>

Running the Demo Models

The examples subdirectory contains some example models. These include a linear regression model, a confidence interval model, a multivariate regression model, and a mixture of regression models.

These examples can be run as follows.

dune build -f @linear_regression_demo
dune build -f @confidence_interval_demo
dune build -f @multivariate_regression_demo
dune build -f @regression_mixture_demo

About

OCaml Library and PPX rewriter for abductive programming

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published