Source code for py3dtiles.tilers.matrix_manipulation

from typing import TypeVar

import numpy as np
import numpy.typing as npt

_T = TypeVar("_T", bound=npt.NBitBase)


[docs] def make_rotation_matrix( z1: "npt.NDArray[np.floating[_T]]", z2: "npt.NDArray[np.floating[_T]]" ) -> "npt.NDArray[np.floating[_T]]": v0: "npt.NDArray[np.floating[_T]]" = z1 / np.linalg.norm(z1) v1: "npt.NDArray[np.floating[_T]]" = z2 / np.linalg.norm(z2) angle = np.arccos(np.clip(np.dot(v0, v1), -1.0, 1.0)) direction = np.cross(v0, v1) sina = np.sin(angle) cosa = np.cos(angle) direction[:3] /= np.sqrt(np.dot(direction[:3], direction[:3])) # rotation matrix around unit vector rotation_matrix = np.diag([cosa, cosa, cosa]) rotation_matrix += np.outer(direction, direction) * (1.0 - cosa) direction *= sina rotation_matrix += np.array( [ [0.0, -direction[2], direction[1]], [direction[2], 0.0, -direction[0]], [-direction[1], direction[0], 0.0], ] ) final_rotation_matrix = np.identity(4, dtype=z1.dtype) final_rotation_matrix[:3, :3] = rotation_matrix return final_rotation_matrix
[docs] def make_scale_matrix(factor: float) -> npt.NDArray[np.float32]: return np.diag([factor, factor, factor, 1.0])
[docs] def make_translation_matrix( direction: "npt.NDArray[np.floating[_T]]", ) -> "npt.NDArray[np.floating[_T]]": translation_matrix = np.identity(4, dtype=direction.dtype) translation_matrix[:3, 3] = direction[:3] return translation_matrix