Pregunta

Es allí una manera de detectar la versión de BLAS que R está utilizando desde el interior de R?Estoy usando Ubuntu, y tengo un par de BLAS versiones instaladas - yo no sé lo que es un "activo" de R del punto de vista!

Soy consciente de http://r.789695.n4.nabble.com/is-Rs-own-BLAS-td911515.html donde Brian Ripley dijo en junio de 2006, que no fue posible -, pero han cambiado las cosas?

¿Fue útil?

Solución

Creo que no se puede.R será construido en contra de la BLAS interfaz, y R de sí mismo no se que paquete proporciona la biblioteca real.

Sólo se pueden mirar ldd de salida.En mi servidor, esto apunta a Atlas

edd@max:~$ ldd /usr/lib/R/bin/exec/R
    linux-vdso.so.1 =>  (0x00007fffc8ddb000)
    libR.so => /usr/lib/libR.so (0x00007f8be940c000)
    libpthread.so.0 => /lib/x86_64-linux-gnu/libpthread.so.0 (0x00007f8be91ef000)
    libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007f8be8e4d000)
    libblas.so.3gf => /usr/lib/atlas-base/atlas/libblas.so.3gf (0x00007f8be88e4000)
    libm.so.6 => /lib/x86_64-linux-gnu/libm.so.6 (0x00007f8be8660000)
    libreadline.so.6 => /lib/libreadline.so.6 (0x00007f8be841d000)
    libpcre.so.3 => /lib/x86_64-linux-gnu/libpcre.so.3 (0x00007f8be81e1000)
    liblzma.so.2 => /usr/lib/liblzma.so.2 (0x00007f8be7fbf000)
    libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007f8be7da6000)
    librt.so.1 => /lib/x86_64-linux-gnu/librt.so.1 (0x00007f8be7b9e000)
    libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007f8be799a000)
    libgomp.so.1 => /usr/lib/x86_64-linux-gnu/libgomp.so.1 (0x00007f8be778b000)
    /lib64/ld-linux-x86-64.so.2 (0x00007f8be99a5000)
    libgfortran.so.3 => /usr/lib/x86_64-linux-gnu/libgfortran.so.3 (0x00007f8be7475000)
    libgcc_s.so.1 => /lib/x86_64-linux-gnu/libgcc_s.so.1 (0x00007f8be725f000)
    libtinfo.so.5 => /lib/libtinfo.so.5 (0x00007f8be7037000)
    libquadmath.so.0 => /usr/lib/x86_64-linux-gnu/libquadmath.so.0 (0x00007f8be6e01000)
edd@max:~$ 

lo cual tiene sentido ya que esto BLAS-ofreciendo paquetes obtiene la más alta prioridad por los paquetes de Debian.

Otros consejos

Respuesta parcial para Linux si se instala LSOF.

# on a system using openblas:
> grep('blas', system2('lsof', c('-p', Sys.getpid()), stdout=TRUE), value = TRUE)
[1] "R       282 docker  mem    REG   0,52 29998440     233 /usr/lib/libopenblasp-r0.2.12.so"


# on a system using R internal Blas:
> grep('blas', system2('lsof', c('-p', Sys.getpid()), stdout=TRUE), value = TRUE)
[1] "R       157 docker  mem    REG   0,44   180936     3105 /usr/local/lib/R/lib/libRblas.so"

Esta solución funciona si es suficiente para que usted sepa en qué camino se puede encontrar la biblioteca BLAS.Por ejemplo, utilizo esta solución para decidir si desea cargar las bibliotecas de paquetes para la versión "Normal" R o la versión OpenBlas.

Por supuesto, no puede saber dónde almacenan otras bibliotecas, por lo que para su uso en un paquete o código compartido no es adecuado.Pero por mantenimiento propio se puede utilizar:

extSoftVersion()["BLAS"]
## [1] "/the/path/to/your/libblas.so"

en r, tipo:

sessionInfo()

que debe darte una entre otras cosas, la Blas también se usa.

Por ejemplo, en mi máquina obtengo:

Platform: x86_64-pc-linux-gnu (64-bit)
Running under: Ubuntu 18.04.3 LTS

Matrix products: default
BLAS:   /usr/lib/x86_64-linux-gnu/openblas/libblas.so.3
LAPACK: /usr/lib/x86_64-linux-gnu/libopenblasp-r0.2.20.so

locale:
 [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C               LC_TIME=en_US.UTF-8        LC_COLLATE=en_US.UTF-8     LC_MONETARY=en_US.UTF-8   
 [6] LC_MESSAGES=en_US.UTF-8    LC_PAPER=en_US.UTF-8       LC_NAME=C                  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     

loaded via a namespace (and not attached):
[1] compiler_3.6.1    Matrix_1.2-17     tools_3.6.1       Rcpp_1.0.2        grid_3.6.1        data.table_1.12.2 packrat_0.5.0     lattice_0.20-38  
[9] stm_1.3.3        

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top