gravitytrope / dex-lang

Research language for array processing in the Haskell/ML family

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Dex Test status

Dex (named for "index") is a research language for array processing in the Haskell/ML family. The goal of the project is to explore:

  • Type systems for array programming
  • Mathematical program transformations like differentiation and integration
  • User-directed compilation to parallel hardware
  • Interactive and incremental numerical programming and visualization

To learn more, check out our workshop paper or these example programs:

Please note that Dex is an experimental research project at an early stage of development. We welcome contributions. There's plenty of work to do!

Setup

  • Install stack
  • Install LLVM 9, e.g. apt-get install llvm-9-dev on Ubuntu/Debian. On macOS, the best approach seems to be to build LLVM from source, as described here.

Building

  • Build Dex: make
  • Run tests: make tests
  • Set up alias (e.g. in .bashrc) alias dex="stack exec dex --"

Running

  • Traditional REPL: dex repl
  • Execute script: dex script examples/tutorial.dx
  • Notebook interface: dex web examples/tutorial.dx

License

BSD-3

This is an early-stage research project, not an official Google product.

About

Research language for array processing in the Haskell/ML family

License:BSD 3-Clause "New" or "Revised" License


Languages

Language:Haskell 93.0%Language:Python 2.7%Language:C 1.3%Language:Makefile 0.8%Language:JavaScript 0.6%Language:TeX 0.5%Language:Emacs Lisp 0.5%Language:CSS 0.3%Language:Shell 0.1%Language:HTML 0.1%