SPLV20 VS ATS-Postiats

Compare SPLV20 vs ATS-Postiats and see what are their differences.

ATS-Postiats

ATS2: Unleashing the Potentials of Types and Templates (by githwxi)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
SPLV20 ATS-Postiats
1 18
102 349
- -
10.0 0.0
over 1 year ago about 1 year ago
Idris ATS
- GNU General Public License v3.0 or later
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.

SPLV20

Posts with mentions or reviews of SPLV20. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-10-11.
  • The Little Typer – The Beauty of Dependent Type Systems, One Step at a Time
    4 projects | news.ycombinator.com | 11 Oct 2022
    Internally, the Idris2 compiler uses deBruijn numbering for its terms, which is tricky to get right once you start trying to manipulate terms. To help with this, it keeps a list of the names corresponding to the deBruijn indices at the type level. The type checker catches mistakes as you write code to manipulate them (inserting names, removing names, or renaming things).

    I ran through some exercises teaching this technique[1]. My take-away as a beginner was that it was a pain to make the compiler happy and my code that the compiler didn't like was actually wrong.

    I remember reading someone had written a functional red-black tree (with proof of correctness leveraging dependent types) and said the delete algorithm naturally followed from the types. That has was not my experience (delete wasn't immediately obvious to me), but I need to find some time to give it another go.

    The Idris2 docs have an example of a lambda expression interpreter[2] whose terms have a vector of the types in the environment as a type parameter (erased at runtime), to ensure everything is type safe in the resulting interpreter.

    Typescript has added some bits of dependent typing. For example, asserting a function returns true if the argument has type X, that a function throws if the argument is falsy, and I think type level string manipulation. They are fairly pragmatic, it's not a research language, so I presume that specific functionality is useful to a lot of people. I've used it a little bit of it to help the type checker infer non-null after my assert function was called.

    All of that said, I think people are still exploring how dependent types can be used in practice.

    [1]: https://github.com/edwinb/SPLV20/blob/master/Code/Lecture2/E...

ATS-Postiats

Posts with mentions or reviews of ATS-Postiats. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-10-24.

What are some alternatives?

When comparing SPLV20 and ATS-Postiats you can also consider the following projects:

pie - The Pie language, which accompanies The Little Typer by Friedman and Christiansen

lean4 - Lean 4 programming language and theorem prover

Idris - Codes related to Idris

chapel - a Productive Parallel Programming Language

cicada - An old-school bash-like Unix shell written in Rust

c3c - Compiler for the C3 language

virgil - A fast and lightweight native programming language

HVM - A massively parallel, optimal functional runtime in Rust

coq - Coq is a formal proof management system. It provides a formal language to write mathematical definitions, executable algorithms and theorems together with an environment for semi-interactive development of machine-checked proofs.

polyglot - Tool to count lines of source code.

zacc - zaalang compiler