# Python User Guide --- Supported Platforms: Linux and macOS. For Windows, Refer to [Windows User Guide](./win.md). ### 1. Install - We recommend using [conda](https://docs.conda.io/projects/conda/en/latest/user-guide/install/) to prepare the Python environment as follows: ```bash conda create -n bigdl python=3.7 # "bigdl" is conda environment name, you can use any name you like. conda activate bigdl ``` - You need to install JDK in the environment, and properly set the environment variable `JAVA_HOME`. __JDK8__ is highly recommended. You may take the following commands as a reference for installing [OpenJDK](https://openjdk.java.net/install/): ```bash # For Ubuntu sudo apt-get install openjdk-8-jre export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64/ # For CentOS su -c "yum install java-1.8.0-openjdk" export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.282.b08-1.el7_9.x86_64/jre export PATH=$PATH:$JAVA_HOME/bin java -version # Verify the version of JDK. ``` #### 1.1 Official Release You can install the latest release version of BigDL (built on top of Spark 2.4.6 by default) as follows: ```bash pip install bigdl ``` _**Note:** Installing BigDL will automatically install all the BigDL packages including `bigdl-nano`, `bigdl-dllib`, `bigdl-orca`, `bigdl-chronos`, `bigdl-friesian`, `bigdl-serving` and their dependencies if they haven't been detected in your conda environment._ #### 1.2 Nightly Build You can install the latest nightly build of BigDL as follows: ```bash pip install --pre --upgrade bigdl ``` Alternatively, you can find the list of the nightly build versions [here](https://pypi.org/project/BigDL/#history), and install a specific version as follows: ```bash pip install bigdl==version ``` _**Note:** If you are using a custom URL of Python Package Index, you may need to check whether the latest packages have been sync'ed with pypi. Or you can add the option `-i https://pypi.python.org/simple` when pip install to use pypi as the index-url._ You could uninstall all the packages of BigDL as follows: ```bash pip uninstall bigdl-dllib bigdl-core bigdl-tf bigdl-math bigdl-orca bigdl-chronos bigdl-friesian bigdl-nano bigdl-serving bigdl ``` #### 1.3 BigDL on Spark 3 You can install BigDL built on top of Spark 3.1.3 as follows: ```bash pip install bigdl-spark3 # Install the latest release version pip install --pre --upgrade bigdl-spark3 # Install the latest nightly build version ``` You can find the list of the nightly build versions built on top of Spark 3.1.3 [here](https://pypi.org/project/bigdl-spark3/#history). You could uninstall all the packages of BigDL on Spark3 as follows: ```bash pip uninstall bigdl-dllib-spark3 bigdl-core bigdl-tf bigdl-math bigdl-orca-spark3 bigdl-chronos-spark3 bigdl-friesian-spark3 bigdl-nano bigdl-serving bigdl-spark3 ``` --- ### 2. Run _**Note:** Installing BigDL from pip will automatically install `pyspark`. To avoid possible conflicts, you are highly recommended to **unset the environment variable `SPARK_HOME`** if it exists in your environment._ #### 2.1 Interactive Shell You may test if the installation is successful using the interactive Python shell as follows: * Type `python` in the command line to start a REPL. * Try to run the example code below to verify the installation: ```python from bigdl.orca import init_orca_context sc = init_orca_context() # Initiation of bigdl on the underlying cluster. ``` #### 2.2 Jupyter Notebook You can start the Jupyter notebook as you normally do using the following command and run BigDL programs directly in a Jupyter notebook: ```bash jupyter notebook --notebook-dir=./ --ip=* --no-browser ``` #### 2.3 Python Script You can directly write BigDL programs in a Python file (e.g. script.py) and run in the command line as a normal Python program: ```bash python script.py ``` --- ### 3. Python Dependencies We recommend using [conda](https://docs.conda.io/projects/conda/en/latest/user-guide/install/) to manage your Python dependencies. Libraries installed in the current conda environment will be automatically distributed to the cluster when calling `init_orca_context`. You can also add extra dependencies as `.py`, `.zip` and `.egg` files by specifying `extra_python_lib` argument in `init_orca_context`. For more details, please refer to [Orca Context](../Orca/Overview/orca-context.md). --- ### 4. Compatibility BigDL has been tested on __Python 3.6 and 3.7__ with the following library versions: ```bash pyspark==2.4.6 or 3.1.3 ray==1.9.2 tensorflow==1.15.0 or >2.0 pytorch>=1.5.0 torchvision>=0.6.0 horovod==0.19.2 mxnet>=1.6.0 bayesian-optimization==1.1.0 dask==2.14.0 h5py==2.10.0 numpy==1.18.1 opencv-python==4.2.0.34 pandas==1.0.3 Pillow==7.1.1 protobuf==3.12.0 psutil==5.7.0 py4j==0.10.7 redis==3.4.1 scikit-learn==0.22.2.post1 scipy==1.4.1 tensorboard==1.15.0 tensorboardX>=2.1 tensorflow-datasets==3.2.0 tensorflow-estimator==1.15.1 tensorflow-gan==2.0.0 tensorflow-hub==0.8.0 tensorflow-metadata==0.21.1 tensorflow-probability==0.7.0 Theano==1.0.4 ``` --- ### 5. Known Issues - If you meet the following error when `pip install bigdl`: ``` ERROR: Could not find a version that satisfies the requirement pypandoc (from versions: none) ERROR: No matching distribution found for pypandoc Could not import pypandoc - required to package PySpark Traceback (most recent call last): File "/root/anaconda3/lib/python3.8/site-packages/setuptools/installer.py", line 126, in fetch_build_egg subprocess.check_call(cmd) File "/root/anaconda3/lib/python3.8/subprocess.py", line 364, in check_call raise CalledProcessError(retcode, cmd) subprocess.CalledProcessError: Command '['/root/anaconda3/bin/python', '-m', 'pip', '--disable-pip-version-check', 'wheel', '--no-deps', '-w', '/tmp/tmprefr87ue', '--quiet', 'pypandoc']' returned non-zero exit status 1. ``` This is actually caused by `pip install pyspark` in your Python environment. You can fix it by running `pip install pypandoc` first and then `pip install bigdl`.