233

Show HN: Chili. Rust port of Spice, a low-overhead parallelization library

I love this, the overhead of rayon always made it hard to gauge whether to use it for small operations (or could be small operations). This seems to solve that, at least for relatively short workloads

2 months agodangoodmanUT

> a "low-overhead" parallelization library

Who is out here building high-overhead parallelization libraries?

2 months agozbowling

I have almost certainly built high overhead parallelization primitives during my junior years.

2 months agozamalek

Check out my high-overhead replacement for 'cat' in BASH

    ~ $ type cat
    cat is a function
    cat () 
    { 
        while read; do
            printf '%s\n' "$REPLY";
        done < "$@"
    }
It probably butchers things. Why? I got bored in a meeting and someone accidentally posted 'cat' to Teams
2 months agobravetraveler

Relatively, Rayon is higher overhead

2 months agointernetter

Yeah, why are those bastards writing slow code? They should just write fast code instead

2 months agoandrepd

Fast code is often unmaintainable, that's why new high-speed libraries keep popping up.

2 months agosilon42

Yeah and people should make sure not to commit bugs too. I look at all these commits with bugs and I'm like why are you committing bugs.

2 months agotherein

Stop publishing software, you don't refine your meal constantly! Enough is enough!

2 months agobravetraveler

In the early 2000s we were still in high school and a friend of mine told me that it's pointless to chose a carrier in SWE because eventually all the software will be written and there would be nothing to do.

Well we both ended up in CS but it's really a funny take nowadays (by then I wasn't so sure and it made me worry a bit).

2 months agobionsystem

we got paid to fix someone else code, whoever invented wordpress has made a million jobs

2 months agotonyhart7

Out of curiosity, how do Spice/Chili/Rayon compare against the boring answer, OpenMP?

I guess they must have some really neat capabilities.

2 months agobee_rider

That’s what I was wondering. Iiuc openmp uses work stealing and the spice readme talks about the inefficiency of that:

https://github.com/judofyr/spice?tab=readme-ov-file#work-ste...

so I’d be interested in seeing a benchmark.

2 months agomarmaduke

Reading the implementation details kinda got me wanting to do a c11 threads based port.

2 months agomarmaduke

Thanks. That’s some pretty clever stuff, with a nice intuitive description.

2 months agobee_rider

Rayon is known to have a higher overhead for the simple, and arguably most common case in numerical codes, static block size scheduling. Things get better, and you start to benefit from rayon, as work gets less balanced.

2 months agonestorD

Well, for one thing OpenMP is a c/c++ library, and chili and rayon are rust libraries.

It's probably possible to use openmp from rust, but the interface probably isn't as nice, you would need some kind of translation layer from rust closures and iterators to the OpenMP API

2 months agothayne

Plus Fortran!

There’d definitely be some work translating Rust concepts over. It might be impossible/not worth it. But maybe it would be nice to have Rust, C, and Fortran all talking to the same runtime?

2 months agobee_rider

Interesting, I wonder if I could use this on embedded. I was trying to get Rayon to work on embedded but was getting stack overflows when I tried. Maybe this will do the trick…

2 months agoclarkmcc

Is there anything like ray.io in rust? Nobody running computations on clusters in rust?

2 months agojmakov

The company I work at (Hadean) used to have this as a product - think erlang-like multi machine IPC, with automatic acquisition of cloud resources and language integration for Rust, C, C++, Python. Pretty easy to point it at some machines and get them running a distributed application (as in simulation or big data).

But infrastructure for developers is hard to make money with - developers like to build it themselves and people holding the purse strings point at kubernetes and say "that's free". So we just use it as an internal platform for a distributed simulation engine and it works pretty well.

I did an analysis of removing it (it's a lot of bespoke code that we have to maintain for something that isn't our actual product) and I think you could probably implement something on top of Nomad that's close enough...but then Nomad went BSL and Kubernetes is a big complexity shift.

So...if anyone knows of something out there let me know, I'd love to be able to use it outside of work :)

2 months agoaidanhs

ray.io seems to be doing pretty well financially...

2 months agojmakov

Right, because Anyscale found a niche that distributed compute matters in (AI) and built great libraries/hosted platforms/services around that. I would venture that the money they make from people who pare back things to just ray core is ~0, which is why it's open source.

Put another way - building such a platform doesn't preclude commercial success, but (at least for us) it isn't sufficient. Fly.io might be able to pull it off if they want to explore that direction imo.

Fwiw if you dig around in the ray core codebase (as I did when I was doing competitor analysis years ago) you can use the core C code from other languages to build such a platform for Rust if you like - they had Java and C++ interfaces at the time, but I haven't looked in the last 5 years.

2 months agoaidanhs

Not related to the content, but as a port of "spice" -- being from New Mexico, we would usually refer to a spicy pepper as (eg green) "chile," or a chunky dish with beans and meat as (eg Texas) "chili." Looks like the AP Stylebook agrees, though Webster's makes it seem less clear, so you can probably get away with it either way.

2 months agon8henrie

Further abroad (Australia), Chile is a country and chili is the hot pepper, so I suspect the (English) language here is highly regional.

Eg I’ve even lived in North American and never come across that spelling for the pepper.

2 months agoandyferris

The "chile" spelling is from Spanish, particularly Mexican and Central American Spanish. The word is derived from Nahuatl (Aztec).

That said, I'm in northern US and I would spell the pepper "chili"

2 months agoanamexis

Oddly I associate `chile` with the pepper and `chili` with the stew. Curiously chili pepper seems to be the common spelling around where I live so I have no clue where I picked this up.

2 months agodarby_nine

And the name of the country Chile has no relation to the nahuatl word for pepper but comes from a word in a south American language (likely Aymara)

2 months agoithkuil

Yeah, I've lived in the northeast US my whole life and have never seen "Chile" used for anything but the country before; the pepper and the food are both spelled "chili" in my experience. That being said, pronouncing the country's name as a homophone of "chili" is a bit of an anglicism too, since from what I remember of Spanish in high school, the more accurate pronunciation would be something like "chee-lay" rather than "chill-ee". I wouldn't be shocked if both the spelling "chili" and the pronunciation of it had roots in the name of the country and in English usage drifted over time (sort of like the pronunciation of the name of the city "Amarillo" in Texas).

2 months agosaghm

Was just arguing with a friend the other day about distinction between a "chili" and what New Mexican's have in "green chile stew." I have had what by at least strong family-resemblance is a chili but had essentially an adovada meat base, but would never call something chili that had potatoes or any visible vegetables. But in NM, even frito pies get the (superior) "green chile stew" topping.

2 months agobeepbooptheory

> or a chunky dish with beans and meat as (eg Texas) "chili."

My understanding was that the name of the dish was short for "chili con carne" i.e. chili (the pepper) with meat

2 months agothayne

If it has beans it isn’t Texas chili…

2 months agoskipkey
[deleted]
2 months ago

[flagged]

2 months agoadityaathalyo