Although it's good to comply with the regular heuristic rules like pass by reference, using pre-increment instead of post-increment etc, it's a very bad practice to fully rely on them when optimizing C++ programs. It's always recommended to measure and profile your program using a tool or timer.
We can use a profiler software to profile our program. The output of the profiler will contain the time taken by each function, and also the memory they consume. There are two kinds of profiler.
Due to varying external factors like process scheduling and system load which affects how many times memory and cache is swapped, we get different results each time we measure the performance. Contrast the system which is heavily loaded (where you are running a test) and in the background you have web browsers with multiple tabs open, and a music player running, and you are compiling another big project VS the system where you are only running the test with nothing else running on the system. Given that both the systems have the same specs, the test in the former scenario will definitely take more time. Hence to get proper results, we should keep the conditions consistent when running and measuring performance tests . Also to remove the randomness caused due to these external factors, we should also measure our program multiple times.
Hence when optimizing, a developer, like a good scientist should,
But care should be taken to not make the program overly complicated or unreadable, while optimizing. Long term maintainability of the code-base is a very important criteria to keep in mind.
Having documentation can also aid developers in convincing managers and other stake holders to incorporate their changes.
We could also time our functions by using the calls to high_resolution_clock::now. Make this call at the beginning of the function and another time at the end of the function, and then take the time difference between the two in-order to find how long the function will take to run. However the reading will never be accurate due to -
Hence it's important to take measure of the function's performance as many times as required and take the average. We can also record the minimum and maximum, each time we measure our optimization effort.
I highly recommend checking out Optimized C++ by Kurt Guntheroth. He discusses much more in details about the history and evolution of computer clocks, how accuracy is different from resolution, profilers among other things
We can use a profiler software to profile our program. The output of the profiler will contain the time taken by each function, and also the memory they consume. There are two kinds of profiler.
- Compile the program with the profiler, by using special flags. By doing this, the compiler adds hidden statements in the executable, one before the function and one after the function.
- We attach the profiler to the program externally.
Due to varying external factors like process scheduling and system load which affects how many times memory and cache is swapped, we get different results each time we measure the performance. Contrast the system which is heavily loaded (where you are running a test) and in the background you have web browsers with multiple tabs open, and a music player running, and you are compiling another big project VS the system where you are only running the test with nothing else running on the system. Given that both the systems have the same specs, the test in the former scenario will definitely take more time. Hence to get proper results, we should keep the conditions consistent when running and measuring performance tests . Also to remove the randomness caused due to these external factors, we should also measure our program multiple times.
Hence when optimizing, a developer, like a good scientist should,
- Make hypothesis about why the program is running slow, and suggest improvements.
- Incorporate the code improvements, and document it.
- Take measurements (a number of times), and document these results along with it's corresponding code changes.
- Continue steps 1-3, till satisfied with results.
But care should be taken to not make the program overly complicated or unreadable, while optimizing. Long term maintainability of the code-base is a very important criteria to keep in mind.
Having documentation can also aid developers in convincing managers and other stake holders to incorporate their changes.
We could also time our functions by using the calls to high_resolution_clock::now. Make this call at the beginning of the function and another time at the end of the function, and then take the time difference between the two in-order to find how long the function will take to run. However the reading will never be accurate due to -
- Computers clocks are not built capture time accurately.
- The variability introduced by outside factors.
- Inherent latency and communication delays among the different components of the computer.
Hence it's important to take measure of the function's performance as many times as required and take the average. We can also record the minimum and maximum, each time we measure our optimization effort.
I highly recommend checking out Optimized C++ by Kurt Guntheroth. He discusses much more in details about the history and evolution of computer clocks, how accuracy is different from resolution, profilers among other things
C++ optimization - Measure and profile
Reviewed by zeroingTheDot
on
June 06, 2018
Rating:
No comments: