import numpy as np

class StepWindow:
    def __init__(self, period:int, duration:int, warmup:int=0):
        self.period, self.duration, self.warmup = period, duration, warmup
        self.idx = 0     # increments each minibatch gradient computation 
        self.active = False 
        self.switched_off = False 
        self.switched_on = False 

    def is_warming_up(self) -> bool: return self.idx < self.warmup 
    def is_active(self) -> bool: return self.active
    def has_switched_on(self) -> bool: return self.switched_on
    def has_switched_off(self) -> bool: return self.switched_off
    
    def on_update(self):
        self.idx += 1
        self.switched_off = False 
        self.switched_on = False 

        if self.idx < self.warmup: 
            new_active = False 
        else: 
            t = (self.idx - self.warmup) % self.period
            new_active = 0 <= t < self.duration

        if self.active and not new_active: 
            self.switched_off = True 

        if (not self.active) and new_active: 
            self.switched_on = True

        self.active = new_active 
