• Successful_Try543@feddit.org
    link
    fedilink
    arrow-up
    24
    arrow-down
    1
    ·
    6 days ago

    Does Python have the ability to specify loops that should be executed in parallel, as e.g. Matlab uses parfor instead of for?

    • lime!@feddit.nu
      link
      fedilink
      English
      arrow-up
      55
      arrow-down
      4
      ·
      6 days ago

      python has way too many ways to do that. asyncio, future, thread, multiprocessing

        • lime!@feddit.nu
          link
          fedilink
          English
          arrow-up
          11
          ·
          6 days ago

          yup, that’s true. most meaningful tasks are io-bound so “parallel” basically qualifies as “whatever allows multiple threads of execution to keep going”. if you’re doing numbercrunching in pythen without a proper library like pandas, that can parallelize your calculations, you’re doing it wrong.

          • WolfLink@sh.itjust.works
            link
            fedilink
            arrow-up
            8
            ·
            edit-2
            6 days ago

            I’ve used multiprocessing to squeeze more performance out of numpy and scipy. But yeah, resorting to multiprocessing is a sign that you should be dropping into something like Rust or a C variant.

      • danhab99@programming.dev
        link
        fedilink
        arrow-up
        10
        arrow-down
        1
        ·
        6 days ago

        I’ve always hated object oriented multi threading. Goroutines (green threads) are just the best way 90% of the time. If I need to control where threads go I’ll write it in rust.

            • entropicdrift@lemmy.sdf.org
              link
              fedilink
              arrow-up
              2
              arrow-down
              1
              ·
              6 days ago

              Meh, even Java has decent FP paradigm support these days. Just because you can do everything in an OO way in Java doesn’t mean you need to.

          • danhab99@programming.dev
            link
            fedilink
            arrow-up
            2
            arrow-down
            2
            ·
            6 days ago

            If I have to put a thread object in a variable and call a method on it to start it then it’s OO multi threading. I don’t want to know when the thread spawns, I don’t want to know what code it’s running, and I don’t want to know when it’s done. I just want shit to happen at the same time (90% of the time)

            • lime!@feddit.nu
              link
              fedilink
              English
              arrow-up
              4
              ·
              6 days ago

              the thread library is aping the posix thread interface with python semantics.

          • Successful_Try543@feddit.org
            link
            fedilink
            arrow-up
            5
            ·
            edit-2
            6 days ago

            We weren’t doing any ressource extensive computations with Matlab, mainly just for teaching FEM, as we’ve had an extensive collection of scripts for that purpose, and pre- and some post processing.

            • twice_hatch@midwest.social
              link
              fedilink
              English
              arrow-up
              1
              ·
              6 days ago

              I don’t like that they don’t write their own algorithms in any other language. I was trying to understand low-pass filters a while back and so many web pages were like, “Call this MATLAB function” or “here’s a code generator that puts out bad C for specific filter parameters” Like no, I want the algorithm explained to me…

      • Panties@lemmy.ca
        link
        fedilink
        arrow-up
        7
        ·
        6 days ago

        I was telling a colleague about how my department started using Rust for some parts of our projects lately. (normally Python was good enough for almost everything but we wanted to try it out)

        They asked me why we’re not using MATLAB. They were not joking. So, I can at least tell you their reasoning. It was their first programming language in university, it’s safer and faster than Python, and it’s quite challenging to use.