README.md
[data:image/s3,"s3://crabby-images/14ca1/14ca116879cc7415d2c4eab59ceee9f1356daf70" alt="Run in Livebook"](https://livebook.dev/run?url=https%3A%2F%2Fhexdocs.pm%2Fcharms%2F0.1.1%2Fprogramming-with-charms.livemd)
# Charms
[data:image/s3,"s3://crabby-images/d1cbd/d1cbdfe25c873251cea34d0fd2ad2f1a3b4d25d2" alt="Package"](https://hex.pm/packages/charms) [data:image/s3,"s3://crabby-images/d0734/d07344a9bc11702891f809f7b8c86d57a1fca8cd" alt="Documentation"](https://hexdocs.pm/charms)
Elixir compiler to compile a subset of Elixir to native targets
- [x] `defm` to define native functions, some examples
- [quick sort](/bench/enif_quick_sort.ex)
- [vector add](/bench/vec_add_int_list.ex)
- [x] Multi-threaded compilation, built upon Elixir processes and MLIR's multi-threaded capabilities
- [ ] SIMD support
- [ ] SIMT support
## Installation
If [available in Hex](https://hex.pm/docs/publish), the package can be installed
by adding `charms` to your list of dependencies in `mix.exs`:
```elixir
def deps do
[
{:charms, "~> 0.1.0"}
]
end
```
## Development
To run the benchmarks:
```sh
mix run bench/sort_benchmark.exs
mix run bench/list_add_benchmark.exs
```