import time
from collections import defaultdict

class TimeTracker:
    """Timer class for profiling the duration of various execution stages."""
    def __init__(self):
        self.times = defaultdict(float)
        self.starts = {}
        self.counts = defaultdict(int)
    
    def start(self, stage_name):
        """Start timing a stage."""
        self.starts[stage_name] = time.time()
    
    def end(self, stage_name):
        """End timing a stage and accumulate the time."""
        if stage_name in self.starts:
            elapsed = time.time() - self.starts[stage_name]
            self.times[stage_name] += elapsed
            self.counts[stage_name] += 1
            del self.starts[stage_name]
    
    def get_average(self, stage_name):
        """Get the average time for a stage."""
        if self.counts[stage_name] > 0:
            return self.times[stage_name] / self.counts[stage_name]
        return 0
    
    def get_total(self, stage_name):
        """Get the total time for a stage."""
        return self.times[stage_name]
    
    def reset(self):
        """Reset all timing data."""
        self.times.clear()
        self.starts.clear()
        self.counts.clear()
    
    def summary(self):
        """Output summary information."""
        if not self.times:
            return ""
        
        summary_lines = ["\n=== Time Statistics ==="]
        total_time = sum(self.times.values())
        
        for stage_name in sorted(self.times.keys()):
            stage_total = self.times[stage_name]
            percentage = (stage_total / total_time * 100) if total_time > 0 else 0
            avg_time = self.get_average(stage_name)
            summary_lines.append(
                f"{stage_name}: {stage_total:.2f}s (Avg: {avg_time:.3f}s, percentage: {percentage:.1f}%)"
            )
        
        summary_lines.append(f"Total time: {total_time:.2f}s")
        summary_lines.append("=" * 15 + "\n")
        
        return "\n".join(summary_lines)