import numpy as np
import torch

def canonicalize(pc):
    centroid = pc.mean(0)
    pc_center = pc - centroid
    scale = np.abs(pc_center).max()
    if scale == 0:
        scale = 1.0
    pc_norm = pc_center / scale
    return pc_norm, dict(center=centroid, scale=scale)

def denormalize_position(pos, transform):
    return pos * transform["scale"] + transform["center"]

def normalize_quat_tensor(q):
    norm = torch.norm(q, dim=-1, keepdim=True).clamp_min(1e-8)
    return q / norm

def quaternion_geodesic_distance(q1, q2):
    dot = torch.sum(q1 * q2, dim=-1)
    dot = torch.clamp(dot, -1 + 1e-4, 1 - 1e-4)
    angle = 2 * torch.acos(torch.abs(dot))
    return angle