import os
import json
import pickle
import numpy as np
import pandas as pd
from tqdm import tqdm
import sys
sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), '..')))

from utils import hexbin_plot, compute_alphashape


data_root = '/path/to/pandaset/'
output_root = '/your/out/dir/maps'
step = 5

os.makedirs(output_root, exist_ok=True)
os.makedirs(output_root.replace('maps', 'bounds'), exist_ok=True)
os.makedirs(output_root.replace('maps', 'maps_with_bounds'), exist_ok=True)

for sequence_id in tqdm(os.listdir(data_root)):
    # Load lidar files
    lidar_files = sorted(os.listdir(os.path.join(data_root, sequence_id, 'lidar')))[::step]
    with open(os.path.join(data_root, sequence_id, 'lidar/poses.json'), 'rb') as f:
        poses = json.load(f)[::step]

    selected_data = []
    for file, pose in zip(lidar_files, poses):
        if not file.endswith('.pkl'):
            continue
        with open(os.path.join(data_root, sequence_id, f'lidar/{file}'), 'rb') as f:
            pcl = pickle.load(f)
        selected_data.append(pcl)
        
    _ = list(map(lambda xy: xy[1].insert(3,'f', xy[0]), enumerate(selected_data)))  # Add column 'f' to each data frame in order

    selected_data = pd.concat(selected_data)  # Concatenate in order
    selected_data['f'] = (selected_data['f'] - selected_data['f'].min()) + 0.1*(selected_data['f'].max() - selected_data['f'].min())  # Add 10% of color range as base color (otherwise frame0 has white points)
    selected_data['f'] /= selected_data['f'].max()

    pointclouds = np.vstack((np.array(selected_data['x']), np.array(selected_data['y']), np.array(selected_data['z'])))
    
    concave_hull = compute_alphashape(pointclouds, save_path=os.path.join(output_root.replace('maps', 'bounds'), f'{sequence_id}.pkl'))
    hexbin_plot(pointclouds, save_path_png=os.path.join(output_root.replace('maps', 'maps_with_bounds'), f'{sequence_id}.png'), shape=concave_hull)
