In order to run RLink certain conditions should hold. We will explain how these conditions can be met and who is responsible for it.
Requirements and responsibilities
RLink requires the following to be installed on the system:
- R (version 3.0.0 or newer)
- Rcpp (version 0.12.9 or newer)
- DataLink (version 126.96.36.199 or newer)
- aimms (contained in RLink)
The R package called aimms (lower case) contains the functions SetData and GetData. In R they are in the namespace aimms because of the package name. In this way we can do
aimms::GetData in R, so the name makes sense. Still it may be confusing with AIMMS the program or AIMMS the language. To avoid confusion, throughout this manual we will use aimms (lower case) to refer to the R package and R namespace.
Rlink can be run in AIMMS development platform, in AIMMS PRO and in AIMMS Cloud.
For the AIMMS development platform, the AIMMS PRO/Cloud Client side and the AIMMS PRO Server side make sure that R and Rcpp are installed on the machine. The developer has to make sure RLink and DataLink are added to the project. The R package aimms can be installed on the machine as well. Alternatively the developer can call:
PostMainInitialization procedure of the project. In this way the aimms package that is included in RLink will be installed.
For the AIMMS Cloud Server side R and Rpcc are already provided. If RLink and DataLink are added to the project, then they will be automatically fetched from the library repository. The R package aimms is not provided on the AIMMS Cloud Server, to make sure that it is always current with the latest version of RLink. To publish an app that uses RLink, the developer must call:
PostMainInitialization procedure of the project, so that the aimms package is always being fetched from the RLink library and installed.
Besides AIMMS the following may need to be installed:
- R (Executable)
- Rcpp (R Package)
- RLink (AIMMS Library)
- DataLink (AIMMS Library)
- aimms (R Package)
R and Rcpp
R is not just a software environment for statistical computing. It is a community with a foundation that maintains the software as an open source project. Out of respect to this community it feels inappropriate to bundle the binaries of R with RLink. For this reason R has to be downloaded and installed independently of RLink.
R can be obtained from “The Comprehensive R Archive Network”:https://cran.r-project.org/. Here you can choose the binaries you need to install R on your system, or even build it from source. Also extensive documentation is available, i.e.: “R Installation and Administration”:https://cran.r-project.org/doc/manuals/r-release/R-admin.html .
Rcpp can be found “here”:https://cran.r-project.org/web/packages/Rcpp/index.html.
Rcpp can be installed just like any other R packages from the command line using:
R CMD INSTALL [options] [-l lib] Rcpp
or on windows using
Rcmd.exe INSTALL [options] [-l lib] Rcpp
Alternatively the package can be installed inside R using:
It will prompt and ask for a repository if no default repository is specified. Alternatively you can specify a repository, like:
install.packages is a normal R function and can also be called in RLink. The AIMMS Cloud Server requires the linux version of the packages and on CRAN they are only provided as source. This means that an app installing a package will always have to download and compile it, every time the app is launched, adding considerable to the startup time.
RLink and DataLink
RLink and DataLink are made available by AIMMS in the library repository. In order to include these libraries, in AIMMS go to the menu File / Library Manager….
In the library manager the panel on the left shows the library configuration of the current project. On the right there are choices to add a library. Click option Add Library from Repository… and a new window opens. On the left there is a list of Available Libraries/Versions. Clicking the name shows details about the latest version of the library. Clicking the AIMMS logo in front of it also shows previous versions.
By clicking on _RLink_ in the left panel you’ll see its dependency on DataLink with the required version. The Library Manager is smart enough to add DataLink to the list when you click the “_Select_” button at the bottom. The window closes and we are back in the window showing the library structure. The two libraries, RLink and DataLink, are now visible in the left pane, that shows the “new” library configuration of the project. By clicking “_OK_” the project is updated and the RLink and DataLink libraries are added to the project.
When publishing in our cloud, the RLink and DataLink libraries don’t have to be included in the
.aimms file of the project contains all information needed for fetching these libraries from the repository, and that will happen automatically in the cloud.
R package aimms
The aimms package is included in RLink. In this way RLink and the aimms package can be developed further, and the most recent version of aimms can be released together with newer versions of RLink.
It is possible to install aimms at a location that is in the
.libPath of R. This is the directory list used by R to find installed packages. It is possible to install aimms at a location that is in the
.libPath. In that case RLink can call R and R can find and use the aimms package.
To install the aimms package locally we first need to know where the package is. To do this open an AIMMS project for which library RLink is added. The libraries from the repository typically get installed in a writable
temp directory. Go to library RLink and look at the data of string parameter
Open R and at the prompt you can use
setwd to change the current working directory. Here we copy the string from
rlink::LIBRARY_ROOT between quotes as argument in
setwd. It will look something like this:
setwd("C:\\Users\\alice\\ ... \\vc120_x64_Release\\")
... is used because the string can be quite long. On windows we also have to “double” the backslashes otherwise R will complain.
Now the current working directory of R is the location where RLink is installed. You can check this using
getwd(). The package aimms is located in directory R, so we have to do
will show the files in the current directory. One of the files looks like
aimms_0.1.0.zip. The numbers can be different, but this is the aimms package that has to be installed. Next we have to decided where we want to install the aimms package. In R you can do
to show the default locations where R looks for packages. To pick a single location we can simply select one. i.e.
will pick the first location from
.libPaths(). Now we are ready to install the packgae. We can do:
Where we passed the arguments:
- The name of the package:
aimms_0.1.0.zip, which is the file we found in the R directory.
- The location where we want to install it:
.libPaths(), which is the first directory in the search path of R.
repos=NULL, which says that we want to load it from disk rather then a repository.
type="source" indicates that there is no C/C++ code that needs to be compiled.
For situations where the AIMMS developer does not have control over the R installation (AIMMS PRO server or the AIMMS Cloud), the following function is available:
This functions calls the R script
cniaimms.r that is located in the R directory of RLink. It will add this directory to the
.libPath and installs the aimms package here if no aimms package is found.
rlink::CheckAndInstallPackage should be called in the
MainInitialization of the project. The first time the project is run the installation may happen. In all subsequent runs of the project no installation is needed, but the R directory still should be added to the