import os
import numpy as np

class PoseLibrary:
    def __init__(self, window_size=32, stride=16):
        self.entries = [] 
        self.window_size = window_size
        self.stride = stride

    def load_library(self, root_dir):
        for fname in os.listdir(root_dir):
            if fname.endswith('_embed.npy'):
                embed_path = os.path.join(root_dir, fname)
                pose_path = os.path.join(root_dir, fname.replace('_embed.npy', '_pose.npy'))
                
                embed = np.load(embed_path)  
                pose = np.load(pose_path)   

                min_len = min(len(embed), len(pose))
                embed = embed[:min_len]
                pose = pose[:min_len]
                
                for start in range(0, min_len - self.window_size + 1, self.stride):
                    end = start + self.window_size
                    self.entries.append((embed[start:end], pose[start:end]))

    def get_all_embeddings(self):
        return np.stack([np.mean(e[0], axis=0) for e in self.entries])  # (N, 512)

    def get_pose_by_index(self, idx):
        return self.entries[idx][1]  # shape (32, 6)
