-
Notifications
You must be signed in to change notification settings - Fork 2
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Optimize pyinstaller build #25
Comments
Interesting benchmark! That does look bad... Any idea what I'm doing differently with my pyinstaller build? |
Hmmm, for the Linux version this might be in part because it's using I'm now trying to test automated builds using |
Ok, this gives similar result as the local pyinstaller build: Still likely that running it from a subprocess will be much slower, but then it's ~3 seconds instead of ~30 seconds which is absolutely much better :) I'll build the full toolchain and report back soon :) |
Sweet! One thing to keep in mind, is that that will make it link against a libc that was packaged with a distro from 2023. That's a bit recent, and could lead to compatibility issues with older distros. Might be better to (somehow) install python 3.11 on a debian bullseye runner... |
yeah perhaps, or we can use ubuntu-20.04 with python3.11 instead of the current privileged container runtime |
oh yeah that'd make sense |
Hmm, oddly enough running from plugdata it takes much longer: That's nearly 15 times slower! o.O |
Damn, maybe we're reading the process output too often or something? |
At line 83 of ExportingProgressView.h, you see "Time::waitForMillisecondCounter(Time::getMillisecondCounter() + 100);" You could try to make the wait much longer, see if that improves performance? |
Alright, just updated the build server to run on Ubuntu 20.04 (oldest I could find with Python 3.11 available) with the newer python. So that should at least help a bit. |
I think by default 20.04 uses python3.10 no? But anyway it doesn't seem that this is our biggest bottleneck. I'll try patching ExportProgressView.h and see what that does .. [edit: I made the wait |
According to the ubuntu repo site, 22.04 comes with 3.10, 20.04 comes with 3.8.2. So we needed to install python from an external repo anyway, might as well do it on the oldest distro. Ah, unfortunate that that wasn't it. Is this the time in ms that heavy reports? Here on macOS it's "133.29ms" for an empty patch, is that close to what you get? |
Yeah an empty patch is |
Though if we're only getting around 100ms for an empty patch, but 19554ms for a large patch, that would suggest that this is not the overhead of starting a process. So maybe it is something about the file access? But wouldn't that be the same with regular Heavy? |
Oh wait, IIRC it unzips itself and all of its resources at startup right? That would make it take longer. But I'm not sure how that delay could be detected from inside Heavy? I think it's also an option to not make a "zipped" package with pyinstaller. Maybe that is what you are doing with your local pyinstaller builds? |
This is the "--windowed" flag, and I've just pushed a commit that disabled it. Seems to make a bit of a difference here at least, an empty patch now takes about 80ms instead of 130ms. |
My local pyinstaller build uses the same commands, but the differences I am now reporting is the same Heavy build from the toolchain, just local VS plugdata execution and that is 15x slower when executed from plugdata. These timings are indeed Heavy timing its own |
The latest build with 20.04 default python takes:
Local is about 30% slower than the bookworm/py311 build, but plugdata is ~comparable as before. This leads me to believe that the main bottleneck is still in plugdata 🤔 |
We're using a newer pyinstaller that has everything self-contained. It will take a bit longer to start (decompressing to |
Heh, we already used to do that, but I reverted it because I suspected it made stuff slower. But if you don't notice a difference, I guess either is fine |
It only slows down the startup of the program, by like a few 100 ms maybe. We are still using py311 and I'm suspecting that py312 will be faster .. so hopefully we can move to that for the next release .. |
Hmm, trying the latest toolchain on my laptop and there it gives (with this "big" patch that I've been trying with): Whereas on my workstation (that is much more powerful) I still get something like ~20s - maybe there is something strange going on with the builds on my workstation. I will try to build a completely fresh plugdata there later this week. |
I think the reason it's so slow on macOS is that I'm currently not signing and notarising the Heavy toolchain. I've seen the same thing happen with externals on pd-vanilla: if you download binaries from within a codesigned application (like how plugdata downloads the toolchain), they will work normally but take a lot longer to start up. |
I didn't know it was also slow on macOS? We have a bit of startup time with the bundled pyinstaller build of course, but the numbers I've been sharing are execution time of converting a patch measured from inside the program. |
Yeah, basically compilation is fast but it takes a while to get started. I noticed this before, but could never explain it before |
Hmm, I see. Maybe we can already show something in the console when we know the Heavy command is running. Right now we only get output once it is done. At least this will give the illusion of progress :P |
Hmm, a different complex patch (one I ran on the Field at DMF) takes |
As discussed here: plugdata-team/plugdata#1453
Execution of the pyinstaller version of hvcc is very slow. Next to the fact that executing from a JUCE subprocess also seems to give some performance penalty.
Converting a fairly complex patch (will link something shortly) gives the following compile times:
The final result was a manual pyinstaller build of latest hvcc and is much more in line with what is expected.
It seems our build in the toolchain is particularly sluggish by over a factor difference.
It would be good to investigate how to make sure that the toolchain build gets the same performance as local pyinstaller builds.
The text was updated successfully, but these errors were encountered: