Я сейчас разбираюсь в том, как использовать мой университетский кластер. Он имеет 2 версии R. System wide R 2.11 (Debian 6.0) и R 2.14.2 в нестандартном расположении.
Я пытаюсь использовать MPI вместе со снегом. Код, который я пытаюсь запустить, следующий
library(snow)
library(Rmpi)
cl <- makeMPIcluster(mpi.universe.size()-1)
stopCluster(cl)
mpi.quit()
Он работает без проблем на R 2.11. (Я запускаю script с помощью mpirun -H localhost,n1,n2,n3,n4 -n 1 R --slave -f code.R
). Теперь, когда я пытаюсь сделать это с помощью R 2.14.2, я получаю следующее сообщение:
Error: This is R 2.11.1, package 'snow' needs >= 2.12.1
In addition: Warning message:
Итак, кажется, что R загружает версию снега пакета, скомпилированную для R 2.11. Я установил снег под R 2.14 в свою домашнюю папку, и я добавил следующие строки в свой код:
.libPaths("/soft/R/lib/R/library")
.libPaths("~/R/x86_64-pc-linux-gnu-library/2.11")
print(.libPaths())
print(sessionInfo())
print(version)
И результат перед ошибкой подтверждает, что я действительно запускаю R 2.14.2, а моя папка пакетов R сначала находится в пути поиска. Но я все еще получаю ошибку.
Итак, мой вопрос: как определить, какая версия пакета загружена в R? Я могу видеть с installed.packages
все установленные пакеты, так что, возможно, есть функция, которая перечисляет аналогичную информацию для загруженных пакетов?