Skip to content

Latest commit

 

History

History
181 lines (127 loc) · 7.05 KB

README.md

File metadata and controls

181 lines (127 loc) · 7.05 KB

Machine Learning Stream Software Requirements

Requirements

For this workshop, you are required to bring a computer (not a tablet, Chromebook, etc.) with a working version of Python installed. It is recommended that you have administrative privileges on your computer — the lessons require specific software packages installed.

We will be using Scikit Learn and fast.ai for this workshop, please make sure you have installed Anaconda Distribution, and Jupyter Notebook (a programming environment that runs in a web browser) and also other relevant packages listed as below:

Prerequisites:

  • Pytorch >= v1.0 (See instruction below based on your OS)
  • fast.ai v1 for PyTorch https://github.com/fastai/fastai (See instruction below based on your OS)
  • A dataset from Kaggle competition. You can download all of them here.
  • Signup and apply for access Google Colab https://colab.research.google.com/ – anyone with a Google Drive account can sign up for Colab by heading to colab website.

Please ensure you have a reasonably up-to-date Web browser. The current versions of Chrome, Safari and Firefox are all supported, but some older browsers, including Internet Explorer version 9 are not.

  • Clone this repository to your working directory
$ git clone https://github.com/pmlg/ResBaz19_Perth.git

Windows

Install Anaconda Python 3.7 distribution https://www.anaconda.com/distribution/. Make sure you have defined the PATH system variable.

  1. Find your current Python and Conda path: Open Windows command prompt (Press win and type cmd) Type where python and where conda

Example:

C:\>where python
C:\Users\ResBaz\AppData\Local\Continuum\anaconda3\python.exe

C:\>where conda
C:\Users\ResBaz\AppData\Local\Continuum\anaconda3\condabin\conda.bat
C:\Users\ResBaz\AppData\Local\Continuum\anaconda3\Library\bin\conda.bat
C:\Users\ResBaz\AppData\Local\Continuum\anaconda3\Scripts\conda.exe
  1. Press + R together to get a command prompt. Type sysdm.cpl → go to Advanced tab → select Environment Variables

In the System variables section, choose Path → select Edit → click New

System properties

Add the path → press OK

System variables

Note! your path may differ from the instruction

Adding path

  • using command line to verify Python has been successfully installed. Open terminal console (i.e. Anaconda Prompt, Git Bash, Cmder, etc.) → type python then press Enter

Example: Python test

Type exit() then Enter or Ctrl + D to exit.

  • Download a dataset from Kaggle competition to your working directory. You can download all of them here.
# In terminal, create a directory called 'rossmann'
$ mkdir rossmann
# Change to 'rossmann' directory:
$ cd rossmann
# Run the following command to untar rossmann.tgz file
$ tar xvzf rossmann.tgz
  1. Create a virtual environment called resbazml

Note: By creating the virtual environment via Anaconda distribution, you will be working on an isolated working copy of Python with specific versions of libraries or Python itself without affecting the base Anaconda or other projects.

Make sure the conda will be the latest version (conda install will also do the update)

$ conda install conda

Create a virtual environment from YAML file which is available in this repo.

$ conda env create -f resbazml_environment_win64.yml

Close your Anaconda Prompt terminal (or others) and relaunch it

Activate the environment

$ conda activate resbazml
  1. Check the fastai installation and Pytorch version
$ python -m fastai.utils.show_install

Fastai Pytorch test

If you can see the details as example above, your fastai installation should be working fine.

  1. Fastai and Pytorch packages verification

Type the command line as below for the verification

Fastai and PyTorch verification

To check if your CUDA is available or not

CUDA test

If the result is True, your CUDA is available for use. Otherwise, it will be False.

MacOS and Linux

CUDA test

If you don’t get an output similar to the one above, adjust the following commands to reflect your installation path and either run them interactively or add them to your .bashrc:

$ export PATH="$HOME/miniconda3/bin:$PATH"
$ source $HOME/miniconda3/bin/activate
  • Create a directory to download the dataset and course content into:
$ mkdir resbazml
$ cd resbazml
$ mkdir rossmann
$ cd rossmann
$ wget http://files.fast.ai/part2/lesson14/rossmann.tgz
$ tar xvzf rossmann.tgz
  • Create and activate a virtual environment called resbazml
$ conda create --name resbazml -c conda-forge -c fastai python=3.7 pytorch fastai jupyter nb_conda_kernels py-xgboost=0.90 pandas-profiling seaborn plotly python-cufflinks
$ conda activate resbazml
$ pip install isoweek
  • Check the fastai and Pytorch installations using steps 4 and 5 in the Windows instructions.

Optional Settings

  • Create a Jupyter Notebook Kernel for the Python Environment so you can switch to different kernel. Create the Jupyter kernel and install ipywidgets
$ python -m ipykernel install --user --name resbazml --display-name "resbazml"
  • Sometimes there will be ‘autopep8’ error once you start Jupyter Notebook. So you can reinstall ‘autopep8’ package using conda
$ conda install -c conda-forge autopep8
  • Some extensions would be helpful for using the notebook (i.e. code folding, collapsible heading, etc.) The original GitHub repository which contains a source code is here

  • Install Nbextensions using Conda

$ conda install -c conda-forge jupyter_contrib_nbextensions
  • Install Nbextensions Configurator using Conda
$ conda install -c conda-forge jupyter_nbextensions_configurator
  • Nbextensions tab will also appear right next to Clusters tab

Example of configuration

Configurable nbextensions

  • Increase cell width in a web browser - this solution will not change your default settings. All you need to do is add this following code into any cell of your current notebook and run the cell.
from IPython.core.display import display, HTML
display(HTML("<style>.container { width:100% !important; }</style>"))