I'm assuming that by "turning the graph into a matrix" you're referring to the adjacency matrix associated with a given directed graph, which encodes a connection between two vertices
data:image/s3,"s3://crabby-images/c2775/c27758de491048ab086304b94c462e923060eae8" alt="v_i"
and
data:image/s3,"s3://crabby-images/92daf/92daf40e1f09ba6219933ec0624a9c09a11722d2" alt="v_j"
by the number
data:image/s3,"s3://crabby-images/8e7de/8e7def84fe1be0947c1c9274d5ab42740be92c24" alt="a_(ij)=1"
if there's an edge beginning at
data:image/s3,"s3://crabby-images/c2775/c27758de491048ab086304b94c462e923060eae8" alt="v_i"
and terminating at
data:image/s3,"s3://crabby-images/92daf/92daf40e1f09ba6219933ec0624a9c09a11722d2" alt="v_j"
and 0 otherwise. Here
data:image/s3,"s3://crabby-images/dcc4e/dcc4eb31fc1880143723ec84a93dcde2c379a14b" alt="a_(ij)"
is the entry of the adjacency matrix
data:image/s3,"s3://crabby-images/08f3a/08f3a83910ab8a9ea456475ad4c1be9056556083" alt="\mathbf A"
in the
data:image/s3,"s3://crabby-images/b1bfd/b1bfd8c6a7a07739ce70d12adc39d810b5e2ceca" alt="i"
th row and
data:image/s3,"s3://crabby-images/7cb48/7cb48f8bb892e04820637abd5f5bbaed6596e77d" alt="j"
th column.
data:image/s3,"s3://crabby-images/7f785/7f7853dd4c7608f58219940ef688212e77bb4733" alt="a_(ij)=\begin{cases}1&\text{if }v_i\to v_j\\0&\text{otherwise}\end{cases}"
Let's consider a simple example of a graph
data:image/s3,"s3://crabby-images/0c0cd/0c0cd50845b5d2f19f9be7f89d1f0ec69c81428b" alt="G(V,E)"
on three vertices
data:image/s3,"s3://crabby-images/11a73/11a733277d4bc13050d4c44464882bbdca19278a" alt="V=\{v_1,v_2,v_3\}"
, where the edge set is
data:image/s3,"s3://crabby-images/92841/92841f23d82ca6e3c9b3c2bd71daedc3e48d875c" alt="E=\{v_1v_2,v_1v_3,v_3v_1\}"
. (image below)
The corresponding adjacency matrix is
data:image/s3,"s3://crabby-images/8fc18/8fc18afef23273c6581d677006822124acd9afaf" alt="\mathbf A=\begin{bmatrix}0&1&1\\0&0&0\\1&1&0\end{bmatrix}"
and squaring this gives the matrix
data:image/s3,"s3://crabby-images/fada4/fada44329fb6861529e8fd8ebe4c61467bee62e4" alt="\mathbf B=\mathbf A^2=\begin{bmatrix}1&1&0\\0&0&0\\0&1&1\end{bmatrix}"
Let's think about what the entry
data:image/s3,"s3://crabby-images/4d625/4d625726640a86465f0fcebbecdd7b92ae6b5ce4" alt="b_(11)"
is saying. We obtained it by computing the vector product,
data:image/s3,"s3://crabby-images/d8e15/d8e1572bd38fd790d127d409d728c6c09c597fe6" alt="b_(11)=a_(1j)\cdot a_(i1)=\begin{bmatrix}0&1&1\end{bmatrix}\begin{bmatrix}0\\0\\1\end{bmatrix}=0\cdot0+1\cdot0+1\cdot1=1"
We can interpret each term as counting the number of two-step paths we can take starting from
data:image/s3,"s3://crabby-images/e5c6d/e5c6d220eb1d74945d330bebf9abc84332d5a6b1" alt="v_1"
and ending up back on
data:image/s3,"s3://crabby-images/e5c6d/e5c6d220eb1d74945d330bebf9abc84332d5a6b1" alt="v_1"
. We'll require that staying in place is not an option, that a path from one vertex to itself must involve leaving the first vertex.
The first term is then 0, since there is no path from
data:image/s3,"s3://crabby-images/e5c6d/e5c6d220eb1d74945d330bebf9abc84332d5a6b1" alt="v_1"
to itself:
data:image/s3,"s3://crabby-images/16d9a/16d9a4e748181581dc5d194118bb81c924b4087a" alt="a_(1,1)\cdot a_(1,1)=0"
The second term is also 0, since we can take a step from
data:image/s3,"s3://crabby-images/e5c6d/e5c6d220eb1d74945d330bebf9abc84332d5a6b1" alt="v_1"
over to
data:image/s3,"s3://crabby-images/465ea/465ea1195b35a7a1f4680c87670d5fa318d745a2" alt="v_2"
, but we can't go back:
data:image/s3,"s3://crabby-images/d56b8/d56b835b9c0f7347a759dbd7fd860d77b1c6d66a" alt="a_(1,2)\cdot a_(2,1)=0"
The third term is 1, because we can take a step from
data:image/s3,"s3://crabby-images/e5c6d/e5c6d220eb1d74945d330bebf9abc84332d5a6b1" alt="v_1"
to
data:image/s3,"s3://crabby-images/03022/03022ccf06abcbd258e5c8f757b248bfe1ff3e6e" alt="v_3"
, and we can then undo that step by going backwards from
data:image/s3,"s3://crabby-images/03022/03022ccf06abcbd258e5c8f757b248bfe1ff3e6e" alt="v_3"
to
data:image/s3,"s3://crabby-images/e5c6d/e5c6d220eb1d74945d330bebf9abc84332d5a6b1" alt="v_1"
:
data:image/s3,"s3://crabby-images/05a0b/05a0b28430d4fb1a4fde686ed61e112d524bf51a" alt="a_(1,3)\cdot a_(3,1)=1"
And so on. We can make the claim that
data:image/s3,"s3://crabby-images/fc46d/fc46d123268a1afc655584749b9e3de079b1d3f9" alt="b_(ij)"
(the
data:image/s3,"s3://crabby-images/70dd9/70dd9b315ae06485059186bccceaa6db1ac8f6ca" alt="(i,j)"
th element of
data:image/s3,"s3://crabby-images/986bc/986bc7827c70a61b2fd349b43193b257a6294710" alt="\mathbf A^2"
) will give you the number of 2-edge paths from
data:image/s3,"s3://crabby-images/c2775/c27758de491048ab086304b94c462e923060eae8" alt="v_i"
to
data:image/s3,"s3://crabby-images/92daf/92daf40e1f09ba6219933ec0624a9c09a11722d2" alt="v_j"
.
And more generally,
data:image/s3,"s3://crabby-images/d20f3/d20f3438a6afabddbfcf512d3700ce045fa0993d" alt="\mathbf A^n"
will give the number of paths consisting of
data:image/s3,"s3://crabby-images/64b3a/64b3a02d283d0e714080badcc2f9f894aed83bef" alt="n"
steps.