• @[email protected]
    link
    fedilink
    231 month 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!
      link
      fedilink
      English
      511 month ago

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

      • @[email protected]
        link
        fedilink
        421 month ago

        Of the ways you listed the only one that will actually take advantage of a multi core CPU is multiprocessing

        • lime!
          link
          fedilink
          English
          111 month 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.

          • @[email protected]
            link
            fedilink
            8
            edit-2
            1 month 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.

            • @[email protected]
              link
              fedilink
              01 month ago

              Most numpy array functions already utilize multiple cores, because they’re optimized and written in C

      • @[email protected]
        link
        fedilink
        91 month 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.

        • lime!
          link
          fedilink
          English
          71 month ago

          nothing about any of those libraries dictates an OO approach.

            • @[email protected]
              link
              fedilink
              11 month 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.

          • @[email protected]
            link
            fedilink
            01 month 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!
              link
              fedilink
              English
              41 month ago

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

          • @[email protected]
            link
            fedilink
            5
            edit-2
            1 month 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.

            • @[email protected]
              link
              fedilink
              English
              11 month 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…

      • @[email protected]
        link
        fedilink
        71 month 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.

        • @[email protected]
          link
          fedilink
          English
          41 month ago

          “Just use MATLAB” - Someone with a kind heart who has never deployed anything to anything