package quill
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=a9a8a9787f8250337187bb7b21cb317c41bfd2ecf08bcfe0ab407c7b6660764d
sha512=fe13cf257c487e41efe2967be147d80fa94bac8996d3aab2b8fd16f0bbbd108c15e0e58c025ec9bf294d4a0d220ca2ba00c3b1b42fa2143f758c5f0ee4c15782
Description
Quill is an interactive notebook application for data exploration, prototyping, and knowledge sharing in OCaml. It provides a Jupyter-like experience with rich visualization and documentation capabilities.
README
Raven
Modern scientific computing for OCaml.
Raven is a comprehensive ecosystem that brings scientific computing capabilities to OCaml, designed for teams who need both rapid prototyping and production-ready systems.
We're prioritizing developer experience and competitive performance to give developers a real choice beyond Python for scientific computing.
The Ecosystem
Raven is built from modular projects that form a cohesive ecosystem:
Core Libraries: | Raven Project | Python Equivalent | Description | | ------------------- | --------------------- | --------------------------------------------------- | | Nx | NumPy | N-dimensional arrays with pluggable backends | | Hugin | Matplotlib | Publication-quality data visualization and plotting | | Quill | Jupyter | A love letter to scientific writing |
Rune Ecosystem: | Raven Project | Python Equivalent | Description | | ----------------------- | --------------------- | ------------------------------------------------------ | | Rune | JAX | Autodiff with multi-device support and JIT compilation | | Kaun ᚲ | PyTorch/Flax | Deep learning framework built on Rune | | Sowilo ᛋ | OpenCV | Computer vision framework built on Rune |
Why Raven?
- Ship reliable systems: Strong typing catches bugs that would crash your ML pipeline in production
- Stop rewriting code: Prototype and deploy in the same language, no more "Python for research, X for production"
- Match Python's performance: JIT compilation designed to compete with NumPy and PyTorch, not just beat them by 20%
- Built for developers: Notebooks that feel like writing documents, intuitive APIs, and an ecosystem designed to work seamlessly together
- Designed for extension: Pluggable backends, modular architecture, and building blocks you can actually extend and customize
Documentation
📖 Read the Introduction - Learn about our vision, philosophy, and approach
More comprehensive documentation and examples are coming soon as we are heading towards the release.
Contributing
Raven is in active development and we welcome contributions from the community!
Ways to Contribute:
- Share feedback - Open issues or email us with your thoughts on APIs, performance, or developer experience
- Test the libraries - Try Raven libraries with your workflows and report what works (or breaks)
- Improve documentation - Help us make the docs clearer and more comprehensive
- Build new libraries - Interested in creating any of the planned libraries below? Let's collaborate!
Future Libraries (Open for Contributions): For our first release, we're focused on the foundation (Nx, Hugin, Quill) and the deep learning vertical (Rune, Kaun). These areas are planned for future development:
- DataFrame library (Pandas equivalent)
- Statistical computing (R-like statistical functions)
- Time series analysis and geospatial computing
- Distributed computing (Dask equivalent)
Whether you're an OCaml expert or new to the language, we'd love your help building the future of scientific computing in OCaml!
See our CONTRIBUTING.md for detailed guidelines.
Support Raven
Building a complete scientific computing ecosystem takes time and focus. We're raising funds to work on Raven full-time and deliver on our roadmap.
Your sponsorship helps us release a stable V1 with GPU backends, achieve NumPy/PyTorch performance parity, and build comprehensive documentation and tutorials.
License
Raven is available under the ISC License, making it free for both personal and commercial use.
Dependencies (20)
-
hugin
= version
-
sowilo
= version
-
kaun
= version
-
rune
= version
-
nx-text
= version
-
nx-datasets
= version
-
nx
= version
- base64
- brr
- vdom
- cmarkit
- crunch
- ppx_deriving_yojson
-
dream
>= "1.0.0~alpha8"
- js_of_ocaml-toplevel
- wasm_of_ocaml-compiler
- cmdliner
-
dune-site
>= "3.19.0"
-
dune
>= "3.19"
-
ocaml
>= "5.2.0" & < "5.4.0"
Used by (1)
-
raven
< "1.0.0~alpha1"
Conflicts
None