Metadata-Version: 2.1
Name: pyrofiler
Version: 0.1.7
Summary: Toolset for granular and live profiling
Home-page: https://github.com/DaniloZZZ/pyrofiler
Author: Dan Lykov
Author-email: lkv97dn@gmail.com
License: MIT license
Keywords: pyrofiler
Platform: UNKNOWN
Classifier: Development Status :: 2 - Pre-Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Requires-Python: >=3.5
License-File: LICENSE

=========
Pyrofiler
=========


.. image:: https://img.shields.io/pypi/v/pyrofiler.svg
        :target: https://pypi.python.org/pypi/pyrofiler

.. image:: https://img.shields.io/travis/DaniloZZZ/pyrofiler.svg
        :target: https://travis-ci.com/DaniloZZZ/pyrofiler

.. image:: https://readthedocs.org/projects/pyrofiler/badge/?version=latest
        :target: https://pyrofiler.readthedocs.io/en/latest/?badge=latest
        :alt: Documentation Status



Toolset for granular memory and cpu live profiling


Quick start
-----------

Contextmanager that measures time of execution

.. code-block:: python

    # examples/simple_profile.py
    import pyrofiler
    import time

    with pyrofiler.timing('Time elapsed'):
        time.sleep(1)

.. code-block:: console

    $ python simple_profile.py
    Time elapsed : 1.001563310623169


Decorators for profiling functions

.. code-block:: python

    # examples/simple_profile_cpu.py
    import pyrofiler

    @pyrofiler.cpu_util(description='Cpu usage')
    @pyrofiler.timed('Time elapsed')
    def sum_series(x, N):
        return sum([x**i/i for i in range(1, N)])

    sum_series(.3, 1000_000)

.. code-block:: console

    $ python simple_profile_cpu.py
    Time elapsed : 0.13478374481201172
    Cpu usage : 29.4

Aggregate the results in common context:

.. code-block:: python

    # examples/profile_with_context.py
    from pyrofiler import Profiler
    import time

    prof = Profiler()

    with prof.timing('Time 1'):
        time.sleep(1)

    with prof.timing('Time 2'):
        time.sleep(1.5)

    print('Profiling data recorded:')
    print(prof.data)

.. code-block:: console

    $ python profile_with_context.py                                                    
    Time 1 : 1.0011215209960938
    Time 2 : 1.5020403861999512
    Profiling data recorded:
    {'Time 1': 1.0011215209960938, 'Time 2': 1.5020403861999512}

You can use other actions, for example appending results to some list in data.
Check the `documentation <https://pyrofiler.readthedocs.io/en/latest/usage.html>`_ for more use cases


Design
------

There are following types of objects in pyrofiler:

#. `Measures`, which are run as a context manager

#. `Decorators`, that are based on `measures`

#. `Profiler` class that uses `decorators` to aggregate data


Callbacks
=========

The `decorators` have an optional argument ``callback``,
to which you can pass a function that will handle the data.
The function will be passed profiling results as a first argument,
as well as any other arguments that you provided to original `decorator`.

Here, a custom ``spice`` argument is provided

.. code-block:: python

    def print_spicy_time(time, spice):
        print(f'Spice {spice} took {time} seconds')

    @pyrofiler.timed(spice='spicy', callback=print_spicy_time)
    def spicy_sleep():
        time.sleep(10)

Similar products
----------------

- Syrpy https://github.com/jeetsukumaran/Syrupy 
- Scalene https://github.com/emeryberger/scalene
- ... and lots of `others <https://github.com/matuskosut/python-perfres/>`_

Problems
--------
Either you have a cli tool that profiles memory and cpu, but **no code api for granular data** 

or you have stuff like decorators and **no memory profiling**

Having a live dashboard would help also, use https://github.com/libvis for that


Features
--------

* TODO

Credits
-------

This package was created with Cookiecutter_ and the `audreyr/cookiecutter-pypackage`_ project template.

.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`audreyr/cookiecutter-pypackage`: https://github.com/audreyr/cookiecutter-pypackage


=======
History
=======

0.1.0 (2020-03-04)
------------------

* First release on PyPI.


