kani VS nomicon

Compare kani vs nomicon and see what are their differences.

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
kani nomicon
47 87
1,905 1,699
3.7% 2.6%
9.5 5.6
7 days ago about 1 month ago
Rust CSS
Apache License 2.0 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.

kani

Posts with mentions or reviews of kani. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-01-30.
  • The C Bounded Model Checker: Criminally Underused
    7 projects | news.ycombinator.com | 30 Jan 2024
    This is also the backend for Kani - Amazon's formal verification tool for Rust.

    https://github.com/model-checking/kani

  • Boletรญn AWS Open Source, Christmas Edition
    9 projects | dev.to | 24 Dec 2023
  • The Wizardry Frontier
    2 projects | /r/rust | 10 Dec 2023
    Nice read! Rust has pushed, and will continue to push, the limits of practical, bare metal, memory safe languages. And it's interesting to think about what's next, maybe eventually there will be some form of practical theorem proving "for the masses". Lean 4 looks great and has potential, but it's still mostly a language for mathematicians. There has been some research on AI constructed proofs, which could be the best of both worlds because then the type checker can verify that the AI generated code/proof is indeed correct. Tools like Kani are also a step forward in program correctness.
  • Kani 0.40.0 has been released!
    1 project | /r/KaniRustVerifier | 5 Nov 2023
    Ease setup in Amazon Linux 2 by @adpaco-aws in #2833
  • Kani 0.39.0 has been released!
    1 project | /r/KaniRustVerifier | 21 Oct 2023
    Limit --exclude to workspace packages by @tautschnig in #2808
  • Kani 0.38.0 has been released !
    1 project | /r/KaniRustVerifier | 7 Oct 2023
    Here's a summary of what's new in version 0.38.0:
  • CVE-2023-4863: Heap buffer overflow in WebP (Chrome)
    18 projects | news.ycombinator.com | 12 Sep 2023
    > those applications need the proof for correctness so that more dangerous code---say, what would need `unsafe` in Rust---can be safely added

    There are actually already tools built for this very purpose in Rust (see Kani [1] for instance).

    Formal verification has a serious scaling problem, so forming programs in such a way that there are a few performance-critical areas that use unsafe routines seems like the best route. I feel like Rust leans into this paradigm with `unsafe` blocks.

    [1] - https://github.com/model-checking/kani

  • Kani 0.36.0 has been released!
    1 project | /r/KaniRustVerifier | 9 Sep 2023
    Enable concrete playback for failure of UB checks by @zhassan-aws in https://github.com/model-checking/kani/pull/2727
  • Kani 0.34.0 has been released!
    1 project | /r/KaniRustVerifier | 11 Aug 2023
    Change default solver to CaDiCaL by @celinval in https://github.com/model-checking/kani/pull/2557 By default, Kani will now run CBMC with CaDiCaL, since this solver has outperformed Minisat in most of our benchmarks. User's should still be able to select Minisat (or a different solver) either by using #[solver] harness attribute, or by passing --solver= command line option.
  • Kani 0.33.0 has been released!
    1 project | /r/KaniRustVerifier | 30 Jul 2023
    Add support for sysconf by feliperodri in #2557

nomicon

Posts with mentions or reviews of nomicon. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-12-07.
  • [Media] I'm comparing writing a double-linked list in C++ vs with Rust. The Rust implementation looks substantially more complex. Is this a bad example? (URL in the caption)
    6 projects | /r/rust | 7 Dec 2023
    itโ€™s even written by the same person that wrote the Nomicon (the guide to the dark arts of unsafe)
  • Rust books to read
    2 projects | /r/rust | 23 Jun 2023
    If you want to dive deeper you can always have other options but now there are concrete cases, if you want to do low level thing https://doc.rust-lang.org/nomicon/ while if you want multi thread/concurrency stuff https://marabos.nl/atomics/ . There are many many books so you will have to point yourself to what you want
  • Thread-shared boolean flag
    1 project | /r/rust | 23 Jun 2023
    Nonononono. SeqCst is the most error prone memory order: https://github.com/rust-lang/nomicon/issues/166
  • [Media] Hashmap behaviour inside a loop due to lifetime issue
    1 project | /r/rust | 22 Jun 2023
    Hope this helps. For more details, see the Rustonomicon. I referenced the subtyping chapter here extensively.
  • Unsafe Rust
    2 projects | /r/rust | 15 Jun 2023
    Nice video! Glad I could help out. This stuff is hard, and I'm still learning a lot about it myself even years later. The Rustonomicon is a great read if you haven't already.
  • Stepping up the YAML engineer game
    2 projects | /r/devops | 25 May 2023
    Have you got a moment to read through the good book , after reading through this perhaps try the Rustonomicon.
  • Questions about ownership rule
    2 projects | /r/rust | 23 May 2023
  • CppCon 2022 Best Practices Every C++ Programmer Needs to Follow โ€“ Oz Syed
    1 project | news.ycombinator.com | 19 May 2023
    That is not what UB means. Undefined Behaviour is behaviour that the compiler is allowed to assume will never happen, and which can consequently cause miscompilations due to optimisation passes gone wrong if it does in fact occur in the source code.

    It's true that Rust does not have a written specification that clearly delineates what is and isn't UB in a single place. But:

    1. UB is impossible in safe code (modulo bugs in unsafe code)

    2. There are resources such as the Rustinomicon (https://doc.rust-lang.org/nomicon/) that provide a detailed guide on what is and isn't allowed in unsafe code.

    In practice, it's much easier to avoid UB in Rust than it is in C++.

  • How to write deserializer for custom binary protocol?
    2 projects | /r/rust | 13 May 2023
    However, this is a wide topic out of scope for a Reddit comment, so maybe just read the Rustonomicon. It explains everything about data handling in Rust.
  • Performance critical ML: How viable is Rust as an alternative to C++
    4 projects | /r/rust | 2 May 2023
    The ownership model & borrow checker makes rust a bit of an awkward language in which to write complex data structures like trees and graphs. It can be done - since you can always use raw pointers & unsafe code when you absolutely need to to treat rust like C. But the language fights you, and the community can get a bit moralistic about this sort of thing. The rust nomicon is a fantastic resource for learning the limits of the borrow checker, and where and how to use unsafe code correctly. You will need unsafe less than you think you will, but sometimes you will have no choice.

What are some alternatives?

When comparing kani and nomicon you can also consider the following projects:

prusti-dev - A static verifier for Rust, based on the Viper verification infrastructure.

book - The Rust Programming Language

awesome-rust-formalized-reasoning - An exhaustive list of all Rust resources regarding automated or semi-automated formalization efforts in any area, constructive mathematics, formal algorithms, and program verification.

mdBook - Create book from markdown files. Like Gitbook but implemented in Rust

MIRAI - Rust mid-level IR Abstract Interpreter

rust-ffmpeg - Safe FFmpeg wrapper.

gdbstub - An ergonomic, featureful, and easy-to-integrate implementation of the GDB Remote Serial Protocol in Rust (with no-compromises #![no_std] support)

Theseus - Theseus is a modern OS written from scratch in Rust that explores ๐ข๐ง๐ญ๐ซ๐š๐ฅ๐ข๐ง๐ ๐ฎ๐š๐ฅ ๐๐ž๐ฌ๐ข๐ ๐ง: closing the semantic gap between compiler and hardware by maximally leveraging the power of language safety and affine types. Theseus aims to shift OS responsibilities like resource management into the compiler.

rmc - Kani Rust Verifier [Moved to: https://github.com/model-checking/kani]

Exercism - website - The codebase for Exercism's website.

watt - Runtime for executing procedural macros as WebAssembly

miri - An interpreter for Rust's mid-level intermediate representation