[R] Merging matrices of different rows
Rui Barradas
ru|pb@rr@d@@ @end|ng |rom @@po@pt
Thu Jun 26 13:11:17 CEST 2025
Às 11:46 de 26/06/2025, Steven Yen escreveu:
> I'd like to cbind matrices of different number of rows, with missing values filled by "NA". I used dplyr. The following is obviously not working. Help appreciated.
>
>> library(dplyr)
>> a<-matrix(1:12,nrow=6); a
> [,1] [,2]
> [1,] 1 7
> [2,] 2 8
> [3,] 3 9
> [4,] 4 10
> [5,] 5 11
> [6,] 6 12
>> b<-matrix(5:12,nrow=4); b
> [,1] [,2]
> [1,] 5 9
> [2,] 6 10
> [3,] 7 11
> [4,] 8 12
>> cbind.fill(a,b)
> Error in cbind.fill(a, b) : could not find function "cbind.fill"
>
> Steven from iPhone
> [[alternative HTML version deleted]]
>
> ______________________________________________
> R-help using r-project.org mailing list -- To UNSUBSCRIBE and more, see
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide https://www.R-project.org/posting-guide.html
> and provide commented, minimal, self-contained, reproducible code.
Hello,
The error message says that though you have dplyr loaded, R cannot find
cbind.ill. This means that that function is not a dplyr function.
A google search found rowr::cbind.fill but package rowr is not available
for R 4.5.0. Abandonware?
Program your own cbind.fill.
cbind.fill <- function(...) {
dots <- list(...)
i <- sapply(dots, \(x) inherits(x, "matrix"))
dots <- dots[i]
mx <- max(sapply(dots, nrow))
out_list <- lapply(dots, \(x) {
if(nrow(x) < mx)
x <- rbind(x, matrix(nrow = mx - nrow(x), ncol = ncol(x)))
x
})
do.call(cbind, out_list)
}
a<-matrix(1:12,nrow=6)
b<-matrix(5:12,nrow=4)
cbind.fill(a, b)
#> [,1] [,2] [,3] [,4]
#> [1,] 1 7 5 9
#> [2,] 2 8 6 10
#> [3,] 3 9 7 11
#> [4,] 4 10 8 12
#> [5,] 5 11 NA NA
#> [6,] 6 12 NA NA
cbind.fill(b, a, b)
#> [,1] [,2] [,3] [,4] [,5] [,6]
#> [1,] 5 9 1 7 5 9
#> [2,] 6 10 2 8 6 10
#> [3,] 7 11 3 9 7 11
#> [4,] 8 12 4 10 8 12
#> [5,] NA NA 5 11 NA NA
#> [6,] NA NA 6 12 NA NA
cbind.fill(b, a, b, a[1:5, ])
#> [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8]
#> [1,] 5 9 1 7 5 9 1 7
#> [2,] 6 10 2 8 6 10 2 8
#> [3,] 7 11 3 9 7 11 3 9
#> [4,] 8 12 4 10 8 12 4 10
#> [5,] NA NA 5 11 NA NA 5 11
#> [6,] NA NA 6 12 NA NA NA NA
(Then I found [1], with a version of cbind.fill equivalent to mine.)
[1] https://stackoverflow.com/a/7962286/8245406
Hope this helps,
Rui Barradas
--
Este e-mail foi analisado pelo software antivírus AVG para verificar a presença de vírus.
www.avg.com
More information about the R-help
mailing list