<%@include file="includes/setup.md.rsp"%>

<%@string colname="colCummins"%>
<%@string rowname="rowCummins"%>
<%@string fcnname="colRowCummins_subset"%>
<%@meta title="${colname}() and ${rowname}() benchmarks on subsetted computation"%>
<%@meta author="Dongcan Jiang"%>
<%@meta date="2015-06-06"%>

<%@include file="${header}"%>


# <%@meta name="title"%>

This report benchmark the performance of <%=colname%>() and <%=rowname%>() on subsetted computation.


<% for (mode in c("integer", "double")) { %>

## Data type "<%=mode%>"

### Data
```r
<%=withCapture({
<%@include file="R/random-matrices.R"%>
data <- rmatrices(mode = mode)
})%>
```

### Results

<% for (dataLabel in names(data)) { %>
<% mprintf("%s: %s\n", mode, dataLabel)  %>
#### <%=dataLabel%> <%=mode%> matrix

```r
<%=withCapture({
X <- data[[.dataLabel.]]
rows <- sample.int(nrow(X), size = nrow(X)*0.7)
cols <- sample.int(ncol(X), size = ncol(X)*0.7)
X_S <- X[rows, cols]
gc()

colStats <- microbenchmark(
 "colCummins_X_S"           = colCummins(X_S),
 "colCummins(X, rows, cols)"  = colCummins(X, rows = rows, cols = cols),
 "colCummins(X[rows, cols])" = colCummins(X[rows, cols]),
 unit = "ms"
)

X <- t(X)
X_S <- t(X_S)
gc()

rowStats <- microbenchmark(
 "rowCummins_X_S"           = rowCummins(X_S),
 "rowCummins(X, cols, rows)"  = rowCummins(X, rows = cols, cols = rows),
 "rowCummins(X[cols, rows])" = rowCummins(X[cols, rows]),
 unit = "ms"
)
})%>
```

<% crBenchmarkResults(colStats, rowStats, tags=c(mode, dataLabel)) %>

<% } # for (dataLabel ...) %>

<% } # for (mode ...) %>


<%@include file="${footer}"%>


<%---------------------------------------------------------------------------
HISTORY:
2015-06-06
o Created.
---------------------------------------------------------------------------%>