import torch

from qtorch.config import QTORCH_CONFIG
from qtorch.quantumstate.densitymatrix import _validateDensityMatrix

def DepolarizingChannel(rho:torch.Tensor, num_qubits:int, prob:float,**kwargs
                        )->torch.Tensor:
    '''
    Apply the depolarizing channel to the quantum state
    
    Arguments
    ---------
    rho: torch.Tensor
        The density matrix to apply the channel to
    num_qubits: int
        The number of qubits in the system
    prob: float
        The probability of the depolarizing channel
    
    Keyword Arguments (for validation)
    ----------------------------------
    atol: float
        absolute tolerance to be passed to torch.isclose(),
        defaults to 1e-8
    rtol: float
        relative tolerance to be passed to torch.isclose(),
        defaults to 1e-5

    Returns
    -------
    torch.Tensor:
        The resulting dentsity matrix
    '''
    if not QTORCH_CONFIG['skipValidation']:
        _validateDensityMatrix(num_qubits, rho, **kwargs)
        if prob < 0.0 or prob > 1.0:
            raise ValueError(f'Invalid probability: {prob} supplied for '
                             'depolarizing channel.')
    
    d = 2**num_qubits
    I = torch.eye(d,dtype=rho.dtype,device=rho.device)
    return prob*I/d + (1.0-prob)*rho
