Sheerpower Logo
C.2  Built-in Code Profiler
SheerPower's built-in profiler generates a report showing the execution time and frequency of each routine. By identifying the routines with the longest execution times, you can focus your optimization efforts where they will have the greatest impact on performance. Sheerpower includes a built-in code profiler. It is used for:
  • Identifing Bottlenecks: Pinpoints slow or inefficient parts of the code.
  • Optimizing Performance: Helps make data-driven decisions to improve code efficiency.
  • Providing Detailed Insights: Provides comprehensive statistics on execution times and resource usage.
  • Improving Debugging: Works alongside debugging tools to provide a complete picture of code performance.
  • Producing Cost-Effective Development: Reduces time spent on trial-and-error optimizations, streamlining the development process.

To activate it, add these statements to the top of your code:
debug on stats on
Then, after you have run your code long enough or just before your program ends:
list stats
This writes profiling information to a file named myprogram_stats.txt where myprogram is the name of your program. The statistics file contains the names of every routine that is called. For each routine the amount of elapsed time spent in that routine and a count is provided. The count is the maximum number of times any statement within the routine was executed.

At the end of the file is a list of the top 20 routines that took the longest elapsed time to execute. This information lets you focus on which routines need to be optimized the most.
debug on stats on for idx = 1 to 10 more_work do_it do_it2 next idx list stats stats off debug off stop routine more_work x=x+1 delay .05 end routine routine do_it2 delay .2 x=x+1 end routine routine do_it delay .2 x=x+1 end routine stop

Below is the profile as generated:
sheerpower Profiling Statistics 07-SEP-2022 08:02:25 C:\sheerpower\stats.spsrc 0.62 10 routine more_work 2.02 10 routine do_it2 2.00 10 routine do_it ***** Longest Executing Routines ***** 2.02 10 routine do_it2 2.00 10 routine do_it 0.62 10 routine more_work ************************ --- End of stats ---

Note: You will need to download sheerpower to try the profiling feature. Also note that profiling only works when running from source code and not when running deployed (SPRUN) code.

In addition, individual blocks of code can be timed by using:
  • START TIMER
  • ... your code here ...
  • print _elapsed // elapsed time in seconds sice the last START TIMER

x = 90 start timer for i=1 to 1_000_000 y = sin(x) next i print 'Elapsed time: '; _elapsed

Hide Description

    

       


      

Enter or modify the code below, and then click on RUN

Looking for the full power of Sheerpower?
Check out the Sheerpower website. Free to download. Free to use.
Wide screen