schism
futhark
schism | futhark | |
---|---|---|
7 | 53 | |
188 | 2,318 | |
0.0% | 2.1% | |
10.0 | 9.8 | |
almost 4 years ago | about 14 hours ago | |
Haskell | ||
Apache License 2.0 | ISC License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
schism
-
Scheme in Scheme on WASM in the Browser
I don't know why you've been downvoted, I've given you an upvote for linking to an interesting project (even if it's linked in some way to Google). I'd also like to link to the updated GH link: <https://github.com/schism-lang/schism>.
-
Writing a C compiler in 500 lines of Python
Looks like Schism (https://github.com/schism-lang/schism) got part of the way there, but it unfortunately seems to be dead.
-
Two-tier programming language
It would be interesting to reboot something like Lush but using Wasm and Scheme with https://github.com/schism-lang/schism then you could use code generation internally be emitting wasm from your schism code and then reloading the entire environment.
- Langjam 17-19 Feb
-
Multiple assignment and tuple unpacking improve Python code readability
I love E! Or at least the problems it is trying to solve. As you know Wasm also has a capabilities model. And it is fairly trivial to persist the Wasm heap, it just an array of bytes. I think Wasm aligns nicely.
Chez is a great Scheme, but it doesn't have a Wasm backend. I find https://github.com/schism-lang/schism very interesting.
As for C programs going crazy, well yeah. I did a thing where I would copy of the body of functions around in memory, it worked on some version of Linux and GCC, but only by accident. I would be much less comfortable doing this kind of circuit bending than modifying Python stack frames. If I were to achieve a similar goal in the future, I'd use TCC, generate C code and compile directly into memory.
Framehacks aren't going to do the same thing, and one should have tests for it regardless. Framehacks get you tail calls, stack scope and a bunch of other nice properties.
Happy Hacking!
- Schism: A self-hosting Scheme to WebAssembly compiler
-
Racketscript/Racketscript: Racket to JavaScript Compiler
There is a WIP unofficial project from developers at Google called Schism [1].
[1] https://github.com/schism-lang/schism
futhark
-
What downsides exist to Futhark? Seems almost too good to be true?
Why Futhark? (futhark-lang.org)
-
GPU Programming: When, Why and How?
There is no on-going work to support Metal apart from the work done by Miles. There's an old issue about it: https://github.com/diku-dk/futhark/issues/853#issuecomment-5...
-
Is Parallel Programming Hard, and, If So, What Can You Do About It? v2023.06.11a
Functional programming can be a great way to handle parallel programming in a sane way. See the Futhark language [1], for example, that accepts high-level constructs like map and convert them to the appropriate machine code, either on the CPU or the GPU.
[1] https://futhark-lang.org/
-
Is there a programming language that will blow my mind?
Futhark - use a functional language to program the gpu
-
Does This Language Exist?
You might want to look into Futhark, although it's mainly designed for writing GPU code.
- Learn WebGPU
-
Two-tier programming language
Futhark https://futhark-lang.org/
- Best book on writing an optimizing compiler (inlining, types, abstract interpretation)?
- Functional GPU programming: what are alternatives or generalizations of the idea of "number of cycles must be known at compile time"?
- APL: An Array Oriented Programming Language (2018)
What are some alternatives?
racketscript - Racket to JavaScript Compiler
arrayfire-rust - Rust wrapper for ArrayFire
biwascheme - Scheme interpreter written in JavaScript
dex-lang - Research language for array processing in the Haskell/ML family
langjam
Halide - a language for fast, portable data-parallel computation
micrograd - A tiny scalar-valued autograd engine and a neural net library on top of it with PyTorch-like API
julia - The Julia Programming Language
nearley - 📜🔜🌲 Simple, fast, powerful parser toolkit for JavaScript.
BQN - An APL-like programming language. Self-hosted!
gambit - Gambit is an efficient implementation of the Scheme programming language.
kompute - General purpose GPU compute framework built on Vulkan to support 1000s of cross vendor graphics cards (AMD, Qualcomm, NVIDIA & friends). Blazing fast, mobile-enabled, asynchronous and optimized for advanced GPU data processing usecases. Backed by the Linux Foundation.