Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bbqbaron/reasoned-typer
Pie a la core.logic
https://github.com/bbqbaron/reasoned-typer
Last synced: 8 days ago
JSON representation
Pie a la core.logic
- Host: GitHub
- URL: https://github.com/bbqbaron/reasoned-typer
- Owner: bbqbaron
- License: mit
- Created: 2020-04-26T15:10:30.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2020-04-26T15:11:57.000Z (over 4 years ago)
- Last Synced: 2024-12-20T00:23:54.625Z (about 1 month ago)
- Language: Clojure
- Size: 7.81 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# pie
An attempt to learn both minikanren a la [The Reasoned Schemer](https://mitpress.mit.edu/books/reasoned-schemer) and Pie from [The Little Typer](https://mitpress.mit.edu/books/little-typer) at the same time by encoding Pie's typechecking rules in Clojure's core.logic (which is hopefully close enough to minikanren to qualify).
It turns out this has [come up before](https://icfp18.sigplan.org/details/scheme-2018-papers/7/A-Surprisingly-Competitive-Conditional-Operator-miniKanrenizing-the-Inference-Rules-), thought I deliberately haven't watched the talk yet, to insulate myself.
The first pass was to encode the rules as literally and naively as possible, transcribing Pie's rules directly into minikanren where possible. As a result, there are certainly many typechecking failures that will result in infinite or near-infinite searches!
## License
See [LICENSE](LICENSE)