A matrix is a two-dimensional, rectangular structure
of elements of the same type.
The elements can be accessed by their two-dimensional
position (row, column).
The rows and columns of the matrix might additionally be named and
consequently can be also accessed by a pair (rowname,
colname).
A matrix can be manually created from a
vector.
Depending on the arguments, elements are put to the matrix in a
different order:
m <- matrix( 1:6, nrow = 2 );
m     [,1] [,2] [,3]
[1,]    1    3    5
[2,]    2    4    6m <- matrix( 1:6, nrow = 2, byrow = TRUE );
m     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    4    5    6m <- matrix( 1:6, ncol = 2 );
m     [,1] [,2]
[1,]    1    4
[2,]    2    5
[3,]    3    6Test the class of m:
class( m )[1] "matrix" "array" Try the function str to get a compact summary of matrix
content:
str( m ) int [1:3, 1:2] 1 2 3 4 5 6There are several functions to get dimensions of a matrix.
Number of columns is provided by:
ncol( m )[1] 2Number of rows is provided by:
nrow( m )[1] 3Dimensions (two elements: number of rows and number of columns):
dim( m )[1] 3 2colnames( m ) and rownames( m ) are used to
set and get the vectors with columns and rows names.
Try to set the names:
m     [,1] [,2]
[1,]    1    4
[2,]    2    5
[3,]    3    6colnames( m ) <- c( "A", "B" )
m     A B
[1,] 1 4
[2,] 2 5
[3,] 3 6rownames( m ) <- c( "X", "Y", "Z" )
m  A B
X 1 4
Y 2 5
Z 3 6To get the names use:
rownames( m )[1] "X" "Y" "Z"colnames( m )[1] "A" "B"Use single brackets notation with two arguments
[ row(s), col(s) ] to get/set
elements.
Note, when getting only a single row or a single column the result is
returned as a vector, not matrix.
m[ 3, 1 ]             # a single element as a vector[1] 3m[ 3, ]               # a single row as a vectorA B 
3 6 m[ , 1 ]              # a single column as a vectorX Y Z 
1 2 3 m[ c( 2, 3 ), 1 ]     # two rows/one column, still a vectorY Z 
2 3 m[ c( 2, 3 ), c( "B", "A" ) ]     # a matrix  B A
Y 5 2
Z 6 3m[ c( F, T, T ), c( "B", "A" ) ]  # a matrix  B A
Y 5 2
Z 6 3Notice the difference in the output class when only a single element is requested:
class( m[ 3, 1 ] )[1] "integer"class( m[ c( 2, 3 ), c( "B", "A" ) ] )[1] "matrix" "array" With the drop argument you may enforce that always a
matrix is returned (never a vector):
m[ 3, 1 ]                 # a vector[1] 3m[ 3, 1, drop = FALSE ]   # a matrix  A
Z 3class( m[ 3, 1, drop = FALSE ] )[1] "matrix" "array" Empty row/column argument field means all rows and/or all columns:
m[ , c( "B", "A" ) ]       # all rows, selected columns  B A
X 4 1
Y 5 2
Z 6 3m[ c( "Z", "X", "Y" ), ]   # selected rows, all columns  A B
Z 3 6
X 1 4
Y 2 5m[ , ]                     # all rows and columns, same as just "m"  A B
X 1 4
Y 2 5
Z 3 6Short summary of matrix operations: http://www.statmethods.net/advstats/matrix.html
m <- matrix( 1:6, nrow = 3 );
colnames( m ) <- c( "A", "B" )
rownames( m ) <- c( "X", "Y", "Z" )
m  A B
X 1 4
Y 2 5
Z 3 6t(m)  X Y Z
A 1 2 3
B 4 5 6m  A B
X 1 4
Y 2 5
Z 3 6t( m )  X Y Z
A 1 2 3
B 4 5 6m %*% t( m )   X  Y  Z
X 17 22 27
Y 22 29 36
Z 27 36 45m  A B
X 1 4
Y 2 5
Z 3 6m+1  A B
X 2 5
Y 3 6
Z 4 7m * (m+1)   A  B
X  2 20
Y  6 30
Z 12 42m  A B
X 1 4
Y 2 5
Z 3 6rowMeans( m )  X   Y   Z 
2.5 3.5 4.5 rowSums( m )X Y Z 
5 7 9 colMeans( m )A B 
2 5 colSums( m ) A  B 
 6 15 Copyright © 2023 Biomedical Data Sciences (BDS) | LUMC