Update installation instructions, and replace 'import numpy' with 'import numpy as np'
parent
5fa306c6a0
commit
ec681a3174
13
README.md
13
README.md
|
@ -14,11 +14,11 @@ Simply open the [Jupyter](http://jupyter.org/) notebooks you are interested in:
|
||||||
|
|
||||||
# Installation
|
# Installation
|
||||||
|
|
||||||
You will need [git](https://git-scm.com/), obviously.
|
Obviously, you will need [git](https://git-scm.com/) and [python](https://www.python.org/downloads/) (2 or 3).
|
||||||
|
|
||||||
First, clone this repository:
|
First, clone this repository:
|
||||||
|
|
||||||
$ cd {*your development directory*}
|
$ cd {your development directory}
|
||||||
$ git clone https://github.com/ageron/ml-notebooks.git
|
$ git clone https://github.com/ageron/ml-notebooks.git
|
||||||
$ cd ml-notebooks
|
$ cd ml-notebooks
|
||||||
|
|
||||||
|
@ -27,15 +27,12 @@ If you want an isolated environment, you can use [virtualenv](https://virtualenv
|
||||||
$ virtualenv env
|
$ virtualenv env
|
||||||
$ source ./env/bin/activate
|
$ source ./env/bin/activate
|
||||||
|
|
||||||
Next, install the required python packages using pip:
|
Next, edit `requirements.txt` to uncomment the right version of TensorFlow for your platform, then install the required python packages using pip:
|
||||||
|
|
||||||
$ pip install -r requirements.txt # On Linux
|
$ pip install -r requirements.txt
|
||||||
OR
|
|
||||||
$ pip install -r requirements_macosx.txt # On MacOSX
|
|
||||||
|
|
||||||
Finally, launch Jupyter:
|
Finally, launch Jupyter:
|
||||||
|
|
||||||
$ jupyter notebook
|
$ jupyter notebook
|
||||||
|
|
||||||
This should start the Jupyter server locally, and open a browser window. Click on `index.ipynb` to get started.
|
This should start the Jupyter server locally, and open your browser. Click on `index.ipynb` to get started.
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
"name": "python",
|
"name": "python",
|
||||||
"nbconvert_exporter": "python",
|
"nbconvert_exporter": "python",
|
||||||
"pygments_lexer": "ipython2",
|
"pygments_lexer": "ipython2",
|
||||||
"version": "2.7.10"
|
"version": "2.7.11"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nbformat": 4,
|
"nbformat": 4,
|
||||||
|
|
|
@ -43,7 +43,7 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"cell_type": "code",
|
"cell_type": "code",
|
||||||
"execution_count": null,
|
"execution_count": 47,
|
||||||
"metadata": {
|
"metadata": {
|
||||||
"collapsed": false
|
"collapsed": false
|
||||||
},
|
},
|
||||||
|
@ -120,7 +120,7 @@
|
||||||
"cell_type": "markdown",
|
"cell_type": "markdown",
|
||||||
"metadata": {},
|
"metadata": {},
|
||||||
"source": [
|
"source": [
|
||||||
"Now, let's plot a mathematical function. We use numpy's `linspace` function to create an array `x` containing 500 floats ranging from -2 to 2, then we create a second array `y` computed as the square of `x`."
|
"Now, let's plot a mathematical function. We use NumPy's `linspace` function to create an array `x` containing 500 floats ranging from -2 to 2, then we create a second array `y` computed as the square of `x` (to learn about NumPy, read the [NumPy tutorial](tools_numpy.ipynb))."
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -131,8 +131,8 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"import numpy\n",
|
"import numpy as np\n",
|
||||||
"x = numpy.linspace(-2, 2, 500)\n",
|
"x = np.linspace(-2, 2, 500)\n",
|
||||||
"y = x**2\n",
|
"y = x**2\n",
|
||||||
"\n",
|
"\n",
|
||||||
"plt.plot(x, y)\n",
|
"plt.plot(x, y)\n",
|
||||||
|
@ -269,7 +269,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-1.4, 1.4, 30)\n",
|
"x = np.linspace(-1.4, 1.4, 30)\n",
|
||||||
"plt.plot(x, x, 'g--', x, x**2, 'r:', x, x**3, 'b^')\n",
|
"plt.plot(x, x, 'g--', x, x**2, 'r:', x, x**3, 'b^')\n",
|
||||||
"plt.show()"
|
"plt.show()"
|
||||||
]
|
]
|
||||||
|
@ -290,7 +290,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-1.4, 1.4, 30)\n",
|
"x = np.linspace(-1.4, 1.4, 30)\n",
|
||||||
"line1, line2, line3 = plt.plot(x, x, 'g--', x, x**2, 'r:', x, x**3, 'b^')\n",
|
"line1, line2, line3 = plt.plot(x, x, 'g--', x, x**2, 'r:', x, x**3, 'b^')\n",
|
||||||
"line1.set_linewidth(3.0)\n",
|
"line1.set_linewidth(3.0)\n",
|
||||||
"line1.set_dash_capstyle(\"round\")\n",
|
"line1.set_dash_capstyle(\"round\")\n",
|
||||||
|
@ -315,7 +315,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-1.4, 1.4, 30)\n",
|
"x = np.linspace(-1.4, 1.4, 30)\n",
|
||||||
"plt.plot(x, x**2)\n",
|
"plt.plot(x, x**2)\n",
|
||||||
"plt.savefig(\"my_square_function.png\", transparent=True)"
|
"plt.savefig(\"my_square_function.png\", transparent=True)"
|
||||||
]
|
]
|
||||||
|
@ -337,7 +337,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-1.4, 1.4, 30)\n",
|
"x = np.linspace(-1.4, 1.4, 30)\n",
|
||||||
"plt.subplot(2, 2, 1) # 2 rows, 2 columns, 1st subplot = top left\n",
|
"plt.subplot(2, 2, 1) # 2 rows, 2 columns, 1st subplot = top left\n",
|
||||||
"plt.plot(x, x)\n",
|
"plt.plot(x, x)\n",
|
||||||
"plt.subplot(2, 2, 2) # 2 rows, 2 columns, 2nd subplot = top right\n",
|
"plt.subplot(2, 2, 2) # 2 rows, 2 columns, 2nd subplot = top right\n",
|
||||||
|
@ -430,7 +430,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-1.4, 1.4, 30)\n",
|
"x = np.linspace(-1.4, 1.4, 30)\n",
|
||||||
"\n",
|
"\n",
|
||||||
"plt.figure(1)\n",
|
"plt.figure(1)\n",
|
||||||
"plt.subplot(211)\n",
|
"plt.subplot(211)\n",
|
||||||
|
@ -490,11 +490,11 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-2, 2, 200)\n",
|
"x = np.linspace(-2, 2, 200)\n",
|
||||||
"fig1, (ax_top, ax_bottom) = plt.subplots(2, 1, sharex=True)\n",
|
"fig1, (ax_top, ax_bottom) = plt.subplots(2, 1, sharex=True)\n",
|
||||||
"fig1.set_size_inches(10,5)\n",
|
"fig1.set_size_inches(10,5)\n",
|
||||||
"line1, line2 = ax_top.plot(x, numpy.sin(3*x**2), \"r-\", x, numpy.cos(5*x**2), \"b-\")\n",
|
"line1, line2 = ax_top.plot(x, np.sin(3*x**2), \"r-\", x, np.cos(5*x**2), \"b-\")\n",
|
||||||
"line3, = ax_bottom.plot(x, numpy.sin(3*x), \"r-\")\n",
|
"line3, = ax_bottom.plot(x, np.sin(3*x), \"r-\")\n",
|
||||||
"ax_top.grid(True)\n",
|
"ax_top.grid(True)\n",
|
||||||
"\n",
|
"\n",
|
||||||
"fig2, ax = plt.subplots(1, 1)\n",
|
"fig2, ax = plt.subplots(1, 1)\n",
|
||||||
|
@ -514,7 +514,7 @@
|
||||||
"\n",
|
"\n",
|
||||||
"Pyplot provides a number of tools to plot graphs, including the state-machine interface to the underlying object-oriented plotting library.\n",
|
"Pyplot provides a number of tools to plot graphs, including the state-machine interface to the underlying object-oriented plotting library.\n",
|
||||||
"\n",
|
"\n",
|
||||||
"Pylab is a convenience module that imports matplotlib.pyplot and numpy in a single name space. You will find many examples using pylab, but it is no longer recommended (because *explicit* imports are better than *implicit* ones)."
|
"Pylab is a convenience module that imports matplotlib.pyplot and NumPy in a single name space. You will find many examples using pylab, but it is no longer recommended (because *explicit* imports are better than *implicit* ones)."
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -533,7 +533,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-1.5, 1.5, 30)\n",
|
"x = np.linspace(-1.5, 1.5, 30)\n",
|
||||||
"px = 0.8\n",
|
"px = 0.8\n",
|
||||||
"py = px**2\n",
|
"py = px**2\n",
|
||||||
"\n",
|
"\n",
|
||||||
|
@ -642,7 +642,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-1.4, 1.4, 50)\n",
|
"x = np.linspace(-1.4, 1.4, 50)\n",
|
||||||
"plt.plot(x, x**2, \"r--\", label=\"Square function\")\n",
|
"plt.plot(x, x**2, \"r--\", label=\"Square function\")\n",
|
||||||
"plt.plot(x, x**3, \"g-\", label=\"Cube function\")\n",
|
"plt.plot(x, x**3, \"g-\", label=\"Cube function\")\n",
|
||||||
"plt.legend(loc=\"best\")\n",
|
"plt.legend(loc=\"best\")\n",
|
||||||
|
@ -667,8 +667,8 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(0.1, 15, 500)\n",
|
"x = np.linspace(0.1, 15, 500)\n",
|
||||||
"y = x**3/numpy.exp(2*x)\n",
|
"y = x**3/np.exp(2*x)\n",
|
||||||
"\n",
|
"\n",
|
||||||
"plt.figure(1)\n",
|
"plt.figure(1)\n",
|
||||||
"plt.plot(x, y)\n",
|
"plt.plot(x, y)\n",
|
||||||
|
@ -716,7 +716,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-2, 2, 100)\n",
|
"x = np.linspace(-2, 2, 100)\n",
|
||||||
"\n",
|
"\n",
|
||||||
"plt.figure(1, figsize=(15,10))\n",
|
"plt.figure(1, figsize=(15,10))\n",
|
||||||
"plt.subplot(131)\n",
|
"plt.subplot(131)\n",
|
||||||
|
@ -726,7 +726,7 @@
|
||||||
"\n",
|
"\n",
|
||||||
"ax = plt.subplot(132)\n",
|
"ax = plt.subplot(132)\n",
|
||||||
"plt.plot(x, x**3)\n",
|
"plt.plot(x, x**3)\n",
|
||||||
"ax.xaxis.set_ticks(numpy.arange(-2, 2, 1))\n",
|
"ax.xaxis.set_ticks(np.arange(-2, 2, 1))\n",
|
||||||
"plt.grid(True)\n",
|
"plt.grid(True)\n",
|
||||||
"plt.title(\"Manual ticks on the x-axis\")\n",
|
"plt.title(\"Manual ticks on the x-axis\")\n",
|
||||||
"\n",
|
"\n",
|
||||||
|
@ -735,7 +735,7 @@
|
||||||
"plt.minorticks_on()\n",
|
"plt.minorticks_on()\n",
|
||||||
"ax.tick_params(axis='x', which='minor', bottom='off')\n",
|
"ax.tick_params(axis='x', which='minor', bottom='off')\n",
|
||||||
"ax.xaxis.set_ticks([-2, 0, 1, 2])\n",
|
"ax.xaxis.set_ticks([-2, 0, 1, 2])\n",
|
||||||
"ax.yaxis.set_ticks(numpy.arange(-5, 5, 1))\n",
|
"ax.yaxis.set_ticks(np.arange(-5, 5, 1))\n",
|
||||||
"ax.yaxis.set_ticklabels([\"min\", -4, -3, -2, -1, 0, 1, 2, 3, \"max\"])\n",
|
"ax.yaxis.set_ticklabels([\"min\", -4, -3, -2, -1, 0, 1, 2, 3, \"max\"])\n",
|
||||||
"plt.title(\"Manual ticks and tick labels\\n(plus minor ticks) on the y-axis\")\n",
|
"plt.title(\"Manual ticks and tick labels\\n(plus minor ticks) on the y-axis\")\n",
|
||||||
"\n",
|
"\n",
|
||||||
|
@ -762,11 +762,11 @@
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"radius = 1\n",
|
"radius = 1\n",
|
||||||
"theta = numpy.linspace(0, 2*numpy.pi*radius, 1000)\n",
|
"theta = np.linspace(0, 2*np.pi*radius, 1000)\n",
|
||||||
"\n",
|
"\n",
|
||||||
"plt.subplot(111, projection='polar')\n",
|
"plt.subplot(111, projection='polar')\n",
|
||||||
"plt.plot(theta, numpy.sin(5*theta), \"g-\")\n",
|
"plt.plot(theta, np.sin(5*theta), \"g-\")\n",
|
||||||
"plt.plot(theta, 0.5*numpy.cos(20*theta), \"b-\")\n",
|
"plt.plot(theta, 0.5*np.cos(20*theta), \"b-\")\n",
|
||||||
"plt.show()"
|
"plt.show()"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
@ -790,11 +790,11 @@
|
||||||
"source": [
|
"source": [
|
||||||
"from mpl_toolkits.mplot3d import Axes3D\n",
|
"from mpl_toolkits.mplot3d import Axes3D\n",
|
||||||
"\n",
|
"\n",
|
||||||
"x = numpy.linspace(-5, 5, 50)\n",
|
"x = np.linspace(-5, 5, 50)\n",
|
||||||
"y = numpy.linspace(-5, 5, 50)\n",
|
"y = np.linspace(-5, 5, 50)\n",
|
||||||
"X, Y = numpy.meshgrid(x, y)\n",
|
"X, Y = np.meshgrid(x, y)\n",
|
||||||
"R = numpy.sqrt(X**2 + Y**2)\n",
|
"R = np.sqrt(X**2 + Y**2)\n",
|
||||||
"Z = numpy.sin(R)\n",
|
"Z = np.sin(R)\n",
|
||||||
"\n",
|
"\n",
|
||||||
"figure = plt.figure(1, figsize = (12, 4))\n",
|
"figure = plt.figure(1, figsize = (12, 4))\n",
|
||||||
"subplot3d = plt.subplot(111, projection='3d')\n",
|
"subplot3d = plt.subplot(111, projection='3d')\n",
|
||||||
|
@ -969,11 +969,11 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"data1 = numpy.random.randn(400)\n",
|
"data1 = np.random.randn(400)\n",
|
||||||
"data2 = numpy.random.randn(500) + 3\n",
|
"data2 = np.random.randn(500) + 3\n",
|
||||||
"data3 = numpy.random.randn(450) + 6\n",
|
"data3 = np.random.randn(450) + 6\n",
|
||||||
"data4a = numpy.random.randn(200) + 9\n",
|
"data4a = np.random.randn(200) + 9\n",
|
||||||
"data4b = numpy.random.randn(100) + 10\n",
|
"data4b = np.random.randn(100) + 10\n",
|
||||||
"\n",
|
"\n",
|
||||||
"plt.hist(data1, bins=5, color='g', alpha=0.75, label='bar hist') # default histtype='bar'\n",
|
"plt.hist(data1, bins=5, color='g', alpha=0.75, label='bar hist') # default histtype='bar'\n",
|
||||||
"plt.hist(data2, color='b', alpha=0.65, histtype='stepfilled', label='stepfilled hist')\n",
|
"plt.hist(data2, color='b', alpha=0.65, histtype='stepfilled', label='stepfilled hist')\n",
|
||||||
|
@ -1065,7 +1065,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"img = numpy.arange(100*100).reshape(100, 100)\n",
|
"img = np.arange(100*100).reshape(100, 100)\n",
|
||||||
"print img\n",
|
"print img\n",
|
||||||
"plt.imshow(img)\n",
|
"plt.imshow(img)\n",
|
||||||
"plt.show()"
|
"plt.show()"
|
||||||
|
@ -1107,7 +1107,7 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"img = numpy.empty((20,30,3))\n",
|
"img = np.empty((20,30,3))\n",
|
||||||
"img[:, :10] = [0, 0, 0.6]\n",
|
"img[:, :10] = [0, 0, 0.6]\n",
|
||||||
"img[:, 10:20] = [1, 1, 1]\n",
|
"img[:, 10:20] = [1, 1, 1]\n",
|
||||||
"img[:, 20:] = [0.6, 0, 0]\n",
|
"img[:, 20:] = [0.6, 0, 0]\n",
|
||||||
|
@ -1175,9 +1175,9 @@
|
||||||
},
|
},
|
||||||
"outputs": [],
|
"outputs": [],
|
||||||
"source": [
|
"source": [
|
||||||
"x = numpy.linspace(-1, 1, 100)\n",
|
"x = np.linspace(-1, 1, 100)\n",
|
||||||
"y = numpy.sin(x**2*25)\n",
|
"y = np.sin(x**2*25)\n",
|
||||||
"data = numpy.array([x, y])\n",
|
"data = np.array([x, y])\n",
|
||||||
"\n",
|
"\n",
|
||||||
"fig = plt.figure()\n",
|
"fig = plt.figure()\n",
|
||||||
"line, = plt.plot([], [], \"r-\") # start with an empty plot\n",
|
"line, = plt.plot([], [], \"r-\") # start with an empty plot\n",
|
||||||
|
@ -1188,7 +1188,7 @@
|
||||||
"\n",
|
"\n",
|
||||||
"# this function will be called at every iteration\n",
|
"# this function will be called at every iteration\n",
|
||||||
"def update_line(num, data, line):\n",
|
"def update_line(num, data, line):\n",
|
||||||
" line.set_data(data[..., :num] + numpy.random.rand(2, num) / 25) # we only plot the first `num` data points.\n",
|
" line.set_data(data[..., :num] + np.random.rand(2, num) / 25) # we only plot the first `num` data points.\n",
|
||||||
" return line,\n",
|
" return line,\n",
|
||||||
"\n",
|
"\n",
|
||||||
"line_ani = animation.FuncAnimation(fig, update_line, frames=100, fargs=(data, line), interval=67)\n",
|
"line_ani = animation.FuncAnimation(fig, update_line, frames=100, fargs=(data, line), interval=67)\n",
|
||||||
|
@ -1241,7 +1241,7 @@
|
||||||
"name": "python",
|
"name": "python",
|
||||||
"nbconvert_exporter": "python",
|
"nbconvert_exporter": "python",
|
||||||
"pygments_lexer": "ipython2",
|
"pygments_lexer": "ipython2",
|
||||||
"version": "2.7.10"
|
"version": "2.7.11"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nbformat": 4,
|
"nbformat": 4,
|
||||||
|
|
Loading…
Reference in New Issue