Skip to content
Liang Wang edited this page Nov 2, 2016 · 34 revisions

What is the future plan of Owl?

Owl aims to be a general OCaml numerical library for scientific computing. The library focuses on the following perspective:

  • Dense matrix operations (95% completed)
  • Sparse matrix operations (90% completed)
  • Advanced mathematical functions (90% completed)
  • Advanced statistical functions (70% completed)
  • Linear algebra (30% completed)
  • Regression functions (30% completed)
  • Machine learning (10% completed)
  • Basic Plotting functions (75% completed)

As you can see, Owl is still in its infancy phase. I appreciate any comments and look forward to any help from anyone who want to contribute.

What are the specific TODOs?

There is a list of things (either well-defined or not) in my mind to push the project forward. Bold font marks the task I am currently working on.

  • Enhance sparse real matrices.
  • Add FFT functions.
  • Support dense and sparse N-dimensional array.
  • Add hypothesis tests in Stats module.
  • Finalise the Constants module by adding CODATA2014.
  • Serialise matrices to standard formats such as HDF5.
  • Add integration and ODE functions.
  • Add Graph module (build atop of ocamlgraph).
  • Extensive tests on Dense matrix module to eliminate bugs.
  • Complete some missing functions in Sparse matrix module.
  • Make Sparse matrix module support "x.{i,j}" to access the elements.
  • Add more types of plots in Plot module.
  • Add consistent error management in all modules.
  • Complete all the missing functions in Linalg module for dense matrices.
  • Automate the document generation using ocamldoc.
  • Make a docker image supporting GUI so Plot module can plot in X window.
  • Make Linalg module support sparse matrices.
  • Implement more optimisation algorithms in Optimise module: e.g., coordinate descent, proximal gradient, and etc.
  • Implement more machine learning algorithms (clustering, deep neural networks, and etc.), may introduce a new separate module in Owl.
  • Include a set of approximate algorithms in Owl as a separate module (e.g., approximate k-means, approximate k-nn, and etc.)
  • Improve the documentation and write a series of tutorials (posts) on how to use Owl.
  • Embed a small probabilistic programming language in Stats module.
  • Add a web interface so that the plot can be dynamically updated on the fly.
  • whatever else helpful ...

What have been DONE?

  • Add the supports of sparse complex matrices.
  • Add the supports of dense complex matrices.
  • Get rid of ctypes.foreign, use stub generation to interface with GSL
  • Add widely used constants to the module, e.g., pi, speed of light, natural number, gravity constant, and etc.