ubpf VS Befunge

Compare ubpf vs Befunge and see what are their differences.

Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
ubpf Befunge
5 5
746 18
2.1% -
8.5 3.5
1 day ago 6 months ago
C JavaScript
Apache License 2.0 -
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
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.

ubpf

Posts with mentions or reviews of ubpf. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-01-16.
  • Rust-Written Linux Scheduler Showing Promising Results for Gaming Performance
    3 projects | news.ycombinator.com | 16 Jan 2024
    eBPF doesn't run in user space in the context of eBPF in the linux kernel. It's verified so that the kernel can be sure it won't loop forever and then gets JIT'ed and run in kernel space.

    There are some user space BPF vms like https://github.com/iovisor/ubpf and Solana.

  • bpftime: Extending eBPF from Kernel to Userspace
    4 projects | dev.to | 14 Jan 2024
    ubpf: https://github.com/iovisor/ubpf
  • Ask HN: Recommendation for general purpose JIT compiler
    12 projects | news.ycombinator.com | 15 May 2022
    The usual recommendation have been given. Now for more touristic approach what I would like to use if given excuse and time. All those options are mostly written in C:

    - QBE [1] - small compiler backend with nice IL

    - DynASM [2] - IIUC the laujit's backend, that can and is used by other languages

    - uBPF - Userspace eBPF VM. Depending on your DSL the eBPF toolchain could fit your use-case, but this would probably be the biggest excursion.

    [1] https://c9x.me/compile/

    [2] https://luajit.org/dynasm.html

    [3] https://github.com/iovisor/ubpf

  • how to build eBPF learning env on my Mac
    1 project | /r/eBPF | 21 Jan 2022
    There are eBPF-specific userspace implementations you can consider looking into but right now the best support for bpf would be the linux kernel so if the goal is learning you'll most likely want to run linux in a proper virtual machine (e.g. Qemu, VirtualBox, Parallels, etc.)
  • Bytecode for a Register Machine
    5 projects | /r/ProgrammingLanguages | 15 Feb 2021
    This may be entirely irrelevant to what you are looking for, but a good widely used finite register-based VM is the eBPF VM in the Linux Kernel. The IOVisor uBPF project (https://github.com/iovisor/ubpf) is a version of the VM in user space.

Befunge

Posts with mentions or reviews of Befunge. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-04-20.
  • The Rust Performance Book
    2 projects | news.ycombinator.com | 20 Apr 2023
    1. C compilers don't do a good job, & thus even CPython, which has historically stuck to rather vanilla C, uses computed goto, as described in https://eli.thegreenplace.net/2012/07/12/computed-goto-for-e...

    I resorted to similar techniques in optimizing Befunge: https://github.com/serprex/Befunge (See bejit.c & marsh.c/marsh.h)

    2. Rust enums are not variable sized, think of them as tagged C unions, where the Rust compiler can sometimes apply tricks to make Option> the same size as Vec

    3. match can specialize for straight forward cases, when in doubt use https://godbolt.org

  • Ask HN: Recommendation for general purpose JIT compiler
    12 projects | news.ycombinator.com | 15 May 2022
  • Why asynchronous Rust doesn't work
    8 projects | news.ycombinator.com | 13 Nov 2021
    I've found async to be straight forward anytime I've used it. Promise#then is equivalent to callbacks

    async/await often requires very little changes compared to synchronous code, whereas reworking a program into callbacks is much more impactful. & the async/await compilation process tends to produce better performance in addition to this. My first async/await work was a few years ago to increase a data importer's performance by an order of magnitude compared to the blocking code

    Here's an example where looping made for a callback that recursively called, using async/await I get to use a plain loop:

    before: https://github.com/serprex/Befunge/blob/946ea0024c4d87a1b75d...

    after: https://github.com/serprex/Befunge/blob/9677ddddb7a26b7a17dd...

    I don't see why people find it so complicated to separate begin-compute & wait-on-compute

    I've since rewritten a nodejs game server into rust, https://github.com/serprex/openEtG/tree/master/src/rs/server... handleget/handlews are quite straight forward

  • Python interpreter written in rust reaches 10000 commits
    8 projects | news.ycombinator.com | 3 Nov 2021
  • Compilers Are Hard
    7 projects | news.ycombinator.com | 20 Jan 2021
    You'll also find them used in CPython's ceval.c

    I use them in both my C befunge implementations:

    https://github.com/serprex/Befunge/blob/c97c8e63a4eb262f3a60...

    https://github.com/serprex/Befunge/blob/c97c8e63a4eb262f3a60...

What are some alternatives?

When comparing ubpf and Befunge you can also consider the following projects:

qbe-rs - QBE IR in natural Rust data structures

openEtG

sljit - Platform independent low-level JIT compiler

Rustler - Safe Rust bridge for creating Erlang NIF functions

minivm - A VM That is Dynamic and Fast

LjTools - LuaJIT 2.0 bytecode parser, viewer, assembler and test VM. Lua 5.1 parser, IDE and debugger.

rune - An embeddable dynamic programming language for Rust.

Som - Parser, code model, navigable browser and VM for the SOM Smalltalk dialect

MAD-NG.docs - MAD documentation

bug - Scala 2 bug reports only. Please, no questions — proper bug reports only.