• @[email protected]
    link
    fedilink
    233 months 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
      513 months ago

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

      • @[email protected]
        link
        fedilink
        423 months 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
          113 months 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
            3 months 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
              13 months ago

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

      • @[email protected]
        link
        fedilink
        93 months 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
          73 months ago

          nothing about any of those libraries dictates an OO approach.

            • @[email protected]
              link
              fedilink
              13 months 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
            03 months 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
              43 months ago

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

          • @[email protected]
            link
            fedilink
            5
            edit-2
            3 months 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
              13 months 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
        73 months 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
          43 months ago

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