Hacker News new | ask | show | jobs
by znpy 3123 days ago
So I see that profile-guided optimization are being used.

Profile-guided optimization, in layman terms, means that you run you code under a profiler for a while, see what parts (branches, functions, data structures etc) are being used the most and use this information to make a build of your code that considers the profiler's findings when doing optimization.

So what does it mean? It means, basically, that revsys is publishing a python build that is optimized for their use-case. Which may or may not be your use-case. This is not good nor bad.

Still, the claim "up to 19% faster" is false in general (but true in a particular case -- their use case).

Just keep this in mind, because this python build might perform worse than a regular python build.

1 comments

Actually I thought that as well when I first saw it was an option, but these are numbers comparing the official images to these images we built using the standard Python benchmarks. Not compared to say some code we wrote or run in production.

We did 10 runs of each on a large AWS instance and averaged the results.

The build info and benchmark results are up here https://github.com/revsys/optimized-python-docker if we’re wrong about something please let us know.

However, definitely agree that any optimization like this could have negative performance consequences for certain specific bits of code. But that’s likely true of any build to the next.