10404
Comment:
|
13413
organize titles/headings
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
## page was renamed from EMAN2/COMPILE_EMAN2_ANACONDA/2.9 ## page was renamed from EMAN2/COMPILE_EMAN2_ANACONDA |
|
Line 2: | Line 4: |
{{{#!html <h1 style="margin-bottom:5px;"> Building EMAN2/SPARX/SPHIRE from Source </h1> <p style="font-size:110%; text-align:center; margin-top:5px; margin-left:20px; margin-right:20px;"> <i> Standard instructions for establishing a build and runtime environment for EMAN/SPARX/SPHIRE on Linux and macOS </i> </p> }}} * While the instructions look long, in reality it should only take 10-15 minutes to complete the entire process (with a decent network connection). * We use [[https://docs.conda.io/en/latest/|Conda]] for a working environment and most of the dependencies. [[https://www.anaconda.com/distribution/|Anaconda distribution]] has become ubiquitous for Python and R-based scientific computing and education over the last decade. While it may be possible to build the system without using Conda, we do not recommend doing this, and cannot provide support for a non-conda approach. If you follow the instructions below, you should have a painless source build very quickly. * We make use of the [[https://docs.conda.io/projects/conda/en/latest/user-guide/tasks/manage-environments.html|environment]] system in [[https://docs.conda.io/en/latest/|conda]], the package manager, to isolate EMAN2 dependencies from other conda packages you may have installed. If you need to install other packages you wish to use in concert with EMAN2, you will need to install them within the EMAN2 environment. Be warned that sometimes installing another package may trigger a version change in one of EMAN2's dependencies, which may or may not be a problem, depending on which dependency it is. We strongly suggest getting the base EMAN2 installed and working first, before trying to install any additional packages within the same conda environment. * Note that even with a source build it may be difficult to get this working on systems with very old operating system installs. We normally try to support OS versions as much as 5-7 years old. Please report any problems. * '''GPU Support (Linux Only!):''' For features which support the GPU, please complete the standard source install instructions below, then follow the [[EMAN2/Install/BinaryInstallAnaconda/2.31#Using_the_GPU|GPU instructions]] from the binary installation page. |
|
Line 4: | Line 30: |
{{{#!wiki note The older instructions are here, [[EMAN2/COMPILE_EMAN2_ANACONDA-PRE-CONDA-ENVIRONMENTS|pre-conda-environments instructons]]. }}} = Anaconda based Build, All Platforms (except Windows) = EMAN2 source lives on [[https://github.com/cryoem/eman2|GitHub]], downloading the source is part of the instructions below. Do not check it out yet. EMAN2 has a number of dependencies, the most important of which is Python, and some of these dependencies require specific versions. Rather than struggling with system library incompatibilities and other issues, EMAN2 has adopted Anaconda as its install environment. This (FOSS) system provides a cross-platform compatible environment in which specific library versions can be installed without interfering with anything else on the system, and can support multiple such environments within one Anaconda installation. While it ''may'' still be possible to compile EMAN2 without Anaoconda, this is an unsupported approach, and you should anticipate a fair amount of effort. If you follow the instructions below, you should have a painless source build (Linux/Mac only) very quickly. Note that even with a source build it may be difficult to get this working on systems with very old operating system installs. We normally try to support OS versions as much as 5-7 years old. Please report any problems. === GPU Support === For features which support the GPU, please complete the standard source install instructions below, then follow the [[EMAN2/Install/BinaryInstallAnaconda/2.31#Using_the_GPU|GPU instructions]] from the binary installation page. == Installing EMAN2/SPHIRE/SPARX from source == Anaconda comes in two flavors ''Anaconda'' which is a full featured system with many libraries and capabilities built in, and ''Miniconda'' which is a stripped down version of the system. Both systems are the same, it is just a question of which packages come preinstalled. These instructions are based on the smaller Miniconda install. You may also have success with Anaconda, but a better approach may be to install Miniconda, then add in any extra packages you actually need. We make use of the [[https://docs.conda.io/projects/conda/en/latest/user-guide/tasks/manage-environments.html|environment]] system in Anaconda to isolate EMAN2 dependencies from other Anaconda packages you may have installed. If you need to install other packages you wish to use in concert with EMAN2, you will need to install them within the EMAN2 environment. Be warned that sometimes installing another package may trigger a version change in one of EMAN2's dependencies, which may or may not be a problem, depending on which dependency it is. We strongly suggest getting the base EMAN2 installed and working first, before trying to install any additional packages within the same Anaconda environment. === Initial Setup === 1. If you do not have Anaconda/Miniconda (or another copy of EMAN2/SPARX/SPHIRE) already installed in your account, skip to the next step. If you DO have Anaconda or Miniconda installed in your account, these instructions will be installing a new complete copy of Miniconda, so you must insure that any existing install you have is not active in your shell (not in PATH, no LD_LIBRARY_PATH or PYTHONPATH set). While it may also be possible to set up an environment for EMAN2 in your existing install, you would need to adapt these instructions to your own situation yourself to do that. |
== Initial Setup and Build (one time) == 1. '''Remove/disable other Anaconda/Miniconda/EMAN installations.''' If you do not have Anaconda/Miniconda (or another copy of EMAN2/SPARX/SPHIRE) already installed in your account, skip to step [[#install_miniconda|2]]. If you DO have Anaconda or Miniconda installed in your account, you must ensure that any existing install you have is not active in your shell (not in PATH, no LD_LIBRARY_PATH, PYTHONPATH or PYTHONHOME set). While it may also be possible to set up an environment for EMAN2 in your existing Anaconda install, you will need to know what you're doing, and adapt these instructions to your situation. |
Line 39: | Line 43: |
1. Download and install this specific version of '''Miniconda''': [[https://repo.continuum.io/miniconda/Miniconda3-4.6.14-Linux-x86_64.sh|Linux]] or [[https://repo.continuum.io/miniconda/Miniconda3-4.6.14-MacOSX-x86_64.sh|MacOSX]] | <<Anchor(install_miniconda)>> 1. '''Download and install''' '''''this specific version (4.8.3) of''''' '''Miniconda''': [[https://repo.anaconda.com/miniconda/Miniconda3-py37_4.8.3-Linux-x86_64.sh|Linux]] or [[https://repo.anaconda.com/miniconda/Miniconda3-py37_4.8.3-MacOSX-x86_64.sh|macOS]] |
Line 49: | Line 54: |
1. Initialize conda for shell interaction. These instructions will depend on what shell you use. The default on most systems is ''bash''. If you use a different shell ( ''tsch'', ''zsh'', ... ), you will need to take this into account: | 1. '''Initialize conda for shell interaction.''' These instructions will depend on what shell you use. The default on most systems is ''bash''. If you use a different shell ( ''tsch'', ''zsh'', ... ), you will need to take this into account: |
Line 60: | Line 65: |
# we suggest the following, meaning you will need to use ''conda activate'' after logging in before using EMAN2 |
}}} As it says after you run this command, you will need to close and reopen your shell/terminal for it to take effect. This command modified your shell initialization so the ''conda activate'' command can be used properly. For more information on conda-init and activation, see [[https://docs.conda.io/projects/conda/en/latest/user-guide/tasks/manage-environments.html#activating-an-environment|Environment Activation]]. {{{#!wiki caution '''macOS''' Users (bash only) On macOS, this modifies ''~/.bash_profile''. If you have a ''~/.profile'' startup file, creation of ''~/.bash_profile'' will prevent ''~/.profile'' from being read. A simple solution is to ''source .profile'' within ''.bash_profile''. For differences between login- and non-login shells and order of reading the startup files on macOS, see, [[https://www.anintegratedworld.com/basics-of-osx-bashrc-v-profile-v-bash_profile/]]. }}} 1. '''Configure and update conda.''' {{{#!highlight bash # We suggest the following, meaning you will need to use ''conda activate'' after logging in before using EMAN2 |
Line 63: | Line 81: |
}}} As it says after you run this command, you will need to close and reopen your shell/terminal for it to take effect. This command modified your shell initialization so the ''conda activate'' command can be used properly. For more information on conda-init and activation, see [[https://docs.conda.io/projects/conda/en/latest/user-guide/tasks/manage-environments.html#activating-an-environment|Environment Activation]]. {{{#!wiki caution '''MacOS''' Users (bash only) On MacOS, this modifies ''~/.bash_profile''. If you have a ''~/.profile'' startup file, creation of ''~/.bash_profile'' will prevent ''~/.profile'' from being read. A simple solution is to ''source .profile'' within ''.bash_profile''. For differences between login- and non-login shells and order of reading the startup files on Mac OSX, see, [[https://www.anintegratedworld.com/basics-of-osx-bashrc-v-profile-v-bash_profile/]]. }}} 1. Configure conda. {{{#!highlight bash # Automatic Anaconda/Miniconda updates may cause things to break, so we suggest making all package upgrades explicitly # The current version verified to work with EMAN is '''conda 4.6.14''' |
# Automatic conda updates may cause things to break, so we suggest making all package upgrades explicitly # The current version verified to work with EMAN is '''conda 4.9.1''' |
Line 81: | Line 85: |
}}} 1. Create a new environment with EMAN2 dependencies. ''eman2'' below is the name of the environment. You may make this whatever you like, as long as you remember to use the same name when doing ''conda activate''. Note that this name will appear as part of your prompt when activated, so you may want to keep it short. {{{#!highlight bash conda create -n eman2 eman-deps=15.1 cmake=3.14 -c cryoem -c defaults -c conda-forge }}} If you wish to see the [[https://github.com/cryoem/eman-deps-feedstock/blob/v15.1/recipe/meta.yaml#L9-L53|list of conda dependencies]] that '''eman-deps''' is built from, look [[https://github.com/cryoem/eman-deps-feedstock/blob/v15.1/recipe/meta.yaml#L9-L53|here]]. |
# Flexible channel priority works better for eman-deps conda config --set channel_priority flexible # Update base environment to get the latest conda conda update --all -n base }}} 1. '''Create a new environment''' with EMAN2 dependencies. ''eman2'' below is the name of the environment. You may make this whatever you like, as long as you remember to use the same name when doing ''conda activate''. Note that this name will appear as part of your prompt when activated, so you may want to keep it short. {{{#!highlight bash conda create -n eman2 eman-deps-dev -c cryoem -c defaults -c conda-forge }}} If you wish to see the list of conda dependencies that '''eman-deps''' (current version is '''24.1''') is built from, look [[https://github.com/cryoem/eman-deps-feedstock/blob/master/recipe/meta.yaml|here]]. {{{{#!wiki caution '''macOS Big Sur Users''' The new Big Sur macOS release (fall 2020) broke some things in Python, which are only now (Dec 2020) getting fixed. These fixes have not yet made their way into Anaconda. If you experience an error similar to "Unable to load OpenGL library", install a patched pyopengl package from cryoem channel (as of 1/13/2021). {{{#!shell conda install pyopengl -c cryoem }}} '''OR''' This quick fix seems to provide a temporary solution until Anaconda gets the necessary updates: You need to go into your miniconda3 or anaconda3 folder and find this file (the path may be slightly different on your install, but you should be able to find it): ''~/anaconda3/envs/eman2/lib/python3.7/site-packages/OpenGL/platform/ctypesloader.py'' Around line 80 you should find a line like: '' fullName = util.find_library( name )'' change this line to: '' fullName = '/System/Library/Frameworks/' + name + '.framework/' + name '' (important to use 8 spaces before fullName, not a <tab>) }}}} 1. Ensure you have '''OpenGL''': EMAN2 uses OpenGL (via !PyQt) for all of its graphics. OpenGL installation depends on OS variant and, for example, whether you are using proprietary NVidia drivers under Linux. You will need to have OpenGL set up on your machine as a whole before continuing. On Mac, you should already have this with XCode. On Linux with an NVidia driver you will likely also need to install the Mesa header files. If you aren't sure how to set up OpenGL, Google can probably help. |
Line 108: | Line 151: |
git checkout <branch> git pull --rebase }}} |
git fetch --all --prune git checkout master }}} |
Line 113: | Line 155: |
{{{#!highlight bash | 1. '''CMake''' {{{#!highlight bash |
Line 115: | Line 158: |
cmake <source-directory> # - eg $HOME/src/eman2. On linux, also add -DENABLE_OPTIMIZE_MACHINE=ON }}} * If you use '''cmake-gui''', since conda is not in PATH anymore, cmake will fail to find the environment directory. In that case set CONDA_PREFIX to your conda environment directory manually. * Make sure to delete any cmake variables that cmake already found, variables like *_LIBRARY or similar, *_INCLUDE_PATH or similar, CONDA_EXECUTABLE, CMAKE_INSTALL_PREFIX and any variables that are expected to contain conda environment related values. * Configure and generate in cmake. {{{#!highlight bash make -j |
# on Mac: cmake <source-directory> # - eg $HOME/src/eman2, optionally add -DCMAKE_VERBOSE_MAKEFILE # on Linux: cmake <source-directory> -DENABLE_OPTIMIZE_MACHINE=ON # - eg $HOME/src/eman2, optionally add -DCMAKE_VERBOSE_MAKEFILE }}} * '''cmake-gui''' * If you use '''cmake-gui''', since conda is not in PATH anymore, cmake will fail to find the environment directory. In that case set CONDA_PREFIX to your conda environment directory manually. * Make sure to delete any cmake variables that cmake already found, variables like *_LIBRARY or similar, *_INCLUDE_PATH or similar, CONDA_EXECUTABLE, CMAKE_INSTALL_PREFIX and any variables that are expected to contain conda environment related values. * Configure and generate. * '''ccmake''' * If you use '''ccmake''', you may get an error related to OpenGL. If this happens try quitting ccmake and running it again. 1. '''Make''' {{{#!highlight bash make -j 8 |
Line 126: | Line 177: |
1. You may also wish to run {{{#!highlight bash make test # if everything passes you are fine, if there are failures, you are welcome to ask |
Note that the '''make -j 8''' above will compile using 8 threads. On some machines omitting the 8 will compile faster and cause no problems, and if you have more than 8 threads on your machine, you can increase the number. 1. '''Test your installation.''' We do NOT recommend this for end-users. A failure does NOT necessarily indicate an installation problem. These commands are mostly provided for developers actively changing the code to detect harmful changes before committing them. Sometimes the system will have a failing test, and still be absolutely fine. {{{#!highlight bash make test # if everything passes you are fine, if there are failures, please ask. A failure does not necessarily mean a bad build, it may be a problem with the test. |
Line 133: | Line 186: |
== EMAN Daily Development == | {{{#!wiki note For debugging and reporting, see [[#debug_and_report|Debugging and Reporting]]. }}} == EMAN Daily Development (updating code, etc) == |
Line 141: | Line 201: |
1. Periodically you should update your source using standard git techniques. If you are not modifying EMAN, just compiling from source, you just need to periodically: | 1. '''Update'''. Periodically you should update your source using standard git techniques. If you are not modifying EMAN, just compiling from source, you just need to periodically: |
Line 155: | Line 215: |
1. To switch to another conda environment (stop working with EMAN2), first deactivate your current environment. | 1. '''Other Environments'''. To switch to another conda environment (stop working with EMAN2), first deactivate your current environment. |
Line 161: | Line 221: |
{{{#!wiki note For debugging and reporting, see [[#debug_and_report|Debugging and Reporting]]. }}} <<Anchor(debug_and_report)>> == Debugging and Reporting == Please, provide the output of the following commands when reporting a problem. Record the session via '''script''' command. This, also, records the commands. 1. {{{#!highlight bash script filename.txt conda activate eman2 conda info -a conda list conda list --explicit cd <source-dir> git status git log -1 cd <build-dir> rm CMakeCache.txt cmake <source-dir> cmake . -LA make clean make -j make install make test-verbose conda deactivate exit # or Ctrl+D }}} 1. Send '''filename.txt'''. |
|
Line 163: | Line 267: |
The approach above will install EMAN with a precompiled version of OpenMPI, which may or may not work with the batch queuing system on your cluster. If it does not work, the symptom will be that MPI parallel jobs will use only a single node, no matter how many you have allocated in your job. If this happens please see the linux cluster installations on the [[EMAN2/Install/BinaryInstallAnaconda/2.31#Linux_Clusters|binary install page]]. Those instructions should also work with either of the source-based installations below. | The approach above will install EMAN with a precompiled version of OpenMPI, which may or may not work with the batch queuing system on your cluster. If it does not work, the symptom will be that MPI parallel jobs will use only a single node, no matter how many you have allocated in your job. Currently, we do not have alternative OpenMPI installation instructions. |
Building EMAN2/SPARX/SPHIRE from Source
Standard instructions for establishing a build and runtime environment for EMAN/SPARX/SPHIRE on Linux and macOS
- While the instructions look long, in reality it should only take 10-15 minutes to complete the entire process (with a decent network connection).
We use Conda for a working environment and most of the dependencies. Anaconda distribution has become ubiquitous for Python and R-based scientific computing and education over the last decade. While it may be possible to build the system without using Conda, we do not recommend doing this, and cannot provide support for a non-conda approach. If you follow the instructions below, you should have a painless source build very quickly.
We make use of the environment system in conda, the package manager, to isolate EMAN2 dependencies from other conda packages you may have installed. If you need to install other packages you wish to use in concert with EMAN2, you will need to install them within the EMAN2 environment. Be warned that sometimes installing another package may trigger a version change in one of EMAN2's dependencies, which may or may not be a problem, depending on which dependency it is. We strongly suggest getting the base EMAN2 installed and working first, before trying to install any additional packages within the same conda environment.
- Note that even with a source build it may be difficult to get this working on systems with very old operating system installs. We normally try to support OS versions as much as 5-7 years old. Please report any problems.
GPU Support (Linux Only!): For features which support the GPU, please complete the standard source install instructions below, then follow the GPU instructions from the binary installation page.
Contents
Initial Setup and Build (one time)
Remove/disable other Anaconda/Miniconda/EMAN installations. If you do not have Anaconda/Miniconda (or another copy of EMAN2/SPARX/SPHIRE) already installed in your account, skip to step 2. If you DO have Anaconda or Miniconda installed in your account, you must ensure that any existing install you have is not active in your shell (not in PATH, no LD_LIBRARY_PATH, PYTHONPATH or PYTHONHOME set). While it may also be possible to set up an environment for EMAN2 in your existing Anaconda install, you will need to know what you're doing, and adapt these instructions to your situation.
1 echo $PATH 2 # make sure no Anaconda/Miniconda/EMAN2 entries 3 echo $LD_LIBRARY_PATH 4 echo $PYTHONPATH 5 # ideally, both return nothing. If it set to something it is possible that it may interfere with Anaconda 6 # strongly suggest at least during the install, ''unset'' both of these. After installation you can test 7 # to see if they cause any issues 8
Download and install this specific version (4.8.3) of Miniconda: Linux or macOS
and follow the prompts. When you see Do you wish the installer to initialize Miniconda3 by running conda init?, say no, then move on to the next step.
Initialize conda for shell interaction. These instructions will depend on what shell you use. The default on most systems is bash. If you use a different shell ( tsch, zsh, ... ), you will need to take this into account:
As it says after you run this command, you will need to close and reopen your shell/terminal for it to take effect. This command modified your shell initialization so the conda activate command can be used properly. For more information on conda-init and activation, see Environment Activation.
macOS Users (bash only)
On macOS, this modifies ~/.bash_profile. If you have a ~/.profile startup file, creation of ~/.bash_profile will prevent ~/.profile from being read. A simple solution is to source .profile within .bash_profile.
For differences between login- and non-login shells and order of reading the startup files on macOS, see, https://www.anintegratedworld.com/basics-of-osx-bashrc-v-profile-v-bash_profile/.
Configure and update conda.
1 # We suggest the following, meaning you will need to use ''conda activate'' after logging in before using EMAN2 2 conda config --set auto_activate_base False 3 4 # Automatic conda updates may cause things to break, so we suggest making all package upgrades explicitly 5 # The current version verified to work with EMAN is '''conda 4.9.1''' 6 conda config --set auto_update_conda False 7 8 # Flexible channel priority works better for eman-deps 9 conda config --set channel_priority flexible 10 11 # Update base environment to get the latest conda 12 conda update --all -n base
Create a new environment with EMAN2 dependencies. eman2 below is the name of the environment. You may make this whatever you like, as long as you remember to use the same name when doing conda activate. Note that this name will appear as part of your prompt when activated, so you may want to keep it short.
1 conda create -n eman2 eman-deps-dev -c cryoem -c defaults -c conda-forge
If you wish to see the list of conda dependencies that eman-deps (current version is 24.1) is built from, look here.
macOS Big Sur Users
The new Big Sur macOS release (fall 2020) broke some things in Python, which are only now (Dec 2020) getting fixed. These fixes have not yet made their way into Anaconda. If you experience an error similar to "Unable to load OpenGL library", install a patched pyopengl package from cryoem channel (as of 1/13/2021).
conda install pyopengl -c cryoem
OR
This quick fix seems to provide a temporary solution until Anaconda gets the necessary updates:
You need to go into your miniconda3 or anaconda3 folder and find this file (the path may be slightly different on your install, but you should be able to find it):
~/anaconda3/envs/eman2/lib/python3.7/site-packages/OpenGL/platform/ctypesloader.py
Around line 80 you should find a line like:
fullName = util.find_library( name )
change this line to:
fullName = '/System/Library/Frameworks/' + name + '.framework/' + name
(important to use 8 spaces before fullName, not a <tab>)
Ensure you have OpenGL:
EMAN2 uses OpenGL (via PyQt) for all of its graphics. OpenGL installation depends on OS variant and, for example, whether you are using proprietary NVidia drivers under Linux. You will need to have OpenGL set up on your machine as a whole before continuing. On Mac, you should already have this with XCode. On Linux with an NVidia driver you will likely also need to install the Mesa header files. If you aren't sure how to set up OpenGL, Google can probably help.
Get EMAN code from GitHub:cryoem/eman2.
Create a build directory (out-of-source builds are recommended).
Activate your environment. If you used a different name above, use it here too.
1 conda activate eman2
Checkout source code and pull from the remote.
Build EMAN
CMake
cmake-gui
If you use cmake-gui, since conda is not in PATH anymore, cmake will fail to find the environment directory. In that case set CONDA_PREFIX to your conda environment directory manually.
- Make sure to delete any cmake variables that cmake already found, variables like *_LIBRARY or similar, *_INCLUDE_PATH or similar, CONDA_EXECUTABLE, CMAKE_INSTALL_PREFIX and any variables that are expected to contain conda environment related values.
- Configure and generate.
ccmake
If you use ccmake, you may get an error related to OpenGL. If this happens try quitting ccmake and running it again.
Make
Note that the make -j 8 above will compile using 8 threads. On some machines omitting the 8 will compile faster and cause no problems, and if you have more than 8 threads on your machine, you can increase the number.
Test your installation. We do NOT recommend this for end-users. A failure does NOT necessarily indicate an installation problem. These commands are mostly provided for developers actively changing the code to detect harmful changes before committing them. Sometimes the system will have a failing test, and still be absolutely fine.
For debugging and reporting, see Debugging and Reporting.
EMAN Daily Development (updating code, etc)
When you start a new shell, these are the steps you will need to take before running EMAN2 programs or compiling the system:
Activate your environment. If you used a different name above, use it here too.
1 conda activate eman2
Update. Periodically you should update your source using standard git techniques. If you are not modifying EMAN, just compiling from source, you just need to periodically:
Build EMAN
Other Environments. To switch to another conda environment (stop working with EMAN2), first deactivate your current environment.
1 conda deactivate
For debugging and reporting, see Debugging and Reporting.
Debugging and Reporting
Please, provide the output of the following commands when reporting a problem. Record the session via script command. This, also, records the commands.
1 script filename.txt 2 3 conda activate eman2 4 5 conda info -a 6 conda list 7 conda list --explicit 8 9 cd <source-dir> 10 11 git status 12 git log -1 13 14 cd <build-dir> 15 16 rm CMakeCache.txt 17 cmake <source-dir> 18 cmake . -LA 19 20 make clean 21 make -j 22 make install 23 make test-verbose 24 25 conda deactivate 26 27 exit # or Ctrl+D 28
Send filename.txt.
Linux Clusters
The approach above will install EMAN with a precompiled version of OpenMPI, which may or may not work with the batch queuing system on your cluster. If it does not work, the symptom will be that MPI parallel jobs will use only a single node, no matter how many you have allocated in your job. Currently, we do not have alternative OpenMPI installation instructions.