ludwig/utils/time_utils.py (61 lines of code) (raw):
#! /usr/bin/env python
# coding=utf-8
# Copyright (c) 2019 Uber Technologies, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ==============================================================================
import logging
import time
from datetime import datetime, timedelta
logger = logging.getLogger(__name__)
class WithTimer(object):
def __init__(self, title='', quiet=False):
self.title = title
self.quiet = quiet
def elapsed(self):
return time.time() - self.wall, time.clock() - self.proc
def enter(self):
"""Manually trigger enter"""
self.__enter__()
def __enter__(self):
self.proc = time.clock()
self.wall = time.time()
return self
def __exit__(self, *args):
if not self.quiet:
elapsed_wp = self.elapsed()
logger.info(
'Elapsed {}: wall {:.06f}, sys {:.06f}'.format(self.title,
elapsed_wp[0],
elapsed_wp[1]))
class Timer(object):
def __init__(self):
self.reset()
def reset(self):
self._proc = time.clock()
self._wall = time.time()
def elapsed(self):
return self.wall(), self.proc()
def elapsed_str(self):
return strdelta(self.wall() * 1000.0), strdelta(self.proc() * 1000.0)
def wall(self):
return time.time() - self._wall
def proc(self):
return time.clock() - self._proc
def tic(self):
"""Like Matlab tic/toc for wall time and processor time"""
self.reset()
def toc(self):
"""Like Matlab tic/toc for wall time"""
return self.wall()
def tocproc(self):
"""Like Matlab tic/toc, but for processor time"""
return self.proc()
def timestamp():
return '{:%Y_%m_%d_%H_%M_%S}'.format(datetime.now())
def strdelta(tdelta):
if isinstance(tdelta, (int, float)):
tdelta = timedelta(milliseconds=tdelta)
d = {'D': tdelta.days}
d['H'], rem = divmod(tdelta.seconds, 3600)
d['M'], d['S'] = divmod(rem, 60)
d['f'] = str(tdelta.microseconds)[0:4]
if d['D'] > 0:
t = '{D}d {H}h {M}m {S}.{f}s'
elif d['H'] > 0:
t = '{H}h {M}m {S}.{f}s'
elif d['M'] > 0:
t = '{M}m {S}.{f}s'
else:
t = '{S}.{f}s'
return t.format(**d)