-
-
Notifications
You must be signed in to change notification settings - Fork 94
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Error compiling a simple model with read-only access to CmdStan #1175
Comments
This makes me wonder about thread safety: is it safe to compile model files concurrently using the same instance of CmdStan, or would there be a race condition trying to modify the same files? |
I believe the only time cmdstan would write files is the first time a compilation is performed (assuming none of the source files are changed) |
In that case, would you recommend I ask my devops colleagues to run 'make examples/bernoulli/bernoulli' as part of the installation script? |
That might help, but I'm not 100% sure. Our Makefiles definitely aren't set up with read-only setups in mind |
An update: I tried the same test on a copy of CmdStan which had already compiled a model, and it failed with the same error. |
I have been working with my devops colleagues internally to test a centralized install of CmdStan via |
My colleague (@jekriske-lilly) pointed out these lines which modify sundials: https://github.com/stan-dev/math/blob/develop/make/libraries#L66-L80 |
Depending by what you mean by centralized, this is likely a use case which would be ill supported by the current CmdStan build process. Because the build is entirely in-tree, it is difficult to make that work in a shared computing environment where e.g. different nodes would have different architectures. When using CmdStan in a cluster environment I generally keep a local checkout that I clean and re-build on the worker node Something like e.g. cmake could be one solution to this (not without its own problems and headaches), but given the current way CmdStan builds I would consider the cmdstan source to be closer to "source code for the program I am building" than "a library like MKL I can use broadly". |
On this idea, I tried to see if I could compile a Stan model with a temporary copy of CmdStan (see below). It looks like CmdStan has both dynamic/shared libraries and the source code for the program currently compiling. If it had only the former or only the latter, then compilation on shared systems would be much easier. In the former case, I could have temp <- tempfile()
fs::dir_create(temp)
cmdstanr::install_cmdstan(dir = temp)
cmdstanr::cmdstan_path()
#> [1] "/var/folders/4v/vh7xp8553lsbl49svl48g7p00000gp/T/RtmpGaahT0/file115b469395fee/cmdstan-2.32.2"
upstream <- file.path(
cmdstanr::cmdstan_path(),
"examples",
"bernoulli",
"bernoulli.stan"
)
file.copy(upstream, "model.stan")
cmdstanr::cmdstan_model("model.stan")
unlink(cmdstanr::cmdstan_path(), TRUE)
rstudioapi::restartSession()
cmdstanr::cmdstan_path()
#> [1] "/Users/CENSORED/.cmdstan/cmdstan-2.31.0"
model <- cmdstanr::cmdstan_model(exe_file = "model", compile = FALSE)
model$sample(data = list(y = c(0, 0, 1, 0, 1)))
#> Chain 1 dyld[80398]: Library not loaded: @rpath/libtbb.dylib
#> Chain 1 Referenced from: <BB67563E-5FD5-32DA-8442-CECE9216941D> /Users/CENSORED/Desktop/model
#> Chain 1 Reason: tried: '/private/var/folders/4v/vh7xp8553lsbl49svl48g7p00000gp/T/RtmpGaahT0/file115b469395fee/cmdstan-2.32.2/stan/lib/stan_math/lib/tbb/libtbb.dylib' (no such file)
#> ... |
If your shared environment has TBB installed, you can ask CmdStan to use that instead using something like this in TBB_CXX_TYPE=gcc
TBB_INTERFACE_NEW=true # if using TBB newer than 2020
TBB_INC=$(TBBROOT)/include/
TBB_LIB=$(TBBROOT)/lib/ My work's shared computing environment uses the We also do this when packaging cmdstan for Conda |
Interesting. Is TBB the only shared library I would need to handle this way? |
Yes, SUNDIALS is statically linked by default in CmdStan. You could do something similar if you wanted to also use a vendor-provided version of SUNDIALs, though (see stan-dev/math#2861) |
`rethinking` pkg uses cmdstan and cmdstan needs access to writable directories. Therefore, install it using micromamba. See for the discussion pertaining to this issue: https://discourse.mc-stan.org/t/problem-running-cmdstan-on-computing-cluster/34747/4 stan-dev/cmdstan#1175
Summary:
I cannot compile Stan models if I only have read permissions to CmdStan.
Description:
I work in a large highly-regulated company with a centrally-maintained computing environment. Users are discouraged from installing their own software because of validation requirements. Our devops team installed a copy of CmdStan 2.32.2, and I cannot compile models with it because I only have read permissions.
Reproducible Steps:
With an instance of CmdStan installed by a different user, a simple
make ~/bernoulli
fails with the output below, wherebernoulli.stan
comes from the example files in CmdStan.Current Output:
The full output is too long to include in this thread, but all the relevant output is at the beginning:
Expected Output:
I expected the model to compile successfully.
Current Version:
v2.32.2
The text was updated successfully, but these errors were encountered: