跳转至

schmidt_decompose

QuICT.simulation.matrix_product_state.schmidt_decompose

schmidt_decompose(state_vector: ndarray, A_qubits: int)

A quantum state |psi> of a composite system A, B could be decomposed as |psi> = sum lambda_i |i_A> |i_B>, where lambda_i are non-negative real numbers, sum lambda_i^2 = 1, and |i_A>, |i_B> are orthonormal states. Such decomposition is called Schmidt decomposition, the lambda_i are called Schmidt coefficients, the number of non-zero lambda_i is called Schmidt number, and |i_A>, |i_B> are called Schmidt bases.

In this function, we restrict A and B to be the first several qubits and the last several qubits respectively.

Parameters:

  • state_vector(np.ndarray)

    the state vector of the given state

  • A_qubits(int)

    the number of the first qubits corresponding to A

Returns:

  • np.ndarray, np.ndarray, np.ndarray: lambda_i, |i_A>, |i_B> respectively

Source code in QuICT/simulation/matrix_product_state/schmidt_decompostion.py
def schmidt_decompose(state_vector: np.ndarray, A_qubits: int):
    """
    A quantum state |psi> of a composite system A, B could be decomposed as |psi> = sum lambda_i |i_A> |i_B>,
    where lambda_i are non-negative real numbers, sum lambda_i^2 = 1, and |i_A>, |i_B> are orthonormal states.
    Such decomposition is called Schmidt decomposition, the lambda_i are called Schmidt coefficients,
    the number of non-zero lambda_i is called Schmidt number, and |i_A>, |i_B> are called Schmidt bases.

    In this function, we restrict A and B to be the first several qubits and the last several qubits respectively.

    Args:
        state_vector(np.ndarray): the state vector of the given state
        A_qubits(int): the number of the first qubits corresponding to A

    Returns:
        np.ndarray, np.ndarray, np.ndarray: lambda_i, |i_A>, |i_B> respectively
    """
    state_vector = np.array(state_vector)
    num_qubits = int(np.log2(state_vector.size))
    assert state_vector.ndim == 1 and 1 << num_qubits == state_vector.size,\
        ValueError('Quantum state should be an array with length 2^n')
    assert isinstance(A_qubits, int) and 0 < A_qubits and A_qubits < num_qubits,\
        ValueError('System A should have less qubits than total')
    B_qubits = num_qubits - A_qubits

    if state_vector.shape[0] != 1 << A_qubits:
        state_vector = state_vector.reshape(1 << A_qubits, 1 << B_qubits)
    U, d, V = np.linalg.svd(state_vector, full_matrices=False)
    return d, U.T, V