[Rd] methods() not listing some S3 plot methods...?
Gavin Simpson
gavin.simpson at ucl.ac.uk
Sat Aug 27 00:17:03 CEST 2011
On Fri, 2011-08-26 at 07:06 -0700, Martin Morgan wrote:
> On 08/26/2011 04:44 AM, Gavin Simpson wrote:
> > Dear List,
> >
> > This may be related to this email thread initiated by Ben Bolker last
> > month: https://stat.ethz.ch/pipermail/r-devel/2011-July/061630.html
> >
> > In answering this Question on StackOverflow
> > http://stackoverflow.com/q/7195628/429846 I noticed that `methods()` was
> > not listing some S3 methods for `plot()` provided by the mgcv package.
>
> Hi Gavin --
>
> In the mgcv NAMESPACE, the methods is not registered with S3method
> (which would have made it appear with a *) and is not export'ed; the
> author of the package apparently intends that it be strictly internal to
> the package. Dispatch works within the package name space, but not
> outside, e.g., a=list; class(a) = "mgcv.smooth"; plot(a) ends up at
> plot.default.
Thanks for the explanation Martin. This strikes me as being somewhat
suboptimal and not conducive to studying and understanding code. Now
that I am aware of the distinction I won't be surprised when methods
don't show up.
Cheers
G
> > At the time I wanted to check the development version of R as I recalled
> > Uwe mentioning that `plot.function` was listed by `methods()` there but
> > not in R2.13.x. I have now compiled the development version on two
>
> It looks like the cog that has changed between release and devel is the
> addition of export(plot.function) and S3method(plot, "function") to the
> NAMESPACE of graphics.
>
> Martin
>
> > Fedora installations and certain plot methods are still not being
> > listed. Details of the exact revision of R Devel are shown at the end of
> > this email.
> >
> > As an example, consider:
> >
> >> require(mgcv)
> > Loading required package: mgcv
> > This is mgcv 1.7-6. For overview type 'help("mgcv-package")'.
> >> methods("plot")
> > [1] plot.acf* plot.ACF* plot.augPred*
> > [4] plot.compareFits* plot.data.frame* plot.decomposed.ts*
> > [7] plot.default plot.dendrogram* plot.density
> > [10] plot.ecdf plot.factor* plot.formula*
> > [13] plot.function plot.gam plot.gls*
> > [16] plot.hclust* plot.histogram* plot.HoltWinters*
> > [19] plot.intervals.lmList* plot.isoreg* plot.lm
> > [22] plot.lme* plot.lmList* plot.medpolish*
> > [25] plot.mlm plot.nffGroupedData* plot.nfnGroupedData*
> > [28] plot.nls* plot.nmGroupedData* plot.pdMat*
> > [31] plot.ppr* plot.prcomp* plot.princomp*
> > [34] plot.profile.nls* plot.ranef.lme* plot.ranef.lmList*
> > [37] plot.shingle* plot.simulate.lme* plot.spec
> > [40] plot.stepfun plot.stl* plot.table*
> > [43] plot.trellis* plot.ts plot.tskernel*
> > [46] plot.TukeyHSD plot.Variogram*
> >
> > Non-visible functions are asterisked
> >
> >> pmeth<- methods("plot")
> >> grep("plot.mgcv.smooth", pmeth)
> > integer(0)
> >> getS3method("plot", "mgcv.smooth")
> > Error in getS3method("plot", "mgcv.smooth") :
> > S3 method 'plot.mgcv.smooth' not found
> >> pfun<- getAnywhere("plot.mgcv.smooth")
> >> str(pfun)
> > List of 5
> > $ name : chr "plot.mgcv.smooth"
> > $ objs :List of 1
> > ..$ :function (x, P = NULL, data = NULL, label = "", se1.mult = 1,
> > se2.mult = 2, partial.resids = FALSE, rug = TRUE, se = TRUE,
> > scale = -1, n = 100, n2 = 40, pers = FALSE, theta = 30, phi = 30,
> > jit = FALSE, xlab = NULL, ylab = NULL, main = NULL, ylim = NULL,
> > xlim = NULL, too.far = 0.1, shade = FALSE, shade.col = "gray80",
> > shift = 0, trans = I, by.resids = FALSE, scheme = NULL, ...)
> > $ where : chr "namespace:mgcv"
> > $ visible: logi FALSE
> > $ dups : logi FALSE
> > - attr(*, "class")= chr "getAnywhere"
> >
> > Both `methods()` and `getS3method()` don't list/find this method, but
> > the function exists in the mgcv name space and this method will be used
> > via R's S3 dispatch system in `plot.gam()`.
> >
> > Shouldn't this method be returned by either `methods()` or
> > `getS3method()`?
> >
> > TIA,
> >
> > Gavin
> >
> >> sessionInfo()
> > R Under development (unstable) (2011-08-26 r56801)
> > Platform: x86_64-unknown-linux-gnu (64-bit)
> >
> > locale:
> > [1] LC_CTYPE=en_GB.UTF-8 LC_NUMERIC=C
> > [3] LC_TIME=en_GB.UTF-8 LC_COLLATE=en_GB.UTF-8
> > [5] LC_MONETARY=en_GB.UTF-8 LC_MESSAGES=en_GB.UTF-8
> > [7] LC_PAPER=C LC_NAME=C
> > [9] LC_ADDRESS=C LC_TELEPHONE=C
> > [11] LC_MEASUREMENT=en_GB.UTF-8 LC_IDENTIFICATION=C
> >
> > attached base packages:
> > [1] stats graphics grDevices utils datasets methods
> > base
> >
> > other attached packages:
> > [1] mgcv_1.7-6
> >
> > loaded via a namespace (and not attached):
> > [1] grid_2.14.0 lattice_0.19-33 Matrix_0.9996875-3
> > nlme_3.1-102
> > [5] tools_2.14.0
>
>
--
%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%
Dr. Gavin Simpson [t] +44 (0)20 7679 0522
ECRC, UCL Geography, [f] +44 (0)20 7679 0565
Pearson Building, [e] gavin.simpsonATNOSPAMucl.ac.uk
Gower Street, London [w] http://www.ucl.ac.uk/~ucfagls/
UK. WC1E 6BT. [w] http://www.freshwaters.org.uk
%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%~%
More information about the R-devel
mailing list