Treating arrays as functions, although very powerful, completely neglects the linear algebra structures we are familiar with, that is, matrix-vector and matrix-matrix operations. Fortunately, these linear algebra operations may all be written in a similar unified form:
The vector-vector operation:
data:image/s3,"s3://crabby-images/ebaaf/ebaaf251ad14a3fd4d818b815f4c93231c534645" alt=""
The matrix-vector operation:
data:image/s3,"s3://crabby-images/0abbd/0abbdee4d921728f3f8d75a831a8fff6e4bf00c7" alt=""
The matrix-matrix operation:
data:image/s3,"s3://crabby-images/664da/664da7fc07643ffbe400cc4bfd2b5ab11aa0556d" alt=""
The vector-matrix operation:
data:image/s3,"s3://crabby-images/7b02f/7b02fce552b9c3f2a3d07d4482b27b683b0b0d2f" alt=""
The essential mathematical concept is that of reduction. For a matrix-vector operation, the reduction is given by:
data:image/s3,"s3://crabby-images/8c177/8c17716096ab8b8bf1e23859e056c7808d21a744" alt=""
In general, a reduction operation defined between two tensors,  and
, of respective number of dimensions
 and
 may be defined as:
data:image/s3,"s3://crabby-images/be082/be082e576a4bffcfd9d3874b5fa4c657b5508623" alt=""
Clearly, the shapes of the tensors must be compatible with that operation to make
any sense. This requirement is familiar for matrix-matrix multiplication. The multiplication Â
of matrices and
only makes sense if the number of columns ofÂ
 equals the number of...