import time

import torch

LAST_TIME = None
TICED = False


def tic():
    global LAST_TIME, TICED
    torch.cuda.synchronize()  # Ensure all CUDA operations are complete
    if not TICED:
        LAST_TIME = time.time()
        TICED = True
    else:
        raise RuntimeError("tic() was called twice without a corresponding toc() call.")


def toc():
    global LAST_TIME, TICED
    torch.cuda.synchronize()  # Ensure all CUDA operations are complete
    if TICED:
        elapsed = time.time() - LAST_TIME
        TICED = False
        LAST_TIME = None
        return elapsed
    else:
        raise RuntimeError("toc() was called without a corresponding tic() call.")