Why I Switched from Python to Rust for AI Deployment

Поделиться
HTML-код
  • Опубликовано: 14 янв 2025

Комментарии • 78

  • @zendr0
    @zendr0 11 месяцев назад +27

    So what's the conclusion? Is it ready for ML or datascience production systems

    • @codeinajiffy
      @codeinajiffy  11 месяцев назад +32

      I wouldn't say so. Python still has more libraries for ML and is easier to develop. I would use Rust for only deployment and only in the condition that Python is too slow for your use case.

    • @zendr0
      @zendr0 11 месяцев назад +10

      @@codeinajiffy gotcha. Have you tried the candle crate by huggingface. They say it is Rust alternative to Pytorch. You should give it a shot. May be make a video on that if you like it.

    • @codeinajiffy
      @codeinajiffy  11 месяцев назад +14

      @@zendr0 That sounds super interesting. I will consider it in my next videos if I find it to be a useful.

    • @berkes
      @berkes 9 месяцев назад +11

      It is. But very much "it depends".
      Rust isn't just "faster to run" (less CPU and less memory, which the video dies not go into).
      It's above all stricter and thus protects you against many mistakes and bugs. Not all, but many.
      While that may even slow down a developer in the initial days or hours, it starts paying back within weeks. And seeing that we typically do some POC or exploration at first, Python (or even bash) is probably a much better fit there.
      But the moment we put something into production, make it a team project and/or start maintenance and continued development, the strictness of rust pays off. Often withind days.
      I typically cludge together a PoC in python. Once/if I'm happy with the direction and setup, I'll throw out that hodgepodge of python, bash/sed/awk, JavaScript and whatnot.
      And write it in Rust.

    • @julyort6762
      @julyort6762 9 месяцев назад +5

      ​@@berkes Yeah so design in python and deploy in Rust seems really good

  • @Mn16Cr45
    @Mn16Cr45 11 месяцев назад +62

    Now you can switch from Rust to Mojo and make new video about why I switched

    • @jorge1869
      @jorge1869 9 месяцев назад

      Agree❤

    • @421048
      @421048 6 месяцев назад

      damn, I searched about mojo, and tbh I cannot wait to it become stable to use in serious project man. fucking sh111t

    • @huvineshrajendran6809
      @huvineshrajendran6809 4 месяца назад +4

      As much as I would like to agree with you, Mojo is not quite ready yet

    • @DataPastor
      @DataPastor Месяц назад +2

      And Mojo’s license is quite restricting, hindering the adoption of the language.

    • @blaisepascal3905
      @blaisepascal3905 20 дней назад

      Is Mojo mature enough though?

  • @vectoralphaSec
    @vectoralphaSec 10 месяцев назад +6

    What about Mojo? The language that was literally designed for AI from the ground up? Plus Mojo's speed could be tested too.

    • @codeinajiffy
      @codeinajiffy  10 месяцев назад +1

      Yup, I will look into that very soon. It's just a new language that might not yet be ready for production, but we can give it a try.

    • @mahakasem810
      @mahakasem810 9 месяцев назад +1

      ​@@codeinajiffy
      Their benchmark was recently revealed a lie after someone uncompleted the binary. Turns out something shady is happening in their compiler that doesn't match their claims. Big disappointment.

    • @houstonbova3136
      @houstonbova3136 8 месяцев назад

      Mojo is low-key trash.

    • @vectoralphaSec
      @vectoralphaSec 8 месяцев назад +1

      @@houstonbova3136 Its better than Rust in every way for AI though.

    • @houstonbova3136
      @houstonbova3136 8 месяцев назад +3

      @@vectoralphaSec Having done Data Science in a mix of professional and hobby for the last 5 years I’m going to have to hard disagree with that.
      I strongly prefer just using Python for exploration and then subbing out to raw Rust when I need gains. But, I also understand Rust. Mojo rarely matches its performance in practice and reduces my ability to create effective FFIs or directly manage the data when needed.

  • @francismatsika3727
    @francismatsika3727 11 месяцев назад +11

    I have been trying rust and the learning curve it steep . Unfortunately python has a huge ecosystem and u cant just jump it. Thats why i am looking carefully at Mojo which has similar memory management features to rust , the borrower checker and how referencing is done in rust. This can be a game changer. Mojo can bring in C perforance, Rust security and python versatility in one language

    • @kevinmcfarlane2752
      @kevinmcfarlane2752 7 месяцев назад

      From what I can see, Mojo is going to clean up in this area in the long run. Rust isn’t going anywhere but it will clean up outside of AI and scientific computing tasks.
      Right now, F# is more mature for AI and can play nicely in the existing ecosystem.

  • @julyort6762
    @julyort6762 9 месяцев назад +7

    Anyway polar can run also in 1 thread, maybe you were using only the default which is multi-thread and that's bad for non intensive request

  • @Mbd3Bal7dod
    @Mbd3Bal7dod 11 месяцев назад +3

    running multi workers for the api will solve the concrent request issue ,

    • @codeinajiffy
      @codeinajiffy  11 месяцев назад +1

      Nice suggestion, but multi-workers here also increased resource consumption by quite a bit. It was quite close to increasing k8s pods.

  • @CoolDude911
    @CoolDude911 2 месяца назад +2

    Using two packages is not comparing the two languages. There are plenty of dataframe libraries that make different compromises on the backend that can do better than pandas.

  • @its_code
    @its_code 11 месяцев назад +9

    Why not mojo language

    • @codeinajiffy
      @codeinajiffy  11 месяцев назад +8

      I am considering trying it out next actually. It seems very interesting.

    • @its_code
      @its_code 11 месяцев назад +1

      @@codeinajiffy 🥰🥰😝

  • @gamex-animex6289
    @gamex-animex6289 Месяц назад

    where did you get this animation at 0:25?

  • @bacharsaleh6984
    @bacharsaleh6984 4 месяца назад

    I think not is time to show us how you created that recommendation system :)

  • @jnorris32
    @jnorris32 6 месяцев назад +1

    So did you switch from Python to Go or Rust?

  • @houstonbova3136
    @houstonbova3136 8 месяцев назад +2

    I’m curious if in the Rust implementation of polars, did you use lazy execution or eager?

    • @codeinajiffy
      @codeinajiffy  8 месяцев назад +1

      I used Lazy mostly to optimize the execution as much as possible. But yes you will need to understand lazy and eager to make this work fast.

  • @ajaypatro1554
    @ajaypatro1554 3 месяца назад

    What if you used dask dataframe and dask array or maybe cython

  • @cloudguru3018
    @cloudguru3018 9 месяцев назад +1

    Now you can switch to Mojo

  • @djthedadiofficial
    @djthedadiofficial 10 месяцев назад +2

    look at virtually any published benchmarking of pandas vs polars and polars is many times faster. Without seeing your code it's impossible to prove, but this was almost certainly a skill issue in terms of writing the rust. I am also extremely skeptical about your Golang conclusions, were you using goroutines?
    as for your last slide, you can spawn threads in Python too
    but, for all the newbies out there, alas you're unlikely to see almost any of these options. Much more likely to see something like Java, Kafka, Flink, or even Postgres with plugins. For applications that need super quick inference speed, very likely to see C or CPP

  • @johanngambolputty5351
    @johanngambolputty5351 11 месяцев назад +4

    The only thing that was stopping me from moving from python to something like c/c++ before was ergonomics, not that c++ can't be concise, but a lot of libraries seem to require verbose interfacing. Rust, like python, seems to be very concise, so it offers a best of both, in brevity and performance, that I always thought were mutually exclusive. I was never under the illusion that python was efficient, it just had great syntax, which made prototyping a joy. It feels like I can prototype in rust same as I used to in python, and then get the proper implementation for free at the end.
    All that said, wasn't the GIL getting removed and couldn't you use multiprocessing.pool?

    • @codeinajiffy
      @codeinajiffy  11 месяцев назад

      I didn't try multiprocessing.pool but that is a good suggestion. It might not be consistent between requests, but I will try it out.

  • @dimensionalcookie
    @dimensionalcookie 6 месяцев назад

    Hi, if possible, can you please do a tutorial how to deploy AI on production? Thank you. I know you when im interested in Go and Rust, and now im working in AI industry too. Those banger videos about AI project on your channel really help, but its a coincident when I realize this video is on the same channel.

  • @martincontrerasu
    @martincontrerasu 9 месяцев назад +1

    is there any git code link to check your recommendation project?

    • @codeinajiffy
      @codeinajiffy  9 месяцев назад +2

      no github link because this was company code. I am thinking of doing another project that I can share.

  • @guttenbergovitz
    @guttenbergovitz 6 месяцев назад

    You nailed it. Rust shall it be... 🦀

  • @izidorobaltazar907
    @izidorobaltazar907 3 месяца назад

    Interesting. I tried the simple counting at 4:54 mark Python vs Rust. Python with numba decorator wins on my system - Rust is 3x slower.

    • @chats-bug
      @chats-bug 13 дней назад

      Numba vectorizes the operation, you can do something similar in rust as well.

  •  8 месяцев назад +1

    👏👍👍

  • @vuhuy8952
    @vuhuy8952 5 месяцев назад

    polars is doppelganger of spark when write code...

  • @aaronelmquist8607
    @aaronelmquist8607 2 месяца назад

    Yeah relying on just FastAPI operating asynchronously is just the wrong approach for python under a heavy CPU workload.
    Those operations really would need to move off the main thread with something like celery to keep things from blocking.

  • @nurmohammed9642
    @nurmohammed9642 10 месяцев назад +2

    Biggest advantage of using rust is Zero-Cost-Abstraction, For example `sumation()` function could be write as:
    (1..=n).sum()
    and it would still out performed.

  • @Singlton
    @Singlton 8 месяцев назад

    when trying to learn rust polars functionality , each time I run the code the compilation time takes around 10 seconds!
    any body knows how to reduce the time spent in compilation to make it ideal to learn and try polars functionality as a newbie ?

    • @LibreGlider
      @LibreGlider 8 месяцев назад

      Are you doing debug builds or release builds? Debug builds will be faster you can also set your debug builds to be incremental. You can also use sccache to cache compiler output. You could change the default linker or send -Z threads=8 to the rustic compiler. That is an unstable option but it will break up the front-end compilation of each package into 8 slices. But a 10 sec compile time isn't that bad considering the performance gains you get.
      Oh there is also cargo-watch, it will recompile your code when the file is saved. It also depends on how you are running/testing this code. Are you reading in your data from a file or stdin or are you hardcoding data in the source code?

  • @jasonshen
    @jasonshen 3 месяца назад

    to be honest rust is cool but when it comes to ai python is still the best option, speed of the development and the libs available, i did turn to rust from python, trust me i regret as the project progresses

  • @anon_y_mousse
    @anon_y_mousse 10 месяцев назад +7

    Well, I didn't learn anything from the video, but it did add yet another data point confirming what I already knew. Python makes it immensely difficult to write efficient code and requires external libraries written in better languages to achieve any degree of speed and general usefulness. Rust is basically a more obtuse C++ that nearly everyone in the future will use because the propaganda machine surrounding it is exceedingly effective. I know that a lot of people will claim that Rust is easier to learn, but since you can write your code in C++ exactly the same way as in Rust to achieve the same goal the same way and it will be equally as fast, the ease of use of C++ for simple projects shouldn't be understated. If you write idiomatic modern C++, it's as safe as Rust.

    • @mahakasem810
      @mahakasem810 9 месяцев назад +2

      Sad but true reality.

    • @Codotaku
      @Codotaku 9 месяцев назад +3

      "it's as safe as Rust", sorry but that's an absurd statement if you knew what you're talking about

    • @anon_y_mousse
      @anon_y_mousse 9 месяцев назад +1

      @@Codotaku There were some qualifiers on that, but if you missed them and all the rest of what I said, then you must be a Rust user.

    • @LibreGlider
      @LibreGlider 8 месяцев назад +2

      @@anon_y_mousse Idiomatic C++ won't guarantee memory safety because it's unreasonable to expect devs not to make mistakes. Not to mention the safety you get out of the box with Rust, thits a fact. 100% idiomatic C++ 100% of the time?

    • @anon_y_mousse
      @anon_y_mousse 8 месяцев назад

      @@LibreGlider If you write idiomatic C++, then the compiler will catch most errors. The more insidious errors that aren't logic errors can be caught by external tools like the open source and often used `valgrind`, which catches everything the compiler misses and more than `rustc` will catch. If you had learned to program 20 years ago when they were still teaching people how to actually program instead of merely use a tool, then you would know these things. So I feel sorry for anyone learning how to use tools now instead of how to actually solve problems like an actual programmer, but we get what we allow to exist instead of what should because we've slacked off and not done our job for future generations. Sorry, my generation's intransigence in doing our duty for your generation has royally screwed you.

  • @RoyAAD
    @RoyAAD 8 месяцев назад +1

    Where's the AI?

  • @UnbenutzerKanalname
    @UnbenutzerKanalname 6 месяцев назад

    Try Julia for ML

  • @enchantedshit
    @enchantedshit 9 месяцев назад

    please provide free resources for rust

    • @codeinajiffy
      @codeinajiffy  8 месяцев назад +1

      I learned Rust from this video: ruclips.net/video/ygL_xcavzQ4/видео.html .
      Then just jump on project and figure things out along the way. This should enough if you have some background in programming.

  • @ArminMahyar
    @ArminMahyar 9 месяцев назад +3

    Only c++, rust is a copy of that, dont be naive

    • @SupremelyAverage
      @SupremelyAverage 9 месяцев назад

      I agree. But it's quite better imo

    • @herkerr
      @herkerr 8 месяцев назад

      At the end it’s all assembly. Why complicate it?

    • @slip-shape994
      @slip-shape994 7 месяцев назад +7

      That means you even don't know C++

    • @ArminMahyar
      @ArminMahyar 7 месяцев назад

      @@slip-shape994
      How old R U?
      U Tell me what c++ is?

    • @Miles-co5xm
      @Miles-co5xm 7 месяцев назад +3

      C--

  • @Singlton
    @Singlton 8 месяцев назад

    do you have discord ?

    • @codeinajiffy
      @codeinajiffy  8 месяцев назад

      Not yet, I am thinking of creating one.