Implemented base MATLAB function in R

This commit is contained in:
Waldir Leoncio 2020-01-30 15:44:13 +01:00
parent 309519dd08
commit e645d00fca
3 changed files with 72 additions and 0 deletions

30
R/size.R Normal file
View file

@ -0,0 +1,30 @@
#' @title Size of an object
#' @description This functions tries to replicate the behavior of the base function "size" in Matlab
#' @param x object to be evaluated
#' @param d dimension of object to be evaluated
#' @note On MATLAB, size(1, 100) returns 1. As a matter of fact, if the user
#' calls for a dimension which x doesn't have `size()` always returns 1. R's
#' default behavior is more reasonable in those cases (i.e., returning NA),
#' but since the point of this function is to replicate MATLAB behaviors
#' (bugs and questionable behaviors included), this function also does this.
size <- function(x, d) {
# Determining the number of dimensions
if (length(x) == 1) {
# x is surely a scalar
return(1)
} else {
# x is a vector, a matrix or an array
n_dim <- ifelse(is.null(dim(x)), 1, length(dim(x)))
if (missing(d)) {
if (n_dim == 1) {
out <- range(x)
} else {
out <- dim(x)
}
} else {
out <- ifelse(n_dim == 1, range(x)[d], dim(x)[d])
if (is.na(out)) out <- 1 # for MATLAB compatibility
}
return(out)
}
}