pysimdjson VS embassy

Compare pysimdjson vs embassy 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
pysimdjson embassy
6 70
629 4,405
- 4.9%
5.3 9.9
3 months ago about 23 hours ago
Python Rust
GNU General Public License v3.0 or later 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.

pysimdjson

Posts with mentions or reviews of pysimdjson. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-03-18.
  • Analyzing multi-gigabyte JSON files locally
    14 projects | news.ycombinator.com | 18 Mar 2023
  • I Use C When I Believe in Memory Safety
    5 projects | news.ycombinator.com | 5 Feb 2023
    Its magic function wrapping comes at a cost, trading ease of use for runtime performance. When you have a single C++ function to call that will run for a "long" time, pybind all the way. But pysimdjson tends to call a single function very quickly, and the overhead of a single function call is orders of magnitude slower than with cython when being explit with types and signatures. Wrap a class in pybind11 and cython and compare the stack trace between the two, and the difference is startling.

    Ex: https://github.com/TkTech/pysimdjson/issues/73

  • Processing JSON 2.5x faster than simdjson with msgspec
    5 projects | /r/Python | 3 Oct 2022
    simdjson
  • [package-find] lsp-bridge
    5 projects | /r/emacs | 23 May 2022
    You are aware of simdjson being available in python if you really need some json crunching, albeit json module in Python is implemented in C itself, so I don't think understand why do you think Python is slow there?
  • The fastest tool for querying large JSON files is written in Python (benchmark)
    16 projects | news.ycombinator.com | 12 Apr 2022
    json: 113.79130696877837 ms

    While `orjson`, is faster than `ujson`/`json` here, it's only ~6% faster (in this benchmark). `simdjson` and `msgspec` (my library, see https://jcristharif.com/msgspec/) are much faster due to them avoiding creating PyObjects for fields that are never used.

    If spyql's query engine can determine the fields it will access statically before processing, you might find using `msgspec` for JSON gives a nice speedup (it'll also type check the JSON if you know the type of each field). If this information isn't known though, you may find using `pysimdjson` (https://pysimdjson.tkte.ch/) gives an easy speed boost, as it should be more of a drop-in for `orjson`.

  • How I cut GTA Online loading times by 70%
    7 projects | /r/programming | 28 Feb 2021
    I don't think JSON is really the problem - parsing 10MB of JSON is not so slow. For example, using Python's json.load takes about 800ms for a 47MB file on my system, using something like simdjson cuts that down to ~70ms.

embassy

Posts with mentions or reviews of embassy. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-05.
  • Embassy 在 Blue Pill 上的点灯案例
    2 projects | dev.to | 5 Apr 2024
  • Why choose async/await over threads?
    11 projects | news.ycombinator.com | 25 Mar 2024
    thanks. looked that up. for the curious: https://embassy.dev/
  • Accessing the Pinecil UART with Picoprobe
    2 projects | news.ycombinator.com | 30 Jan 2024
    Running the Embassy RP2040 USB CDC ACM serial example takes about 5 seconds on a Pico.

    https://github.com/embassy-rs/embassy/blob/main/examples/rp/...

  • Avoid Async Rust at All Cost
    1 project | news.ycombinator.com | 23 Jan 2024
    Async solves different problems, you can, for instance, have just a single-threaded CPU and still have a nice API if you have async-await. It might not be so cool at a higher level as Go's approach of channels and threads, but it's cool in embedded, read this:

    https://github.com/embassy-rs/embassy?tab=readme-ov-file#rus...

    "Rust's async/await allows for unprecedently easy and efficient multitasking in embedded systems. Tasks get transformed at compile time into state machines that get run cooperatively. It requires no dynamic memory allocation, and runs on a single stack, so no per-task stack size tuning is required. It obsoletes the need for a traditional RTOS with kernel context switching, and is faster and smaller than one!"

    I'm just toying with Raspberry Pi Pico and it's pretty nice.

    Go and Rust have different use cases, the async-await is nice at a low level.

  • Is anyone using coroutines seriously?
    4 projects | /r/cpp | 5 Dec 2023
    I have not yet dipped by toes in the Rust waters, but reading about the embassy project is actually what piqued my curiosity about using C++ coroutines in embedded. Are you familiar with the project or have you found it lacking?
  • The state of BLE and Rust (no_std)
    2 projects | /r/rust | 10 Nov 2023
    I think I get the basics (shoutout to the Rust Embedded Working Group!), and I've started looking for the stack I'd be using. I think Embassy is really amazing, as well as the work of the ESP team -- hats off.
  • Rust newcomers are 70x less likely to create vulnerabilities than C++ newcomers [pdf]
    5 projects | news.ycombinator.com | 6 Nov 2023
    > }

    And this is how to do it using embassy, which is an async framework for embedded in rust:

    https://github.com/embassy-rs/embassy/blob/main/examples/rp/...

  • The State of Async Rust
    9 projects | news.ycombinator.com | 25 Sep 2023
    > not good for embedded

    embassy begs to differ

    https://embassy.dev/

    async/await is really just a syntax for building state machines in a way that resembles regular code. It's compiled down to the same code that you would write by hand anyway (early on it had some bloat in state size but I think it's all fixed now).

    And embedded has a lot of state machines!

  • Asynchronous Rust on Cortex-M Microcontrollers
    5 projects | news.ycombinator.com | 19 Jul 2023
    You can run multiple executors at different interrupt priority levels (with multiple tasks per executor), which allows tasks on the higher priority executor to interrupt other tasks. Here's an example https://github.com/embassy-rs/embassy/blob/main/examples/nrf...
  • Espressif advances with Rust – 30-06-2023
    6 projects | news.ycombinator.com | 1 Jul 2023

What are some alternatives?

When comparing pysimdjson and embassy you can also consider the following projects:

orjson - Fast, correct Python JSON library supporting dataclasses, datetimes, and numpy

rtic - Real-Time Interrupt-driven Concurrency (RTIC) framework for ARM Cortex-M microcontrollers

cysimdjson - Very fast Python JSON parsing library

rusty-clock - An alarm clock with environment stats in pure bare metal embedded rust

ultrajson - Ultra fast JSON decoder and encoder written in C with Python bindings

smoltcp - a smol tcp/ip stack

Fast JSON schema for Python - Fast JSON schema validator for Python.

rust-mos - Empowering everyone to build reliable and efficient software.

lupin is a Python JSON object mapper - Python document object mapper (load python object from JSON and vice-versa)

nrf-hal - A Rust HAL for the nRF family of devices

PyValico - Small python wrapper around https://github.com/rustless/valico

async-std - Async version of the Rust standard library