Clarify installation instructions
parent
326d32cae0
commit
e220c68425
92
README.md
92
README.md
|
@ -1,7 +1,7 @@
|
|||
Machine Learning Notebooks
|
||||
==========================
|
||||
|
||||
This project aims at teaching you the fundamentals of Machine Learning in
|
||||
sThis project aims at teaching you the fundamentals of Machine Learning in
|
||||
python. It contains the example code and solutions to the exercises in my O'Reilly book [Hands-on Machine Learning with Scikit-Learn and TensorFlow](http://shop.oreilly.com/product/0636920052289.do):
|
||||
|
||||
[![book](http://akamaicovers.oreilly.com/images/0636920052289/rc_cat.gif)](http://shop.oreilly.com/product/0636920052289.do)
|
||||
|
@ -10,37 +10,85 @@ Simply open the [Jupyter](http://jupyter.org/) notebooks you are interested in:
|
|||
|
||||
* Using [jupyter.org's notebook viewer](http://nbviewer.jupyter.org/github/ageron/handson-ml/blob/master/index.ipynb)
|
||||
* note: [github.com's notebook viewer](https://github.com/ageron/handson-ml/blob/master/index.ipynb) also works but it is slower and the math formulas are not displayed correctly
|
||||
* or by cloning this repository and running Jupyter locally
|
||||
* if you prefer this option, follow the installation instructions below.
|
||||
* or by cloning this repository and running Jupyter locally. This option lets you play around with the code. In this case, follow the installation instructions below.
|
||||
|
||||
# Installation
|
||||
|
||||
Obviously, you will need [git](https://git-scm.com/) and [python](https://www.python.org/downloads/) (python 3 is recommended, but python 2 should work as well).
|
||||
First, you will need to install [git](https://git-scm.com/), if you don't have it already.
|
||||
|
||||
First, clone this repository:
|
||||
Next, clone this repository by opening a terminal and typing the following commands:
|
||||
|
||||
$ cd {your development directory}
|
||||
$ cd $HOME # or any other development directory you prefer
|
||||
$ git clone https://github.com/ageron/handson-ml.git
|
||||
$ cd handson-ml
|
||||
|
||||
If you want an isolated environment (recommended), you can use [virtualenv](https://virtualenv.readthedocs.org/en/latest/):
|
||||
|
||||
$ virtualenv env
|
||||
$ source ./env/bin/activate
|
||||
|
||||
If you want to go through chapter 16 on Reinforcement Learning, you will need to [install OpenAI gym](https://gym.openai.com/docs) and its dependencies for Atari simulations.
|
||||
|
||||
Then make sure pip is up to date, and use it to install the required python packages:
|
||||
If you are familiar with Python and you know how to install Python libraries, go ahead and install the libraries listed in `requirements.txt` and jump to the [Starting Jupyter](#starting-jupyter) section. If you need detailed instructions, please read on.
|
||||
|
||||
$ pip install --upgrade pip
|
||||
$ pip install --upgrade -r requirements.txt
|
||||
## Python & Required Libraries
|
||||
Of course, you obviously need Python. Python 2 is already preinstalled on most systems nowadays, and sometimes even Python 3. You can check which version(s) you have by typing the following commands:
|
||||
|
||||
If you prefer to use [Anaconda](https://www.continuum.io/), you can run the following commands instead:
|
||||
$ python --version # for Python 2
|
||||
$ python3 --version # for Python 3
|
||||
|
||||
$ conda install -c conda-forge tensorflow=1.0.0
|
||||
$ conda install -c conda-forge jupyter_contrib_nbextensions
|
||||
Any Python 3 version should be fine, preferably ≥3.5, as well as Python ≥2.6. However, if you don't have Python 3, I recommend installing it (Python 2 should work, but it is deprecated so Python 3 is preferable). To do so, you have several options: on Windows or MacOSX, you can just download it from [python.org](https://www.python.org/downloads/). On MacOSX, you can alternatively use [MacPorts](https://www.macports.org/) or [Homebrew](https://brew.sh/). On Linux, unless you know what you are doing, you should use your system's packaging system. For example, on Debian or Ubuntu, type:
|
||||
|
||||
If you want to install the Jupyter extensions, run the following command:
|
||||
$ sudo apt-get update
|
||||
$ sudo apt-get install python3
|
||||
|
||||
Another option is to download and install [Anaconda](https://www.continuum.io/downloads). This is a package that includes both Python and many scientific libraries. You should prefer the Python 3 version.
|
||||
|
||||
If you choose to use Anaconda, read the next section, or else you can skip it.
|
||||
|
||||
## Using Anaconda
|
||||
When using Anaconda, you can optionally create an isolated Python environment dedicated to this project. This is recommended as it makes it possible to have a different environment for each project (e.g. one for this propject), with potentially different libraries and library versions:
|
||||
|
||||
$ conda create -n mlbook python=3.5 anaconda
|
||||
$ source activate mlbook
|
||||
|
||||
This creates a fresh Python 3.5 environment called `mlbook` (you can change the name if you want to), and it activates it. This environment contains all the scientific libraries that come with Anaconda. This includes all the libraries we will need (NumPy, Matplotlib, Pandas, Jupyter and a few others), except for TensorFlow, so let's install it:
|
||||
|
||||
$ conda install -n mlbook -c conda-forge tensorflow=1.0.0
|
||||
|
||||
This installs TensorFlow 1.0.0 in the `mlbook` environment (fetching it from the `conda-forge` repository). If you chose not to create an `mlbook` environment, then just remove the `-n mlbook` option.
|
||||
|
||||
Next, you can optionally install Jupyter extensions. These are useful to have nice table of contents in the notebooks, but they are not required.
|
||||
|
||||
$ conda install -n mlbook -c conda-forge jupyter_contrib_nbextensions
|
||||
|
||||
You are all set! Next, jump to the [Starting Jupyter](#starting-jupyter) section.
|
||||
|
||||
## Using pip
|
||||
If you are not using Anaconda, you need to install several scientific Python libraries that are necessary for this project, in particular NumPy, Matplotlib, Pandas, Jupyter and TensorFlow (and a few others). For this, you can either use Python's integrated packaging system, pip, or you may prefer to use your system's own packaging system (if available, e.g. on Linux, or on MacOSX when using MacPorts or Homebrew). The advantage of using pip is that it is easy to create multiple isolated Python environments with different libraries and different library versions (e.g. one environment for each project). The advantage of using your system's packaging system is that there is less risk of having conflicts between your Python libraries and your system's other packages. Since I have many projects with different library requirements, I prefer to use pip with isolated environments.
|
||||
|
||||
These are the commands you need to type in a terminal if you want to use pip to install the required libraries. Note: in all the following commands, if you chose to use Python 2 rather than Python 3, you must replace `pip3` with `pip`, and `python3` with `python`.
|
||||
|
||||
First you need to make sure you have the latest version of pip installed:
|
||||
|
||||
$ pip3 install --user --upgrade pip
|
||||
|
||||
The `--user` option will install the latest version of pip only for the current user. If you prefer to install it system wide (i.e. for all users), you must have administrator rights (e.g. use `sudo pip3` instead of `pip3` on Linux), and you should remove the `--user` option. The same is true of the command below that uses the `--user` option.
|
||||
|
||||
Next, you can optionally create an isolated environment. As explained above, this is recommended as it makes it possible to have a different environment for each project (e.g. one for this course), with potentially very different libraries, and different versions:
|
||||
|
||||
$ pip3 install --user --upgrade virtualenv
|
||||
$ virtualenv -p `which python3` env
|
||||
|
||||
This creates a new directory called `env` in the current directory, containing an isolated Python environment based on Python 3. If you installed multiple versions of Python 3 on your system, you can replace \``which python3`\` with the path to the Python executable you prefer to use.
|
||||
|
||||
Now you want to activate this environment. You will need to run this command every time you want to use this environment.
|
||||
|
||||
$ source ./env/bin/activate
|
||||
|
||||
Next, use pip to install the required python packages. If you are not using virtualenv, you should add the `--user` option (or else you will probably need administrator rights, e.g. using `sudo pip3` instead of `pip3` on Linux).
|
||||
|
||||
$ pip3 install --upgrade -r requirements.txt
|
||||
|
||||
Great! You're all set, you just need to start Jupyter now.
|
||||
|
||||
## Starting Jupyter
|
||||
If you want to use the Jupyter extensions (optional), you first need to install them:
|
||||
|
||||
$ jupyter contrib nbextension install --user
|
||||
|
||||
|
@ -48,10 +96,12 @@ Then you can activate an extension, such as the Table of Contents (2) extension:
|
|||
|
||||
$ jupyter nbextension enable toc2/main
|
||||
|
||||
Finally, launch Jupyter:
|
||||
Okay! You can now start Jupyter, simply type:
|
||||
|
||||
$ jupyter notebook
|
||||
|
||||
This should start the Jupyter server locally, and open your browser. If your browser does not open automatically, visit [localhost:8888](http://localhost:8888/tree). Click on `index.ipynb` to get started. You can visit [http://localhost:8888/nbextensions](http://localhost:8888/nbextensions) to activate and configure Jupyter extensions.
|
||||
This should open up your browser, and you should see Jupyter's tree view, with the contents of the current directory. If your browser does not open automatically, visit [localhost:8888](http://localhost:8888/tree). Click on `index.ipynb` to get started!
|
||||
|
||||
That's it! Have fun learning ML.
|
||||
Note: you can also visit [http://localhost:8888/nbextensions](http://localhost:8888/nbextensions) to activate and configure Jupyter extensions.
|
||||
|
||||
Congrats! You are ready to learn Machine Learning, hands on!
|
||||
|
|
Loading…
Reference in New Issue