import torch
from torch import Tensor
from torch import Size, Tensor

def randomized_rp(
    A: Tensor,
    rank: int,
    niter: int,
    test_matrix: str = "subs",
) -> tuple[Tensor, Tensor]:
    m,n = A.shape
    gen = torch.Generator(device=A.device)
    P = torch.randn((n, rank), generator=gen, device=A.device, dtype=A.dtype) * (1.0 / rank) ** 0.5
    Q = A @ P
    R = P.T
    Q = Q.to(A.dtype)
    R = R.to(A.dtype)
    return Q , R

def rp_reconstruct(
    Q: Tensor,
    R: Tensor,
) -> Tensor:

    assert isinstance(Q, Tensor)
    assert isinstance(R, Tensor)

    return Q @ R
