Using Julia packages on Bianca¶
Julia
- At UPPMAX there is a central library with installed packages.
- This is good, especially when working on Bianca, since you then do not need to install via the wharf.
- It is often better to install you own, see below, or ask the support to install centrally.
Installation principle:
- install on Transit
- sync to wharf
- move the files on Bianca
- Typical place to put julia packages: ~/.julia/packages
- Otherwise you may have to update export JULIA_LOAD_PATH="path1:path2:..."
UPPMAX Central library¶
Info
The Julia application at UPPMAX comes with several preinstalled packages. A selection of the Julia packages and libraries installed on UPPMAX are:
- BenchmarkTools
- CSV
- CUDA
- MPI (needs gcc and openmpi loaded)
- Distributed
- IJulia (needs python loaded)
- Plots
- PyPlot (needs python loaded)
- Gadfly
- DataFrames
- DistributedArrays
- PlotlyJS
- In Julia you can check if the packages are there by: using <package-name>- The first time Julia will precompile the package for you!
 
- You may control the present "central library" by typing ml help julia/<version>in the BASH shell.- There you will also find which python, gcc and openmpi version that are compatible.
- Or see the Julia user guide at UPPMAX
 
- A possibly more up-to-date status can be found from the Julia shell:
    using Pkg
    Pkg.activate(DEPOT_PATH[2]*"/environments/v1.8");     #change version (1.8) accordingly if you have another main version of Julia
    Pkg.status()
    Pkg.activate(DEPOT_PATH[1]*"/environments/v1.8");     #to return to user library
First time run on Bianca¶
You may have to build some package the first time with Pkg.build(“<package>”). Since <package> is pre-installed centrally on UPPMAX you must activate the central environment by following these steps below. This should only be needed the first time like this
Install yourself¶
If you have started Julia once you will get the folders like this in the ~/.julia folder.
   $ tree .julia/ -d -L 1
   .
   ├── artifacts
   ├── bin
   ├── compiled
   ├── conda
   ├── environments
   ├── logs
   ├── packages
   ├── prefs
   ├── registries
   └── scratchspaces
The plan is that what you install on Transit should be moved here in the same manner
- Make an installation of the package on Transit in the Julia package manager
- 
Use a transfer method to move the package files to the wharf- To be certain to include all files, you may transfer the whole .juliadir. However, that can grow rather big with time.
 
- To be certain to include all files, you may transfer the whole 
- 
Prepare tar file of all packages if needed: 
Transfer to the wharf
If you have not uploaded anything to your wharf, this will be empty. It might have a few things in it.
- Alt1: If you would like all your locally installed packages:
- 
That may take a while since you are sending thousands of files. Consider archiving the .julia directory (a copy) and then transfer it with the putcommand.
- 
Alt 2: Just transfer the latest installed julia package(s) The following part still needs some update 
- 
Check what was installed. It may have been several dependency packages as well. Look at the times! 
sftp> put -r .julia/packages/<package name 1>
# and if several packages
sftp> put -r .julia/packages/<package name 2>
# and so on...
Move to site-packages folder On Bianca
If many files or packages
you may want to tar before copying to include all possible symbolic links:
and in target directory (wharf_mnt) on Bianca:
Move environments
- 
Identify the environment files 
- 
Copy the files: 
- 
On the new machine 
More info
- Julia course: isolated environments