Skip to main content

Block-wise timer for Python

Project description

tiner

Block-wise, thread-safety timer for loops

Install

pip install tiner

Usage

Works like a context manager

from tiner import tiner
from time import sleep

with tiner("see this block"):
  sleep(1)
# return the block running time
print(tiner.get('see this block'))

or as a python decorator

@tiner('see this function')
def f():
  #do something

Global mining and grouping

the timing is managed by tiner, not its instances:

# A.py
for _ in range(20):
  with tiner("t1"):
    #do something
...
# B.py
for _ in range(20):
  with tiner("t2"):
    #do something
...
# main.py
tiner.table()
#-------------------------
╒═════════╤═══════════╤════════╕
 Block      Time(s)    Hits 
╞═════════╪═══════════╪════════╡
 t1       0.026127       20 
├─────────┼───────────┼────────┤
 t2       0.0131467      10 
╘═════════╧═══════════╧════════╛

tiner internally records the different locations for the same block name, display the additional infomation with tiner.table(verbose=True):

for _ in range(10):
  with tiner("test:loop"):
    sleep(duration)
  
tiner.table(verbose=True)
#-------------------------
test:loop
╒═════════════════════╤════════╤═══════════╤════════╕
 File                   Line    Time(s)    Hits 
╞═════════════════════╪════════╪═══════════╪════════╡
 tests/test_tiner.py     107  0.0128279      10 
├─────────────────────┼────────┼───────────┼────────┤
 tests/test_tiner.py     112  0.0132992      10 
╘═════════════════════╧════════╧═══════════╧════════╛

Design for loops

from tiner import tiner
from time import sleep

for _ in range(10):
  #do something
  with tiner("see this loop"):
    sleep(0.1)
  #do something
  
# return the block running time over the loops
print(tiner.get('see this loop'))

Handle asynchronous programs

import os
from tiner import tiner

# tiner will call the synchronize function when the block is over
with tiner("loop", synchronize=torch.cuda.synchronize):
  # machine learning running
  
# return the block running time over the loops
print(tiner.get('loop'))

Easy to use

A timer should be clear and simple

tiner.get(BLOCK_NAME) # return a certain block running time so far
tiner.table([BLOCK1, ...]) # print some blocks' time on a formatted table
tiner.zero([BLOCK1, ...]) # empty some blocks' time
tiner.disable() # disable time logging
tiner.enable() # enable time logging

NOTE: tiner's timing is relatively precise. You should only use it for comparison of the timings of different blocks in one run, not for different runs of your program.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tiner-0.0.8.tar.gz (4.9 kB view details)

Uploaded Source

File details

Details for the file tiner-0.0.8.tar.gz.

File metadata

  • Download URL: tiner-0.0.8.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.16

File hashes

Hashes for tiner-0.0.8.tar.gz
Algorithm Hash digest
SHA256 c768bd65827eab6d8339f8a0ad626f6ae7e5b414004a21b9c0e7d62a9acf0792
MD5 4930445ca0ff63c14391e00b7f68f3cf
BLAKE2b-256 5c8eff8786f47546a705aafcc042fc74bc3c0dc9c2f61219f10ca747266e8124

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page