import os
import scipy.io as sio
import numpy as np

def explore_penn_action_dataset(data_path):
    mat_files = [f for f in os.listdir(data_path) if f.endswith('.mat')]
    dimensions = {
        'total_files': len(mat_files),
        'frame_counts': [],
        'x_shapes': [],
        'y_shapes': [],
        'visibility_shapes': []
    }
    print("Penn Action Dataset Exploration:")
    print("=" * 50)
    for i, filename in enumerate(mat_files[:10]):
        file_path = os.path.join(data_path, filename)
        mat_data = sio.loadmat(file_path)
        print(f"\nFile {i+1}: {filename}")
        print("-" * 30)
        nframes = mat_data['nframes'][0][0]
        dimensions['frame_counts'].append(nframes)
        print(f"Number of Frames: {nframes}")
        x_coords = mat_data['x']
        dimensions['x_shapes'].append(x_coords.shape)
        print(f"x coordinates shape: {x_coords.shape}")
        y_coords = mat_data['y']
        dimensions['y_shapes'].append(y_coords.shape)
        print(f"y coordinates shape: {y_coords.shape}")
        visibility = mat_data['visibility']
        dimensions['visibility_shapes'].append(visibility.shape)
        print(f"Visibility shape: {visibility.shape}")
        action = mat_data['action'][0][0]
        print(f"Action: {action}")
        print("\nSample x coordinates (first 5 frames, first 3 joints):")
        print(x_coords[:5, :3])
        print("\nSample y coordinates (first 5 frames, first 3 joints):")
        print(y_coords[:5, :3])
    print("\nDataset Summary:")
    print(f"Total files: {dimensions['total_files']}")
    print(f"Frame count range: {min(dimensions['frame_counts'])} - {max(dimensions['frame_counts'])}")
    print(f"x coordinate shape set: {set(dimensions['x_shapes'])}")
    print(f"y coordinate shape set: {set(dimensions['y_shapes'])}")
    print(f"Visibility shape set: {set(dimensions['visibility_shapes'])}")

def main():
    data_path = "../penn"
    if not os.path.exists(data_path):
        print(f"Directory not found: {data_path}")
        return
    explore_penn_action_dataset(data_path)

if __name__ == '__main__':
    main()
