I am trying to plot two regression summaries side-by-side with one centered title. Each regression summary is generated by plot.rqs()
and amounts to a set of 9
First we generate an example object, fm
. Then we copy plot.rqs
and use trace
on the copy to insert par <- list
at top effectively nullifying any use of par
within the function. Then we do the same with plot.summary.rqs
. Finally we test it out with our own par
:
library(quantreg)
example(plot.rqs) # fm to use in example
# plot.rqs
plot.rqs <- quantreg::plot.rqs
trace("plot.rqs", quote(par <- list), print = FALSE)
# plot.summary.rqs
plot.summary.rqs <- quantreg::plot.summary.rqs
trace("plot.summary.rqs", quote(par <- list), print = FALSE)
# test it out
op <- par(mfrow = c(2, 2))
plot(summary(fm))
plot(fm)
title("My Plots", outer = TRUE, line = -1)
par(op)
EDIT: added plot.summary.rqs
.
You can patch a function as follows:
use dput
and capture.output
to retrieve
the code of the function, as a string;
change it as you want (here, I just replace each occurrence of par
with a function that does nothing);
finally evaluate the result to produce a new function.
library(quantreg)
a <- capture.output(dput(plot.summary.rqs))
b <- gsub("^\\s*par\\(", "nop(", a)
nop <- function(...) {}
my.plot.summary.rqs <- eval(parse(text=b))