[Rd] [External] memory consumption of nested (un)serialize of sys.frames()
Andreas Kersting
r-deve| @end|ng |rom @ker@t|ng@de
Thu Apr 8 10:45:07 CEST 2021
Hi,
For (hopefully) full reproducibility:
docker run rocker/tidyverse:4.0.5 Rscript -e 'devtools::install_github("akersting/dumpTest", INSTALL_opts = "--with-keep.source"); library(dumpTest); for (i in 1:100) {print(i); print(system.time(f()))}'
Regards,
Andreas
2021-04-07 17:09 GMT+02:00 "Andreas Kersting" <r-devel using akersting.de>:
> Hi Dirk, hi Luke,
>
> Thanks for checking!
>
> I could narrow it down further. I have the issue only if I install --with-keep.source, i.e.
>
> R CMD INSTALL --with-keep.source dumpTest
>
> Since this is the default in RStudio when clicking "Install and Restart", I was always having the issue - also from base R. If I install using e.g. devtools::install_github() directly it is also fine for me.
>
> Could you please confirm? Thanks!
>
> Regards,
> Andreas
>
> 2021-04-07 16:20 GMT+02:00 "Dirk Eddelbuettel" <edd using debian.org>:
>>
>> On 7 April 2021 at 16:06, Andreas Kersting wrote:
>> | Hi Luke,
>> |
>> | Please see https://github.com/akersting/dumpTest for the package.
>> |
>> | Here a session showing my issue:
>> |
>> | > library(dumpTest)
>> | > sessionInfo()
>> | R version 4.0.5 (2021-03-31)
>> | Platform: x86_64-pc-linux-gnu (64-bit)
>> | Running under: Debian GNU/Linux 10 (buster)
>> |
>> | Matrix products: default
>> | BLAS: /usr/lib/x86_64-linux-gnu/blas/libblas.so.3.8.0
>> | LAPACK: /usr/lib/x86_64-linux-gnu/lapack/liblapack.so.3.8.0
>> |
>> | locale:
>> | [1] LC_CTYPE=en_US.UTF-8 LC_NUMERIC=C
>> | [3] LC_TIME=en_US.UTF-8 LC_COLLATE=en_US.UTF-8
>> | [5] LC_MONETARY=en_US.UTF-8 LC_MESSAGES=en_US.UTF-8
>> | [7] LC_PAPER=en_US.UTF-8 LC_NAME=C
>> | [9] LC_ADDRESS=C LC_TELEPHONE=C
>> | [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C
>> |
>> | attached base packages:
>> | [1] stats graphics grDevices utils datasets methods base
>> |
>> | other attached packages:
>> | [1] dumpTest_0.1.0
>> |
>> | loaded via a namespace (and not attached):
>> | [1] compiler_4.0.5
>> | > for (i in 1:100) {
>> | + print(i)
>> | + print(system.time(f()))
>> | + }
>> | [1] 1
>> | user system elapsed
>> | 0.028 0.004 0.034
>> | [1] 2
>> | user system elapsed
>> | 0.067 0.008 0.075
>> | [1] 3
>> | user system elapsed
>> | 0.176 0.000 0.176
>> | [1] 4
>> | user system elapsed
>> | 0.335 0.012 0.349
>> | [1] 5
>> | user system elapsed
>> | 0.745 0.023 0.770
>> | [1] 6
>> | user system elapsed
>> | 1.495 0.060 1.572
>> | [1] 7
>> | user system elapsed
>> | 2.902 0.136 3.040
>> | [1] 8
>> | user system elapsed
>> | 5.753 0.272 6.034
>> | [1] 9
>> | user system elapsed
>> | 11.807 0.708 12.597
>> | [1] 10
>> | ^C
>> | Timing stopped at: 6.638 0.549 7.214
>> |
>> | I had to interrupt in iteration 10 because I was running low on RAM.
>>
>> No issue here. Ubuntu 20.10, R 4.0.5 'from CRAN' i.e. Michael's PPA build
>> off my Debian package, hence instrumentation as in the Debian package.
>>
>> edd using rob:~$ installGithub.r akersting/dumpTest
>> Using github PAT from envvar GITHUB_PAT
>> Downloading GitHub repo akersting/dumpTest using HEAD
>> ✔ checking for file ‘/tmp/remotes3f9af733166ccd/akersting-dumpTest-3bed8e2/DESCRIPTION’ ...
>> ─ preparing ‘dumpTest’:
>> ✔ checking DESCRIPTION meta-information ...
>> ─ checking for LF line-endings in source and make files and shell scripts
>> ─ checking for empty or unneeded directories
>> ─ building ‘dumpTest_0.1.0.tar.gz’
>>
>> Installing package into ‘/usr/local/lib/R/site-library’
>> (as ‘lib’ is unspecified)
>> * installing *source* package ‘dumpTest’ ...
>> ** using staged installation
>> ** R
>> ** byte-compile and prepare package for lazy loading
>> ** help
>> No man pages found in package ‘dumpTest’
>> *** installing help indices
>> ** building package indices
>> ** testing if installed package can be loaded from temporary location
>> ** testing if installed package can be loaded from final location
>> ** testing if installed package keeps a record of temporary installation path
>> * DONE (dumpTest)
>> edd using rob:~$ Rscript -e 'system.time({for (i in 1:100) dumpTest::f()})'
>> user system elapsed
>> 0.481 0.019 0.500
>> edd using rob:~$
>>
>> (I also ran the variant you showed with the dual print statements, it just
>> consumes more screen real estate and ends on
>>
>> [...]
>> [1] 97
>> user system elapsed
>> 0.004 0.000 0.005
>> [1] 98
>> user system elapsed
>> 0.004 0.000 0.005
>> [1] 99
>> user system elapsed
>> 0.004 0.000 0.004
>> [1] 100
>> user system elapsed
>> 0.005 0.000 0.005
>> edd using rob:~$ )
>>
>> Dirk
>>
>> --
>> https://dirk.eddelbuettel.com | @eddelbuettel | edd using debian.org
>>
> ______________________________________________
> R-devel using r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-devel
>
More information about the R-devel
mailing list