import numpy as np


def construct_co_occurrence(
    A: np.ndarray,
    L: int,
    S: int
) -> np.ndarray:
    """
    Construct a co-occurrence matrix using the limiting
    form defined in the paper. 

    Parameters
    ----------
    A: ndarray
        The adjacency matrix of the graph.
    L: int
        The length of the random walk.
    S: int
        The size of the context window.
    
    Returns
    -------
    C: ndarray
        The co-occurrence matrix. 
    """

    # The number of nodes in the graph
    n = A.shape[0]

    # Construct the diagonal degree matrix of A.
    D = np.diag(A.sum(axis=1))

    # Construct the transition matrix of A.
    P = np.linalg.inv(D) @ A

    # Initialize the co-occurrence matrix to all zeros.
    C = np.zeros((n,n))

    # Construct the co-occurrence matrix
    for s in range(1, S+1):
        # W = np.linalg.matrix_power(P, s)
        C = C + (L - s)*(D @ np.linalg.matrix_power(P, s))

    return 2*C/A.sum()
