This document provides a guide on setting up your Mac for working within the Materials Virtual Lab.
You will first need to download and install basic compilers:
Create a Github account if you do not have one. Then add your ssh key (in
$HOME/.ssh/id_rsa.pub. If it does not exist, create one using the
ssh-keygen command) to your Github account under settings.
Follow the instructions on this page https://help.github.com/articles/set-up-git.
Conda is a package manager that makes it a lot easier to work with different python versions and packages. After downloading the miniconda installer, run the following in a terminal in the directory where you downloaded the installer:
curl -o Miniconda3-latest-MacOSX-x86_64.sh https://repo.continuum.io/miniconda/Miniconda3-latest-MacOSX-x86_64.sh bash Miniconda3-latest-MacOSX-x86_64.sh -b
Now, you should start a new terminal before proceeding.
Afterwards, install homebrew. This will make life a lot easier.
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
Install the latest copy of Python > 3.7, even though your Mac should already have a compatible version. Python 3+ is mature enough that we are going to work with this from now on. Do the following:
conda update python
Verify your python version by typing
python --version in a terminal.
Conda provides the means for you to create isolated environments. It is useful if you are going to work with lots of python packages that may have incompatible dependencies. If you are planning to work exclusively on Materials Virtual Lab stuff, you can skip this step.
To create a new environment in conda, do
conda create -n my_env python
If you want to use python 2.7 for testing, type
conda create -n my_env python=2.7
To go to that environment, just type:
source activate my_env
These must be installed first as they are needed to compile the other packages. Use the conda versions as these will have Intel MKL, which is faster.
conda install --yes numpy scipy matplotlib jupyter git pandas sympy
Start a new terminal before continuing.
Before you setup the repos, it is generally advised that you keep all your repos in a single directory, e.g., $HOME/repos. Many of MAVRL’s useful scripts assume this as the default location for your repos.
These are to be installed in developmental mode from source. You will be working with and modifying these a lot.
git clone email@example.com:materialsproject/pymatgen.git cd pymatgen python setup.py develop
Do the same for the pymatgen-db, custodian and fireworks repos.
To be installed in developmental mode from source. You will be working with this a lot as well. This is the private overall repo for the MAVRL.
git clone firstname.lastname@example.org:materialsvirtuallab/pymacy.git cd pymacy python setup.py develop
You need the VASP psuedopotential files in order to generate VASP input files. These are provided in the pymacy repo under resources.
Add a VASP_PSP_DIR to your .pmgrc.yaml, by running the following.
pmg config --add PMG_VASP_PSP_DIR /path/to/pymacy/resources/VASP_PSP
Test that you have set it up correctly by typing:
python -c 'from pymatgen.io.vasp import Potcar; print(Potcar(["Li_sv", "O"]))'
There should be no errors. Otherwise, you have not done setup correctly.
An Integrated Development Environment (IDE) makes it easier for you to code and maintain good style, especially for Python. Note that for group members, it is highly recommended you use an IDE unless you believe yourself to be a superior Python coder to your adviser (and have the goods to prove it).
Download the community version fo Pycharm or install it via
brew cask install.
brew cask install pycharm-ce
It is unlikely you need anything more than the community version.
Learn how to commit and push changes with git. The model is that you should be creating branches for anything that you do, and you should commit often.
Pymatgen has extensive documentation at http://pymatgen.org. Read and learn to use it. A hour spent figuring out how to work with pymatgen will save you 100 hours over a year (and probably more as you become more familiar).
Read the materialsvirtuallab Coding guidelines, and follow them strictly.
Here are some recommended software. Most can be installed via homebrew via
brew install or
brew cask install. Note that you can use
brew cask install to install many GUI apps, including Google Chrome
(google-chrome), Zoom (zoomus), etc. You can look for apps using
brew cask search.
brew cask install atom
brew cask install iterm2
brew cask install alfred
brew cask install mendeley-desktop
brew cask install vesta
brew install coreutils
brew install tree
All MAVRL group members are required to backup their personal computers as well as data. There are two forms of backup that you will need to do:
Unless it is bad or irrelevant data, do not throw data away, even after you finish a project. Organize your data on your laptops and mavrldata carefully.