######## Profiler ######## The **Profiler** pane recursively determines the run time and number of calls for every function and method called in a file, breaking down each procedure into its smallest individual units. This allows you to easily identify the bottlenecks in your code, points you toward the exact statements most critical for optimization, and measures the performance delta after followup changes. .. image:: /images/profiler/profiler-standard.png :alt: Spyder Profiler pane, displaying a list of functions and their execution time ==================== Running the Profiler ==================== You can browse for a file using the open button to the right of the Profiler's path box (top left of the pane), which will run profiling over this file automatically. .. image:: /images/profiler/profiler-execution-browse.gif :alt: Spyder Profiler pane, showing browsing a file and running profiler You can manually enter the path in the pane's path box and then run the analysis on the file by pressing :guilabel:`Profile` in the Profiler pane. You can also run profiling for the file that is currently open in the :doc:`editor` by clicking :menuselection:`&Run --> Profile` in the menu bar, or by using a configurable shortcut (:kbd:`F10` by default). .. image:: /images/profiler/profiler-execution-menu.gif :alt: Spyder Profiler pane, showing running profiler from menu bar If you'd like to cancel an in-progress run, click the :guilabel:`Stop` button in the top right, and if profiling fails for any reason, the :guilabel:`Output` dialog will be displayed, indicating the error that occurred. By double-clicking an item in the Profiler, you will be taken to the file and line in the :doc:`editor` where it was called. .. image:: /images/profiler/profiler-open-file.gif :alt: Spyder Profiler pane, showing opening a file when clicking on its analysis You can increase the number of levels displayed for a particular object by clicking the dropdown arrows to the left of the name, and expand/collapse all the items with the buttons in the top left. .. image:: /images/profiler/profiler-dropdown.gif :alt: Spyder Profiler pane, showing dropdown arrows and buttons for expanding and collapsing By clicking the dropdown or press the :kbd:`Down Arrow` key in the filename field, you can recall paths of previous profiled files. .. image:: /images/profiler/profiler-previous-paths.png :alt: Spyder Profiler pane, showing dropdown of previous profiled files Finally, you can save the data for a given run to disk as a file with the ``.Result`` extension using the :guilabel:`Save data` button. This can be loaded to compare with a previous run of the same file using the :guilabel:`Load data` button. To remove the loaded data, click the :guilabel:`Clear comparison` button. .. image:: /images/profiler/profiler-save-load.gif :alt: Spyder Profiler pane, showing running profiler from menu bar ======================== Interpreting the results ======================== Results are broken down by function/method/statement, with each sub-element listed hierarchically under the top-level item that called them. :guilabel:`Total Time` is that taken by the specified item and every function "underneath" (*i.e.* called by) it, while :guilabel:`Local Time` only counts the time spent in the particular callable object's own scope. The :guilabel:`Calls` column displays the total number of times the specified object was called at that level inside its parent calling function (or within the ``__main__`` scope, if a top-level object). Finally, the numbers in the :guilabel:`Diff` columns for each of the three appear if a comparison is loaded, and indicate the deltas between each measurement. .. image:: /images/profiler/profiler-comparison.png :alt: Profiler with a comparison loaded, displaying the time deltas between two runs For example, suppose you ran the :guilabel:`Profiler` on a file calling a function ``sleep_wrapper()`` that in turn called the ``sleep()`` function, and the ``sleep_wrapper()`` function took a total of 3.87 ms to run, with 3.86 ms of that spent executing the ``sleep()`` function inside it. Therefore, if ``sleep()`` called nothing else itself, its :guilabel:`Total Time` and :guilabel:`Local Time` would both be identical, at 3.87 ms. Meanwhile, :guilabel:`Total Time` for ``sleep_wrapper()`` would be 3.86 ms, but :guilabel:`Local Time` only 0.01 ms as the rest was spent inside the ``sleep()`` function it called. ================ Profiler plugins ================ There are two additional plugins that you can install to enable other types of profiling in Spyder. First, Spyder Line Profiler allows you to benchmark each line of your code individually. To learn more, visit the `spyder-line-profiler git repository`_. .. _spyder-line-profiler git repository: https://github.com/spyder-ide/spyder-line-profiler .. image:: /images/profiler/profiler-line-profiler.png :alt: Spyder Profiler pane, displaying a list of functions and their execution time Second, Spyder Memory Profiler measures the memory usage of your code. For more information, go to the `spyder-memory-profiler git repository`_. .. _spyder-memory-profiler git repository: https://github.com/spyder-ide/spyder-memory-profiler .. image:: /images/profiler/profiler-memory-profiler.png :alt: Spyder Profiler pane, displaying a list of functions and their execution time ============= Related panes ============= * :doc:`ipythonconsole` * :doc:`pylint`