a-mir-formality VS theory-exploration-benchmarks

Compare a-mir-formality vs theory-exploration-benchmarks and see what are their differences.

a-mir-formality

a model of MIR and the Rust type/trait system (by rust-lang)

theory-exploration-benchmarks

Mirror of http://chriswarbo.net/git/theory-exploration-benchmarks (by Warbo)
Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
a-mir-formality theory-exploration-benchmarks
4 2
244 0
5.7% -
9.3 10.0
3 months ago over 5 years ago
Rust Racket
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.

a-mir-formality

Posts with mentions or reviews of a-mir-formality. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-08-17.
  • My resignation letter as R7RS-large chair
    7 projects | news.ycombinator.com | 17 Aug 2023
    Racket is very used in the PLT community (programming language theory) for prototyping programming languages. Lots of cool stuff in this area.

    For example, the MIR formality [0] project of the Rust programming language to formalize MIR (their intermediate language) was first prototyped in Racket [1], then rewritten in Rust. [1]'s readme give a rationale:

    > For the time being, the model is implemented in PLT Redex. PLT Redex was chosen because it is ridiculously accessible and fun to use. It lets you write down type system rules and operational semantics and then execute them, using a notation that is very similar to what is commonly used in published papers. You can also write collections of unit tests and fuzz your model by generating test programs automatically.

    > The hope is that PLT Redex will prove to be a sufficiently accessible tool that many Rust contributors will be able to understand, play with, and extend the model.

    > One downside of PLT Redex is that it doesn't scale naturally to performing proofs. We may choose to port the model to another system at some point, or maintain multiple variants.

    [0] https://github.com/rust-lang/a-mir-formality

    [1] https://github.com/rust-lang/a-mir-formality/tree/1f40120f09...

  • Officially announcing the types team
    2 projects | /r/rust | 20 Jan 2023
  • Why are Rust programs slow to compile?
    4 projects | /r/rust | 24 Sep 2022
    But MIR optimizations are a bit of a mess right now. The semantics of MIR are not completely settled but that is an area of active work: https://github.com/nikomatsakis/a-mir-formality
  • Announcing: MiniRust
    7 projects | news.ycombinator.com | 8 Aug 2022
    That's happening separately, in the "mir-formality" project: https://github.com/nikomatsakis/a-mir-formality

    The two projects are related, but have different objectives (mir-formality includes traits and borrow checking, while MiniRust focuses on operational semantics).

theory-exploration-benchmarks

Posts with mentions or reviews of theory-exploration-benchmarks. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-08-17.
  • My resignation letter as R7RS-large chair
    7 projects | news.ycombinator.com | 17 Aug 2023
    I chose Racket for a project that involved lots of AST manipulation. Those ASTs were already in s-expression format, so Scheme seemed a natural fit.

    The lack of static types was annoying; Typed Racket helped, but was so slow I only enabled it during unit tests (more precisely: Typed Racket functions can be faster than those written in normal Racket, but calling them from normal Racket functions will be slow as it performs run-time checks)

    https://github.com/Warbo/theory-exploration-benchmarks/tree/...

  • Use TOML for `.env` Files?
    7 projects | news.ycombinator.com | 10 Feb 2023
    > "CLI args are usually passed around explicitly" -- I think this is a pro, not a con.

    Sure; I never said it's a con. They have different characteristics, and are both useful in certain situations :)

    > I think the correct term for "things the caller knows better than the implementor" are parameters.

    True; that's also the name Racket gives to dynamically-scoped variables https://docs.racket-lang.org/guide/parameterize.html

    In fact, Racket uses a parameter (dynamically-scoped variable) to store the environment. This is actually slightly annoying, since the parameter is one big hashmap of all the env vars; but I usually want to override them individually. One of my Racket projects actually defines a helper function to override individual env vars makes a copies all the other environment ( made a are contained in a parameterhttps://github.com/Warbo/theory-exploration-benchmarks/blob/...

What are some alternatives?

When comparing a-mir-formality and theory-exploration-benchmarks you can also consider the following projects:

datafrog - A lightweight Datalog engine in Rust

renegade-way - Option Trading Application