# File src/library/graphics/R/matplot.R # Part of the R package, http://www.R-project.org # # Copyright (C) 1995-2012 The R Core Team # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # A copy of the GNU General Public License is available at # http://www.r-project.org/Licenses/ ## Author: Martin Maechler, Date: 27 Jun 97 matpoints <- function(x, y, type = "p", lty=1:5, lwd = 1, pch=NULL, col=1:6, ...) matplot(x=x, y=y, type = type, lty=lty, lwd=lwd, pch=pch, col=col, add=TRUE, ...) matlines <- function(x, y, type = "l", lty=1:5, lwd = 1, pch=NULL, col=1:6, ...) matplot(x=x, y=y, type = type, lty=lty, lwd=lwd, pch=pch, col=col, add=TRUE, ...) matplot <- function(x, y, type = "p", lty = 1:5, lwd = 1, lend = par("lend"), pch=NULL, col=1:6, cex=NULL, bg=NA, xlab=NULL, ylab=NULL, xlim=NULL, ylim=NULL, ..., add= FALSE, verbose = getOption("verbose")) { paste.ch <- function(chv) paste0('"',chv,'"', collapse=" ") str2vec <- function(string) { if(nchar(string, type="c")[1L] > 1) strsplit(string[1L], NULL)[[1L]] else string } ## These from plot.default : xlabel <- if (!missing(x)) deparse(substitute(x))# else NULL ylabel <- if (!missing(y)) deparse(substitute(y)) ## if(missing(x)) { if(missing(y)) stop("must specify at least one of 'x' and 'y'") else x <- 1L:NROW(y) } else if(missing(y)) { y <- x; ylabel <- xlabel x <- 1L:NROW(y); xlabel <- "" } kx <- ncol(x <- as.matrix(x)) ky <- ncol(y <- as.matrix(y)) n <- nrow(x) if(n != nrow(y)) stop("'x' and 'y' must have same number of rows") if(kx > 1 && ky > 1 && kx != ky) stop("'x' and 'y' must have only 1 or the same number of columns") if(kx == 1) x <- matrix(x, nrow = n, ncol = ky) if(ky == 1) y <- matrix(y, nrow = n, ncol = kx) k <- max(kx,ky)## k == kx == ky type <- str2vec(type) if(is.null(pch)) { pch <- c(1L:9L, 0L, letters, LETTERS) if(k > length(pch) && any(type %in% c("p","o","b"))) warning("default 'pch' is smaller than number of columns and hence recycled") } else if(is.character(pch)) pch <- str2vec(pch) ## else pch is numeric supposedly if(verbose) message("matplot: doing ", k, " plots with ", paste0(" col= (", paste.ch(col), ")"), paste0(" pch= (", paste.ch(pch), ")"), " ...\n", domain=NA) ii <- match("log", names(xargs <- list(...)), nomatch = 0L) log <- if (ii != 0) xargs[[ii]] xy <- xy.coords(x, y, xlabel, ylabel, log=log) xlab <- if (is.null(xlab)) xy$xlab else xlab ylab <- if (is.null(ylab)) xy$ylab else ylab xlim <- if (is.null(xlim)) range(xy$x[is.finite(xy$x)]) else xlim ylim <- if (is.null(ylim)) range(xy$y[is.finite(xy$y)]) else ylim if(length(type)< k) type<- rep(type,length.out = k) if(length(lty) < k) lty <- rep(lty, length.out = k) if(length(lend)< k) lend <- rep(lend, length.out = k) if(length(lwd) < k) lwd <- rep(lwd, length.out = k) if(length(pch) < k) pch <- rep(pch, length.out = k) if(length(col) < k) col <- rep(col, length.out = k) if(length(bg) < k) bg <- rep(bg, length.out = k) ## should not be able to call rep() on NULL if(is.null(cex)) cex <- 1 if(length(cex) < k) cex <- rep(cex, length.out = k) ii <- seq_len(k) dev.hold(); on.exit(dev.flush()) if(!add) { ii <- ii[-1L] plot(x[,1],y[,1], type=type[1L], xlab=xlab, ylab=ylab, xlim = xlim, ylim = ylim, lty=lty[1L], lwd=lwd[1L], lend=lend[1L], pch=pch[1L], col=col[1L], cex=cex[1L], bg=bg[1L], ...) } for (i in ii) { lines(x[,i], y[,i], type=type[i], lty=lty[i], lwd=lwd[i], lend=lend[i], pch=pch[i], col=col[i], cex=cex[i], bg=bg[i]) } invisible() }